aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/scsi/sata_sil24.c17
1 files changed, 6 insertions, 11 deletions
diff --git a/drivers/scsi/sata_sil24.c b/drivers/scsi/sata_sil24.c
index 47a7bfc4a6d8..547c29a5613b 100644
--- a/drivers/scsi/sata_sil24.c
+++ b/drivers/scsi/sata_sil24.c
@@ -214,7 +214,6 @@ struct sil24_cmd_block {
214 * here from the previous interrupt. 214 * here from the previous interrupt.
215 */ 215 */
216struct sil24_port_priv { 216struct sil24_port_priv {
217 void *port;
218 struct sil24_cmd_block *cmd_block; /* 32 cmd blocks */ 217 struct sil24_cmd_block *cmd_block; /* 32 cmd blocks */
219 dma_addr_t cmd_block_dma; /* DMA base addr for them */ 218 dma_addr_t cmd_block_dma; /* DMA base addr for them */
220}; 219};
@@ -414,10 +413,11 @@ static void sil24_qc_prep(struct ata_queued_cmd *qc)
414static int sil24_qc_issue(struct ata_queued_cmd *qc) 413static int sil24_qc_issue(struct ata_queued_cmd *qc)
415{ 414{
416 struct ata_port *ap = qc->ap; 415 struct ata_port *ap = qc->ap;
416 void *port = (void *)ap->ioaddr.cmd_addr;
417 struct sil24_port_priv *pp = ap->private_data; 417 struct sil24_port_priv *pp = ap->private_data;
418 dma_addr_t paddr = pp->cmd_block_dma + qc->tag * sizeof(*pp->cmd_block); 418 dma_addr_t paddr = pp->cmd_block_dma + qc->tag * sizeof(*pp->cmd_block);
419 419
420 writel((u32)paddr, pp->port + PORT_CMD_ACTIVATE); 420 writel((u32)paddr, port + PORT_CMD_ACTIVATE);
421 return 0; 421 return 0;
422} 422}
423 423
@@ -428,8 +428,7 @@ static void sil24_irq_clear(struct ata_port *ap)
428 428
429static void sil24_reset_controller(struct ata_port *ap) 429static void sil24_reset_controller(struct ata_port *ap)
430{ 430{
431 struct sil24_port_priv *pp = ap->private_data; 431 void *port = (void *)ap->ioaddr.cmd_addr;
432 void *port = pp->port;
433 int cnt; 432 int cnt;
434 u32 tmp; 433 u32 tmp;
435 434
@@ -480,8 +479,7 @@ static void sil24_eng_timeout(struct ata_port *ap)
480static void sil24_error_intr(struct ata_port *ap, u32 slot_stat) 479static void sil24_error_intr(struct ata_port *ap, u32 slot_stat)
481{ 480{
482 struct ata_queued_cmd *qc = ata_qc_from_tag(ap, ap->active_tag); 481 struct ata_queued_cmd *qc = ata_qc_from_tag(ap, ap->active_tag);
483 struct sil24_port_priv *pp = ap->private_data; 482 void *port = (void *)ap->ioaddr.cmd_addr;
484 void *port = pp->port;
485 u32 irq_stat, cmd_err, sstatus, serror; 483 u32 irq_stat, cmd_err, sstatus, serror;
486 484
487 irq_stat = readl(port + PORT_IRQ_STAT); 485 irq_stat = readl(port + PORT_IRQ_STAT);
@@ -509,8 +507,7 @@ static void sil24_error_intr(struct ata_port *ap, u32 slot_stat)
509static inline void sil24_host_intr(struct ata_port *ap) 507static inline void sil24_host_intr(struct ata_port *ap)
510{ 508{
511 struct ata_queued_cmd *qc = ata_qc_from_tag(ap, ap->active_tag); 509 struct ata_queued_cmd *qc = ata_qc_from_tag(ap, ap->active_tag);
512 struct sil24_port_priv *pp = ap->private_data; 510 void *port = (void *)ap->ioaddr.cmd_addr;
513 void *port = pp->port;
514 u32 slot_stat; 511 u32 slot_stat;
515 512
516 slot_stat = readl(port + PORT_SLOT_STAT); 513 slot_stat = readl(port + PORT_SLOT_STAT);
@@ -561,7 +558,6 @@ static irqreturn_t sil24_interrupt(int irq, void *dev_instance, struct pt_regs *
561static int sil24_port_start(struct ata_port *ap) 558static int sil24_port_start(struct ata_port *ap)
562{ 559{
563 struct device *dev = ap->host_set->dev; 560 struct device *dev = ap->host_set->dev;
564 struct sil24_host_priv *hpriv = ap->host_set->private_data;
565 struct sil24_port_priv *pp; 561 struct sil24_port_priv *pp;
566 struct sil24_cmd_block *cb; 562 struct sil24_cmd_block *cb;
567 size_t cb_size = sizeof(*cb); 563 size_t cb_size = sizeof(*cb);
@@ -579,7 +575,6 @@ static int sil24_port_start(struct ata_port *ap)
579 } 575 }
580 memset(cb, 0, cb_size); 576 memset(cb, 0, cb_size);
581 577
582 pp->port = hpriv->port_base + ap->port_no * PORT_REGS_SIZE;
583 pp->cmd_block = cb; 578 pp->cmd_block = cb;
584 pp->cmd_block_dma = cb_dma; 579 pp->cmd_block_dma = cb_dma;
585 580
@@ -700,7 +695,7 @@ static int sil24_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
700 u32 tmp; 695 u32 tmp;
701 int cnt; 696 int cnt;
702 697
703 probe_ent->port[i].cmd_addr = portu; 698 probe_ent->port[i].cmd_addr = portu + PORT_PRB;
704 probe_ent->port[i].scr_addr = portu + PORT_SCONTROL; 699 probe_ent->port[i].scr_addr = portu + PORT_SCONTROL;
705 700
706 ata_std_ports(&probe_ent->port[i]); 701 ata_std_ports(&probe_ent->port[i]);