diff options
-rw-r--r-- | drivers/ata/sata_mv.c | 62 |
1 files changed, 38 insertions, 24 deletions
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c index 0ccd990c8dac..80ade5b93b86 100644 --- a/drivers/ata/sata_mv.c +++ b/drivers/ata/sata_mv.c | |||
@@ -35,8 +35,6 @@ | |||
35 | 35 | ||
36 | 6) Add port multiplier support (intermediate) | 36 | 6) Add port multiplier support (intermediate) |
37 | 37 | ||
38 | 7) Test and verify 3.0 Gbps support | ||
39 | |||
40 | 8) Develop a low-power-consumption strategy, and implement it. | 38 | 8) Develop a low-power-consumption strategy, and implement it. |
41 | 39 | ||
42 | 9) [Experiment, low priority] See if ATAPI can be supported using | 40 | 9) [Experiment, low priority] See if ATAPI can be supported using |
@@ -286,10 +284,10 @@ enum { | |||
286 | EDMA_RSP_Q_OUT_PTR_OFS = 0x24, /* also contains BASE_LO */ | 284 | EDMA_RSP_Q_OUT_PTR_OFS = 0x24, /* also contains BASE_LO */ |
287 | EDMA_RSP_Q_PTR_SHIFT = 3, | 285 | EDMA_RSP_Q_PTR_SHIFT = 3, |
288 | 286 | ||
289 | EDMA_CMD_OFS = 0x28, | 287 | EDMA_CMD_OFS = 0x28, /* EDMA command register */ |
290 | EDMA_EN = (1 << 0), | 288 | EDMA_EN = (1 << 0), /* enable EDMA */ |
291 | EDMA_DS = (1 << 1), | 289 | EDMA_DS = (1 << 1), /* disable EDMA; self-negated */ |
292 | ATA_RST = (1 << 2), | 290 | ATA_RST = (1 << 2), /* reset trans/link/phy */ |
293 | 291 | ||
294 | EDMA_IORDY_TMOUT = 0x34, | 292 | EDMA_IORDY_TMOUT = 0x34, |
295 | EDMA_ARB_CFG = 0x38, | 293 | EDMA_ARB_CFG = 0x38, |
@@ -301,14 +299,13 @@ enum { | |||
301 | MV_HP_ERRATA_60X1B2 = (1 << 3), | 299 | MV_HP_ERRATA_60X1B2 = (1 << 3), |
302 | MV_HP_ERRATA_60X1C0 = (1 << 4), | 300 | MV_HP_ERRATA_60X1C0 = (1 << 4), |
303 | MV_HP_ERRATA_XX42A0 = (1 << 5), | 301 | MV_HP_ERRATA_XX42A0 = (1 << 5), |
304 | MV_HP_GEN_I = (1 << 6), | 302 | MV_HP_GEN_I = (1 << 6), /* Generation I: 50xx */ |
305 | MV_HP_GEN_II = (1 << 7), | 303 | MV_HP_GEN_II = (1 << 7), /* Generation II: 60xx */ |
306 | MV_HP_GEN_IIE = (1 << 8), | 304 | MV_HP_GEN_IIE = (1 << 8), /* Generation IIE: 6042/7042 */ |
307 | 305 | ||
308 | /* Port private flags (pp_flags) */ | 306 | /* Port private flags (pp_flags) */ |
309 | MV_PP_FLAG_EDMA_EN = (1 << 0), | 307 | MV_PP_FLAG_EDMA_EN = (1 << 0), /* is EDMA engine enabled? */ |
310 | MV_PP_FLAG_EDMA_DS_ACT = (1 << 1), | 308 | MV_PP_FLAG_HAD_A_RESET = (1 << 2), /* 1st hard reset complete? */ |
311 | MV_PP_FLAG_HAD_A_RESET = (1 << 2), | ||
312 | }; | 309 | }; |
313 | 310 | ||
314 | #define IS_GEN_I(hpriv) ((hpriv)->hp_flags & MV_HP_GEN_I) | 311 | #define IS_GEN_I(hpriv) ((hpriv)->hp_flags & MV_HP_GEN_I) |
@@ -318,8 +315,12 @@ enum { | |||
318 | enum { | 315 | enum { |
319 | MV_DMA_BOUNDARY = 0xffffffffU, | 316 | MV_DMA_BOUNDARY = 0xffffffffU, |
320 | 317 | ||
318 | /* mask of register bits containing lower 32 bits | ||
319 | * of EDMA request queue DMA address | ||
320 | */ | ||
321 | EDMA_REQ_Q_BASE_LO_MASK = 0xfffffc00U, | 321 | EDMA_REQ_Q_BASE_LO_MASK = 0xfffffc00U, |
322 | 322 | ||
323 | /* ditto, for response queue */ | ||
323 | EDMA_RSP_Q_BASE_LO_MASK = 0xffffff00U, | 324 | EDMA_RSP_Q_BASE_LO_MASK = 0xffffff00U, |
324 | }; | 325 | }; |
325 | 326 | ||
@@ -823,7 +824,7 @@ static void mv_start_dma(void __iomem *base, struct mv_host_priv *hpriv, | |||
823 | } | 824 | } |
824 | 825 | ||
825 | /** | 826 | /** |
826 | * mv_stop_dma - Disable eDMA engine | 827 | * __mv_stop_dma - Disable eDMA engine |
827 | * @ap: ATA channel to manipulate | 828 | * @ap: ATA channel to manipulate |
828 | * | 829 | * |
829 | * Verify the local cache of the eDMA state is accurate with a | 830 | * Verify the local cache of the eDMA state is accurate with a |
@@ -832,7 +833,7 @@ static void mv_start_dma(void __iomem *base, struct mv_host_priv *hpriv, | |||
832 | * LOCKING: | 833 | * LOCKING: |
833 | * Inherited from caller. | 834 | * Inherited from caller. |
834 | */ | 835 | */ |
835 | static int mv_stop_dma(struct ata_port *ap) | 836 | static int __mv_stop_dma(struct ata_port *ap) |
836 | { | 837 | { |
837 | void __iomem *port_mmio = mv_ap_base(ap); | 838 | void __iomem *port_mmio = mv_ap_base(ap); |
838 | struct mv_port_priv *pp = ap->private_data; | 839 | struct mv_port_priv *pp = ap->private_data; |
@@ -865,6 +866,18 @@ static int mv_stop_dma(struct ata_port *ap) | |||
865 | return err; | 866 | return err; |
866 | } | 867 | } |
867 | 868 | ||
869 | static int mv_stop_dma(struct ata_port *ap) | ||
870 | { | ||
871 | unsigned long flags; | ||
872 | int rc; | ||
873 | |||
874 | spin_lock_irqsave(&ap->host->lock, flags); | ||
875 | rc = __mv_stop_dma(ap); | ||
876 | spin_unlock_irqrestore(&ap->host->lock, flags); | ||
877 | |||
878 | return rc; | ||
879 | } | ||
880 | |||
868 | #ifdef ATA_DEBUG | 881 | #ifdef ATA_DEBUG |
869 | static void mv_dump_mem(void __iomem *start, unsigned bytes) | 882 | static void mv_dump_mem(void __iomem *start, unsigned bytes) |
870 | { | 883 | { |
@@ -965,7 +978,7 @@ static u32 mv_scr_read(struct ata_port *ap, unsigned int sc_reg_in) | |||
965 | { | 978 | { |
966 | unsigned int ofs = mv_scr_offset(sc_reg_in); | 979 | unsigned int ofs = mv_scr_offset(sc_reg_in); |
967 | 980 | ||
968 | if (0xffffffffU != ofs) | 981 | if (ofs != 0xffffffffU) |
969 | return readl(mv_ap_base(ap) + ofs); | 982 | return readl(mv_ap_base(ap) + ofs); |
970 | else | 983 | else |
971 | return (u32) ofs; | 984 | return (u32) ofs; |
@@ -975,7 +988,7 @@ static void mv_scr_write(struct ata_port *ap, unsigned int sc_reg_in, u32 val) | |||
975 | { | 988 | { |
976 | unsigned int ofs = mv_scr_offset(sc_reg_in); | 989 | unsigned int ofs = mv_scr_offset(sc_reg_in); |
977 | 990 | ||
978 | if (0xffffffffU != ofs) | 991 | if (ofs != 0xffffffffU) |
979 | writelfl(val, mv_ap_base(ap) + ofs); | 992 | writelfl(val, mv_ap_base(ap) + ofs); |
980 | } | 993 | } |
981 | 994 | ||
@@ -1029,6 +1042,7 @@ static int mv_port_start(struct ata_port *ap) | |||
1029 | void __iomem *port_mmio = mv_ap_base(ap); | 1042 | void __iomem *port_mmio = mv_ap_base(ap); |
1030 | void *mem; | 1043 | void *mem; |
1031 | dma_addr_t mem_dma; | 1044 | dma_addr_t mem_dma; |
1045 | unsigned long flags; | ||
1032 | int rc; | 1046 | int rc; |
1033 | 1047 | ||
1034 | pp = devm_kzalloc(dev, sizeof(*pp), GFP_KERNEL); | 1048 | pp = devm_kzalloc(dev, sizeof(*pp), GFP_KERNEL); |
@@ -1067,10 +1081,14 @@ static int mv_port_start(struct ata_port *ap) | |||
1067 | pp->sg_tbl = mem; | 1081 | pp->sg_tbl = mem; |
1068 | pp->sg_tbl_dma = mem_dma; | 1082 | pp->sg_tbl_dma = mem_dma; |
1069 | 1083 | ||
1084 | spin_lock_irqsave(&ap->host->lock, flags); | ||
1085 | |||
1070 | mv_edma_cfg(ap, hpriv, port_mmio); | 1086 | mv_edma_cfg(ap, hpriv, port_mmio); |
1071 | 1087 | ||
1072 | mv_set_edma_ptrs(port_mmio, hpriv, pp); | 1088 | mv_set_edma_ptrs(port_mmio, hpriv, pp); |
1073 | 1089 | ||
1090 | spin_unlock_irqrestore(&ap->host->lock, flags); | ||
1091 | |||
1074 | /* Don't turn on EDMA here...do it before DMA commands only. Else | 1092 | /* Don't turn on EDMA here...do it before DMA commands only. Else |
1075 | * we'll be unable to send non-data, PIO, etc due to restricted access | 1093 | * we'll be unable to send non-data, PIO, etc due to restricted access |
1076 | * to shadow regs. | 1094 | * to shadow regs. |
@@ -1090,11 +1108,7 @@ static int mv_port_start(struct ata_port *ap) | |||
1090 | */ | 1108 | */ |
1091 | static void mv_port_stop(struct ata_port *ap) | 1109 | static void mv_port_stop(struct ata_port *ap) |
1092 | { | 1110 | { |
1093 | unsigned long flags; | ||
1094 | |||
1095 | spin_lock_irqsave(&ap->host->lock, flags); | ||
1096 | mv_stop_dma(ap); | 1111 | mv_stop_dma(ap); |
1097 | spin_unlock_irqrestore(&ap->host->lock, flags); | ||
1098 | } | 1112 | } |
1099 | 1113 | ||
1100 | /** | 1114 | /** |
@@ -1325,7 +1339,7 @@ static unsigned int mv_qc_issue(struct ata_queued_cmd *qc) | |||
1325 | * port. Turn off EDMA so there won't be problems accessing | 1339 | * port. Turn off EDMA so there won't be problems accessing |
1326 | * shadow block, etc registers. | 1340 | * shadow block, etc registers. |
1327 | */ | 1341 | */ |
1328 | mv_stop_dma(ap); | 1342 | __mv_stop_dma(ap); |
1329 | return ata_qc_issue_prot(qc); | 1343 | return ata_qc_issue_prot(qc); |
1330 | } | 1344 | } |
1331 | 1345 | ||
@@ -1497,7 +1511,7 @@ static void mv_intr_edma(struct ata_port *ap) | |||
1497 | break; | 1511 | break; |
1498 | 1512 | ||
1499 | /* 50xx: get active ATA command */ | 1513 | /* 50xx: get active ATA command */ |
1500 | if (IS_GEN_I(hpriv)) | 1514 | if (IS_GEN_I(hpriv)) |
1501 | tag = ap->active_tag; | 1515 | tag = ap->active_tag; |
1502 | 1516 | ||
1503 | /* Gen II/IIE: get active ATA command via tag, to enable | 1517 | /* Gen II/IIE: get active ATA command via tag, to enable |
@@ -1532,7 +1546,7 @@ static void mv_intr_edma(struct ata_port *ap) | |||
1532 | ata_qc_complete(qc); | 1546 | ata_qc_complete(qc); |
1533 | } | 1547 | } |
1534 | 1548 | ||
1535 | /* advance software response queue pointer, to | 1549 | /* advance software response queue pointer, to |
1536 | * indicate (after the loop completes) to hardware | 1550 | * indicate (after the loop completes) to hardware |
1537 | * that we have consumed a response queue entry. | 1551 | * that we have consumed a response queue entry. |
1538 | */ | 1552 | */ |
@@ -2206,7 +2220,7 @@ static int mv_prereset(struct ata_port *ap, unsigned long deadline) | |||
2206 | struct mv_port_priv *pp = ap->private_data; | 2220 | struct mv_port_priv *pp = ap->private_data; |
2207 | struct ata_eh_context *ehc = &ap->eh_context; | 2221 | struct ata_eh_context *ehc = &ap->eh_context; |
2208 | int rc; | 2222 | int rc; |
2209 | 2223 | ||
2210 | rc = mv_stop_dma(ap); | 2224 | rc = mv_stop_dma(ap); |
2211 | if (rc) | 2225 | if (rc) |
2212 | ehc->i.action |= ATA_EH_HARDRESET; | 2226 | ehc->i.action |= ATA_EH_HARDRESET; |