aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/sata_promise.c50
1 files changed, 43 insertions, 7 deletions
diff --git a/drivers/scsi/sata_promise.c b/drivers/scsi/sata_promise.c
index 4d8201422a12..7c4f6ecc1cc9 100644
--- a/drivers/scsi/sata_promise.c
+++ b/drivers/scsi/sata_promise.c
@@ -84,7 +84,8 @@ static irqreturn_t pdc_interrupt (int irq, void *dev_instance, struct pt_regs *r
84static void pdc_eng_timeout(struct ata_port *ap); 84static void pdc_eng_timeout(struct ata_port *ap);
85static int pdc_port_start(struct ata_port *ap); 85static int pdc_port_start(struct ata_port *ap);
86static void pdc_port_stop(struct ata_port *ap); 86static void pdc_port_stop(struct ata_port *ap);
87static void pdc_phy_reset(struct ata_port *ap); 87static void pdc_pata_phy_reset(struct ata_port *ap);
88static void pdc_sata_phy_reset(struct ata_port *ap);
88static void pdc_qc_prep(struct ata_queued_cmd *qc); 89static void pdc_qc_prep(struct ata_queued_cmd *qc);
89static void pdc_tf_load_mmio(struct ata_port *ap, struct ata_taskfile *tf); 90static void pdc_tf_load_mmio(struct ata_port *ap, struct ata_taskfile *tf);
90static void pdc_exec_command_mmio(struct ata_port *ap, struct ata_taskfile *tf); 91static void pdc_exec_command_mmio(struct ata_port *ap, struct ata_taskfile *tf);
@@ -111,19 +112,22 @@ static Scsi_Host_Template pdc_ata_sht = {
111 .ordered_flush = 1, 112 .ordered_flush = 1,
112}; 113};
113 114
114static struct ata_port_operations pdc_ata_ops = { 115static struct ata_port_operations pdc_sata_ops = {
115 .port_disable = ata_port_disable, 116 .port_disable = ata_port_disable,
116 .tf_load = pdc_tf_load_mmio, 117 .tf_load = pdc_tf_load_mmio,
117 .tf_read = ata_tf_read, 118 .tf_read = ata_tf_read,
118 .check_status = ata_check_status, 119 .check_status = ata_check_status,
119 .exec_command = pdc_exec_command_mmio, 120 .exec_command = pdc_exec_command_mmio,
120 .dev_select = ata_std_dev_select, 121 .dev_select = ata_std_dev_select,
121 .phy_reset = pdc_phy_reset, 122
123 .phy_reset = pdc_sata_phy_reset,
124
122 .qc_prep = pdc_qc_prep, 125 .qc_prep = pdc_qc_prep,
123 .qc_issue = pdc_qc_issue_prot, 126 .qc_issue = pdc_qc_issue_prot,
124 .eng_timeout = pdc_eng_timeout, 127 .eng_timeout = pdc_eng_timeout,
125 .irq_handler = pdc_interrupt, 128 .irq_handler = pdc_interrupt,
126 .irq_clear = pdc_irq_clear, 129 .irq_clear = pdc_irq_clear,
130
127 .scr_read = pdc_sata_scr_read, 131 .scr_read = pdc_sata_scr_read,
128 .scr_write = pdc_sata_scr_write, 132 .scr_write = pdc_sata_scr_write,
129 .port_start = pdc_port_start, 133 .port_start = pdc_port_start,
@@ -131,6 +135,27 @@ static struct ata_port_operations pdc_ata_ops = {
131 .host_stop = ata_host_stop, 135 .host_stop = ata_host_stop,
132}; 136};
133 137
138static struct ata_port_operations pdc_pata_ops = {
139 .port_disable = ata_port_disable,
140 .tf_load = pdc_tf_load_mmio,
141 .tf_read = ata_tf_read,
142 .check_status = ata_check_status,
143 .exec_command = pdc_exec_command_mmio,
144 .dev_select = ata_std_dev_select,
145
146 .phy_reset = pdc_pata_phy_reset,
147
148 .qc_prep = pdc_qc_prep,
149 .qc_issue = pdc_qc_issue_prot,
150 .eng_timeout = pdc_eng_timeout,
151 .irq_handler = pdc_interrupt,
152 .irq_clear = pdc_irq_clear,
153
154 .port_start = pdc_port_start,
155 .port_stop = pdc_port_stop,
156 .host_stop = ata_host_stop,
157};
158
134static struct ata_port_info pdc_port_info[] = { 159static struct ata_port_info pdc_port_info[] = {
135 /* board_2037x */ 160 /* board_2037x */
136 { 161 {
@@ -140,7 +165,7 @@ static struct ata_port_info pdc_port_info[] = {
140 .pio_mask = 0x1f, /* pio0-4 */ 165 .pio_mask = 0x1f, /* pio0-4 */
141 .mwdma_mask = 0x07, /* mwdma0-2 */ 166 .mwdma_mask = 0x07, /* mwdma0-2 */
142 .udma_mask = 0x7f, /* udma0-6 ; FIXME */ 167 .udma_mask = 0x7f, /* udma0-6 ; FIXME */
143 .port_ops = &pdc_ata_ops, 168 .port_ops = &pdc_sata_ops,
144 }, 169 },
145 170
146 /* board_20319 */ 171 /* board_20319 */
@@ -151,7 +176,7 @@ static struct ata_port_info pdc_port_info[] = {
151 .pio_mask = 0x1f, /* pio0-4 */ 176 .pio_mask = 0x1f, /* pio0-4 */
152 .mwdma_mask = 0x07, /* mwdma0-2 */ 177 .mwdma_mask = 0x07, /* mwdma0-2 */
153 .udma_mask = 0x7f, /* udma0-6 ; FIXME */ 178 .udma_mask = 0x7f, /* udma0-6 ; FIXME */
154 .port_ops = &pdc_ata_ops, 179 .port_ops = &pdc_sata_ops,
155 }, 180 },
156 181
157 /* board_20619 */ 182 /* board_20619 */
@@ -162,7 +187,7 @@ static struct ata_port_info pdc_port_info[] = {
162 .pio_mask = 0x1f, /* pio0-4 */ 187 .pio_mask = 0x1f, /* pio0-4 */
163 .mwdma_mask = 0x07, /* mwdma0-2 */ 188 .mwdma_mask = 0x07, /* mwdma0-2 */
164 .udma_mask = 0x7f, /* udma0-6 ; FIXME */ 189 .udma_mask = 0x7f, /* udma0-6 ; FIXME */
165 .port_ops = &pdc_ata_ops, 190 .port_ops = &pdc_pata_ops,
166 }, 191 },
167}; 192};
168 193
@@ -277,12 +302,23 @@ static void pdc_reset_port(struct ata_port *ap)
277 readl(mmio); /* flush */ 302 readl(mmio); /* flush */
278} 303}
279 304
280static void pdc_phy_reset(struct ata_port *ap) 305static void pdc_sata_phy_reset(struct ata_port *ap)
281{ 306{
282 pdc_reset_port(ap); 307 pdc_reset_port(ap);
283 sata_phy_reset(ap); 308 sata_phy_reset(ap);
284} 309}
285 310
311static void pdc_pata_phy_reset(struct ata_port *ap)
312{
313 /* FIXME: add cable detect. Don't assume 40-pin cable */
314 ap->cbl = ATA_CBL_PATA40;
315 ap->udma_mask &= ATA_UDMA_MASK_40C;
316
317 pdc_reset_port(ap);
318 ata_port_probe(ap);
319 ata_bus_reset(ap);
320}
321
286static u32 pdc_sata_scr_read (struct ata_port *ap, unsigned int sc_reg) 322static u32 pdc_sata_scr_read (struct ata_port *ap, unsigned int sc_reg)
287{ 323{
288 if (sc_reg > SCR_CONTROL) 324 if (sc_reg > SCR_CONTROL)