aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi
diff options
context:
space:
mode:
authorTomas Henzl <thenzl@redhat.com>2011-04-29 10:28:30 -0400
committerJames Bottomley <James.Bottomley@suse.de>2011-05-01 17:32:23 -0400
commit87f76152dfb1bf3de18dc01cf97c70a5c9d2583e (patch)
tree6a0b4a19fe3a3c42155f3e07b4a8d91bfa9812c6 /drivers/scsi
parent8b7eb86f61a10132aad7f90e89a15dc89e495d9e (diff)
[SCSI] arcmsr: simplify assumptions in dma_alloc_coherent()
The code currently computes an offset into a dma_alloc_coherent() area on the assumption that the alignment is imprecise. In fact, the API guarantees PAGE_SIZE alignment, so the offset calculation is always zero: remove it. [jejb: make description actually descriptive] Signed-off-by: Tomas henzl <thenzl@redhat.com> Acked-by: Nick Cheng<nick.cheng@areca.com.tw> Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi')
-rw-r--r--drivers/scsi/arcmsr/arcmsr_hba.c12
1 files changed, 5 insertions, 7 deletions
diff --git a/drivers/scsi/arcmsr/arcmsr_hba.c b/drivers/scsi/arcmsr/arcmsr_hba.c
index a47327fe162c..f980600f78a8 100644
--- a/drivers/scsi/arcmsr/arcmsr_hba.c
+++ b/drivers/scsi/arcmsr/arcmsr_hba.c
@@ -441,10 +441,11 @@ static int arcmsr_alloc_ccb_pool(struct AdapterControlBlock *acb)
441 struct CommandControlBlock *ccb_tmp; 441 struct CommandControlBlock *ccb_tmp;
442 int i = 0, j = 0; 442 int i = 0, j = 0;
443 dma_addr_t cdb_phyaddr; 443 dma_addr_t cdb_phyaddr;
444 unsigned long roundup_ccbsize = 0, offset; 444 unsigned long roundup_ccbsize;
445 unsigned long max_xfer_len; 445 unsigned long max_xfer_len;
446 unsigned long max_sg_entrys; 446 unsigned long max_sg_entrys;
447 uint32_t firm_config_version; 447 uint32_t firm_config_version;
448
448 for (i = 0; i < ARCMSR_MAX_TARGETID; i++) 449 for (i = 0; i < ARCMSR_MAX_TARGETID; i++)
449 for (j = 0; j < ARCMSR_MAX_TARGETLUN; j++) 450 for (j = 0; j < ARCMSR_MAX_TARGETLUN; j++)
450 acb->devstate[i][j] = ARECA_RAID_GONE; 451 acb->devstate[i][j] = ARECA_RAID_GONE;
@@ -454,23 +455,20 @@ static int arcmsr_alloc_ccb_pool(struct AdapterControlBlock *acb)
454 firm_config_version = acb->firm_cfg_version; 455 firm_config_version = acb->firm_cfg_version;
455 if((firm_config_version & 0xFF) >= 3){ 456 if((firm_config_version & 0xFF) >= 3){
456 max_xfer_len = (ARCMSR_CDB_SG_PAGE_LENGTH << ((firm_config_version >> 8) & 0xFF)) * 1024;/* max 4M byte */ 457 max_xfer_len = (ARCMSR_CDB_SG_PAGE_LENGTH << ((firm_config_version >> 8) & 0xFF)) * 1024;/* max 4M byte */
457 max_sg_entrys = (max_xfer_len/4096); 458 max_sg_entrys = (max_xfer_len/4096);
458 } 459 }
459 acb->host->max_sectors = max_xfer_len/512; 460 acb->host->max_sectors = max_xfer_len/512;
460 acb->host->sg_tablesize = max_sg_entrys; 461 acb->host->sg_tablesize = max_sg_entrys;
461 roundup_ccbsize = roundup(sizeof(struct CommandControlBlock) + (max_sg_entrys - 1) * sizeof(struct SG64ENTRY), 32); 462 roundup_ccbsize = roundup(sizeof(struct CommandControlBlock) + (max_sg_entrys - 1) * sizeof(struct SG64ENTRY), 32);
462 acb->uncache_size = roundup_ccbsize * ARCMSR_MAX_FREECCB_NUM + 32; 463 acb->uncache_size = roundup_ccbsize * ARCMSR_MAX_FREECCB_NUM;
463 dma_coherent = dma_alloc_coherent(&pdev->dev, acb->uncache_size, &dma_coherent_handle, GFP_KERNEL); 464 dma_coherent = dma_alloc_coherent(&pdev->dev, acb->uncache_size, &dma_coherent_handle, GFP_KERNEL);
464 if(!dma_coherent){ 465 if(!dma_coherent){
465 printk(KERN_NOTICE "arcmsr%d: dma_alloc_coherent got error \n", acb->host->host_no); 466 printk(KERN_NOTICE "arcmsr%d: dma_alloc_coherent got error\n", acb->host->host_no);
466 return -ENOMEM; 467 return -ENOMEM;
467 } 468 }
468 acb->dma_coherent = dma_coherent; 469 acb->dma_coherent = dma_coherent;
469 acb->dma_coherent_handle = dma_coherent_handle; 470 acb->dma_coherent_handle = dma_coherent_handle;
470 memset(dma_coherent, 0, acb->uncache_size); 471 memset(dma_coherent, 0, acb->uncache_size);
471 offset = roundup((unsigned long)dma_coherent, 32) - (unsigned long)dma_coherent;
472 dma_coherent_handle = dma_coherent_handle + offset;
473 dma_coherent = (struct CommandControlBlock *)dma_coherent + offset;
474 ccb_tmp = dma_coherent; 472 ccb_tmp = dma_coherent;
475 acb->vir2phy_offset = (unsigned long)dma_coherent - (unsigned long)dma_coherent_handle; 473 acb->vir2phy_offset = (unsigned long)dma_coherent - (unsigned long)dma_coherent_handle;
476 for(i = 0; i < ARCMSR_MAX_FREECCB_NUM; i++){ 474 for(i = 0; i < ARCMSR_MAX_FREECCB_NUM; i++){