diff options
Diffstat (limited to 'drivers/ata/sata_mv.c')
-rw-r--r-- | drivers/ata/sata_mv.c | 62 |
1 files changed, 27 insertions, 35 deletions
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c index 8cad3b2fe554..206220ec5820 100644 --- a/drivers/ata/sata_mv.c +++ b/drivers/ata/sata_mv.c | |||
@@ -1,10 +1,13 @@ | |||
1 | /* | 1 | /* |
2 | * sata_mv.c - Marvell SATA support | 2 | * sata_mv.c - Marvell SATA support |
3 | * | 3 | * |
4 | * Copyright 2008: Marvell Corporation, all rights reserved. | 4 | * Copyright 2008-2009: Marvell Corporation, all rights reserved. |
5 | * Copyright 2005: EMC Corporation, all rights reserved. | 5 | * Copyright 2005: EMC Corporation, all rights reserved. |
6 | * Copyright 2005 Red Hat, Inc. All rights reserved. | 6 | * Copyright 2005 Red Hat, Inc. All rights reserved. |
7 | * | 7 | * |
8 | * Originally written by Brett Russ. | ||
9 | * Extensive overhaul and enhancement by Mark Lord <mlord@pobox.com>. | ||
10 | * | ||
8 | * Please ALWAYS copy linux-ide@vger.kernel.org on emails. | 11 | * Please ALWAYS copy linux-ide@vger.kernel.org on emails. |
9 | * | 12 | * |
10 | * This program is free software; you can redistribute it and/or modify | 13 | * This program is free software; you can redistribute it and/or modify |
@@ -25,8 +28,6 @@ | |||
25 | /* | 28 | /* |
26 | * sata_mv TODO list: | 29 | * sata_mv TODO list: |
27 | * | 30 | * |
28 | * --> Errata workaround for NCQ device errors. | ||
29 | * | ||
30 | * --> More errata workarounds for PCI-X. | 31 | * --> More errata workarounds for PCI-X. |
31 | * | 32 | * |
32 | * --> Complete a full errata audit for all chipsets to identify others. | 33 | * --> Complete a full errata audit for all chipsets to identify others. |
@@ -68,6 +69,16 @@ | |||
68 | #define DRV_NAME "sata_mv" | 69 | #define DRV_NAME "sata_mv" |
69 | #define DRV_VERSION "1.26" | 70 | #define DRV_VERSION "1.26" |
70 | 71 | ||
72 | /* | ||
73 | * module options | ||
74 | */ | ||
75 | |||
76 | static int msi; | ||
77 | #ifdef CONFIG_PCI | ||
78 | module_param(msi, int, S_IRUGO); | ||
79 | MODULE_PARM_DESC(msi, "Enable use of PCI MSI (0=off, 1=on)"); | ||
80 | #endif | ||
81 | |||
71 | enum { | 82 | enum { |
72 | /* BAR's are enumerated in terms of pci_resource_start() terms */ | 83 | /* BAR's are enumerated in terms of pci_resource_start() terms */ |
73 | MV_PRIMARY_BAR = 0, /* offset 0x10: memory space */ | 84 | MV_PRIMARY_BAR = 0, /* offset 0x10: memory space */ |
@@ -78,12 +89,6 @@ enum { | |||
78 | MV_MINOR_REG_AREA_SZ = 0x2000, /* 8KB */ | 89 | MV_MINOR_REG_AREA_SZ = 0x2000, /* 8KB */ |
79 | 90 | ||
80 | MV_PCI_REG_BASE = 0, | 91 | MV_PCI_REG_BASE = 0, |
81 | MV_IRQ_COAL_REG_BASE = 0x18000, /* 6xxx part only */ | ||
82 | MV_IRQ_COAL_CAUSE = (MV_IRQ_COAL_REG_BASE + 0x08), | ||
83 | MV_IRQ_COAL_CAUSE_LO = (MV_IRQ_COAL_REG_BASE + 0x88), | ||
84 | MV_IRQ_COAL_CAUSE_HI = (MV_IRQ_COAL_REG_BASE + 0x8c), | ||
85 | MV_IRQ_COAL_THRESHOLD = (MV_IRQ_COAL_REG_BASE + 0xcc), | ||
86 | MV_IRQ_COAL_TIME_THRESHOLD = (MV_IRQ_COAL_REG_BASE + 0xd0), | ||
87 | 92 | ||
88 | MV_SATAHC0_REG_BASE = 0x20000, | 93 | MV_SATAHC0_REG_BASE = 0x20000, |
89 | MV_FLASH_CTL_OFS = 0x1046c, | 94 | MV_FLASH_CTL_OFS = 0x1046c, |
@@ -115,16 +120,14 @@ enum { | |||
115 | 120 | ||
116 | /* Host Flags */ | 121 | /* Host Flags */ |
117 | MV_FLAG_DUAL_HC = (1 << 30), /* two SATA Host Controllers */ | 122 | MV_FLAG_DUAL_HC = (1 << 30), /* two SATA Host Controllers */ |
118 | MV_FLAG_IRQ_COALESCE = (1 << 29), /* IRQ coalescing capability */ | ||
119 | 123 | ||
120 | MV_COMMON_FLAGS = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | 124 | MV_COMMON_FLAGS = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | |
121 | ATA_FLAG_MMIO | ATA_FLAG_PIO_POLLING, | 125 | ATA_FLAG_MMIO | ATA_FLAG_PIO_POLLING, |
122 | 126 | ||
123 | MV_GEN_I_FLAGS = MV_COMMON_FLAGS | ATA_FLAG_NO_ATAPI, | 127 | MV_GEN_I_FLAGS = MV_COMMON_FLAGS | ATA_FLAG_NO_ATAPI, |
124 | 128 | ||
125 | MV_GEN_II_FLAGS = MV_COMMON_FLAGS | MV_FLAG_IRQ_COALESCE | | 129 | MV_GEN_II_FLAGS = MV_COMMON_FLAGS | ATA_FLAG_NCQ | |
126 | ATA_FLAG_PMP | ATA_FLAG_ACPI_SATA | | 130 | ATA_FLAG_PMP | ATA_FLAG_ACPI_SATA, |
127 | ATA_FLAG_NCQ, | ||
128 | 131 | ||
129 | MV_GEN_IIE_FLAGS = MV_GEN_II_FLAGS | ATA_FLAG_AN, | 132 | MV_GEN_IIE_FLAGS = MV_GEN_II_FLAGS | ATA_FLAG_AN, |
130 | 133 | ||
@@ -179,16 +182,16 @@ enum { | |||
179 | PCI_HC_MAIN_IRQ_MASK_OFS = 0x1d64, | 182 | PCI_HC_MAIN_IRQ_MASK_OFS = 0x1d64, |
180 | SOC_HC_MAIN_IRQ_CAUSE_OFS = 0x20020, | 183 | SOC_HC_MAIN_IRQ_CAUSE_OFS = 0x20020, |
181 | SOC_HC_MAIN_IRQ_MASK_OFS = 0x20024, | 184 | SOC_HC_MAIN_IRQ_MASK_OFS = 0x20024, |
182 | ERR_IRQ = (1 << 0), /* shift by port # */ | 185 | ERR_IRQ = (1 << 0), /* shift by (2 * port #) */ |
183 | DONE_IRQ = (1 << 1), /* shift by port # */ | 186 | DONE_IRQ = (1 << 1), /* shift by (2 * port #) */ |
184 | HC0_IRQ_PEND = 0x1ff, /* bits 0-8 = HC0's ports */ | 187 | HC0_IRQ_PEND = 0x1ff, /* bits 0-8 = HC0's ports */ |
185 | HC_SHIFT = 9, /* bits 9-17 = HC1's ports */ | 188 | HC_SHIFT = 9, /* bits 9-17 = HC1's ports */ |
186 | PCI_ERR = (1 << 18), | 189 | PCI_ERR = (1 << 18), |
187 | TRAN_LO_DONE = (1 << 19), /* 6xxx: IRQ coalescing */ | 190 | TRAN_COAL_LO_DONE = (1 << 19), /* transaction coalescing */ |
188 | TRAN_HI_DONE = (1 << 20), /* 6xxx: IRQ coalescing */ | 191 | TRAN_COAL_HI_DONE = (1 << 20), /* transaction coalescing */ |
189 | PORTS_0_3_COAL_DONE = (1 << 8), | 192 | PORTS_0_3_COAL_DONE = (1 << 8), /* HC0 IRQ coalescing */ |
190 | PORTS_4_7_COAL_DONE = (1 << 17), | 193 | PORTS_4_7_COAL_DONE = (1 << 17), /* HC1 IRQ coalescing */ |
191 | PORTS_0_7_COAL_DONE = (1 << 21), /* 6xxx: IRQ coalescing */ | 194 | ALL_PORTS_COAL_DONE = (1 << 21), /* GEN_II(E) IRQ coalescing */ |
192 | GPIO_INT = (1 << 22), | 195 | GPIO_INT = (1 << 22), |
193 | SELF_INT = (1 << 23), | 196 | SELF_INT = (1 << 23), |
194 | TWSI_INT = (1 << 24), | 197 | TWSI_INT = (1 << 24), |
@@ -621,7 +624,7 @@ static struct ata_port_operations mv6_ops = { | |||
621 | .softreset = mv_softreset, | 624 | .softreset = mv_softreset, |
622 | .error_handler = mv_pmp_error_handler, | 625 | .error_handler = mv_pmp_error_handler, |
623 | 626 | ||
624 | .sff_check_status = mv_sff_check_status, | 627 | .sff_check_status = mv_sff_check_status, |
625 | .sff_irq_clear = mv_sff_irq_clear, | 628 | .sff_irq_clear = mv_sff_irq_clear, |
626 | .check_atapi_dma = mv_check_atapi_dma, | 629 | .check_atapi_dma = mv_check_atapi_dma, |
627 | .bmdma_setup = mv_bmdma_setup, | 630 | .bmdma_setup = mv_bmdma_setup, |
@@ -1255,8 +1258,8 @@ static void mv_60x1_errata_sata25(struct ata_port *ap, int want_ncq) | |||
1255 | } | 1258 | } |
1256 | 1259 | ||
1257 | /** | 1260 | /** |
1258 | * mv_bmdma_enable - set a magic bit on GEN_IIE to allow bmdma | 1261 | * mv_bmdma_enable - set a magic bit on GEN_IIE to allow bmdma |
1259 | * @ap: Port being initialized | 1262 | * @ap: Port being initialized |
1260 | * | 1263 | * |
1261 | * There are two DMA modes on these chips: basic DMA, and EDMA. | 1264 | * There are two DMA modes on these chips: basic DMA, and EDMA. |
1262 | * | 1265 | * |
@@ -2000,7 +2003,7 @@ static unsigned int mv_qc_issue(struct ata_queued_cmd *qc) | |||
2000 | struct mv_host_priv *hpriv = ap->host->private_data; | 2003 | struct mv_host_priv *hpriv = ap->host->private_data; |
2001 | /* | 2004 | /* |
2002 | * Workaround for 88SX60x1 FEr SATA#25 (part 2). | 2005 | * Workaround for 88SX60x1 FEr SATA#25 (part 2). |
2003 | * | 2006 | * |
2004 | * After any NCQ error, the READ_LOG_EXT command | 2007 | * After any NCQ error, the READ_LOG_EXT command |
2005 | * from libata-eh *must* use mv_qc_issue_fis(). | 2008 | * from libata-eh *must* use mv_qc_issue_fis(). |
2006 | * Otherwise it might fail, due to chip errata. | 2009 | * Otherwise it might fail, due to chip errata. |
@@ -3704,12 +3707,6 @@ static struct pci_driver mv_pci_driver = { | |||
3704 | .remove = ata_pci_remove_one, | 3707 | .remove = ata_pci_remove_one, |
3705 | }; | 3708 | }; |
3706 | 3709 | ||
3707 | /* | ||
3708 | * module options | ||
3709 | */ | ||
3710 | static int msi; /* Use PCI msi; either zero (off, default) or non-zero */ | ||
3711 | |||
3712 | |||
3713 | /* move to PCI layer or libata core? */ | 3710 | /* move to PCI layer or libata core? */ |
3714 | static int pci_go_64(struct pci_dev *pdev) | 3711 | static int pci_go_64(struct pci_dev *pdev) |
3715 | { | 3712 | { |
@@ -3891,10 +3888,5 @@ MODULE_DEVICE_TABLE(pci, mv_pci_tbl); | |||
3891 | MODULE_VERSION(DRV_VERSION); | 3888 | MODULE_VERSION(DRV_VERSION); |
3892 | MODULE_ALIAS("platform:" DRV_NAME); | 3889 | MODULE_ALIAS("platform:" DRV_NAME); |
3893 | 3890 | ||
3894 | #ifdef CONFIG_PCI | ||
3895 | module_param(msi, int, 0444); | ||
3896 | MODULE_PARM_DESC(msi, "Enable use of PCI MSI (0=off, 1=on)"); | ||
3897 | #endif | ||
3898 | |||
3899 | module_init(mv_init); | 3891 | module_init(mv_init); |
3900 | module_exit(mv_exit); | 3892 | module_exit(mv_exit); |