diff options
Diffstat (limited to 'drivers/ata')
68 files changed, 3578 insertions, 3139 deletions
diff --git a/drivers/ata/Kconfig b/drivers/ata/Kconfig index 7bdbe5a914d..365c306c7cf 100644 --- a/drivers/ata/Kconfig +++ b/drivers/ata/Kconfig | |||
@@ -156,11 +156,6 @@ config SATA_INIC162X | |||
156 | help | 156 | help |
157 | This option enables support for Initio 162x Serial ATA. | 157 | This option enables support for Initio 162x Serial ATA. |
158 | 158 | ||
159 | config SATA_INTEL_COMBINED | ||
160 | bool | ||
161 | depends on IDE=y && !BLK_DEV_IDE_SATA && (SATA_AHCI || ATA_PIIX) | ||
162 | default y | ||
163 | |||
164 | config SATA_ACPI | 159 | config SATA_ACPI |
165 | bool | 160 | bool |
166 | depends on ACPI && PCI | 161 | depends on ACPI && PCI |
@@ -184,7 +179,7 @@ config PATA_ALI | |||
184 | If unsure, say N. | 179 | If unsure, say N. |
185 | 180 | ||
186 | config PATA_AMD | 181 | config PATA_AMD |
187 | tristate "AMD/NVidia PATA support (Experimental)" | 182 | tristate "AMD/NVidia PATA support" |
188 | depends on PCI | 183 | depends on PCI |
189 | help | 184 | help |
190 | This option enables support for the AMD and NVidia PATA | 185 | This option enables support for the AMD and NVidia PATA |
@@ -209,6 +204,16 @@ config PATA_ATIIXP | |||
209 | 204 | ||
210 | If unsure, say N. | 205 | If unsure, say N. |
211 | 206 | ||
207 | config PATA_CMD640_PCI | ||
208 | tristate "CMD640 PCI PATA support (Very Experimental)" | ||
209 | depends on PCI && EXPERIMENTAL | ||
210 | help | ||
211 | This option enables support for the CMD640 PCI IDE | ||
212 | interface chip. Only the primary channel is currently | ||
213 | supported. | ||
214 | |||
215 | If unsure, say N. | ||
216 | |||
212 | config PATA_CMD64X | 217 | config PATA_CMD64X |
213 | tristate "CMD64x PATA support (Very Experimental)" | 218 | tristate "CMD64x PATA support (Very Experimental)" |
214 | depends on PCI&& EXPERIMENTAL | 219 | depends on PCI&& EXPERIMENTAL |
@@ -273,7 +278,7 @@ config ATA_GENERIC | |||
273 | If unsure, say N. | 278 | If unsure, say N. |
274 | 279 | ||
275 | config PATA_HPT366 | 280 | config PATA_HPT366 |
276 | tristate "HPT 366/368 PATA support (Very Experimental)" | 281 | tristate "HPT 366/368 PATA support (Experimental)" |
277 | depends on PCI && EXPERIMENTAL | 282 | depends on PCI && EXPERIMENTAL |
278 | help | 283 | help |
279 | This option enables support for the HPT 366 and 368 | 284 | This option enables support for the HPT 366 and 368 |
@@ -282,7 +287,7 @@ config PATA_HPT366 | |||
282 | If unsure, say N. | 287 | If unsure, say N. |
283 | 288 | ||
284 | config PATA_HPT37X | 289 | config PATA_HPT37X |
285 | tristate "HPT 370/370A/371/372/374/302 PATA support (Very Experimental)" | 290 | tristate "HPT 370/370A/371/372/374/302 PATA support (Experimental)" |
286 | depends on PCI && EXPERIMENTAL | 291 | depends on PCI && EXPERIMENTAL |
287 | help | 292 | help |
288 | This option enables support for the majority of the later HPT | 293 | This option enables support for the majority of the later HPT |
@@ -309,7 +314,7 @@ config PATA_HPT3X3 | |||
309 | If unsure, say N. | 314 | If unsure, say N. |
310 | 315 | ||
311 | config PATA_ISAPNP | 316 | config PATA_ISAPNP |
312 | tristate "ISA Plug and Play PATA support (Very Experimental)" | 317 | tristate "ISA Plug and Play PATA support (Experimental)" |
313 | depends on EXPERIMENTAL && ISAPNP | 318 | depends on EXPERIMENTAL && ISAPNP |
314 | help | 319 | help |
315 | This option enables support for ISA plug & play ATA | 320 | This option enables support for ISA plug & play ATA |
@@ -318,8 +323,8 @@ config PATA_ISAPNP | |||
318 | If unsure, say N. | 323 | If unsure, say N. |
319 | 324 | ||
320 | config PATA_IT821X | 325 | config PATA_IT821X |
321 | tristate "IT8211/2 PATA support (Experimental)" | 326 | tristate "IT8211/2 PATA support" |
322 | depends on PCI && EXPERIMENTAL | 327 | depends on PCI |
323 | help | 328 | help |
324 | This option enables support for the ITE 8211 and 8212 | 329 | This option enables support for the ITE 8211 and 8212 |
325 | PATA controllers via the new ATA layer, including RAID | 330 | PATA controllers via the new ATA layer, including RAID |
@@ -390,10 +395,10 @@ config PATA_MPIIX | |||
390 | If unsure, say N. | 395 | If unsure, say N. |
391 | 396 | ||
392 | config PATA_OLDPIIX | 397 | config PATA_OLDPIIX |
393 | tristate "Intel PATA old PIIX support (Experimental)" | 398 | tristate "Intel PATA old PIIX support" |
394 | depends on PCI && EXPERIMENTAL | 399 | depends on PCI |
395 | help | 400 | help |
396 | This option enables support for old(?) PIIX PATA support. | 401 | This option enables support for early PIIX PATA support. |
397 | 402 | ||
398 | If unsure, say N. | 403 | If unsure, say N. |
399 | 404 | ||
@@ -444,7 +449,7 @@ config PATA_PCMCIA | |||
444 | If unsure, say N. | 449 | If unsure, say N. |
445 | 450 | ||
446 | config PATA_PDC_OLD | 451 | config PATA_PDC_OLD |
447 | tristate "Older Promise PATA controller support (Very Experimental)" | 452 | tristate "Older Promise PATA controller support (Experimental)" |
448 | depends on PCI && EXPERIMENTAL | 453 | depends on PCI && EXPERIMENTAL |
449 | help | 454 | help |
450 | This option enables support for the Promise 20246, 20262, 20263, | 455 | This option enables support for the Promise 20246, 20262, 20263, |
@@ -459,7 +464,7 @@ config PATA_QDI | |||
459 | Support for QDI 6500 and 6580 PATA controllers on VESA local bus. | 464 | Support for QDI 6500 and 6580 PATA controllers on VESA local bus. |
460 | 465 | ||
461 | config PATA_RADISYS | 466 | config PATA_RADISYS |
462 | tristate "RADISYS 82600 PATA support (Very experimental)" | 467 | tristate "RADISYS 82600 PATA support (Very Experimental)" |
463 | depends on PCI && EXPERIMENTAL | 468 | depends on PCI && EXPERIMENTAL |
464 | help | 469 | help |
465 | This option enables support for the RADISYS 82600 | 470 | This option enables support for the RADISYS 82600 |
@@ -477,7 +482,7 @@ config PATA_RZ1000 | |||
477 | If unsure, say N. | 482 | If unsure, say N. |
478 | 483 | ||
479 | config PATA_SC1200 | 484 | config PATA_SC1200 |
480 | tristate "SC1200 PATA support (Raving Lunatic)" | 485 | tristate "SC1200 PATA support (Very Experimental)" |
481 | depends on PCI && EXPERIMENTAL | 486 | depends on PCI && EXPERIMENTAL |
482 | help | 487 | help |
483 | This option enables support for the NatSemi/AMD SC1200 SoC | 488 | This option enables support for the NatSemi/AMD SC1200 SoC |
@@ -486,8 +491,8 @@ config PATA_SC1200 | |||
486 | If unsure, say N. | 491 | If unsure, say N. |
487 | 492 | ||
488 | config PATA_SERVERWORKS | 493 | config PATA_SERVERWORKS |
489 | tristate "SERVERWORKS OSB4/CSB5/CSB6/HT1000 PATA support (Experimental)" | 494 | tristate "SERVERWORKS OSB4/CSB5/CSB6/HT1000 PATA support" |
490 | depends on PCI && EXPERIMENTAL | 495 | depends on PCI |
491 | help | 496 | help |
492 | This option enables support for the Serverworks OSB4/CSB5/CSB6 and | 497 | This option enables support for the Serverworks OSB4/CSB5/CSB6 and |
493 | HT1000 PATA controllers, via the new ATA layer. | 498 | HT1000 PATA controllers, via the new ATA layer. |
diff --git a/drivers/ata/Makefile b/drivers/ata/Makefile index 13d7397e000..b7055e30265 100644 --- a/drivers/ata/Makefile +++ b/drivers/ata/Makefile | |||
@@ -22,6 +22,7 @@ obj-$(CONFIG_PATA_ALI) += pata_ali.o | |||
22 | obj-$(CONFIG_PATA_AMD) += pata_amd.o | 22 | obj-$(CONFIG_PATA_AMD) += pata_amd.o |
23 | obj-$(CONFIG_PATA_ARTOP) += pata_artop.o | 23 | obj-$(CONFIG_PATA_ARTOP) += pata_artop.o |
24 | obj-$(CONFIG_PATA_ATIIXP) += pata_atiixp.o | 24 | obj-$(CONFIG_PATA_ATIIXP) += pata_atiixp.o |
25 | obj-$(CONFIG_PATA_CMD640_PCI) += pata_cmd640.o | ||
25 | obj-$(CONFIG_PATA_CMD64X) += pata_cmd64x.o | 26 | obj-$(CONFIG_PATA_CMD64X) += pata_cmd64x.o |
26 | obj-$(CONFIG_PATA_CS5520) += pata_cs5520.o | 27 | obj-$(CONFIG_PATA_CS5520) += pata_cs5520.o |
27 | obj-$(CONFIG_PATA_CS5530) += pata_cs5530.o | 28 | obj-$(CONFIG_PATA_CS5530) += pata_cs5530.o |
diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c index fd27227771b..34c5534ed64 100644 --- a/drivers/ata/ahci.c +++ b/drivers/ata/ahci.c | |||
@@ -170,6 +170,10 @@ enum { | |||
170 | AHCI_FLAG_IGN_IRQ_IF_ERR = (1 << 25), /* ignore IRQ_IF_ERR */ | 170 | AHCI_FLAG_IGN_IRQ_IF_ERR = (1 << 25), /* ignore IRQ_IF_ERR */ |
171 | AHCI_FLAG_HONOR_PI = (1 << 26), /* honor PORTS_IMPL */ | 171 | AHCI_FLAG_HONOR_PI = (1 << 26), /* honor PORTS_IMPL */ |
172 | AHCI_FLAG_IGN_SERR_INTERNAL = (1 << 27), /* ignore SERR_INTERNAL */ | 172 | AHCI_FLAG_IGN_SERR_INTERNAL = (1 << 27), /* ignore SERR_INTERNAL */ |
173 | |||
174 | AHCI_FLAG_COMMON = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
175 | ATA_FLAG_MMIO | ATA_FLAG_PIO_DMA | | ||
176 | ATA_FLAG_SKIP_D2H_BSY, | ||
173 | }; | 177 | }; |
174 | 178 | ||
175 | struct ahci_cmd_hdr { | 179 | struct ahci_cmd_hdr { |
@@ -188,8 +192,10 @@ struct ahci_sg { | |||
188 | }; | 192 | }; |
189 | 193 | ||
190 | struct ahci_host_priv { | 194 | struct ahci_host_priv { |
191 | u32 cap; /* cache of HOST_CAP register */ | 195 | u32 cap; /* cap to use */ |
192 | u32 port_map; /* cache of HOST_PORTS_IMPL reg */ | 196 | u32 port_map; /* port map to use */ |
197 | u32 saved_cap; /* saved initial cap */ | ||
198 | u32 saved_port_map; /* saved initial port_map */ | ||
193 | }; | 199 | }; |
194 | 200 | ||
195 | struct ahci_port_priv { | 201 | struct ahci_port_priv { |
@@ -209,7 +215,6 @@ static u32 ahci_scr_read (struct ata_port *ap, unsigned int sc_reg); | |||
209 | static void ahci_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); | 215 | static void ahci_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); |
210 | static int ahci_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); | 216 | static int ahci_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); |
211 | static unsigned int ahci_qc_issue(struct ata_queued_cmd *qc); | 217 | static unsigned int ahci_qc_issue(struct ata_queued_cmd *qc); |
212 | static irqreturn_t ahci_interrupt (int irq, void *dev_instance); | ||
213 | static void ahci_irq_clear(struct ata_port *ap); | 218 | static void ahci_irq_clear(struct ata_port *ap); |
214 | static int ahci_port_start(struct ata_port *ap); | 219 | static int ahci_port_start(struct ata_port *ap); |
215 | static void ahci_port_stop(struct ata_port *ap); | 220 | static void ahci_port_stop(struct ata_port *ap); |
@@ -263,7 +268,6 @@ static const struct ata_port_operations ahci_ops = { | |||
263 | .qc_prep = ahci_qc_prep, | 268 | .qc_prep = ahci_qc_prep, |
264 | .qc_issue = ahci_qc_issue, | 269 | .qc_issue = ahci_qc_issue, |
265 | 270 | ||
266 | .irq_handler = ahci_interrupt, | ||
267 | .irq_clear = ahci_irq_clear, | 271 | .irq_clear = ahci_irq_clear, |
268 | .irq_on = ata_dummy_irq_on, | 272 | .irq_on = ata_dummy_irq_on, |
269 | .irq_ack = ata_dummy_irq_ack, | 273 | .irq_ack = ata_dummy_irq_ack, |
@@ -298,7 +302,6 @@ static const struct ata_port_operations ahci_vt8251_ops = { | |||
298 | .qc_prep = ahci_qc_prep, | 302 | .qc_prep = ahci_qc_prep, |
299 | .qc_issue = ahci_qc_issue, | 303 | .qc_issue = ahci_qc_issue, |
300 | 304 | ||
301 | .irq_handler = ahci_interrupt, | ||
302 | .irq_clear = ahci_irq_clear, | 305 | .irq_clear = ahci_irq_clear, |
303 | .irq_on = ata_dummy_irq_on, | 306 | .irq_on = ata_dummy_irq_on, |
304 | .irq_ack = ata_dummy_irq_ack, | 307 | .irq_ack = ata_dummy_irq_ack, |
@@ -324,58 +327,41 @@ static const struct ata_port_operations ahci_vt8251_ops = { | |||
324 | static const struct ata_port_info ahci_port_info[] = { | 327 | static const struct ata_port_info ahci_port_info[] = { |
325 | /* board_ahci */ | 328 | /* board_ahci */ |
326 | { | 329 | { |
327 | .sht = &ahci_sht, | 330 | .flags = AHCI_FLAG_COMMON, |
328 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
329 | ATA_FLAG_MMIO | ATA_FLAG_PIO_DMA | | ||
330 | ATA_FLAG_SKIP_D2H_BSY, | ||
331 | .pio_mask = 0x1f, /* pio0-4 */ | 331 | .pio_mask = 0x1f, /* pio0-4 */ |
332 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 332 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
333 | .port_ops = &ahci_ops, | 333 | .port_ops = &ahci_ops, |
334 | }, | 334 | }, |
335 | /* board_ahci_pi */ | 335 | /* board_ahci_pi */ |
336 | { | 336 | { |
337 | .sht = &ahci_sht, | 337 | .flags = AHCI_FLAG_COMMON | AHCI_FLAG_HONOR_PI, |
338 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
339 | ATA_FLAG_MMIO | ATA_FLAG_PIO_DMA | | ||
340 | ATA_FLAG_SKIP_D2H_BSY | AHCI_FLAG_HONOR_PI, | ||
341 | .pio_mask = 0x1f, /* pio0-4 */ | 338 | .pio_mask = 0x1f, /* pio0-4 */ |
342 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 339 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
343 | .port_ops = &ahci_ops, | 340 | .port_ops = &ahci_ops, |
344 | }, | 341 | }, |
345 | /* board_ahci_vt8251 */ | 342 | /* board_ahci_vt8251 */ |
346 | { | 343 | { |
347 | .sht = &ahci_sht, | 344 | .flags = AHCI_FLAG_COMMON | ATA_FLAG_HRST_TO_RESUME | |
348 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | 345 | AHCI_FLAG_NO_NCQ, |
349 | ATA_FLAG_MMIO | ATA_FLAG_PIO_DMA | | ||
350 | ATA_FLAG_SKIP_D2H_BSY | | ||
351 | ATA_FLAG_HRST_TO_RESUME | AHCI_FLAG_NO_NCQ, | ||
352 | .pio_mask = 0x1f, /* pio0-4 */ | 346 | .pio_mask = 0x1f, /* pio0-4 */ |
353 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 347 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
354 | .port_ops = &ahci_vt8251_ops, | 348 | .port_ops = &ahci_vt8251_ops, |
355 | }, | 349 | }, |
356 | /* board_ahci_ign_iferr */ | 350 | /* board_ahci_ign_iferr */ |
357 | { | 351 | { |
358 | .sht = &ahci_sht, | 352 | .flags = AHCI_FLAG_COMMON | AHCI_FLAG_IGN_IRQ_IF_ERR, |
359 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
360 | ATA_FLAG_MMIO | ATA_FLAG_PIO_DMA | | ||
361 | ATA_FLAG_SKIP_D2H_BSY | | ||
362 | AHCI_FLAG_IGN_IRQ_IF_ERR, | ||
363 | .pio_mask = 0x1f, /* pio0-4 */ | 353 | .pio_mask = 0x1f, /* pio0-4 */ |
364 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 354 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
365 | .port_ops = &ahci_ops, | 355 | .port_ops = &ahci_ops, |
366 | }, | 356 | }, |
367 | /* board_ahci_sb600 */ | 357 | /* board_ahci_sb600 */ |
368 | { | 358 | { |
369 | .sht = &ahci_sht, | 359 | .flags = AHCI_FLAG_COMMON | |
370 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
371 | ATA_FLAG_MMIO | ATA_FLAG_PIO_DMA | | ||
372 | ATA_FLAG_SKIP_D2H_BSY | | ||
373 | AHCI_FLAG_IGN_SERR_INTERNAL, | 360 | AHCI_FLAG_IGN_SERR_INTERNAL, |
374 | .pio_mask = 0x1f, /* pio0-4 */ | 361 | .pio_mask = 0x1f, /* pio0-4 */ |
375 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 362 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
376 | .port_ops = &ahci_ops, | 363 | .port_ops = &ahci_ops, |
377 | }, | 364 | }, |
378 | |||
379 | }; | 365 | }; |
380 | 366 | ||
381 | static const struct pci_device_id ahci_pci_tbl[] = { | 367 | static const struct pci_device_id ahci_pci_tbl[] = { |
@@ -413,11 +399,11 @@ static const struct pci_device_id ahci_pci_tbl[] = { | |||
413 | PCI_CLASS_STORAGE_SATA_AHCI, 0xffffff, board_ahci_ign_iferr }, | 399 | PCI_CLASS_STORAGE_SATA_AHCI, 0xffffff, board_ahci_ign_iferr }, |
414 | 400 | ||
415 | /* ATI */ | 401 | /* ATI */ |
416 | { PCI_VDEVICE(ATI, 0x4380), board_ahci_sb600 }, /* ATI SB600 non-raid */ | 402 | { PCI_VDEVICE(ATI, 0x4380), board_ahci_sb600 }, /* ATI SB600 */ |
417 | { PCI_VDEVICE(ATI, 0x4381), board_ahci }, /* ATI SB600 raid */ | ||
418 | 403 | ||
419 | /* VIA */ | 404 | /* VIA */ |
420 | { PCI_VDEVICE(VIA, 0x3349), board_ahci_vt8251 }, /* VIA VT8251 */ | 405 | { PCI_VDEVICE(VIA, 0x3349), board_ahci_vt8251 }, /* VIA VT8251 */ |
406 | { PCI_VDEVICE(VIA, 0x6287), board_ahci_vt8251 }, /* VIA VT8251 */ | ||
421 | 407 | ||
422 | /* NVIDIA */ | 408 | /* NVIDIA */ |
423 | { PCI_VDEVICE(NVIDIA, 0x044c), board_ahci }, /* MCP65 */ | 409 | { PCI_VDEVICE(NVIDIA, 0x044c), board_ahci }, /* MCP65 */ |
@@ -471,10 +457,100 @@ static inline int ahci_nr_ports(u32 cap) | |||
471 | return (cap & 0x1f) + 1; | 457 | return (cap & 0x1f) + 1; |
472 | } | 458 | } |
473 | 459 | ||
474 | static inline void __iomem *ahci_port_base(void __iomem *base, | 460 | static inline void __iomem *ahci_port_base(struct ata_port *ap) |
475 | unsigned int port) | 461 | { |
462 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
463 | |||
464 | return mmio + 0x100 + (ap->port_no * 0x80); | ||
465 | } | ||
466 | |||
467 | /** | ||
468 | * ahci_save_initial_config - Save and fixup initial config values | ||
469 | * @pdev: target PCI device | ||
470 | * @pi: associated ATA port info | ||
471 | * @hpriv: host private area to store config values | ||
472 | * | ||
473 | * Some registers containing configuration info might be setup by | ||
474 | * BIOS and might be cleared on reset. This function saves the | ||
475 | * initial values of those registers into @hpriv such that they | ||
476 | * can be restored after controller reset. | ||
477 | * | ||
478 | * If inconsistent, config values are fixed up by this function. | ||
479 | * | ||
480 | * LOCKING: | ||
481 | * None. | ||
482 | */ | ||
483 | static void ahci_save_initial_config(struct pci_dev *pdev, | ||
484 | const struct ata_port_info *pi, | ||
485 | struct ahci_host_priv *hpriv) | ||
476 | { | 486 | { |
477 | return base + 0x100 + (port * 0x80); | 487 | void __iomem *mmio = pcim_iomap_table(pdev)[AHCI_PCI_BAR]; |
488 | u32 cap, port_map; | ||
489 | int i; | ||
490 | |||
491 | /* Values prefixed with saved_ are written back to host after | ||
492 | * reset. Values without are used for driver operation. | ||
493 | */ | ||
494 | hpriv->saved_cap = cap = readl(mmio + HOST_CAP); | ||
495 | hpriv->saved_port_map = port_map = readl(mmio + HOST_PORTS_IMPL); | ||
496 | |||
497 | /* fixup zero port_map */ | ||
498 | if (!port_map) { | ||
499 | port_map = (1 << ahci_nr_ports(hpriv->cap)) - 1; | ||
500 | dev_printk(KERN_WARNING, &pdev->dev, | ||
501 | "PORTS_IMPL is zero, forcing 0x%x\n", port_map); | ||
502 | |||
503 | /* write the fixed up value to the PI register */ | ||
504 | hpriv->saved_port_map = port_map; | ||
505 | } | ||
506 | |||
507 | /* cross check port_map and cap.n_ports */ | ||
508 | if (pi->flags & AHCI_FLAG_HONOR_PI) { | ||
509 | u32 tmp_port_map = port_map; | ||
510 | int n_ports = ahci_nr_ports(cap); | ||
511 | |||
512 | for (i = 0; i < AHCI_MAX_PORTS && n_ports; i++) { | ||
513 | if (tmp_port_map & (1 << i)) { | ||
514 | n_ports--; | ||
515 | tmp_port_map &= ~(1 << i); | ||
516 | } | ||
517 | } | ||
518 | |||
519 | /* Whine if inconsistent. No need to update cap. | ||
520 | * port_map is used to determine number of ports. | ||
521 | */ | ||
522 | if (n_ports || tmp_port_map) | ||
523 | dev_printk(KERN_WARNING, &pdev->dev, | ||
524 | "nr_ports (%u) and implemented port map " | ||
525 | "(0x%x) don't match\n", | ||
526 | ahci_nr_ports(cap), port_map); | ||
527 | } else { | ||
528 | /* fabricate port_map from cap.nr_ports */ | ||
529 | port_map = (1 << ahci_nr_ports(cap)) - 1; | ||
530 | } | ||
531 | |||
532 | /* record values to use during operation */ | ||
533 | hpriv->cap = cap; | ||
534 | hpriv->port_map = port_map; | ||
535 | } | ||
536 | |||
537 | /** | ||
538 | * ahci_restore_initial_config - Restore initial config | ||
539 | * @host: target ATA host | ||
540 | * | ||
541 | * Restore initial config stored by ahci_save_initial_config(). | ||
542 | * | ||
543 | * LOCKING: | ||
544 | * None. | ||
545 | */ | ||
546 | static void ahci_restore_initial_config(struct ata_host *host) | ||
547 | { | ||
548 | struct ahci_host_priv *hpriv = host->private_data; | ||
549 | void __iomem *mmio = host->iomap[AHCI_PCI_BAR]; | ||
550 | |||
551 | writel(hpriv->saved_cap, mmio + HOST_CAP); | ||
552 | writel(hpriv->saved_port_map, mmio + HOST_PORTS_IMPL); | ||
553 | (void) readl(mmio + HOST_PORTS_IMPL); /* flush */ | ||
478 | } | 554 | } |
479 | 555 | ||
480 | static u32 ahci_scr_read (struct ata_port *ap, unsigned int sc_reg_in) | 556 | static u32 ahci_scr_read (struct ata_port *ap, unsigned int sc_reg_in) |
@@ -511,8 +587,9 @@ static void ahci_scr_write (struct ata_port *ap, unsigned int sc_reg_in, | |||
511 | writel(val, ap->ioaddr.scr_addr + (sc_reg * 4)); | 587 | writel(val, ap->ioaddr.scr_addr + (sc_reg * 4)); |
512 | } | 588 | } |
513 | 589 | ||
514 | static void ahci_start_engine(void __iomem *port_mmio) | 590 | static void ahci_start_engine(struct ata_port *ap) |
515 | { | 591 | { |
592 | void __iomem *port_mmio = ahci_port_base(ap); | ||
516 | u32 tmp; | 593 | u32 tmp; |
517 | 594 | ||
518 | /* start DMA */ | 595 | /* start DMA */ |
@@ -522,8 +599,9 @@ static void ahci_start_engine(void __iomem *port_mmio) | |||
522 | readl(port_mmio + PORT_CMD); /* flush */ | 599 | readl(port_mmio + PORT_CMD); /* flush */ |
523 | } | 600 | } |
524 | 601 | ||
525 | static int ahci_stop_engine(void __iomem *port_mmio) | 602 | static int ahci_stop_engine(struct ata_port *ap) |
526 | { | 603 | { |
604 | void __iomem *port_mmio = ahci_port_base(ap); | ||
527 | u32 tmp; | 605 | u32 tmp; |
528 | 606 | ||
529 | tmp = readl(port_mmio + PORT_CMD); | 607 | tmp = readl(port_mmio + PORT_CMD); |
@@ -545,19 +623,23 @@ static int ahci_stop_engine(void __iomem *port_mmio) | |||
545 | return 0; | 623 | return 0; |
546 | } | 624 | } |
547 | 625 | ||
548 | static void ahci_start_fis_rx(void __iomem *port_mmio, u32 cap, | 626 | static void ahci_start_fis_rx(struct ata_port *ap) |
549 | dma_addr_t cmd_slot_dma, dma_addr_t rx_fis_dma) | ||
550 | { | 627 | { |
628 | void __iomem *port_mmio = ahci_port_base(ap); | ||
629 | struct ahci_host_priv *hpriv = ap->host->private_data; | ||
630 | struct ahci_port_priv *pp = ap->private_data; | ||
551 | u32 tmp; | 631 | u32 tmp; |
552 | 632 | ||
553 | /* set FIS registers */ | 633 | /* set FIS registers */ |
554 | if (cap & HOST_CAP_64) | 634 | if (hpriv->cap & HOST_CAP_64) |
555 | writel((cmd_slot_dma >> 16) >> 16, port_mmio + PORT_LST_ADDR_HI); | 635 | writel((pp->cmd_slot_dma >> 16) >> 16, |
556 | writel(cmd_slot_dma & 0xffffffff, port_mmio + PORT_LST_ADDR); | 636 | port_mmio + PORT_LST_ADDR_HI); |
637 | writel(pp->cmd_slot_dma & 0xffffffff, port_mmio + PORT_LST_ADDR); | ||
557 | 638 | ||
558 | if (cap & HOST_CAP_64) | 639 | if (hpriv->cap & HOST_CAP_64) |
559 | writel((rx_fis_dma >> 16) >> 16, port_mmio + PORT_FIS_ADDR_HI); | 640 | writel((pp->rx_fis_dma >> 16) >> 16, |
560 | writel(rx_fis_dma & 0xffffffff, port_mmio + PORT_FIS_ADDR); | 641 | port_mmio + PORT_FIS_ADDR_HI); |
642 | writel(pp->rx_fis_dma & 0xffffffff, port_mmio + PORT_FIS_ADDR); | ||
561 | 643 | ||
562 | /* enable FIS reception */ | 644 | /* enable FIS reception */ |
563 | tmp = readl(port_mmio + PORT_CMD); | 645 | tmp = readl(port_mmio + PORT_CMD); |
@@ -568,8 +650,9 @@ static void ahci_start_fis_rx(void __iomem *port_mmio, u32 cap, | |||
568 | readl(port_mmio + PORT_CMD); | 650 | readl(port_mmio + PORT_CMD); |
569 | } | 651 | } |
570 | 652 | ||
571 | static int ahci_stop_fis_rx(void __iomem *port_mmio) | 653 | static int ahci_stop_fis_rx(struct ata_port *ap) |
572 | { | 654 | { |
655 | void __iomem *port_mmio = ahci_port_base(ap); | ||
573 | u32 tmp; | 656 | u32 tmp; |
574 | 657 | ||
575 | /* disable FIS reception */ | 658 | /* disable FIS reception */ |
@@ -586,14 +669,16 @@ static int ahci_stop_fis_rx(void __iomem *port_mmio) | |||
586 | return 0; | 669 | return 0; |
587 | } | 670 | } |
588 | 671 | ||
589 | static void ahci_power_up(void __iomem *port_mmio, u32 cap) | 672 | static void ahci_power_up(struct ata_port *ap) |
590 | { | 673 | { |
674 | struct ahci_host_priv *hpriv = ap->host->private_data; | ||
675 | void __iomem *port_mmio = ahci_port_base(ap); | ||
591 | u32 cmd; | 676 | u32 cmd; |
592 | 677 | ||
593 | cmd = readl(port_mmio + PORT_CMD) & ~PORT_CMD_ICC_MASK; | 678 | cmd = readl(port_mmio + PORT_CMD) & ~PORT_CMD_ICC_MASK; |
594 | 679 | ||
595 | /* spin up device */ | 680 | /* spin up device */ |
596 | if (cap & HOST_CAP_SSS) { | 681 | if (hpriv->cap & HOST_CAP_SSS) { |
597 | cmd |= PORT_CMD_SPIN_UP; | 682 | cmd |= PORT_CMD_SPIN_UP; |
598 | writel(cmd, port_mmio + PORT_CMD); | 683 | writel(cmd, port_mmio + PORT_CMD); |
599 | } | 684 | } |
@@ -603,11 +688,13 @@ static void ahci_power_up(void __iomem *port_mmio, u32 cap) | |||
603 | } | 688 | } |
604 | 689 | ||
605 | #ifdef CONFIG_PM | 690 | #ifdef CONFIG_PM |
606 | static void ahci_power_down(void __iomem *port_mmio, u32 cap) | 691 | static void ahci_power_down(struct ata_port *ap) |
607 | { | 692 | { |
693 | struct ahci_host_priv *hpriv = ap->host->private_data; | ||
694 | void __iomem *port_mmio = ahci_port_base(ap); | ||
608 | u32 cmd, scontrol; | 695 | u32 cmd, scontrol; |
609 | 696 | ||
610 | if (!(cap & HOST_CAP_SSS)) | 697 | if (!(hpriv->cap & HOST_CAP_SSS)) |
611 | return; | 698 | return; |
612 | 699 | ||
613 | /* put device into listen mode, first set PxSCTL.DET to 0 */ | 700 | /* put device into listen mode, first set PxSCTL.DET to 0 */ |
@@ -622,29 +709,28 @@ static void ahci_power_down(void __iomem *port_mmio, u32 cap) | |||
622 | } | 709 | } |
623 | #endif | 710 | #endif |
624 | 711 | ||
625 | static void ahci_init_port(void __iomem *port_mmio, u32 cap, | 712 | static void ahci_init_port(struct ata_port *ap) |
626 | dma_addr_t cmd_slot_dma, dma_addr_t rx_fis_dma) | ||
627 | { | 713 | { |
628 | /* enable FIS reception */ | 714 | /* enable FIS reception */ |
629 | ahci_start_fis_rx(port_mmio, cap, cmd_slot_dma, rx_fis_dma); | 715 | ahci_start_fis_rx(ap); |
630 | 716 | ||
631 | /* enable DMA */ | 717 | /* enable DMA */ |
632 | ahci_start_engine(port_mmio); | 718 | ahci_start_engine(ap); |
633 | } | 719 | } |
634 | 720 | ||
635 | static int ahci_deinit_port(void __iomem *port_mmio, u32 cap, const char **emsg) | 721 | static int ahci_deinit_port(struct ata_port *ap, const char **emsg) |
636 | { | 722 | { |
637 | int rc; | 723 | int rc; |
638 | 724 | ||
639 | /* disable DMA */ | 725 | /* disable DMA */ |
640 | rc = ahci_stop_engine(port_mmio); | 726 | rc = ahci_stop_engine(ap); |
641 | if (rc) { | 727 | if (rc) { |
642 | *emsg = "failed to stop engine"; | 728 | *emsg = "failed to stop engine"; |
643 | return rc; | 729 | return rc; |
644 | } | 730 | } |
645 | 731 | ||
646 | /* disable FIS reception */ | 732 | /* disable FIS reception */ |
647 | rc = ahci_stop_fis_rx(port_mmio); | 733 | rc = ahci_stop_fis_rx(ap); |
648 | if (rc) { | 734 | if (rc) { |
649 | *emsg = "failed stop FIS RX"; | 735 | *emsg = "failed stop FIS RX"; |
650 | return rc; | 736 | return rc; |
@@ -653,12 +739,11 @@ static int ahci_deinit_port(void __iomem *port_mmio, u32 cap, const char **emsg) | |||
653 | return 0; | 739 | return 0; |
654 | } | 740 | } |
655 | 741 | ||
656 | static int ahci_reset_controller(void __iomem *mmio, struct pci_dev *pdev) | 742 | static int ahci_reset_controller(struct ata_host *host) |
657 | { | 743 | { |
658 | u32 cap_save, impl_save, tmp; | 744 | struct pci_dev *pdev = to_pci_dev(host->dev); |
659 | 745 | void __iomem *mmio = host->iomap[AHCI_PCI_BAR]; | |
660 | cap_save = readl(mmio + HOST_CAP); | 746 | u32 tmp; |
661 | impl_save = readl(mmio + HOST_PORTS_IMPL); | ||
662 | 747 | ||
663 | /* global controller reset */ | 748 | /* global controller reset */ |
664 | tmp = readl(mmio + HOST_CTL); | 749 | tmp = readl(mmio + HOST_CTL); |
@@ -674,7 +759,7 @@ static int ahci_reset_controller(void __iomem *mmio, struct pci_dev *pdev) | |||
674 | 759 | ||
675 | tmp = readl(mmio + HOST_CTL); | 760 | tmp = readl(mmio + HOST_CTL); |
676 | if (tmp & HOST_RESET) { | 761 | if (tmp & HOST_RESET) { |
677 | dev_printk(KERN_ERR, &pdev->dev, | 762 | dev_printk(KERN_ERR, host->dev, |
678 | "controller reset failed (0x%x)\n", tmp); | 763 | "controller reset failed (0x%x)\n", tmp); |
679 | return -EIO; | 764 | return -EIO; |
680 | } | 765 | } |
@@ -683,18 +768,8 @@ static int ahci_reset_controller(void __iomem *mmio, struct pci_dev *pdev) | |||
683 | writel(HOST_AHCI_EN, mmio + HOST_CTL); | 768 | writel(HOST_AHCI_EN, mmio + HOST_CTL); |
684 | (void) readl(mmio + HOST_CTL); /* flush */ | 769 | (void) readl(mmio + HOST_CTL); /* flush */ |
685 | 770 | ||
686 | /* These write-once registers are normally cleared on reset. | 771 | /* some registers might be cleared on reset. restore initial values */ |
687 | * Restore BIOS values... which we HOPE were present before | 772 | ahci_restore_initial_config(host); |
688 | * reset. | ||
689 | */ | ||
690 | if (!impl_save) { | ||
691 | impl_save = (1 << ahci_nr_ports(cap_save)) - 1; | ||
692 | dev_printk(KERN_WARNING, &pdev->dev, | ||
693 | "PORTS_IMPL is zero, forcing 0x%x\n", impl_save); | ||
694 | } | ||
695 | writel(cap_save, mmio + HOST_CAP); | ||
696 | writel(impl_save, mmio + HOST_PORTS_IMPL); | ||
697 | (void) readl(mmio + HOST_PORTS_IMPL); /* flush */ | ||
698 | 773 | ||
699 | if (pdev->vendor == PCI_VENDOR_ID_INTEL) { | 774 | if (pdev->vendor == PCI_VENDOR_ID_INTEL) { |
700 | u16 tmp16; | 775 | u16 tmp16; |
@@ -708,23 +783,23 @@ static int ahci_reset_controller(void __iomem *mmio, struct pci_dev *pdev) | |||
708 | return 0; | 783 | return 0; |
709 | } | 784 | } |
710 | 785 | ||
711 | static void ahci_init_controller(void __iomem *mmio, struct pci_dev *pdev, | 786 | static void ahci_init_controller(struct ata_host *host) |
712 | int n_ports, unsigned int port_flags, | ||
713 | struct ahci_host_priv *hpriv) | ||
714 | { | 787 | { |
788 | struct pci_dev *pdev = to_pci_dev(host->dev); | ||
789 | void __iomem *mmio = host->iomap[AHCI_PCI_BAR]; | ||
715 | int i, rc; | 790 | int i, rc; |
716 | u32 tmp; | 791 | u32 tmp; |
717 | 792 | ||
718 | for (i = 0; i < n_ports; i++) { | 793 | for (i = 0; i < host->n_ports; i++) { |
719 | void __iomem *port_mmio = ahci_port_base(mmio, i); | 794 | struct ata_port *ap = host->ports[i]; |
795 | void __iomem *port_mmio = ahci_port_base(ap); | ||
720 | const char *emsg = NULL; | 796 | const char *emsg = NULL; |
721 | 797 | ||
722 | if ((port_flags & AHCI_FLAG_HONOR_PI) && | 798 | if (ata_port_is_dummy(ap)) |
723 | !(hpriv->port_map & (1 << i))) | ||
724 | continue; | 799 | continue; |
725 | 800 | ||
726 | /* make sure port is not active */ | 801 | /* make sure port is not active */ |
727 | rc = ahci_deinit_port(port_mmio, hpriv->cap, &emsg); | 802 | rc = ahci_deinit_port(ap, &emsg); |
728 | if (rc) | 803 | if (rc) |
729 | dev_printk(KERN_WARNING, &pdev->dev, | 804 | dev_printk(KERN_WARNING, &pdev->dev, |
730 | "%s (%d)\n", emsg, rc); | 805 | "%s (%d)\n", emsg, rc); |
@@ -752,7 +827,7 @@ static void ahci_init_controller(void __iomem *mmio, struct pci_dev *pdev, | |||
752 | 827 | ||
753 | static unsigned int ahci_dev_classify(struct ata_port *ap) | 828 | static unsigned int ahci_dev_classify(struct ata_port *ap) |
754 | { | 829 | { |
755 | void __iomem *port_mmio = ap->ioaddr.cmd_addr; | 830 | void __iomem *port_mmio = ahci_port_base(ap); |
756 | struct ata_taskfile tf; | 831 | struct ata_taskfile tf; |
757 | u32 tmp; | 832 | u32 tmp; |
758 | 833 | ||
@@ -802,8 +877,7 @@ static int ahci_clo(struct ata_port *ap) | |||
802 | static int ahci_softreset(struct ata_port *ap, unsigned int *class) | 877 | static int ahci_softreset(struct ata_port *ap, unsigned int *class) |
803 | { | 878 | { |
804 | struct ahci_port_priv *pp = ap->private_data; | 879 | struct ahci_port_priv *pp = ap->private_data; |
805 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | 880 | void __iomem *port_mmio = ahci_port_base(ap); |
806 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
807 | const u32 cmd_fis_len = 5; /* five dwords */ | 881 | const u32 cmd_fis_len = 5; /* five dwords */ |
808 | const char *reason = NULL; | 882 | const char *reason = NULL; |
809 | struct ata_taskfile tf; | 883 | struct ata_taskfile tf; |
@@ -820,7 +894,7 @@ static int ahci_softreset(struct ata_port *ap, unsigned int *class) | |||
820 | } | 894 | } |
821 | 895 | ||
822 | /* prepare for SRST (AHCI-1.1 10.4.1) */ | 896 | /* prepare for SRST (AHCI-1.1 10.4.1) */ |
823 | rc = ahci_stop_engine(port_mmio); | 897 | rc = ahci_stop_engine(ap); |
824 | if (rc) { | 898 | if (rc) { |
825 | reason = "failed to stop engine"; | 899 | reason = "failed to stop engine"; |
826 | goto fail_restart; | 900 | goto fail_restart; |
@@ -840,7 +914,7 @@ static int ahci_softreset(struct ata_port *ap, unsigned int *class) | |||
840 | } | 914 | } |
841 | 915 | ||
842 | /* restart engine */ | 916 | /* restart engine */ |
843 | ahci_start_engine(port_mmio); | 917 | ahci_start_engine(ap); |
844 | 918 | ||
845 | ata_tf_init(ap->device, &tf); | 919 | ata_tf_init(ap->device, &tf); |
846 | fis = pp->cmd_tbl; | 920 | fis = pp->cmd_tbl; |
@@ -899,7 +973,7 @@ static int ahci_softreset(struct ata_port *ap, unsigned int *class) | |||
899 | return 0; | 973 | return 0; |
900 | 974 | ||
901 | fail_restart: | 975 | fail_restart: |
902 | ahci_start_engine(port_mmio); | 976 | ahci_start_engine(ap); |
903 | fail: | 977 | fail: |
904 | ata_port_printk(ap, KERN_ERR, "softreset failed (%s)\n", reason); | 978 | ata_port_printk(ap, KERN_ERR, "softreset failed (%s)\n", reason); |
905 | return rc; | 979 | return rc; |
@@ -910,13 +984,11 @@ static int ahci_hardreset(struct ata_port *ap, unsigned int *class) | |||
910 | struct ahci_port_priv *pp = ap->private_data; | 984 | struct ahci_port_priv *pp = ap->private_data; |
911 | u8 *d2h_fis = pp->rx_fis + RX_FIS_D2H_REG; | 985 | u8 *d2h_fis = pp->rx_fis + RX_FIS_D2H_REG; |
912 | struct ata_taskfile tf; | 986 | struct ata_taskfile tf; |
913 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
914 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
915 | int rc; | 987 | int rc; |
916 | 988 | ||
917 | DPRINTK("ENTER\n"); | 989 | DPRINTK("ENTER\n"); |
918 | 990 | ||
919 | ahci_stop_engine(port_mmio); | 991 | ahci_stop_engine(ap); |
920 | 992 | ||
921 | /* clear D2H reception area to properly wait for D2H FIS */ | 993 | /* clear D2H reception area to properly wait for D2H FIS */ |
922 | ata_tf_init(ap->device, &tf); | 994 | ata_tf_init(ap->device, &tf); |
@@ -925,7 +997,7 @@ static int ahci_hardreset(struct ata_port *ap, unsigned int *class) | |||
925 | 997 | ||
926 | rc = sata_std_hardreset(ap, class); | 998 | rc = sata_std_hardreset(ap, class); |
927 | 999 | ||
928 | ahci_start_engine(port_mmio); | 1000 | ahci_start_engine(ap); |
929 | 1001 | ||
930 | if (rc == 0 && ata_port_online(ap)) | 1002 | if (rc == 0 && ata_port_online(ap)) |
931 | *class = ahci_dev_classify(ap); | 1003 | *class = ahci_dev_classify(ap); |
@@ -938,20 +1010,18 @@ static int ahci_hardreset(struct ata_port *ap, unsigned int *class) | |||
938 | 1010 | ||
939 | static int ahci_vt8251_hardreset(struct ata_port *ap, unsigned int *class) | 1011 | static int ahci_vt8251_hardreset(struct ata_port *ap, unsigned int *class) |
940 | { | 1012 | { |
941 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
942 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
943 | int rc; | 1013 | int rc; |
944 | 1014 | ||
945 | DPRINTK("ENTER\n"); | 1015 | DPRINTK("ENTER\n"); |
946 | 1016 | ||
947 | ahci_stop_engine(port_mmio); | 1017 | ahci_stop_engine(ap); |
948 | 1018 | ||
949 | rc = sata_port_hardreset(ap, sata_ehc_deb_timing(&ap->eh_context)); | 1019 | rc = sata_port_hardreset(ap, sata_ehc_deb_timing(&ap->eh_context)); |
950 | 1020 | ||
951 | /* vt8251 needs SError cleared for the port to operate */ | 1021 | /* vt8251 needs SError cleared for the port to operate */ |
952 | ahci_scr_write(ap, SCR_ERROR, ahci_scr_read(ap, SCR_ERROR)); | 1022 | ahci_scr_write(ap, SCR_ERROR, ahci_scr_read(ap, SCR_ERROR)); |
953 | 1023 | ||
954 | ahci_start_engine(port_mmio); | 1024 | ahci_start_engine(ap); |
955 | 1025 | ||
956 | DPRINTK("EXIT, rc=%d, class=%u\n", rc, *class); | 1026 | DPRINTK("EXIT, rc=%d, class=%u\n", rc, *class); |
957 | 1027 | ||
@@ -963,7 +1033,7 @@ static int ahci_vt8251_hardreset(struct ata_port *ap, unsigned int *class) | |||
963 | 1033 | ||
964 | static void ahci_postreset(struct ata_port *ap, unsigned int *class) | 1034 | static void ahci_postreset(struct ata_port *ap, unsigned int *class) |
965 | { | 1035 | { |
966 | void __iomem *port_mmio = ap->ioaddr.cmd_addr; | 1036 | void __iomem *port_mmio = ahci_port_base(ap); |
967 | u32 new_tmp, tmp; | 1037 | u32 new_tmp, tmp; |
968 | 1038 | ||
969 | ata_std_postreset(ap, class); | 1039 | ata_std_postreset(ap, class); |
@@ -1131,8 +1201,7 @@ static void ahci_error_intr(struct ata_port *ap, u32 irq_stat) | |||
1131 | 1201 | ||
1132 | static void ahci_host_intr(struct ata_port *ap) | 1202 | static void ahci_host_intr(struct ata_port *ap) |
1133 | { | 1203 | { |
1134 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | 1204 | void __iomem *port_mmio = ap->ioaddr.cmd_addr; |
1135 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1136 | struct ata_eh_info *ehi = &ap->eh_info; | 1205 | struct ata_eh_info *ehi = &ap->eh_info; |
1137 | struct ahci_port_priv *pp = ap->private_data; | 1206 | struct ahci_port_priv *pp = ap->private_data; |
1138 | u32 status, qc_active; | 1207 | u32 status, qc_active; |
@@ -1283,7 +1352,7 @@ static irqreturn_t ahci_interrupt(int irq, void *dev_instance) | |||
1283 | static unsigned int ahci_qc_issue(struct ata_queued_cmd *qc) | 1352 | static unsigned int ahci_qc_issue(struct ata_queued_cmd *qc) |
1284 | { | 1353 | { |
1285 | struct ata_port *ap = qc->ap; | 1354 | struct ata_port *ap = qc->ap; |
1286 | void __iomem *port_mmio = ap->ioaddr.cmd_addr; | 1355 | void __iomem *port_mmio = ahci_port_base(ap); |
1287 | 1356 | ||
1288 | if (qc->tf.protocol == ATA_PROT_NCQ) | 1357 | if (qc->tf.protocol == ATA_PROT_NCQ) |
1289 | writel(1 << qc->tag, port_mmio + PORT_SCR_ACT); | 1358 | writel(1 << qc->tag, port_mmio + PORT_SCR_ACT); |
@@ -1295,8 +1364,7 @@ static unsigned int ahci_qc_issue(struct ata_queued_cmd *qc) | |||
1295 | 1364 | ||
1296 | static void ahci_freeze(struct ata_port *ap) | 1365 | static void ahci_freeze(struct ata_port *ap) |
1297 | { | 1366 | { |
1298 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | 1367 | void __iomem *port_mmio = ahci_port_base(ap); |
1299 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1300 | 1368 | ||
1301 | /* turn IRQ off */ | 1369 | /* turn IRQ off */ |
1302 | writel(0, port_mmio + PORT_IRQ_MASK); | 1370 | writel(0, port_mmio + PORT_IRQ_MASK); |
@@ -1305,7 +1373,7 @@ static void ahci_freeze(struct ata_port *ap) | |||
1305 | static void ahci_thaw(struct ata_port *ap) | 1373 | static void ahci_thaw(struct ata_port *ap) |
1306 | { | 1374 | { |
1307 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | 1375 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; |
1308 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | 1376 | void __iomem *port_mmio = ahci_port_base(ap); |
1309 | u32 tmp; | 1377 | u32 tmp; |
1310 | 1378 | ||
1311 | /* clear IRQ */ | 1379 | /* clear IRQ */ |
@@ -1319,13 +1387,10 @@ static void ahci_thaw(struct ata_port *ap) | |||
1319 | 1387 | ||
1320 | static void ahci_error_handler(struct ata_port *ap) | 1388 | static void ahci_error_handler(struct ata_port *ap) |
1321 | { | 1389 | { |
1322 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
1323 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1324 | |||
1325 | if (!(ap->pflags & ATA_PFLAG_FROZEN)) { | 1390 | if (!(ap->pflags & ATA_PFLAG_FROZEN)) { |
1326 | /* restart engine */ | 1391 | /* restart engine */ |
1327 | ahci_stop_engine(port_mmio); | 1392 | ahci_stop_engine(ap); |
1328 | ahci_start_engine(port_mmio); | 1393 | ahci_start_engine(ap); |
1329 | } | 1394 | } |
1330 | 1395 | ||
1331 | /* perform recovery */ | 1396 | /* perform recovery */ |
@@ -1335,13 +1400,10 @@ static void ahci_error_handler(struct ata_port *ap) | |||
1335 | 1400 | ||
1336 | static void ahci_vt8251_error_handler(struct ata_port *ap) | 1401 | static void ahci_vt8251_error_handler(struct ata_port *ap) |
1337 | { | 1402 | { |
1338 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
1339 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1340 | |||
1341 | if (!(ap->pflags & ATA_PFLAG_FROZEN)) { | 1403 | if (!(ap->pflags & ATA_PFLAG_FROZEN)) { |
1342 | /* restart engine */ | 1404 | /* restart engine */ |
1343 | ahci_stop_engine(port_mmio); | 1405 | ahci_stop_engine(ap); |
1344 | ahci_start_engine(port_mmio); | 1406 | ahci_start_engine(ap); |
1345 | } | 1407 | } |
1346 | 1408 | ||
1347 | /* perform recovery */ | 1409 | /* perform recovery */ |
@@ -1352,36 +1414,26 @@ static void ahci_vt8251_error_handler(struct ata_port *ap) | |||
1352 | static void ahci_post_internal_cmd(struct ata_queued_cmd *qc) | 1414 | static void ahci_post_internal_cmd(struct ata_queued_cmd *qc) |
1353 | { | 1415 | { |
1354 | struct ata_port *ap = qc->ap; | 1416 | struct ata_port *ap = qc->ap; |
1355 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
1356 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1357 | 1417 | ||
1358 | if (qc->flags & ATA_QCFLAG_FAILED) | 1418 | if (qc->flags & ATA_QCFLAG_FAILED) { |
1359 | qc->err_mask |= AC_ERR_OTHER; | ||
1360 | |||
1361 | if (qc->err_mask) { | ||
1362 | /* make DMA engine forget about the failed command */ | 1419 | /* make DMA engine forget about the failed command */ |
1363 | ahci_stop_engine(port_mmio); | 1420 | ahci_stop_engine(ap); |
1364 | ahci_start_engine(port_mmio); | 1421 | ahci_start_engine(ap); |
1365 | } | 1422 | } |
1366 | } | 1423 | } |
1367 | 1424 | ||
1368 | #ifdef CONFIG_PM | 1425 | #ifdef CONFIG_PM |
1369 | static int ahci_port_suspend(struct ata_port *ap, pm_message_t mesg) | 1426 | static int ahci_port_suspend(struct ata_port *ap, pm_message_t mesg) |
1370 | { | 1427 | { |
1371 | struct ahci_host_priv *hpriv = ap->host->private_data; | ||
1372 | struct ahci_port_priv *pp = ap->private_data; | ||
1373 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
1374 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1375 | const char *emsg = NULL; | 1428 | const char *emsg = NULL; |
1376 | int rc; | 1429 | int rc; |
1377 | 1430 | ||
1378 | rc = ahci_deinit_port(port_mmio, hpriv->cap, &emsg); | 1431 | rc = ahci_deinit_port(ap, &emsg); |
1379 | if (rc == 0) | 1432 | if (rc == 0) |
1380 | ahci_power_down(port_mmio, hpriv->cap); | 1433 | ahci_power_down(ap); |
1381 | else { | 1434 | else { |
1382 | ata_port_printk(ap, KERN_ERR, "%s (%d)\n", emsg, rc); | 1435 | ata_port_printk(ap, KERN_ERR, "%s (%d)\n", emsg, rc); |
1383 | ahci_init_port(port_mmio, hpriv->cap, | 1436 | ahci_init_port(ap); |
1384 | pp->cmd_slot_dma, pp->rx_fis_dma); | ||
1385 | } | 1437 | } |
1386 | 1438 | ||
1387 | return rc; | 1439 | return rc; |
@@ -1389,13 +1441,8 @@ static int ahci_port_suspend(struct ata_port *ap, pm_message_t mesg) | |||
1389 | 1441 | ||
1390 | static int ahci_port_resume(struct ata_port *ap) | 1442 | static int ahci_port_resume(struct ata_port *ap) |
1391 | { | 1443 | { |
1392 | struct ahci_port_priv *pp = ap->private_data; | 1444 | ahci_power_up(ap); |
1393 | struct ahci_host_priv *hpriv = ap->host->private_data; | 1445 | ahci_init_port(ap); |
1394 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
1395 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1396 | |||
1397 | ahci_power_up(port_mmio, hpriv->cap); | ||
1398 | ahci_init_port(port_mmio, hpriv->cap, pp->cmd_slot_dma, pp->rx_fis_dma); | ||
1399 | 1446 | ||
1400 | return 0; | 1447 | return 0; |
1401 | } | 1448 | } |
@@ -1423,8 +1470,6 @@ static int ahci_pci_device_suspend(struct pci_dev *pdev, pm_message_t mesg) | |||
1423 | static int ahci_pci_device_resume(struct pci_dev *pdev) | 1470 | static int ahci_pci_device_resume(struct pci_dev *pdev) |
1424 | { | 1471 | { |
1425 | struct ata_host *host = dev_get_drvdata(&pdev->dev); | 1472 | struct ata_host *host = dev_get_drvdata(&pdev->dev); |
1426 | struct ahci_host_priv *hpriv = host->private_data; | ||
1427 | void __iomem *mmio = host->iomap[AHCI_PCI_BAR]; | ||
1428 | int rc; | 1473 | int rc; |
1429 | 1474 | ||
1430 | rc = ata_pci_device_do_resume(pdev); | 1475 | rc = ata_pci_device_do_resume(pdev); |
@@ -1432,12 +1477,11 @@ static int ahci_pci_device_resume(struct pci_dev *pdev) | |||
1432 | return rc; | 1477 | return rc; |
1433 | 1478 | ||
1434 | if (pdev->dev.power.power_state.event == PM_EVENT_SUSPEND) { | 1479 | if (pdev->dev.power.power_state.event == PM_EVENT_SUSPEND) { |
1435 | rc = ahci_reset_controller(mmio, pdev); | 1480 | rc = ahci_reset_controller(host); |
1436 | if (rc) | 1481 | if (rc) |
1437 | return rc; | 1482 | return rc; |
1438 | 1483 | ||
1439 | ahci_init_controller(mmio, pdev, host->n_ports, | 1484 | ahci_init_controller(host); |
1440 | host->ports[0]->flags, hpriv); | ||
1441 | } | 1485 | } |
1442 | 1486 | ||
1443 | ata_host_resume(host); | 1487 | ata_host_resume(host); |
@@ -1449,10 +1493,7 @@ static int ahci_pci_device_resume(struct pci_dev *pdev) | |||
1449 | static int ahci_port_start(struct ata_port *ap) | 1493 | static int ahci_port_start(struct ata_port *ap) |
1450 | { | 1494 | { |
1451 | struct device *dev = ap->host->dev; | 1495 | struct device *dev = ap->host->dev; |
1452 | struct ahci_host_priv *hpriv = ap->host->private_data; | ||
1453 | struct ahci_port_priv *pp; | 1496 | struct ahci_port_priv *pp; |
1454 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
1455 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1456 | void *mem; | 1497 | void *mem; |
1457 | dma_addr_t mem_dma; | 1498 | dma_addr_t mem_dma; |
1458 | int rc; | 1499 | int rc; |
@@ -1500,85 +1541,29 @@ static int ahci_port_start(struct ata_port *ap) | |||
1500 | ap->private_data = pp; | 1541 | ap->private_data = pp; |
1501 | 1542 | ||
1502 | /* power up port */ | 1543 | /* power up port */ |
1503 | ahci_power_up(port_mmio, hpriv->cap); | 1544 | ahci_power_up(ap); |
1504 | 1545 | ||
1505 | /* initialize port */ | 1546 | /* initialize port */ |
1506 | ahci_init_port(port_mmio, hpriv->cap, pp->cmd_slot_dma, pp->rx_fis_dma); | 1547 | ahci_init_port(ap); |
1507 | 1548 | ||
1508 | return 0; | 1549 | return 0; |
1509 | } | 1550 | } |
1510 | 1551 | ||
1511 | static void ahci_port_stop(struct ata_port *ap) | 1552 | static void ahci_port_stop(struct ata_port *ap) |
1512 | { | 1553 | { |
1513 | struct ahci_host_priv *hpriv = ap->host->private_data; | ||
1514 | void __iomem *mmio = ap->host->iomap[AHCI_PCI_BAR]; | ||
1515 | void __iomem *port_mmio = ahci_port_base(mmio, ap->port_no); | ||
1516 | const char *emsg = NULL; | 1554 | const char *emsg = NULL; |
1517 | int rc; | 1555 | int rc; |
1518 | 1556 | ||
1519 | /* de-initialize port */ | 1557 | /* de-initialize port */ |
1520 | rc = ahci_deinit_port(port_mmio, hpriv->cap, &emsg); | 1558 | rc = ahci_deinit_port(ap, &emsg); |
1521 | if (rc) | 1559 | if (rc) |
1522 | ata_port_printk(ap, KERN_WARNING, "%s (%d)\n", emsg, rc); | 1560 | ata_port_printk(ap, KERN_WARNING, "%s (%d)\n", emsg, rc); |
1523 | } | 1561 | } |
1524 | 1562 | ||
1525 | static void ahci_setup_port(struct ata_ioports *port, void __iomem *base, | 1563 | static int ahci_configure_dma_masks(struct pci_dev *pdev, int using_dac) |
1526 | unsigned int port_idx) | ||
1527 | { | 1564 | { |
1528 | VPRINTK("ENTER, base==0x%lx, port_idx %u\n", base, port_idx); | ||
1529 | base = ahci_port_base(base, port_idx); | ||
1530 | VPRINTK("base now==0x%lx\n", base); | ||
1531 | |||
1532 | port->cmd_addr = base; | ||
1533 | port->scr_addr = base + PORT_SCR; | ||
1534 | |||
1535 | VPRINTK("EXIT\n"); | ||
1536 | } | ||
1537 | |||
1538 | static int ahci_host_init(struct ata_probe_ent *probe_ent) | ||
1539 | { | ||
1540 | struct ahci_host_priv *hpriv = probe_ent->private_data; | ||
1541 | struct pci_dev *pdev = to_pci_dev(probe_ent->dev); | ||
1542 | void __iomem *mmio = probe_ent->iomap[AHCI_PCI_BAR]; | ||
1543 | unsigned int i, cap_n_ports, using_dac; | ||
1544 | int rc; | 1565 | int rc; |
1545 | 1566 | ||
1546 | rc = ahci_reset_controller(mmio, pdev); | ||
1547 | if (rc) | ||
1548 | return rc; | ||
1549 | |||
1550 | hpriv->cap = readl(mmio + HOST_CAP); | ||
1551 | hpriv->port_map = readl(mmio + HOST_PORTS_IMPL); | ||
1552 | cap_n_ports = ahci_nr_ports(hpriv->cap); | ||
1553 | |||
1554 | VPRINTK("cap 0x%x port_map 0x%x n_ports %d\n", | ||
1555 | hpriv->cap, hpriv->port_map, cap_n_ports); | ||
1556 | |||
1557 | if (probe_ent->port_flags & AHCI_FLAG_HONOR_PI) { | ||
1558 | unsigned int n_ports = cap_n_ports; | ||
1559 | u32 port_map = hpriv->port_map; | ||
1560 | int max_port = 0; | ||
1561 | |||
1562 | for (i = 0; i < AHCI_MAX_PORTS && n_ports; i++) { | ||
1563 | if (port_map & (1 << i)) { | ||
1564 | n_ports--; | ||
1565 | port_map &= ~(1 << i); | ||
1566 | max_port = i; | ||
1567 | } else | ||
1568 | probe_ent->dummy_port_mask |= 1 << i; | ||
1569 | } | ||
1570 | |||
1571 | if (n_ports || port_map) | ||
1572 | dev_printk(KERN_WARNING, &pdev->dev, | ||
1573 | "nr_ports (%u) and implemented port map " | ||
1574 | "(0x%x) don't match\n", | ||
1575 | cap_n_ports, hpriv->port_map); | ||
1576 | |||
1577 | probe_ent->n_ports = max_port + 1; | ||
1578 | } else | ||
1579 | probe_ent->n_ports = cap_n_ports; | ||
1580 | |||
1581 | using_dac = hpriv->cap & HOST_CAP_64; | ||
1582 | if (using_dac && | 1567 | if (using_dac && |
1583 | !pci_set_dma_mask(pdev, DMA_64BIT_MASK)) { | 1568 | !pci_set_dma_mask(pdev, DMA_64BIT_MASK)) { |
1584 | rc = pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK); | 1569 | rc = pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK); |
@@ -1604,23 +1589,14 @@ static int ahci_host_init(struct ata_probe_ent *probe_ent) | |||
1604 | return rc; | 1589 | return rc; |
1605 | } | 1590 | } |
1606 | } | 1591 | } |
1607 | |||
1608 | for (i = 0; i < probe_ent->n_ports; i++) | ||
1609 | ahci_setup_port(&probe_ent->port[i], mmio, i); | ||
1610 | |||
1611 | ahci_init_controller(mmio, pdev, probe_ent->n_ports, | ||
1612 | probe_ent->port_flags, hpriv); | ||
1613 | |||
1614 | pci_set_master(pdev); | ||
1615 | |||
1616 | return 0; | 1592 | return 0; |
1617 | } | 1593 | } |
1618 | 1594 | ||
1619 | static void ahci_print_info(struct ata_probe_ent *probe_ent) | 1595 | static void ahci_print_info(struct ata_host *host) |
1620 | { | 1596 | { |
1621 | struct ahci_host_priv *hpriv = probe_ent->private_data; | 1597 | struct ahci_host_priv *hpriv = host->private_data; |
1622 | struct pci_dev *pdev = to_pci_dev(probe_ent->dev); | 1598 | struct pci_dev *pdev = to_pci_dev(host->dev); |
1623 | void __iomem *mmio = probe_ent->iomap[AHCI_PCI_BAR]; | 1599 | void __iomem *mmio = host->iomap[AHCI_PCI_BAR]; |
1624 | u32 vers, cap, impl, speed; | 1600 | u32 vers, cap, impl, speed; |
1625 | const char *speed_s; | 1601 | const char *speed_s; |
1626 | u16 cc; | 1602 | u16 cc; |
@@ -1690,11 +1666,12 @@ static void ahci_print_info(struct ata_probe_ent *probe_ent) | |||
1690 | static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | 1666 | static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
1691 | { | 1667 | { |
1692 | static int printed_version; | 1668 | static int printed_version; |
1693 | unsigned int board_idx = (unsigned int) ent->driver_data; | 1669 | struct ata_port_info pi = ahci_port_info[ent->driver_data]; |
1670 | const struct ata_port_info *ppi[] = { &pi, NULL }; | ||
1694 | struct device *dev = &pdev->dev; | 1671 | struct device *dev = &pdev->dev; |
1695 | struct ata_probe_ent *probe_ent; | ||
1696 | struct ahci_host_priv *hpriv; | 1672 | struct ahci_host_priv *hpriv; |
1697 | int rc; | 1673 | struct ata_host *host; |
1674 | int i, rc; | ||
1698 | 1675 | ||
1699 | VPRINTK("ENTER\n"); | 1676 | VPRINTK("ENTER\n"); |
1700 | 1677 | ||
@@ -1703,6 +1680,7 @@ static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1703 | if (!printed_version++) | 1680 | if (!printed_version++) |
1704 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 1681 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
1705 | 1682 | ||
1683 | /* acquire resources */ | ||
1706 | rc = pcim_enable_device(pdev); | 1684 | rc = pcim_enable_device(pdev); |
1707 | if (rc) | 1685 | if (rc) |
1708 | return rc; | 1686 | return rc; |
@@ -1716,44 +1694,49 @@ static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1716 | if (pci_enable_msi(pdev)) | 1694 | if (pci_enable_msi(pdev)) |
1717 | pci_intx(pdev, 1); | 1695 | pci_intx(pdev, 1); |
1718 | 1696 | ||
1719 | probe_ent = devm_kzalloc(dev, sizeof(*probe_ent), GFP_KERNEL); | ||
1720 | if (probe_ent == NULL) | ||
1721 | return -ENOMEM; | ||
1722 | |||
1723 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
1724 | INIT_LIST_HEAD(&probe_ent->node); | ||
1725 | |||
1726 | hpriv = devm_kzalloc(dev, sizeof(*hpriv), GFP_KERNEL); | 1697 | hpriv = devm_kzalloc(dev, sizeof(*hpriv), GFP_KERNEL); |
1727 | if (!hpriv) | 1698 | if (!hpriv) |
1728 | return -ENOMEM; | 1699 | return -ENOMEM; |
1729 | 1700 | ||
1730 | probe_ent->sht = ahci_port_info[board_idx].sht; | 1701 | /* save initial config */ |
1731 | probe_ent->port_flags = ahci_port_info[board_idx].flags; | 1702 | ahci_save_initial_config(pdev, &pi, hpriv); |
1732 | probe_ent->pio_mask = ahci_port_info[board_idx].pio_mask; | ||
1733 | probe_ent->udma_mask = ahci_port_info[board_idx].udma_mask; | ||
1734 | probe_ent->port_ops = ahci_port_info[board_idx].port_ops; | ||
1735 | 1703 | ||
1736 | probe_ent->irq = pdev->irq; | 1704 | /* prepare host */ |
1737 | probe_ent->irq_flags = IRQF_SHARED; | 1705 | if (!(pi.flags & AHCI_FLAG_NO_NCQ) && (hpriv->cap & HOST_CAP_NCQ)) |
1738 | probe_ent->iomap = pcim_iomap_table(pdev); | 1706 | pi.flags |= ATA_FLAG_NCQ; |
1739 | probe_ent->private_data = hpriv; | 1707 | |
1708 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, fls(hpriv->port_map)); | ||
1709 | if (!host) | ||
1710 | return -ENOMEM; | ||
1711 | host->iomap = pcim_iomap_table(pdev); | ||
1712 | host->private_data = hpriv; | ||
1713 | |||
1714 | for (i = 0; i < host->n_ports; i++) { | ||
1715 | if (hpriv->port_map & (1 << i)) { | ||
1716 | struct ata_port *ap = host->ports[i]; | ||
1717 | void __iomem *port_mmio = ahci_port_base(ap); | ||
1718 | |||
1719 | ap->ioaddr.cmd_addr = port_mmio; | ||
1720 | ap->ioaddr.scr_addr = port_mmio + PORT_SCR; | ||
1721 | } else | ||
1722 | host->ports[i]->ops = &ata_dummy_port_ops; | ||
1723 | } | ||
1740 | 1724 | ||
1741 | /* initialize adapter */ | 1725 | /* initialize adapter */ |
1742 | rc = ahci_host_init(probe_ent); | 1726 | rc = ahci_configure_dma_masks(pdev, hpriv->cap & HOST_CAP_64); |
1743 | if (rc) | 1727 | if (rc) |
1744 | return rc; | 1728 | return rc; |
1745 | 1729 | ||
1746 | if (!(probe_ent->port_flags & AHCI_FLAG_NO_NCQ) && | 1730 | rc = ahci_reset_controller(host); |
1747 | (hpriv->cap & HOST_CAP_NCQ)) | 1731 | if (rc) |
1748 | probe_ent->port_flags |= ATA_FLAG_NCQ; | 1732 | return rc; |
1749 | |||
1750 | ahci_print_info(probe_ent); | ||
1751 | 1733 | ||
1752 | if (!ata_device_add(probe_ent)) | 1734 | ahci_init_controller(host); |
1753 | return -ENODEV; | 1735 | ahci_print_info(host); |
1754 | 1736 | ||
1755 | devm_kfree(dev, probe_ent); | 1737 | pci_set_master(pdev); |
1756 | return 0; | 1738 | return ata_host_activate(host, pdev->irq, ahci_interrupt, IRQF_SHARED, |
1739 | &ahci_sht); | ||
1757 | } | 1740 | } |
1758 | 1741 | ||
1759 | static int __init ahci_init(void) | 1742 | static int __init ahci_init(void) |
diff --git a/drivers/ata/ata_generic.c b/drivers/ata/ata_generic.c index d8e79882b88..92a491ddd03 100644 --- a/drivers/ata/ata_generic.c +++ b/drivers/ata/ata_generic.c | |||
@@ -33,35 +33,6 @@ | |||
33 | */ | 33 | */ |
34 | 34 | ||
35 | /** | 35 | /** |
36 | * generic_pre_reset - probe begin | ||
37 | * @ap: ATA port | ||
38 | * | ||
39 | * Set up cable type and use generic probe init | ||
40 | */ | ||
41 | |||
42 | static int generic_pre_reset(struct ata_port *ap) | ||
43 | { | ||
44 | ap->cbl = ATA_CBL_PATA80; | ||
45 | return ata_std_prereset(ap); | ||
46 | } | ||
47 | |||
48 | |||
49 | /** | ||
50 | * generic_error_handler - Probe specified port on PATA host controller | ||
51 | * @ap: Port to probe | ||
52 | * @classes: | ||
53 | * | ||
54 | * LOCKING: | ||
55 | * None (inherited from caller). | ||
56 | */ | ||
57 | |||
58 | |||
59 | static void generic_error_handler(struct ata_port *ap) | ||
60 | { | ||
61 | ata_bmdma_drive_eh(ap, generic_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
62 | } | ||
63 | |||
64 | /** | ||
65 | * generic_set_mode - mode setting | 36 | * generic_set_mode - mode setting |
66 | * @ap: interface to set up | 37 | * @ap: interface to set up |
67 | * @unused: returned device on error | 38 | * @unused: returned device on error |
@@ -144,8 +115,9 @@ static struct ata_port_operations generic_port_ops = { | |||
144 | 115 | ||
145 | .freeze = ata_bmdma_freeze, | 116 | .freeze = ata_bmdma_freeze, |
146 | .thaw = ata_bmdma_thaw, | 117 | .thaw = ata_bmdma_thaw, |
147 | .error_handler = generic_error_handler, | 118 | .error_handler = ata_bmdma_error_handler, |
148 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 119 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
120 | .cable_detect = ata_cable_unknown, | ||
149 | 121 | ||
150 | .qc_prep = ata_qc_prep, | 122 | .qc_prep = ata_qc_prep, |
151 | .qc_issue = ata_qc_issue_prot, | 123 | .qc_issue = ata_qc_issue_prot, |
diff --git a/drivers/ata/ata_piix.c b/drivers/ata/ata_piix.c index b952c584338..55d306a3e53 100644 --- a/drivers/ata/ata_piix.c +++ b/drivers/ata/ata_piix.c | |||
@@ -93,7 +93,7 @@ | |||
93 | #include <linux/libata.h> | 93 | #include <linux/libata.h> |
94 | 94 | ||
95 | #define DRV_NAME "ata_piix" | 95 | #define DRV_NAME "ata_piix" |
96 | #define DRV_VERSION "2.10ac1" | 96 | #define DRV_VERSION "2.11" |
97 | 97 | ||
98 | enum { | 98 | enum { |
99 | PIIX_IOCFG = 0x54, /* IDE I/O configuration register */ | 99 | PIIX_IOCFG = 0x54, /* IDE I/O configuration register */ |
@@ -155,11 +155,11 @@ struct piix_host_priv { | |||
155 | static int piix_init_one (struct pci_dev *pdev, | 155 | static int piix_init_one (struct pci_dev *pdev, |
156 | const struct pci_device_id *ent); | 156 | const struct pci_device_id *ent); |
157 | static void piix_pata_error_handler(struct ata_port *ap); | 157 | static void piix_pata_error_handler(struct ata_port *ap); |
158 | static void ich_pata_error_handler(struct ata_port *ap); | ||
159 | static void piix_sata_error_handler(struct ata_port *ap); | 158 | static void piix_sata_error_handler(struct ata_port *ap); |
160 | static void piix_set_piomode (struct ata_port *ap, struct ata_device *adev); | 159 | static void piix_set_piomode (struct ata_port *ap, struct ata_device *adev); |
161 | static void piix_set_dmamode (struct ata_port *ap, struct ata_device *adev); | 160 | static void piix_set_dmamode (struct ata_port *ap, struct ata_device *adev); |
162 | static void ich_set_dmamode (struct ata_port *ap, struct ata_device *adev); | 161 | static void ich_set_dmamode (struct ata_port *ap, struct ata_device *adev); |
162 | static int ich_pata_cable_detect(struct ata_port *ap); | ||
163 | 163 | ||
164 | static unsigned int in_module_init = 1; | 164 | static unsigned int in_module_init = 1; |
165 | 165 | ||
@@ -305,6 +305,7 @@ static const struct ata_port_operations piix_pata_ops = { | |||
305 | .thaw = ata_bmdma_thaw, | 305 | .thaw = ata_bmdma_thaw, |
306 | .error_handler = piix_pata_error_handler, | 306 | .error_handler = piix_pata_error_handler, |
307 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 307 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
308 | .cable_detect = ata_cable_40wire, | ||
308 | 309 | ||
309 | .irq_handler = ata_interrupt, | 310 | .irq_handler = ata_interrupt, |
310 | .irq_clear = ata_bmdma_irq_clear, | 311 | .irq_clear = ata_bmdma_irq_clear, |
@@ -336,8 +337,9 @@ static const struct ata_port_operations ich_pata_ops = { | |||
336 | 337 | ||
337 | .freeze = ata_bmdma_freeze, | 338 | .freeze = ata_bmdma_freeze, |
338 | .thaw = ata_bmdma_thaw, | 339 | .thaw = ata_bmdma_thaw, |
339 | .error_handler = ich_pata_error_handler, | 340 | .error_handler = piix_pata_error_handler, |
340 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 341 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
342 | .cable_detect = ich_pata_cable_detect, | ||
341 | 343 | ||
342 | .irq_handler = ata_interrupt, | 344 | .irq_handler = ata_interrupt, |
343 | .irq_clear = ata_bmdma_irq_clear, | 345 | .irq_clear = ata_bmdma_irq_clear, |
@@ -580,12 +582,13 @@ static const struct ich_laptop ich_laptop[] = { | |||
580 | /* devid, subvendor, subdev */ | 582 | /* devid, subvendor, subdev */ |
581 | { 0x27DF, 0x0005, 0x0280 }, /* ICH7 on Acer 5602WLMi */ | 583 | { 0x27DF, 0x0005, 0x0280 }, /* ICH7 on Acer 5602WLMi */ |
582 | { 0x27DF, 0x1025, 0x0110 }, /* ICH7 on Acer 3682WLMi */ | 584 | { 0x27DF, 0x1025, 0x0110 }, /* ICH7 on Acer 3682WLMi */ |
585 | { 0x27DF, 0x1043, 0x1267 }, /* ICH7 on Asus W5F */ | ||
583 | /* end marker */ | 586 | /* end marker */ |
584 | { 0, } | 587 | { 0, } |
585 | }; | 588 | }; |
586 | 589 | ||
587 | /** | 590 | /** |
588 | * piix_pata_cbl_detect - Probe host controller cable detect info | 591 | * ich_pata_cable_detect - Probe host controller cable detect info |
589 | * @ap: Port for which cable detect info is desired | 592 | * @ap: Port for which cable detect info is desired |
590 | * | 593 | * |
591 | * Read 80c cable indicator from ATA PCI device's PCI config | 594 | * Read 80c cable indicator from ATA PCI device's PCI config |
@@ -595,23 +598,18 @@ static const struct ich_laptop ich_laptop[] = { | |||
595 | * None (inherited from caller). | 598 | * None (inherited from caller). |
596 | */ | 599 | */ |
597 | 600 | ||
598 | static void ich_pata_cbl_detect(struct ata_port *ap) | 601 | static int ich_pata_cable_detect(struct ata_port *ap) |
599 | { | 602 | { |
600 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 603 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
601 | const struct ich_laptop *lap = &ich_laptop[0]; | 604 | const struct ich_laptop *lap = &ich_laptop[0]; |
602 | u8 tmp, mask; | 605 | u8 tmp, mask; |
603 | 606 | ||
604 | /* no 80c support in host controller? */ | ||
605 | if ((ap->udma_mask & ~ATA_UDMA_MASK_40C) == 0) | ||
606 | goto cbl40; | ||
607 | |||
608 | /* Check for specials - Acer Aspire 5602WLMi */ | 607 | /* Check for specials - Acer Aspire 5602WLMi */ |
609 | while (lap->device) { | 608 | while (lap->device) { |
610 | if (lap->device == pdev->device && | 609 | if (lap->device == pdev->device && |
611 | lap->subvendor == pdev->subsystem_vendor && | 610 | lap->subvendor == pdev->subsystem_vendor && |
612 | lap->subdevice == pdev->subsystem_device) { | 611 | lap->subdevice == pdev->subsystem_device) { |
613 | ap->cbl = ATA_CBL_PATA40_SHORT; | 612 | return ATA_CBL_PATA40_SHORT; |
614 | return; | ||
615 | } | 613 | } |
616 | lap++; | 614 | lap++; |
617 | } | 615 | } |
@@ -620,20 +618,14 @@ static void ich_pata_cbl_detect(struct ata_port *ap) | |||
620 | mask = ap->port_no == 0 ? PIIX_80C_PRI : PIIX_80C_SEC; | 618 | mask = ap->port_no == 0 ? PIIX_80C_PRI : PIIX_80C_SEC; |
621 | pci_read_config_byte(pdev, PIIX_IOCFG, &tmp); | 619 | pci_read_config_byte(pdev, PIIX_IOCFG, &tmp); |
622 | if ((tmp & mask) == 0) | 620 | if ((tmp & mask) == 0) |
623 | goto cbl40; | 621 | return ATA_CBL_PATA40; |
624 | 622 | return ATA_CBL_PATA80; | |
625 | ap->cbl = ATA_CBL_PATA80; | ||
626 | return; | ||
627 | |||
628 | cbl40: | ||
629 | ap->cbl = ATA_CBL_PATA40; | ||
630 | } | 623 | } |
631 | 624 | ||
632 | /** | 625 | /** |
633 | * piix_pata_prereset - prereset for PATA host controller | 626 | * piix_pata_prereset - prereset for PATA host controller |
634 | * @ap: Target port | 627 | * @ap: Target port |
635 | * | 628 | * |
636 | * | ||
637 | * LOCKING: | 629 | * LOCKING: |
638 | * None (inherited from caller). | 630 | * None (inherited from caller). |
639 | */ | 631 | */ |
@@ -643,8 +635,6 @@ static int piix_pata_prereset(struct ata_port *ap) | |||
643 | 635 | ||
644 | if (!pci_test_config_bits(pdev, &piix_enable_bits[ap->port_no])) | 636 | if (!pci_test_config_bits(pdev, &piix_enable_bits[ap->port_no])) |
645 | return -ENOENT; | 637 | return -ENOENT; |
646 | |||
647 | ap->cbl = ATA_CBL_PATA40; | ||
648 | return ata_std_prereset(ap); | 638 | return ata_std_prereset(ap); |
649 | } | 639 | } |
650 | 640 | ||
@@ -655,30 +645,6 @@ static void piix_pata_error_handler(struct ata_port *ap) | |||
655 | } | 645 | } |
656 | 646 | ||
657 | 647 | ||
658 | /** | ||
659 | * ich_pata_prereset - prereset for PATA host controller | ||
660 | * @ap: Target port | ||
661 | * | ||
662 | * | ||
663 | * LOCKING: | ||
664 | * None (inherited from caller). | ||
665 | */ | ||
666 | static int ich_pata_prereset(struct ata_port *ap) | ||
667 | { | ||
668 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
669 | |||
670 | if (!pci_test_config_bits(pdev, &piix_enable_bits[ap->port_no])) | ||
671 | return -ENOENT; | ||
672 | ich_pata_cbl_detect(ap); | ||
673 | return ata_std_prereset(ap); | ||
674 | } | ||
675 | |||
676 | static void ich_pata_error_handler(struct ata_port *ap) | ||
677 | { | ||
678 | ata_bmdma_drive_eh(ap, ich_pata_prereset, ata_std_softreset, NULL, | ||
679 | ata_std_postreset); | ||
680 | } | ||
681 | |||
682 | static void piix_sata_error_handler(struct ata_port *ap) | 648 | static void piix_sata_error_handler(struct ata_port *ap) |
683 | { | 649 | { |
684 | ata_bmdma_drive_eh(ap, ata_std_prereset, ata_std_softreset, NULL, | 650 | ata_bmdma_drive_eh(ap, ata_std_prereset, ata_std_softreset, NULL, |
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index 0abd72d0dec..ca67484af1e 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
@@ -72,7 +72,7 @@ static unsigned int ata_dev_init_params(struct ata_device *dev, | |||
72 | static unsigned int ata_dev_set_xfermode(struct ata_device *dev); | 72 | static unsigned int ata_dev_set_xfermode(struct ata_device *dev); |
73 | static void ata_dev_xfermask(struct ata_device *dev); | 73 | static void ata_dev_xfermask(struct ata_device *dev); |
74 | 74 | ||
75 | static unsigned int ata_print_id = 1; | 75 | unsigned int ata_print_id = 1; |
76 | static struct workqueue_struct *ata_wq; | 76 | static struct workqueue_struct *ata_wq; |
77 | 77 | ||
78 | struct workqueue_struct *ata_aux_wq; | 78 | struct workqueue_struct *ata_aux_wq; |
@@ -89,6 +89,10 @@ int libata_fua = 0; | |||
89 | module_param_named(fua, libata_fua, int, 0444); | 89 | module_param_named(fua, libata_fua, int, 0444); |
90 | MODULE_PARM_DESC(fua, "FUA support (0=off, 1=on)"); | 90 | MODULE_PARM_DESC(fua, "FUA support (0=off, 1=on)"); |
91 | 91 | ||
92 | static int ata_ignore_hpa = 0; | ||
93 | module_param_named(ignore_hpa, ata_ignore_hpa, int, 0644); | ||
94 | MODULE_PARM_DESC(ignore_hpa, "Ignore HPA limit (0=keep BIOS limits, 1=ignore limits, using full disk)"); | ||
95 | |||
92 | static int ata_probe_timeout = ATA_TMOUT_INTERNAL / HZ; | 96 | static int ata_probe_timeout = ATA_TMOUT_INTERNAL / HZ; |
93 | module_param(ata_probe_timeout, int, 0444); | 97 | module_param(ata_probe_timeout, int, 0444); |
94 | MODULE_PARM_DESC(ata_probe_timeout, "Set ATA probing timeout (seconds)"); | 98 | MODULE_PARM_DESC(ata_probe_timeout, "Set ATA probing timeout (seconds)"); |
@@ -808,6 +812,205 @@ void ata_id_c_string(const u16 *id, unsigned char *s, | |||
808 | *p = '\0'; | 812 | *p = '\0'; |
809 | } | 813 | } |
810 | 814 | ||
815 | static u64 ata_tf_to_lba48(struct ata_taskfile *tf) | ||
816 | { | ||
817 | u64 sectors = 0; | ||
818 | |||
819 | sectors |= ((u64)(tf->hob_lbah & 0xff)) << 40; | ||
820 | sectors |= ((u64)(tf->hob_lbam & 0xff)) << 32; | ||
821 | sectors |= (tf->hob_lbal & 0xff) << 24; | ||
822 | sectors |= (tf->lbah & 0xff) << 16; | ||
823 | sectors |= (tf->lbam & 0xff) << 8; | ||
824 | sectors |= (tf->lbal & 0xff); | ||
825 | |||
826 | return ++sectors; | ||
827 | } | ||
828 | |||
829 | static u64 ata_tf_to_lba(struct ata_taskfile *tf) | ||
830 | { | ||
831 | u64 sectors = 0; | ||
832 | |||
833 | sectors |= (tf->device & 0x0f) << 24; | ||
834 | sectors |= (tf->lbah & 0xff) << 16; | ||
835 | sectors |= (tf->lbam & 0xff) << 8; | ||
836 | sectors |= (tf->lbal & 0xff); | ||
837 | |||
838 | return ++sectors; | ||
839 | } | ||
840 | |||
841 | /** | ||
842 | * ata_read_native_max_address_ext - LBA48 native max query | ||
843 | * @dev: Device to query | ||
844 | * | ||
845 | * Perform an LBA48 size query upon the device in question. Return the | ||
846 | * actual LBA48 size or zero if the command fails. | ||
847 | */ | ||
848 | |||
849 | static u64 ata_read_native_max_address_ext(struct ata_device *dev) | ||
850 | { | ||
851 | unsigned int err; | ||
852 | struct ata_taskfile tf; | ||
853 | |||
854 | ata_tf_init(dev, &tf); | ||
855 | |||
856 | tf.command = ATA_CMD_READ_NATIVE_MAX_EXT; | ||
857 | tf.flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_LBA48 | ATA_TFLAG_ISADDR; | ||
858 | tf.protocol |= ATA_PROT_NODATA; | ||
859 | tf.device |= 0x40; | ||
860 | |||
861 | err = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0); | ||
862 | if (err) | ||
863 | return 0; | ||
864 | |||
865 | return ata_tf_to_lba48(&tf); | ||
866 | } | ||
867 | |||
868 | /** | ||
869 | * ata_read_native_max_address - LBA28 native max query | ||
870 | * @dev: Device to query | ||
871 | * | ||
872 | * Performa an LBA28 size query upon the device in question. Return the | ||
873 | * actual LBA28 size or zero if the command fails. | ||
874 | */ | ||
875 | |||
876 | static u64 ata_read_native_max_address(struct ata_device *dev) | ||
877 | { | ||
878 | unsigned int err; | ||
879 | struct ata_taskfile tf; | ||
880 | |||
881 | ata_tf_init(dev, &tf); | ||
882 | |||
883 | tf.command = ATA_CMD_READ_NATIVE_MAX; | ||
884 | tf.flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_ISADDR; | ||
885 | tf.protocol |= ATA_PROT_NODATA; | ||
886 | tf.device |= 0x40; | ||
887 | |||
888 | err = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0); | ||
889 | if (err) | ||
890 | return 0; | ||
891 | |||
892 | return ata_tf_to_lba(&tf); | ||
893 | } | ||
894 | |||
895 | /** | ||
896 | * ata_set_native_max_address_ext - LBA48 native max set | ||
897 | * @dev: Device to query | ||
898 | * | ||
899 | * Perform an LBA48 size set max upon the device in question. Return the | ||
900 | * actual LBA48 size or zero if the command fails. | ||
901 | */ | ||
902 | |||
903 | static u64 ata_set_native_max_address_ext(struct ata_device *dev, u64 new_sectors) | ||
904 | { | ||
905 | unsigned int err; | ||
906 | struct ata_taskfile tf; | ||
907 | |||
908 | new_sectors--; | ||
909 | |||
910 | ata_tf_init(dev, &tf); | ||
911 | |||
912 | tf.command = ATA_CMD_SET_MAX_EXT; | ||
913 | tf.flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_LBA48 | ATA_TFLAG_ISADDR; | ||
914 | tf.protocol |= ATA_PROT_NODATA; | ||
915 | tf.device |= 0x40; | ||
916 | |||
917 | tf.lbal = (new_sectors >> 0) & 0xff; | ||
918 | tf.lbam = (new_sectors >> 8) & 0xff; | ||
919 | tf.lbah = (new_sectors >> 16) & 0xff; | ||
920 | |||
921 | tf.hob_lbal = (new_sectors >> 24) & 0xff; | ||
922 | tf.hob_lbam = (new_sectors >> 32) & 0xff; | ||
923 | tf.hob_lbah = (new_sectors >> 40) & 0xff; | ||
924 | |||
925 | err = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0); | ||
926 | if (err) | ||
927 | return 0; | ||
928 | |||
929 | return ata_tf_to_lba48(&tf); | ||
930 | } | ||
931 | |||
932 | /** | ||
933 | * ata_set_native_max_address - LBA28 native max set | ||
934 | * @dev: Device to query | ||
935 | * | ||
936 | * Perform an LBA28 size set max upon the device in question. Return the | ||
937 | * actual LBA28 size or zero if the command fails. | ||
938 | */ | ||
939 | |||
940 | static u64 ata_set_native_max_address(struct ata_device *dev, u64 new_sectors) | ||
941 | { | ||
942 | unsigned int err; | ||
943 | struct ata_taskfile tf; | ||
944 | |||
945 | new_sectors--; | ||
946 | |||
947 | ata_tf_init(dev, &tf); | ||
948 | |||
949 | tf.command = ATA_CMD_SET_MAX; | ||
950 | tf.flags |= ATA_TFLAG_DEVICE | ATA_TFLAG_ISADDR; | ||
951 | tf.protocol |= ATA_PROT_NODATA; | ||
952 | |||
953 | tf.lbal = (new_sectors >> 0) & 0xff; | ||
954 | tf.lbam = (new_sectors >> 8) & 0xff; | ||
955 | tf.lbah = (new_sectors >> 16) & 0xff; | ||
956 | tf.device |= ((new_sectors >> 24) & 0x0f) | 0x40; | ||
957 | |||
958 | err = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0); | ||
959 | if (err) | ||
960 | return 0; | ||
961 | |||
962 | return ata_tf_to_lba(&tf); | ||
963 | } | ||
964 | |||
965 | /** | ||
966 | * ata_hpa_resize - Resize a device with an HPA set | ||
967 | * @dev: Device to resize | ||
968 | * | ||
969 | * Read the size of an LBA28 or LBA48 disk with HPA features and resize | ||
970 | * it if required to the full size of the media. The caller must check | ||
971 | * the drive has the HPA feature set enabled. | ||
972 | */ | ||
973 | |||
974 | static u64 ata_hpa_resize(struct ata_device *dev) | ||
975 | { | ||
976 | u64 sectors = dev->n_sectors; | ||
977 | u64 hpa_sectors; | ||
978 | |||
979 | if (ata_id_has_lba48(dev->id)) | ||
980 | hpa_sectors = ata_read_native_max_address_ext(dev); | ||
981 | else | ||
982 | hpa_sectors = ata_read_native_max_address(dev); | ||
983 | |||
984 | /* if no hpa, both should be equal */ | ||
985 | ata_dev_printk(dev, KERN_INFO, "%s 1: sectors = %lld, " | ||
986 | "hpa_sectors = %lld\n", | ||
987 | __FUNCTION__, (long long)sectors, (long long)hpa_sectors); | ||
988 | |||
989 | if (hpa_sectors > sectors) { | ||
990 | ata_dev_printk(dev, KERN_INFO, | ||
991 | "Host Protected Area detected:\n" | ||
992 | "\tcurrent size: %lld sectors\n" | ||
993 | "\tnative size: %lld sectors\n", | ||
994 | (long long)sectors, (long long)hpa_sectors); | ||
995 | |||
996 | if (ata_ignore_hpa) { | ||
997 | if (ata_id_has_lba48(dev->id)) | ||
998 | hpa_sectors = ata_set_native_max_address_ext(dev, hpa_sectors); | ||
999 | else | ||
1000 | hpa_sectors = ata_set_native_max_address(dev, | ||
1001 | hpa_sectors); | ||
1002 | |||
1003 | if (hpa_sectors) { | ||
1004 | ata_dev_printk(dev, KERN_INFO, "native size " | ||
1005 | "increased to %lld sectors\n", | ||
1006 | (long long)hpa_sectors); | ||
1007 | return hpa_sectors; | ||
1008 | } | ||
1009 | } | ||
1010 | } | ||
1011 | return sectors; | ||
1012 | } | ||
1013 | |||
811 | static u64 ata_id_n_sectors(const u16 *id) | 1014 | static u64 ata_id_n_sectors(const u16 *id) |
812 | { | 1015 | { |
813 | if (ata_id_has_lba(id)) { | 1016 | if (ata_id_has_lba(id)) { |
@@ -1270,12 +1473,16 @@ unsigned ata_exec_internal_sg(struct ata_device *dev, | |||
1270 | if (ap->ops->post_internal_cmd) | 1473 | if (ap->ops->post_internal_cmd) |
1271 | ap->ops->post_internal_cmd(qc); | 1474 | ap->ops->post_internal_cmd(qc); |
1272 | 1475 | ||
1273 | if ((qc->flags & ATA_QCFLAG_FAILED) && !qc->err_mask) { | 1476 | /* perform minimal error analysis */ |
1274 | if (ata_msg_warn(ap)) | 1477 | if (qc->flags & ATA_QCFLAG_FAILED) { |
1275 | ata_dev_printk(dev, KERN_WARNING, | 1478 | if (qc->result_tf.command & (ATA_ERR | ATA_DF)) |
1276 | "zero err_mask for failed " | 1479 | qc->err_mask |= AC_ERR_DEV; |
1277 | "internal command, assuming AC_ERR_OTHER\n"); | 1480 | |
1278 | qc->err_mask |= AC_ERR_OTHER; | 1481 | if (!qc->err_mask) |
1482 | qc->err_mask |= AC_ERR_OTHER; | ||
1483 | |||
1484 | if (qc->err_mask & ~AC_ERR_OTHER) | ||
1485 | qc->err_mask &= ~AC_ERR_OTHER; | ||
1279 | } | 1486 | } |
1280 | 1487 | ||
1281 | /* finish up */ | 1488 | /* finish up */ |
@@ -1379,30 +1586,44 @@ unsigned int ata_do_simple_cmd(struct ata_device *dev, u8 cmd) | |||
1379 | * Check if the current speed of the device requires IORDY. Used | 1586 | * Check if the current speed of the device requires IORDY. Used |
1380 | * by various controllers for chip configuration. | 1587 | * by various controllers for chip configuration. |
1381 | */ | 1588 | */ |
1382 | 1589 | ||
1383 | unsigned int ata_pio_need_iordy(const struct ata_device *adev) | 1590 | unsigned int ata_pio_need_iordy(const struct ata_device *adev) |
1384 | { | 1591 | { |
1385 | int pio; | 1592 | /* Controller doesn't support IORDY. Probably a pointless check |
1386 | int speed = adev->pio_mode - XFER_PIO_0; | 1593 | as the caller should know this */ |
1387 | 1594 | if (adev->ap->flags & ATA_FLAG_NO_IORDY) | |
1388 | if (speed < 2) | ||
1389 | return 0; | 1595 | return 0; |
1390 | if (speed > 2) | 1596 | /* PIO3 and higher it is mandatory */ |
1597 | if (adev->pio_mode > XFER_PIO_2) | ||
1598 | return 1; | ||
1599 | /* We turn it on when possible */ | ||
1600 | if (ata_id_has_iordy(adev->id)) | ||
1391 | return 1; | 1601 | return 1; |
1602 | return 0; | ||
1603 | } | ||
1392 | 1604 | ||
1605 | /** | ||
1606 | * ata_pio_mask_no_iordy - Return the non IORDY mask | ||
1607 | * @adev: ATA device | ||
1608 | * | ||
1609 | * Compute the highest mode possible if we are not using iordy. Return | ||
1610 | * -1 if no iordy mode is available. | ||
1611 | */ | ||
1612 | |||
1613 | static u32 ata_pio_mask_no_iordy(const struct ata_device *adev) | ||
1614 | { | ||
1393 | /* If we have no drive specific rule, then PIO 2 is non IORDY */ | 1615 | /* If we have no drive specific rule, then PIO 2 is non IORDY */ |
1394 | |||
1395 | if (adev->id[ATA_ID_FIELD_VALID] & 2) { /* EIDE */ | 1616 | if (adev->id[ATA_ID_FIELD_VALID] & 2) { /* EIDE */ |
1396 | pio = adev->id[ATA_ID_EIDE_PIO]; | 1617 | u16 pio = adev->id[ATA_ID_EIDE_PIO]; |
1397 | /* Is the speed faster than the drive allows non IORDY ? */ | 1618 | /* Is the speed faster than the drive allows non IORDY ? */ |
1398 | if (pio) { | 1619 | if (pio) { |
1399 | /* This is cycle times not frequency - watch the logic! */ | 1620 | /* This is cycle times not frequency - watch the logic! */ |
1400 | if (pio > 240) /* PIO2 is 240nS per cycle */ | 1621 | if (pio > 240) /* PIO2 is 240nS per cycle */ |
1401 | return 1; | 1622 | return 3 << ATA_SHIFT_PIO; |
1402 | return 0; | 1623 | return 7 << ATA_SHIFT_PIO; |
1403 | } | 1624 | } |
1404 | } | 1625 | } |
1405 | return 0; | 1626 | return 3 << ATA_SHIFT_PIO; |
1406 | } | 1627 | } |
1407 | 1628 | ||
1408 | /** | 1629 | /** |
@@ -1431,13 +1652,13 @@ int ata_dev_read_id(struct ata_device *dev, unsigned int *p_class, | |||
1431 | struct ata_taskfile tf; | 1652 | struct ata_taskfile tf; |
1432 | unsigned int err_mask = 0; | 1653 | unsigned int err_mask = 0; |
1433 | const char *reason; | 1654 | const char *reason; |
1655 | int tried_spinup = 0; | ||
1434 | int rc; | 1656 | int rc; |
1435 | 1657 | ||
1436 | if (ata_msg_ctl(ap)) | 1658 | if (ata_msg_ctl(ap)) |
1437 | ata_dev_printk(dev, KERN_DEBUG, "%s: ENTER\n", __FUNCTION__); | 1659 | ata_dev_printk(dev, KERN_DEBUG, "%s: ENTER\n", __FUNCTION__); |
1438 | 1660 | ||
1439 | ata_dev_select(ap, dev->devno, 1, 1); /* select device 0/1 */ | 1661 | ata_dev_select(ap, dev->devno, 1, 1); /* select device 0/1 */ |
1440 | |||
1441 | retry: | 1662 | retry: |
1442 | ata_tf_init(dev, &tf); | 1663 | ata_tf_init(dev, &tf); |
1443 | 1664 | ||
@@ -1494,6 +1715,32 @@ int ata_dev_read_id(struct ata_device *dev, unsigned int *p_class, | |||
1494 | goto err_out; | 1715 | goto err_out; |
1495 | } | 1716 | } |
1496 | 1717 | ||
1718 | if (!tried_spinup && (id[2] == 0x37c8 || id[2] == 0x738c)) { | ||
1719 | tried_spinup = 1; | ||
1720 | /* | ||
1721 | * Drive powered-up in standby mode, and requires a specific | ||
1722 | * SET_FEATURES spin-up subcommand before it will accept | ||
1723 | * anything other than the original IDENTIFY command. | ||
1724 | */ | ||
1725 | ata_tf_init(dev, &tf); | ||
1726 | tf.command = ATA_CMD_SET_FEATURES; | ||
1727 | tf.feature = SETFEATURES_SPINUP; | ||
1728 | tf.protocol = ATA_PROT_NODATA; | ||
1729 | tf.flags |= ATA_TFLAG_ISADDR | ATA_TFLAG_DEVICE; | ||
1730 | err_mask = ata_exec_internal(dev, &tf, NULL, DMA_NONE, NULL, 0); | ||
1731 | if (err_mask) { | ||
1732 | rc = -EIO; | ||
1733 | reason = "SPINUP failed"; | ||
1734 | goto err_out; | ||
1735 | } | ||
1736 | /* | ||
1737 | * If the drive initially returned incomplete IDENTIFY info, | ||
1738 | * we now must reissue the IDENTIFY command. | ||
1739 | */ | ||
1740 | if (id[2] == 0x37c8) | ||
1741 | goto retry; | ||
1742 | } | ||
1743 | |||
1497 | if ((flags & ATA_READID_POSTRESET) && class == ATA_DEV_ATA) { | 1744 | if ((flags & ATA_READID_POSTRESET) && class == ATA_DEV_ATA) { |
1498 | /* | 1745 | /* |
1499 | * The exact sequence expected by certain pre-ATA4 drives is: | 1746 | * The exact sequence expected by certain pre-ATA4 drives is: |
@@ -1560,20 +1807,6 @@ static void ata_dev_config_ncq(struct ata_device *dev, | |||
1560 | snprintf(desc, desc_sz, "NCQ (depth %d/%d)", hdepth, ddepth); | 1807 | snprintf(desc, desc_sz, "NCQ (depth %d/%d)", hdepth, ddepth); |
1561 | } | 1808 | } |
1562 | 1809 | ||
1563 | static void ata_set_port_max_cmd_len(struct ata_port *ap) | ||
1564 | { | ||
1565 | int i; | ||
1566 | |||
1567 | if (ap->scsi_host) { | ||
1568 | unsigned int len = 0; | ||
1569 | |||
1570 | for (i = 0; i < ATA_MAX_DEVICES; i++) | ||
1571 | len = max(len, ap->device[i].cdb_len); | ||
1572 | |||
1573 | ap->scsi_host->max_cmd_len = len; | ||
1574 | } | ||
1575 | } | ||
1576 | |||
1577 | /** | 1810 | /** |
1578 | * ata_dev_configure - Configure the specified ATA/ATAPI device | 1811 | * ata_dev_configure - Configure the specified ATA/ATAPI device |
1579 | * @dev: Target device to configure | 1812 | * @dev: Target device to configure |
@@ -1658,6 +1891,7 @@ int ata_dev_configure(struct ata_device *dev) | |||
1658 | snprintf(revbuf, 7, "ATA-%d", ata_id_major_version(id)); | 1891 | snprintf(revbuf, 7, "ATA-%d", ata_id_major_version(id)); |
1659 | 1892 | ||
1660 | dev->n_sectors = ata_id_n_sectors(id); | 1893 | dev->n_sectors = ata_id_n_sectors(id); |
1894 | dev->n_sectors_boot = dev->n_sectors; | ||
1661 | 1895 | ||
1662 | /* SCSI only uses 4-char revisions, dump full 8 chars from ATA */ | 1896 | /* SCSI only uses 4-char revisions, dump full 8 chars from ATA */ |
1663 | ata_id_c_string(dev->id, fwrevbuf, ATA_ID_FW_REV, | 1897 | ata_id_c_string(dev->id, fwrevbuf, ATA_ID_FW_REV, |
@@ -1684,6 +1918,9 @@ int ata_dev_configure(struct ata_device *dev) | |||
1684 | dev->flags |= ATA_DFLAG_FLUSH_EXT; | 1918 | dev->flags |= ATA_DFLAG_FLUSH_EXT; |
1685 | } | 1919 | } |
1686 | 1920 | ||
1921 | if (ata_id_hpa_enabled(dev->id)) | ||
1922 | dev->n_sectors = ata_hpa_resize(dev); | ||
1923 | |||
1687 | /* config NCQ */ | 1924 | /* config NCQ */ |
1688 | ata_dev_config_ncq(dev, ncq_desc, sizeof(ncq_desc)); | 1925 | ata_dev_config_ncq(dev, ncq_desc, sizeof(ncq_desc)); |
1689 | 1926 | ||
@@ -1773,8 +2010,6 @@ int ata_dev_configure(struct ata_device *dev) | |||
1773 | } | 2010 | } |
1774 | } | 2011 | } |
1775 | 2012 | ||
1776 | ata_set_port_max_cmd_len(ap); | ||
1777 | |||
1778 | /* limit bridge transfers to udma5, 200 sectors */ | 2013 | /* limit bridge transfers to udma5, 200 sectors */ |
1779 | if (ata_dev_knobble(dev)) { | 2014 | if (ata_dev_knobble(dev)) { |
1780 | if (ata_msg_drv(ap) && print_info) | 2015 | if (ata_msg_drv(ap) && print_info) |
@@ -1785,14 +2020,15 @@ int ata_dev_configure(struct ata_device *dev) | |||
1785 | } | 2020 | } |
1786 | 2021 | ||
1787 | if (ata_device_blacklisted(dev) & ATA_HORKAGE_MAX_SEC_128) | 2022 | if (ata_device_blacklisted(dev) & ATA_HORKAGE_MAX_SEC_128) |
1788 | dev->max_sectors = min(ATA_MAX_SECTORS_128, dev->max_sectors); | 2023 | dev->max_sectors = min_t(unsigned int, ATA_MAX_SECTORS_128, |
2024 | dev->max_sectors); | ||
1789 | 2025 | ||
1790 | /* limit ATAPI DMA to R/W commands only */ | 2026 | /* limit ATAPI DMA to R/W commands only */ |
1791 | if (ata_device_blacklisted(dev) & ATA_HORKAGE_DMA_RW_ONLY) | 2027 | if (ata_device_blacklisted(dev) & ATA_HORKAGE_DMA_RW_ONLY) |
1792 | dev->horkage |= ATA_HORKAGE_DMA_RW_ONLY; | 2028 | dev->horkage |= ATA_HORKAGE_DMA_RW_ONLY; |
1793 | 2029 | ||
1794 | if (ap->ops->dev_config) | 2030 | if (ap->ops->dev_config) |
1795 | ap->ops->dev_config(ap, dev); | 2031 | ap->ops->dev_config(dev); |
1796 | 2032 | ||
1797 | if (ata_msg_probe(ap)) | 2033 | if (ata_msg_probe(ap)) |
1798 | ata_dev_printk(dev, KERN_DEBUG, "%s: EXIT, drv_stat = 0x%x\n", | 2034 | ata_dev_printk(dev, KERN_DEBUG, "%s: EXIT, drv_stat = 0x%x\n", |
@@ -1807,6 +2043,56 @@ err_out_nosup: | |||
1807 | } | 2043 | } |
1808 | 2044 | ||
1809 | /** | 2045 | /** |
2046 | * ata_cable_40wire - return 40 wire cable type | ||
2047 | * @ap: port | ||
2048 | * | ||
2049 | * Helper method for drivers which want to hardwire 40 wire cable | ||
2050 | * detection. | ||
2051 | */ | ||
2052 | |||
2053 | int ata_cable_40wire(struct ata_port *ap) | ||
2054 | { | ||
2055 | return ATA_CBL_PATA40; | ||
2056 | } | ||
2057 | |||
2058 | /** | ||
2059 | * ata_cable_80wire - return 80 wire cable type | ||
2060 | * @ap: port | ||
2061 | * | ||
2062 | * Helper method for drivers which want to hardwire 80 wire cable | ||
2063 | * detection. | ||
2064 | */ | ||
2065 | |||
2066 | int ata_cable_80wire(struct ata_port *ap) | ||
2067 | { | ||
2068 | return ATA_CBL_PATA80; | ||
2069 | } | ||
2070 | |||
2071 | /** | ||
2072 | * ata_cable_unknown - return unknown PATA cable. | ||
2073 | * @ap: port | ||
2074 | * | ||
2075 | * Helper method for drivers which have no PATA cable detection. | ||
2076 | */ | ||
2077 | |||
2078 | int ata_cable_unknown(struct ata_port *ap) | ||
2079 | { | ||
2080 | return ATA_CBL_PATA_UNK; | ||
2081 | } | ||
2082 | |||
2083 | /** | ||
2084 | * ata_cable_sata - return SATA cable type | ||
2085 | * @ap: port | ||
2086 | * | ||
2087 | * Helper method for drivers which have SATA cables | ||
2088 | */ | ||
2089 | |||
2090 | int ata_cable_sata(struct ata_port *ap) | ||
2091 | { | ||
2092 | return ATA_CBL_SATA; | ||
2093 | } | ||
2094 | |||
2095 | /** | ||
1810 | * ata_bus_probe - Reset and probe ATA bus | 2096 | * ata_bus_probe - Reset and probe ATA bus |
1811 | * @ap: Bus to probe | 2097 | * @ap: Bus to probe |
1812 | * | 2098 | * |
@@ -1876,6 +2162,10 @@ int ata_bus_probe(struct ata_port *ap) | |||
1876 | goto fail; | 2162 | goto fail; |
1877 | } | 2163 | } |
1878 | 2164 | ||
2165 | /* Now ask for the cable type as PDIAG- should have been released */ | ||
2166 | if (ap->ops->cable_detect) | ||
2167 | ap->cbl = ap->ops->cable_detect(ap); | ||
2168 | |||
1879 | /* After the identify sequence we can now set up the devices. We do | 2169 | /* After the identify sequence we can now set up the devices. We do |
1880 | this in the normal order so that the user doesn't get confused */ | 2170 | this in the normal order so that the user doesn't get confused */ |
1881 | 2171 | ||
@@ -1958,7 +2248,7 @@ void ata_port_probe(struct ata_port *ap) | |||
1958 | * LOCKING: | 2248 | * LOCKING: |
1959 | * None. | 2249 | * None. |
1960 | */ | 2250 | */ |
1961 | static void sata_print_link_status(struct ata_port *ap) | 2251 | void sata_print_link_status(struct ata_port *ap) |
1962 | { | 2252 | { |
1963 | u32 sstatus, scontrol, tmp; | 2253 | u32 sstatus, scontrol, tmp; |
1964 | 2254 | ||
@@ -2352,6 +2642,12 @@ int ata_timing_compute(struct ata_device *adev, unsigned short speed, | |||
2352 | t->active += (t->cycle - (t->active + t->recover)) / 2; | 2642 | t->active += (t->cycle - (t->active + t->recover)) / 2; |
2353 | t->recover = t->cycle - t->active; | 2643 | t->recover = t->cycle - t->active; |
2354 | } | 2644 | } |
2645 | |||
2646 | /* In a few cases quantisation may produce enough errors to | ||
2647 | leave t->cycle too low for the sum of active and recovery | ||
2648 | if so we must correct this */ | ||
2649 | if (t->active + t->recover > t->cycle) | ||
2650 | t->cycle = t->active + t->recover; | ||
2355 | 2651 | ||
2356 | return 0; | 2652 | return 0; |
2357 | } | 2653 | } |
@@ -2481,12 +2777,13 @@ static int ata_dev_set_mode(struct ata_device *dev) | |||
2481 | } | 2777 | } |
2482 | 2778 | ||
2483 | /** | 2779 | /** |
2484 | * ata_set_mode - Program timings and issue SET FEATURES - XFER | 2780 | * ata_do_set_mode - Program timings and issue SET FEATURES - XFER |
2485 | * @ap: port on which timings will be programmed | 2781 | * @ap: port on which timings will be programmed |
2486 | * @r_failed_dev: out paramter for failed device | 2782 | * @r_failed_dev: out paramter for failed device |
2487 | * | 2783 | * |
2488 | * Set ATA device disk transfer mode (PIO3, UDMA6, etc.). If | 2784 | * Standard implementation of the function used to tune and set |
2489 | * ata_set_mode() fails, pointer to the failing device is | 2785 | * ATA device disk transfer mode (PIO3, UDMA6, etc.). If |
2786 | * ata_dev_set_mode() fails, pointer to the failing device is | ||
2490 | * returned in @r_failed_dev. | 2787 | * returned in @r_failed_dev. |
2491 | * | 2788 | * |
2492 | * LOCKING: | 2789 | * LOCKING: |
@@ -2495,14 +2792,12 @@ static int ata_dev_set_mode(struct ata_device *dev) | |||
2495 | * RETURNS: | 2792 | * RETURNS: |
2496 | * 0 on success, negative errno otherwise | 2793 | * 0 on success, negative errno otherwise |
2497 | */ | 2794 | */ |
2498 | int ata_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev) | 2795 | |
2796 | int ata_do_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev) | ||
2499 | { | 2797 | { |
2500 | struct ata_device *dev; | 2798 | struct ata_device *dev; |
2501 | int i, rc = 0, used_dma = 0, found = 0; | 2799 | int i, rc = 0, used_dma = 0, found = 0; |
2502 | 2800 | ||
2503 | /* has private set_mode? */ | ||
2504 | if (ap->ops->set_mode) | ||
2505 | return ap->ops->set_mode(ap, r_failed_dev); | ||
2506 | 2801 | ||
2507 | /* step 1: calculate xfer_mask */ | 2802 | /* step 1: calculate xfer_mask */ |
2508 | for (i = 0; i < ATA_MAX_DEVICES; i++) { | 2803 | for (i = 0; i < ATA_MAX_DEVICES; i++) { |
@@ -2587,6 +2882,29 @@ int ata_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev) | |||
2587 | } | 2882 | } |
2588 | 2883 | ||
2589 | /** | 2884 | /** |
2885 | * ata_set_mode - Program timings and issue SET FEATURES - XFER | ||
2886 | * @ap: port on which timings will be programmed | ||
2887 | * @r_failed_dev: out paramter for failed device | ||
2888 | * | ||
2889 | * Set ATA device disk transfer mode (PIO3, UDMA6, etc.). If | ||
2890 | * ata_set_mode() fails, pointer to the failing device is | ||
2891 | * returned in @r_failed_dev. | ||
2892 | * | ||
2893 | * LOCKING: | ||
2894 | * PCI/etc. bus probe sem. | ||
2895 | * | ||
2896 | * RETURNS: | ||
2897 | * 0 on success, negative errno otherwise | ||
2898 | */ | ||
2899 | int ata_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev) | ||
2900 | { | ||
2901 | /* has private set_mode? */ | ||
2902 | if (ap->ops->set_mode) | ||
2903 | return ap->ops->set_mode(ap, r_failed_dev); | ||
2904 | return ata_do_set_mode(ap, r_failed_dev); | ||
2905 | } | ||
2906 | |||
2907 | /** | ||
2590 | * ata_tf_to_host - issue ATA taskfile to host controller | 2908 | * ata_tf_to_host - issue ATA taskfile to host controller |
2591 | * @ap: port to which command is being issued | 2909 | * @ap: port to which command is being issued |
2592 | * @tf: ATA taskfile register set | 2910 | * @tf: ATA taskfile register set |
@@ -3267,6 +3585,11 @@ static int ata_dev_same_device(struct ata_device *dev, unsigned int new_class, | |||
3267 | "%llu != %llu\n", | 3585 | "%llu != %llu\n", |
3268 | (unsigned long long)dev->n_sectors, | 3586 | (unsigned long long)dev->n_sectors, |
3269 | (unsigned long long)new_n_sectors); | 3587 | (unsigned long long)new_n_sectors); |
3588 | /* Are we the boot time size - if so we appear to be the | ||
3589 | same disk at this point and our HPA got reapplied */ | ||
3590 | if (ata_ignore_hpa && dev->n_sectors_boot == new_n_sectors | ||
3591 | && ata_id_hpa_enabled(new_id)) | ||
3592 | return 1; | ||
3270 | return 0; | 3593 | return 0; |
3271 | } | 3594 | } |
3272 | 3595 | ||
@@ -3441,19 +3764,7 @@ static void ata_dev_xfermask(struct ata_device *dev) | |||
3441 | xfer_mask = ata_pack_xfermask(ap->pio_mask, | 3764 | xfer_mask = ata_pack_xfermask(ap->pio_mask, |
3442 | ap->mwdma_mask, ap->udma_mask); | 3765 | ap->mwdma_mask, ap->udma_mask); |
3443 | 3766 | ||
3444 | /* Apply cable rule here. Don't apply it early because when | 3767 | /* drive modes available */ |
3445 | * we handle hot plug the cable type can itself change. | ||
3446 | */ | ||
3447 | if (ap->cbl == ATA_CBL_PATA40) | ||
3448 | xfer_mask &= ~(0xF8 << ATA_SHIFT_UDMA); | ||
3449 | /* Apply drive side cable rule. Unknown or 80 pin cables reported | ||
3450 | * host side are checked drive side as well. Cases where we know a | ||
3451 | * 40wire cable is used safely for 80 are not checked here. | ||
3452 | */ | ||
3453 | if (ata_drive_40wire(dev->id) && (ap->cbl == ATA_CBL_PATA_UNK || ap->cbl == ATA_CBL_PATA80)) | ||
3454 | xfer_mask &= ~(0xF8 << ATA_SHIFT_UDMA); | ||
3455 | |||
3456 | |||
3457 | xfer_mask &= ata_pack_xfermask(dev->pio_mask, | 3768 | xfer_mask &= ata_pack_xfermask(dev->pio_mask, |
3458 | dev->mwdma_mask, dev->udma_mask); | 3769 | dev->mwdma_mask, dev->udma_mask); |
3459 | xfer_mask &= ata_id_xfermask(dev->id); | 3770 | xfer_mask &= ata_id_xfermask(dev->id); |
@@ -3482,8 +3793,30 @@ static void ata_dev_xfermask(struct ata_device *dev) | |||
3482 | "other device, disabling DMA\n"); | 3793 | "other device, disabling DMA\n"); |
3483 | } | 3794 | } |
3484 | 3795 | ||
3796 | if (ap->flags & ATA_FLAG_NO_IORDY) | ||
3797 | xfer_mask &= ata_pio_mask_no_iordy(dev); | ||
3798 | |||
3485 | if (ap->ops->mode_filter) | 3799 | if (ap->ops->mode_filter) |
3486 | xfer_mask = ap->ops->mode_filter(ap, dev, xfer_mask); | 3800 | xfer_mask = ap->ops->mode_filter(dev, xfer_mask); |
3801 | |||
3802 | /* Apply cable rule here. Don't apply it early because when | ||
3803 | * we handle hot plug the cable type can itself change. | ||
3804 | * Check this last so that we know if the transfer rate was | ||
3805 | * solely limited by the cable. | ||
3806 | * Unknown or 80 wire cables reported host side are checked | ||
3807 | * drive side as well. Cases where we know a 40wire cable | ||
3808 | * is used safely for 80 are not checked here. | ||
3809 | */ | ||
3810 | if (xfer_mask & (0xF8 << ATA_SHIFT_UDMA)) | ||
3811 | /* UDMA/44 or higher would be available */ | ||
3812 | if((ap->cbl == ATA_CBL_PATA40) || | ||
3813 | (ata_drive_40wire(dev->id) && | ||
3814 | (ap->cbl == ATA_CBL_PATA_UNK || | ||
3815 | ap->cbl == ATA_CBL_PATA80))) { | ||
3816 | ata_dev_printk(dev, KERN_WARNING, | ||
3817 | "limited to UDMA/33 due to 40-wire cable\n"); | ||
3818 | xfer_mask &= ~(0xF8 << ATA_SHIFT_UDMA); | ||
3819 | } | ||
3487 | 3820 | ||
3488 | ata_unpack_xfermask(xfer_mask, &dev->pio_mask, | 3821 | ata_unpack_xfermask(xfer_mask, &dev->pio_mask, |
3489 | &dev->mwdma_mask, &dev->udma_mask); | 3822 | &dev->mwdma_mask, &dev->udma_mask); |
@@ -4022,10 +4355,10 @@ void ata_data_xfer_noirq(struct ata_device *adev, unsigned char *buf, | |||
4022 | 4355 | ||
4023 | 4356 | ||
4024 | /** | 4357 | /** |
4025 | * ata_pio_sector - Transfer ATA_SECT_SIZE (512 bytes) of data. | 4358 | * ata_pio_sector - Transfer a sector of data. |
4026 | * @qc: Command on going | 4359 | * @qc: Command on going |
4027 | * | 4360 | * |
4028 | * Transfer ATA_SECT_SIZE of data from/to the ATA device. | 4361 | * Transfer qc->sect_size bytes of data from/to the ATA device. |
4029 | * | 4362 | * |
4030 | * LOCKING: | 4363 | * LOCKING: |
4031 | * Inherited from caller. | 4364 | * Inherited from caller. |
@@ -4040,7 +4373,7 @@ static void ata_pio_sector(struct ata_queued_cmd *qc) | |||
4040 | unsigned int offset; | 4373 | unsigned int offset; |
4041 | unsigned char *buf; | 4374 | unsigned char *buf; |
4042 | 4375 | ||
4043 | if (qc->curbytes == qc->nbytes - ATA_SECT_SIZE) | 4376 | if (qc->curbytes == qc->nbytes - qc->sect_size) |
4044 | ap->hsm_task_state = HSM_ST_LAST; | 4377 | ap->hsm_task_state = HSM_ST_LAST; |
4045 | 4378 | ||
4046 | page = sg[qc->cursg].page; | 4379 | page = sg[qc->cursg].page; |
@@ -4060,17 +4393,17 @@ static void ata_pio_sector(struct ata_queued_cmd *qc) | |||
4060 | buf = kmap_atomic(page, KM_IRQ0); | 4393 | buf = kmap_atomic(page, KM_IRQ0); |
4061 | 4394 | ||
4062 | /* do the actual data transfer */ | 4395 | /* do the actual data transfer */ |
4063 | ap->ops->data_xfer(qc->dev, buf + offset, ATA_SECT_SIZE, do_write); | 4396 | ap->ops->data_xfer(qc->dev, buf + offset, qc->sect_size, do_write); |
4064 | 4397 | ||
4065 | kunmap_atomic(buf, KM_IRQ0); | 4398 | kunmap_atomic(buf, KM_IRQ0); |
4066 | local_irq_restore(flags); | 4399 | local_irq_restore(flags); |
4067 | } else { | 4400 | } else { |
4068 | buf = page_address(page); | 4401 | buf = page_address(page); |
4069 | ap->ops->data_xfer(qc->dev, buf + offset, ATA_SECT_SIZE, do_write); | 4402 | ap->ops->data_xfer(qc->dev, buf + offset, qc->sect_size, do_write); |
4070 | } | 4403 | } |
4071 | 4404 | ||
4072 | qc->curbytes += ATA_SECT_SIZE; | 4405 | qc->curbytes += qc->sect_size; |
4073 | qc->cursg_ofs += ATA_SECT_SIZE; | 4406 | qc->cursg_ofs += qc->sect_size; |
4074 | 4407 | ||
4075 | if (qc->cursg_ofs == (&sg[qc->cursg])->length) { | 4408 | if (qc->cursg_ofs == (&sg[qc->cursg])->length) { |
4076 | qc->cursg++; | 4409 | qc->cursg++; |
@@ -4079,10 +4412,10 @@ static void ata_pio_sector(struct ata_queued_cmd *qc) | |||
4079 | } | 4412 | } |
4080 | 4413 | ||
4081 | /** | 4414 | /** |
4082 | * ata_pio_sectors - Transfer one or many 512-byte sectors. | 4415 | * ata_pio_sectors - Transfer one or many sectors. |
4083 | * @qc: Command on going | 4416 | * @qc: Command on going |
4084 | * | 4417 | * |
4085 | * Transfer one or many ATA_SECT_SIZE of data from/to the | 4418 | * Transfer one or many sectors of data from/to the |
4086 | * ATA device for the DRQ request. | 4419 | * ATA device for the DRQ request. |
4087 | * | 4420 | * |
4088 | * LOCKING: | 4421 | * LOCKING: |
@@ -4097,7 +4430,7 @@ static void ata_pio_sectors(struct ata_queued_cmd *qc) | |||
4097 | 4430 | ||
4098 | WARN_ON(qc->dev->multi_count == 0); | 4431 | WARN_ON(qc->dev->multi_count == 0); |
4099 | 4432 | ||
4100 | nsect = min((qc->nbytes - qc->curbytes) / ATA_SECT_SIZE, | 4433 | nsect = min((qc->nbytes - qc->curbytes) / qc->sect_size, |
4101 | qc->dev->multi_count); | 4434 | qc->dev->multi_count); |
4102 | while (nsect--) | 4435 | while (nsect--) |
4103 | ata_pio_sector(qc); | 4436 | ata_pio_sector(qc); |
@@ -5577,42 +5910,35 @@ void ata_dev_init(struct ata_device *dev) | |||
5577 | } | 5910 | } |
5578 | 5911 | ||
5579 | /** | 5912 | /** |
5580 | * ata_port_init - Initialize an ata_port structure | 5913 | * ata_port_alloc - allocate and initialize basic ATA port resources |
5581 | * @ap: Structure to initialize | 5914 | * @host: ATA host this allocated port belongs to |
5582 | * @host: Collection of hosts to which @ap belongs | ||
5583 | * @ent: Probe information provided by low-level driver | ||
5584 | * @port_no: Port number associated with this ata_port | ||
5585 | * | 5915 | * |
5586 | * Initialize a new ata_port structure. | 5916 | * Allocate and initialize basic ATA port resources. |
5917 | * | ||
5918 | * RETURNS: | ||
5919 | * Allocate ATA port on success, NULL on failure. | ||
5587 | * | 5920 | * |
5588 | * LOCKING: | 5921 | * LOCKING: |
5589 | * Inherited from caller. | 5922 | * Inherited from calling layer (may sleep). |
5590 | */ | 5923 | */ |
5591 | void ata_port_init(struct ata_port *ap, struct ata_host *host, | 5924 | struct ata_port *ata_port_alloc(struct ata_host *host) |
5592 | const struct ata_probe_ent *ent, unsigned int port_no) | ||
5593 | { | 5925 | { |
5926 | struct ata_port *ap; | ||
5594 | unsigned int i; | 5927 | unsigned int i; |
5595 | 5928 | ||
5929 | DPRINTK("ENTER\n"); | ||
5930 | |||
5931 | ap = kzalloc(sizeof(*ap), GFP_KERNEL); | ||
5932 | if (!ap) | ||
5933 | return NULL; | ||
5934 | |||
5596 | ap->lock = &host->lock; | 5935 | ap->lock = &host->lock; |
5597 | ap->flags = ATA_FLAG_DISABLED; | 5936 | ap->flags = ATA_FLAG_DISABLED; |
5598 | ap->print_id = ata_print_id++; | 5937 | ap->print_id = -1; |
5599 | ap->ctl = ATA_DEVCTL_OBS; | 5938 | ap->ctl = ATA_DEVCTL_OBS; |
5600 | ap->host = host; | 5939 | ap->host = host; |
5601 | ap->dev = ent->dev; | 5940 | ap->dev = host->dev; |
5602 | ap->port_no = port_no; | 5941 | |
5603 | if (port_no == 1 && ent->pinfo2) { | ||
5604 | ap->pio_mask = ent->pinfo2->pio_mask; | ||
5605 | ap->mwdma_mask = ent->pinfo2->mwdma_mask; | ||
5606 | ap->udma_mask = ent->pinfo2->udma_mask; | ||
5607 | ap->flags |= ent->pinfo2->flags; | ||
5608 | ap->ops = ent->pinfo2->port_ops; | ||
5609 | } else { | ||
5610 | ap->pio_mask = ent->pio_mask; | ||
5611 | ap->mwdma_mask = ent->mwdma_mask; | ||
5612 | ap->udma_mask = ent->udma_mask; | ||
5613 | ap->flags |= ent->port_flags; | ||
5614 | ap->ops = ent->port_ops; | ||
5615 | } | ||
5616 | ap->hw_sata_spd_limit = UINT_MAX; | 5942 | ap->hw_sata_spd_limit = UINT_MAX; |
5617 | ap->active_tag = ATA_TAG_POISON; | 5943 | ap->active_tag = ATA_TAG_POISON; |
5618 | ap->last_ctl = 0xFF; | 5944 | ap->last_ctl = 0xFF; |
@@ -5632,10 +5958,7 @@ void ata_port_init(struct ata_port *ap, struct ata_host *host, | |||
5632 | INIT_LIST_HEAD(&ap->eh_done_q); | 5958 | INIT_LIST_HEAD(&ap->eh_done_q); |
5633 | init_waitqueue_head(&ap->eh_wait_q); | 5959 | init_waitqueue_head(&ap->eh_wait_q); |
5634 | 5960 | ||
5635 | /* set cable type */ | ||
5636 | ap->cbl = ATA_CBL_NONE; | 5961 | ap->cbl = ATA_CBL_NONE; |
5637 | if (ap->flags & ATA_FLAG_SATA) | ||
5638 | ap->cbl = ATA_CBL_SATA; | ||
5639 | 5962 | ||
5640 | for (i = 0; i < ATA_MAX_DEVICES; i++) { | 5963 | for (i = 0; i < ATA_MAX_DEVICES; i++) { |
5641 | struct ata_device *dev = &ap->device[i]; | 5964 | struct ata_device *dev = &ap->device[i]; |
@@ -5648,100 +5971,209 @@ void ata_port_init(struct ata_port *ap, struct ata_host *host, | |||
5648 | ap->stats.unhandled_irq = 1; | 5971 | ap->stats.unhandled_irq = 1; |
5649 | ap->stats.idle_irq = 1; | 5972 | ap->stats.idle_irq = 1; |
5650 | #endif | 5973 | #endif |
5974 | return ap; | ||
5975 | } | ||
5651 | 5976 | ||
5652 | memcpy(&ap->ioaddr, &ent->port[port_no], sizeof(struct ata_ioports)); | 5977 | static void ata_host_release(struct device *gendev, void *res) |
5978 | { | ||
5979 | struct ata_host *host = dev_get_drvdata(gendev); | ||
5980 | int i; | ||
5981 | |||
5982 | for (i = 0; i < host->n_ports; i++) { | ||
5983 | struct ata_port *ap = host->ports[i]; | ||
5984 | |||
5985 | if (!ap) | ||
5986 | continue; | ||
5987 | |||
5988 | if ((host->flags & ATA_HOST_STARTED) && ap->ops->port_stop) | ||
5989 | ap->ops->port_stop(ap); | ||
5990 | } | ||
5991 | |||
5992 | if ((host->flags & ATA_HOST_STARTED) && host->ops->host_stop) | ||
5993 | host->ops->host_stop(host); | ||
5994 | |||
5995 | for (i = 0; i < host->n_ports; i++) { | ||
5996 | struct ata_port *ap = host->ports[i]; | ||
5997 | |||
5998 | if (!ap) | ||
5999 | continue; | ||
6000 | |||
6001 | if (ap->scsi_host) | ||
6002 | scsi_host_put(ap->scsi_host); | ||
6003 | |||
6004 | kfree(ap); | ||
6005 | host->ports[i] = NULL; | ||
6006 | } | ||
6007 | |||
6008 | dev_set_drvdata(gendev, NULL); | ||
5653 | } | 6009 | } |
5654 | 6010 | ||
5655 | /** | 6011 | /** |
5656 | * ata_port_init_shost - Initialize SCSI host associated with ATA port | 6012 | * ata_host_alloc - allocate and init basic ATA host resources |
5657 | * @ap: ATA port to initialize SCSI host for | 6013 | * @dev: generic device this host is associated with |
5658 | * @shost: SCSI host associated with @ap | 6014 | * @max_ports: maximum number of ATA ports associated with this host |
5659 | * | 6015 | * |
5660 | * Initialize SCSI host @shost associated with ATA port @ap. | 6016 | * Allocate and initialize basic ATA host resources. LLD calls |
6017 | * this function to allocate a host, initializes it fully and | ||
6018 | * attaches it using ata_host_register(). | ||
6019 | * | ||
6020 | * @max_ports ports are allocated and host->n_ports is | ||
6021 | * initialized to @max_ports. The caller is allowed to decrease | ||
6022 | * host->n_ports before calling ata_host_register(). The unused | ||
6023 | * ports will be automatically freed on registration. | ||
6024 | * | ||
6025 | * RETURNS: | ||
6026 | * Allocate ATA host on success, NULL on failure. | ||
5661 | * | 6027 | * |
5662 | * LOCKING: | 6028 | * LOCKING: |
5663 | * Inherited from caller. | 6029 | * Inherited from calling layer (may sleep). |
5664 | */ | 6030 | */ |
5665 | static void ata_port_init_shost(struct ata_port *ap, struct Scsi_Host *shost) | 6031 | struct ata_host *ata_host_alloc(struct device *dev, int max_ports) |
5666 | { | 6032 | { |
5667 | ap->scsi_host = shost; | 6033 | struct ata_host *host; |
6034 | size_t sz; | ||
6035 | int i; | ||
6036 | |||
6037 | DPRINTK("ENTER\n"); | ||
6038 | |||
6039 | if (!devres_open_group(dev, NULL, GFP_KERNEL)) | ||
6040 | return NULL; | ||
6041 | |||
6042 | /* alloc a container for our list of ATA ports (buses) */ | ||
6043 | sz = sizeof(struct ata_host) + (max_ports + 1) * sizeof(void *); | ||
6044 | /* alloc a container for our list of ATA ports (buses) */ | ||
6045 | host = devres_alloc(ata_host_release, sz, GFP_KERNEL); | ||
6046 | if (!host) | ||
6047 | goto err_out; | ||
6048 | |||
6049 | devres_add(dev, host); | ||
6050 | dev_set_drvdata(dev, host); | ||
5668 | 6051 | ||
5669 | shost->unique_id = ap->print_id; | 6052 | spin_lock_init(&host->lock); |
5670 | shost->max_id = 16; | 6053 | host->dev = dev; |
5671 | shost->max_lun = 1; | 6054 | host->n_ports = max_ports; |
5672 | shost->max_channel = 1; | 6055 | |
5673 | shost->max_cmd_len = 12; | 6056 | /* allocate ports bound to this host */ |
6057 | for (i = 0; i < max_ports; i++) { | ||
6058 | struct ata_port *ap; | ||
6059 | |||
6060 | ap = ata_port_alloc(host); | ||
6061 | if (!ap) | ||
6062 | goto err_out; | ||
6063 | |||
6064 | ap->port_no = i; | ||
6065 | host->ports[i] = ap; | ||
6066 | } | ||
6067 | |||
6068 | devres_remove_group(dev, NULL); | ||
6069 | return host; | ||
6070 | |||
6071 | err_out: | ||
6072 | devres_release_group(dev, NULL); | ||
6073 | return NULL; | ||
5674 | } | 6074 | } |
5675 | 6075 | ||
5676 | /** | 6076 | /** |
5677 | * ata_port_add - Attach low-level ATA driver to system | 6077 | * ata_host_alloc_pinfo - alloc host and init with port_info array |
5678 | * @ent: Information provided by low-level driver | 6078 | * @dev: generic device this host is associated with |
5679 | * @host: Collections of ports to which we add | 6079 | * @ppi: array of ATA port_info to initialize host with |
5680 | * @port_no: Port number associated with this host | 6080 | * @n_ports: number of ATA ports attached to this host |
5681 | * | 6081 | * |
5682 | * Attach low-level ATA driver to system. | 6082 | * Allocate ATA host and initialize with info from @ppi. If NULL |
5683 | * | 6083 | * terminated, @ppi may contain fewer entries than @n_ports. The |
5684 | * LOCKING: | 6084 | * last entry will be used for the remaining ports. |
5685 | * PCI/etc. bus probe sem. | ||
5686 | * | 6085 | * |
5687 | * RETURNS: | 6086 | * RETURNS: |
5688 | * New ata_port on success, for NULL on error. | 6087 | * Allocate ATA host on success, NULL on failure. |
6088 | * | ||
6089 | * LOCKING: | ||
6090 | * Inherited from calling layer (may sleep). | ||
5689 | */ | 6091 | */ |
5690 | static struct ata_port * ata_port_add(const struct ata_probe_ent *ent, | 6092 | struct ata_host *ata_host_alloc_pinfo(struct device *dev, |
5691 | struct ata_host *host, | 6093 | const struct ata_port_info * const * ppi, |
5692 | unsigned int port_no) | 6094 | int n_ports) |
5693 | { | 6095 | { |
5694 | struct Scsi_Host *shost; | 6096 | const struct ata_port_info *pi; |
5695 | struct ata_port *ap; | 6097 | struct ata_host *host; |
5696 | 6098 | int i, j; | |
5697 | DPRINTK("ENTER\n"); | ||
5698 | 6099 | ||
5699 | if (!ent->port_ops->error_handler && | 6100 | host = ata_host_alloc(dev, n_ports); |
5700 | !(ent->port_flags & (ATA_FLAG_SATA_RESET | ATA_FLAG_SRST))) { | 6101 | if (!host) |
5701 | printk(KERN_ERR "ata%u: no reset mechanism available\n", | ||
5702 | port_no); | ||
5703 | return NULL; | 6102 | return NULL; |
5704 | } | ||
5705 | 6103 | ||
5706 | shost = scsi_host_alloc(ent->sht, sizeof(struct ata_port)); | 6104 | for (i = 0, j = 0, pi = NULL; i < host->n_ports; i++) { |
5707 | if (!shost) | 6105 | struct ata_port *ap = host->ports[i]; |
5708 | return NULL; | ||
5709 | 6106 | ||
5710 | shost->transportt = &ata_scsi_transport_template; | 6107 | if (ppi[j]) |
6108 | pi = ppi[j++]; | ||
5711 | 6109 | ||
5712 | ap = ata_shost_to_port(shost); | 6110 | ap->pio_mask = pi->pio_mask; |
6111 | ap->mwdma_mask = pi->mwdma_mask; | ||
6112 | ap->udma_mask = pi->udma_mask; | ||
6113 | ap->flags |= pi->flags; | ||
6114 | ap->ops = pi->port_ops; | ||
5713 | 6115 | ||
5714 | ata_port_init(ap, host, ent, port_no); | 6116 | if (!host->ops && (pi->port_ops != &ata_dummy_port_ops)) |
5715 | ata_port_init_shost(ap, shost); | 6117 | host->ops = pi->port_ops; |
6118 | if (!host->private_data && pi->private_data) | ||
6119 | host->private_data = pi->private_data; | ||
6120 | } | ||
5716 | 6121 | ||
5717 | return ap; | 6122 | return host; |
5718 | } | 6123 | } |
5719 | 6124 | ||
5720 | static void ata_host_release(struct device *gendev, void *res) | 6125 | /** |
6126 | * ata_host_start - start and freeze ports of an ATA host | ||
6127 | * @host: ATA host to start ports for | ||
6128 | * | ||
6129 | * Start and then freeze ports of @host. Started status is | ||
6130 | * recorded in host->flags, so this function can be called | ||
6131 | * multiple times. Ports are guaranteed to get started only | ||
6132 | * once. If host->ops isn't initialized yet, its set to the | ||
6133 | * first non-dummy port ops. | ||
6134 | * | ||
6135 | * LOCKING: | ||
6136 | * Inherited from calling layer (may sleep). | ||
6137 | * | ||
6138 | * RETURNS: | ||
6139 | * 0 if all ports are started successfully, -errno otherwise. | ||
6140 | */ | ||
6141 | int ata_host_start(struct ata_host *host) | ||
5721 | { | 6142 | { |
5722 | struct ata_host *host = dev_get_drvdata(gendev); | 6143 | int i, rc; |
5723 | int i; | 6144 | |
6145 | if (host->flags & ATA_HOST_STARTED) | ||
6146 | return 0; | ||
5724 | 6147 | ||
5725 | for (i = 0; i < host->n_ports; i++) { | 6148 | for (i = 0; i < host->n_ports; i++) { |
5726 | struct ata_port *ap = host->ports[i]; | 6149 | struct ata_port *ap = host->ports[i]; |
5727 | 6150 | ||
5728 | if (ap && ap->ops->port_stop) | 6151 | if (!host->ops && !ata_port_is_dummy(ap)) |
5729 | ap->ops->port_stop(ap); | 6152 | host->ops = ap->ops; |
6153 | |||
6154 | if (ap->ops->port_start) { | ||
6155 | rc = ap->ops->port_start(ap); | ||
6156 | if (rc) { | ||
6157 | ata_port_printk(ap, KERN_ERR, "failed to " | ||
6158 | "start port (errno=%d)\n", rc); | ||
6159 | goto err_out; | ||
6160 | } | ||
6161 | } | ||
6162 | |||
6163 | ata_eh_freeze_port(ap); | ||
5730 | } | 6164 | } |
5731 | 6165 | ||
5732 | if (host->ops->host_stop) | 6166 | host->flags |= ATA_HOST_STARTED; |
5733 | host->ops->host_stop(host); | 6167 | return 0; |
5734 | 6168 | ||
5735 | for (i = 0; i < host->n_ports; i++) { | 6169 | err_out: |
6170 | while (--i >= 0) { | ||
5736 | struct ata_port *ap = host->ports[i]; | 6171 | struct ata_port *ap = host->ports[i]; |
5737 | 6172 | ||
5738 | if (ap) | 6173 | if (ap->ops->port_stop) |
5739 | scsi_host_put(ap->scsi_host); | 6174 | ap->ops->port_stop(ap); |
5740 | |||
5741 | host->ports[i] = NULL; | ||
5742 | } | 6175 | } |
5743 | 6176 | return rc; | |
5744 | dev_set_drvdata(gendev, NULL); | ||
5745 | } | 6177 | } |
5746 | 6178 | ||
5747 | /** | 6179 | /** |
@@ -5755,7 +6187,7 @@ static void ata_host_release(struct device *gendev, void *res) | |||
5755 | * PCI/etc. bus probe sem. | 6187 | * PCI/etc. bus probe sem. |
5756 | * | 6188 | * |
5757 | */ | 6189 | */ |
5758 | 6190 | /* KILLME - the only user left is ipr */ | |
5759 | void ata_host_init(struct ata_host *host, struct device *dev, | 6191 | void ata_host_init(struct ata_host *host, struct device *dev, |
5760 | unsigned long flags, const struct ata_port_operations *ops) | 6192 | unsigned long flags, const struct ata_port_operations *ops) |
5761 | { | 6193 | { |
@@ -5766,155 +6198,95 @@ void ata_host_init(struct ata_host *host, struct device *dev, | |||
5766 | } | 6198 | } |
5767 | 6199 | ||
5768 | /** | 6200 | /** |
5769 | * ata_device_add - Register hardware device with ATA and SCSI layers | 6201 | * ata_host_register - register initialized ATA host |
5770 | * @ent: Probe information describing hardware device to be registered | 6202 | * @host: ATA host to register |
6203 | * @sht: template for SCSI host | ||
5771 | * | 6204 | * |
5772 | * This function processes the information provided in the probe | 6205 | * Register initialized ATA host. @host is allocated using |
5773 | * information struct @ent, allocates the necessary ATA and SCSI | 6206 | * ata_host_alloc() and fully initialized by LLD. This function |
5774 | * host information structures, initializes them, and registers | 6207 | * starts ports, registers @host with ATA and SCSI layers and |
5775 | * everything with requisite kernel subsystems. | 6208 | * probe registered devices. |
5776 | * | ||
5777 | * This function requests irqs, probes the ATA bus, and probes | ||
5778 | * the SCSI bus. | ||
5779 | * | 6209 | * |
5780 | * LOCKING: | 6210 | * LOCKING: |
5781 | * PCI/etc. bus probe sem. | 6211 | * Inherited from calling layer (may sleep). |
5782 | * | 6212 | * |
5783 | * RETURNS: | 6213 | * RETURNS: |
5784 | * Number of ports registered. Zero on error (no ports registered). | 6214 | * 0 on success, -errno otherwise. |
5785 | */ | 6215 | */ |
5786 | int ata_device_add(const struct ata_probe_ent *ent) | 6216 | int ata_host_register(struct ata_host *host, struct scsi_host_template *sht) |
5787 | { | 6217 | { |
5788 | unsigned int i; | 6218 | int i, rc; |
5789 | struct device *dev = ent->dev; | ||
5790 | struct ata_host *host; | ||
5791 | int rc; | ||
5792 | |||
5793 | DPRINTK("ENTER\n"); | ||
5794 | 6219 | ||
5795 | if (ent->irq == 0) { | 6220 | /* host must have been started */ |
5796 | dev_printk(KERN_ERR, dev, "is not available: No interrupt assigned.\n"); | 6221 | if (!(host->flags & ATA_HOST_STARTED)) { |
5797 | return 0; | 6222 | dev_printk(KERN_ERR, host->dev, |
6223 | "BUG: trying to register unstarted host\n"); | ||
6224 | WARN_ON(1); | ||
6225 | return -EINVAL; | ||
5798 | } | 6226 | } |
5799 | 6227 | ||
5800 | if (!devres_open_group(dev, ata_device_add, GFP_KERNEL)) | 6228 | /* Blow away unused ports. This happens when LLD can't |
5801 | return 0; | 6229 | * determine the exact number of ports to allocate at |
6230 | * allocation time. | ||
6231 | */ | ||
6232 | for (i = host->n_ports; host->ports[i]; i++) | ||
6233 | kfree(host->ports[i]); | ||
5802 | 6234 | ||
5803 | /* alloc a container for our list of ATA ports (buses) */ | 6235 | /* give ports names and add SCSI hosts */ |
5804 | host = devres_alloc(ata_host_release, sizeof(struct ata_host) + | 6236 | for (i = 0; i < host->n_ports; i++) |
5805 | (ent->n_ports * sizeof(void *)), GFP_KERNEL); | 6237 | host->ports[i]->print_id = ata_print_id++; |
5806 | if (!host) | ||
5807 | goto err_out; | ||
5808 | devres_add(dev, host); | ||
5809 | dev_set_drvdata(dev, host); | ||
5810 | 6238 | ||
5811 | ata_host_init(host, dev, ent->_host_flags, ent->port_ops); | 6239 | rc = ata_scsi_add_hosts(host, sht); |
5812 | host->n_ports = ent->n_ports; | 6240 | if (rc) |
5813 | host->irq = ent->irq; | 6241 | return rc; |
5814 | host->irq2 = ent->irq2; | ||
5815 | host->iomap = ent->iomap; | ||
5816 | host->private_data = ent->private_data; | ||
5817 | 6242 | ||
5818 | /* register each port bound to this device */ | 6243 | /* set cable, sata_spd_limit and report */ |
5819 | for (i = 0; i < host->n_ports; i++) { | 6244 | for (i = 0; i < host->n_ports; i++) { |
5820 | struct ata_port *ap; | 6245 | struct ata_port *ap = host->ports[i]; |
5821 | unsigned long xfer_mode_mask; | 6246 | int irq_line; |
5822 | int irq_line = ent->irq; | 6247 | u32 scontrol; |
6248 | unsigned long xfer_mask; | ||
5823 | 6249 | ||
5824 | ap = ata_port_add(ent, host, i); | 6250 | /* set SATA cable type if still unset */ |
5825 | host->ports[i] = ap; | 6251 | if (ap->cbl == ATA_CBL_NONE && (ap->flags & ATA_FLAG_SATA)) |
5826 | if (!ap) | 6252 | ap->cbl = ATA_CBL_SATA; |
5827 | goto err_out; | ||
5828 | 6253 | ||
5829 | /* dummy? */ | 6254 | /* init sata_spd_limit to the current value */ |
5830 | if (ent->dummy_port_mask & (1 << i)) { | 6255 | if (sata_scr_read(ap, SCR_CONTROL, &scontrol) == 0) { |
5831 | ata_port_printk(ap, KERN_INFO, "DUMMY\n"); | 6256 | int spd = (scontrol >> 4) & 0xf; |
5832 | ap->ops = &ata_dummy_port_ops; | 6257 | ap->hw_sata_spd_limit &= (1 << spd) - 1; |
5833 | continue; | ||
5834 | } | ||
5835 | |||
5836 | /* start port */ | ||
5837 | rc = ap->ops->port_start(ap); | ||
5838 | if (rc) { | ||
5839 | host->ports[i] = NULL; | ||
5840 | scsi_host_put(ap->scsi_host); | ||
5841 | goto err_out; | ||
5842 | } | 6258 | } |
6259 | ap->sata_spd_limit = ap->hw_sata_spd_limit; | ||
5843 | 6260 | ||
5844 | /* Report the secondary IRQ for second channel legacy */ | 6261 | /* report the secondary IRQ for second channel legacy */ |
5845 | if (i == 1 && ent->irq2) | 6262 | irq_line = host->irq; |
5846 | irq_line = ent->irq2; | 6263 | if (i == 1 && host->irq2) |
6264 | irq_line = host->irq2; | ||
5847 | 6265 | ||
5848 | xfer_mode_mask =(ap->udma_mask << ATA_SHIFT_UDMA) | | 6266 | xfer_mask = ata_pack_xfermask(ap->pio_mask, ap->mwdma_mask, |
5849 | (ap->mwdma_mask << ATA_SHIFT_MWDMA) | | 6267 | ap->udma_mask); |
5850 | (ap->pio_mask << ATA_SHIFT_PIO); | ||
5851 | 6268 | ||
5852 | /* print per-port info to dmesg */ | 6269 | /* print per-port info to dmesg */ |
5853 | ata_port_printk(ap, KERN_INFO, "%cATA max %s cmd 0x%p " | 6270 | if (!ata_port_is_dummy(ap)) |
5854 | "ctl 0x%p bmdma 0x%p irq %d\n", | 6271 | ata_port_printk(ap, KERN_INFO, "%cATA max %s cmd 0x%p " |
5855 | ap->flags & ATA_FLAG_SATA ? 'S' : 'P', | 6272 | "ctl 0x%p bmdma 0x%p irq %d\n", |
5856 | ata_mode_string(xfer_mode_mask), | 6273 | ap->cbl == ATA_CBL_SATA ? 'S' : 'P', |
5857 | ap->ioaddr.cmd_addr, | 6274 | ata_mode_string(xfer_mask), |
5858 | ap->ioaddr.ctl_addr, | 6275 | ap->ioaddr.cmd_addr, |
5859 | ap->ioaddr.bmdma_addr, | 6276 | ap->ioaddr.ctl_addr, |
5860 | irq_line); | 6277 | ap->ioaddr.bmdma_addr, |
5861 | 6278 | irq_line); | |
5862 | /* freeze port before requesting IRQ */ | 6279 | else |
5863 | ata_eh_freeze_port(ap); | 6280 | ata_port_printk(ap, KERN_INFO, "DUMMY\n"); |
5864 | } | ||
5865 | |||
5866 | /* obtain irq, that may be shared between channels */ | ||
5867 | rc = devm_request_irq(dev, ent->irq, ent->port_ops->irq_handler, | ||
5868 | ent->irq_flags, DRV_NAME, host); | ||
5869 | if (rc) { | ||
5870 | dev_printk(KERN_ERR, dev, "irq %lu request failed: %d\n", | ||
5871 | ent->irq, rc); | ||
5872 | goto err_out; | ||
5873 | } | ||
5874 | |||
5875 | /* do we have a second IRQ for the other channel, eg legacy mode */ | ||
5876 | if (ent->irq2) { | ||
5877 | /* We will get weird core code crashes later if this is true | ||
5878 | so trap it now */ | ||
5879 | BUG_ON(ent->irq == ent->irq2); | ||
5880 | |||
5881 | rc = devm_request_irq(dev, ent->irq2, | ||
5882 | ent->port_ops->irq_handler, ent->irq_flags, | ||
5883 | DRV_NAME, host); | ||
5884 | if (rc) { | ||
5885 | dev_printk(KERN_ERR, dev, "irq %lu request failed: %d\n", | ||
5886 | ent->irq2, rc); | ||
5887 | goto err_out; | ||
5888 | } | ||
5889 | } | 6281 | } |
5890 | 6282 | ||
5891 | /* resource acquisition complete */ | ||
5892 | devres_remove_group(dev, ata_device_add); | ||
5893 | |||
5894 | /* perform each probe synchronously */ | 6283 | /* perform each probe synchronously */ |
5895 | DPRINTK("probe begin\n"); | 6284 | DPRINTK("probe begin\n"); |
5896 | for (i = 0; i < host->n_ports; i++) { | 6285 | for (i = 0; i < host->n_ports; i++) { |
5897 | struct ata_port *ap = host->ports[i]; | 6286 | struct ata_port *ap = host->ports[i]; |
5898 | u32 scontrol; | ||
5899 | int rc; | 6287 | int rc; |
5900 | 6288 | ||
5901 | /* init sata_spd_limit to the current value */ | 6289 | /* probe */ |
5902 | if (sata_scr_read(ap, SCR_CONTROL, &scontrol) == 0) { | ||
5903 | int spd = (scontrol >> 4) & 0xf; | ||
5904 | ap->hw_sata_spd_limit &= (1 << spd) - 1; | ||
5905 | } | ||
5906 | ap->sata_spd_limit = ap->hw_sata_spd_limit; | ||
5907 | |||
5908 | rc = scsi_add_host(ap->scsi_host, dev); | ||
5909 | if (rc) { | ||
5910 | ata_port_printk(ap, KERN_ERR, "scsi_add_host failed\n"); | ||
5911 | /* FIXME: do something useful here */ | ||
5912 | /* FIXME: handle unconditional calls to | ||
5913 | * scsi_scan_host and ata_host_remove, below, | ||
5914 | * at the very least | ||
5915 | */ | ||
5916 | } | ||
5917 | |||
5918 | if (ap->ops->error_handler) { | 6290 | if (ap->ops->error_handler) { |
5919 | struct ata_eh_info *ehi = &ap->eh_info; | 6291 | struct ata_eh_info *ehi = &ap->eh_info; |
5920 | unsigned long flags; | 6292 | unsigned long flags; |
@@ -5959,16 +6331,52 @@ int ata_device_add(const struct ata_probe_ent *ent) | |||
5959 | ata_scsi_scan_host(ap); | 6331 | ata_scsi_scan_host(ap); |
5960 | } | 6332 | } |
5961 | 6333 | ||
5962 | VPRINTK("EXIT, returning %u\n", ent->n_ports); | ||
5963 | return ent->n_ports; /* success */ | ||
5964 | |||
5965 | err_out: | ||
5966 | devres_release_group(dev, ata_device_add); | ||
5967 | VPRINTK("EXIT, returning %d\n", rc); | ||
5968 | return 0; | 6334 | return 0; |
5969 | } | 6335 | } |
5970 | 6336 | ||
5971 | /** | 6337 | /** |
6338 | * ata_host_activate - start host, request IRQ and register it | ||
6339 | * @host: target ATA host | ||
6340 | * @irq: IRQ to request | ||
6341 | * @irq_handler: irq_handler used when requesting IRQ | ||
6342 | * @irq_flags: irq_flags used when requesting IRQ | ||
6343 | * @sht: scsi_host_template to use when registering the host | ||
6344 | * | ||
6345 | * After allocating an ATA host and initializing it, most libata | ||
6346 | * LLDs perform three steps to activate the host - start host, | ||
6347 | * request IRQ and register it. This helper takes necessasry | ||
6348 | * arguments and performs the three steps in one go. | ||
6349 | * | ||
6350 | * LOCKING: | ||
6351 | * Inherited from calling layer (may sleep). | ||
6352 | * | ||
6353 | * RETURNS: | ||
6354 | * 0 on success, -errno otherwise. | ||
6355 | */ | ||
6356 | int ata_host_activate(struct ata_host *host, int irq, | ||
6357 | irq_handler_t irq_handler, unsigned long irq_flags, | ||
6358 | struct scsi_host_template *sht) | ||
6359 | { | ||
6360 | int rc; | ||
6361 | |||
6362 | rc = ata_host_start(host); | ||
6363 | if (rc) | ||
6364 | return rc; | ||
6365 | |||
6366 | rc = devm_request_irq(host->dev, irq, irq_handler, irq_flags, | ||
6367 | dev_driver_string(host->dev), host); | ||
6368 | if (rc) | ||
6369 | return rc; | ||
6370 | |||
6371 | rc = ata_host_register(host, sht); | ||
6372 | /* if failed, just free the IRQ and leave ports alone */ | ||
6373 | if (rc) | ||
6374 | devm_free_irq(host->dev, irq, host); | ||
6375 | |||
6376 | return rc; | ||
6377 | } | ||
6378 | |||
6379 | /** | ||
5972 | * ata_port_detach - Detach ATA port in prepration of device removal | 6380 | * ata_port_detach - Detach ATA port in prepration of device removal |
5973 | * @ap: ATA port to be detached | 6381 | * @ap: ATA port to be detached |
5974 | * | 6382 | * |
@@ -6043,32 +6451,6 @@ void ata_host_detach(struct ata_host *host) | |||
6043 | ata_port_detach(host->ports[i]); | 6451 | ata_port_detach(host->ports[i]); |
6044 | } | 6452 | } |
6045 | 6453 | ||
6046 | struct ata_probe_ent * | ||
6047 | ata_probe_ent_alloc(struct device *dev, const struct ata_port_info *port) | ||
6048 | { | ||
6049 | struct ata_probe_ent *probe_ent; | ||
6050 | |||
6051 | probe_ent = devm_kzalloc(dev, sizeof(*probe_ent), GFP_KERNEL); | ||
6052 | if (!probe_ent) { | ||
6053 | printk(KERN_ERR DRV_NAME "(%s): out of memory\n", | ||
6054 | kobject_name(&(dev->kobj))); | ||
6055 | return NULL; | ||
6056 | } | ||
6057 | |||
6058 | INIT_LIST_HEAD(&probe_ent->node); | ||
6059 | probe_ent->dev = dev; | ||
6060 | |||
6061 | probe_ent->sht = port->sht; | ||
6062 | probe_ent->port_flags = port->flags; | ||
6063 | probe_ent->pio_mask = port->pio_mask; | ||
6064 | probe_ent->mwdma_mask = port->mwdma_mask; | ||
6065 | probe_ent->udma_mask = port->udma_mask; | ||
6066 | probe_ent->port_ops = port->port_ops; | ||
6067 | probe_ent->private_data = port->private_data; | ||
6068 | |||
6069 | return probe_ent; | ||
6070 | } | ||
6071 | |||
6072 | /** | 6454 | /** |
6073 | * ata_std_ports - initialize ioaddr with standard port offsets. | 6455 | * ata_std_ports - initialize ioaddr with standard port offsets. |
6074 | * @ioaddr: IO address structure to be initialized | 6456 | * @ioaddr: IO address structure to be initialized |
@@ -6334,6 +6716,10 @@ const struct ata_port_operations ata_dummy_port_ops = { | |||
6334 | .port_stop = ata_dummy_noret, | 6716 | .port_stop = ata_dummy_noret, |
6335 | }; | 6717 | }; |
6336 | 6718 | ||
6719 | const struct ata_port_info ata_dummy_port_info = { | ||
6720 | .port_ops = &ata_dummy_port_ops, | ||
6721 | }; | ||
6722 | |||
6337 | /* | 6723 | /* |
6338 | * libata is essentially a library of internal helper functions for | 6724 | * libata is essentially a library of internal helper functions for |
6339 | * low-level ATA host controller drivers. As such, the API/ABI is | 6725 | * low-level ATA host controller drivers. As such, the API/ABI is |
@@ -6345,10 +6731,15 @@ EXPORT_SYMBOL_GPL(sata_deb_timing_normal); | |||
6345 | EXPORT_SYMBOL_GPL(sata_deb_timing_hotplug); | 6731 | EXPORT_SYMBOL_GPL(sata_deb_timing_hotplug); |
6346 | EXPORT_SYMBOL_GPL(sata_deb_timing_long); | 6732 | EXPORT_SYMBOL_GPL(sata_deb_timing_long); |
6347 | EXPORT_SYMBOL_GPL(ata_dummy_port_ops); | 6733 | EXPORT_SYMBOL_GPL(ata_dummy_port_ops); |
6734 | EXPORT_SYMBOL_GPL(ata_dummy_port_info); | ||
6348 | EXPORT_SYMBOL_GPL(ata_std_bios_param); | 6735 | EXPORT_SYMBOL_GPL(ata_std_bios_param); |
6349 | EXPORT_SYMBOL_GPL(ata_std_ports); | 6736 | EXPORT_SYMBOL_GPL(ata_std_ports); |
6350 | EXPORT_SYMBOL_GPL(ata_host_init); | 6737 | EXPORT_SYMBOL_GPL(ata_host_init); |
6351 | EXPORT_SYMBOL_GPL(ata_device_add); | 6738 | EXPORT_SYMBOL_GPL(ata_host_alloc); |
6739 | EXPORT_SYMBOL_GPL(ata_host_alloc_pinfo); | ||
6740 | EXPORT_SYMBOL_GPL(ata_host_start); | ||
6741 | EXPORT_SYMBOL_GPL(ata_host_register); | ||
6742 | EXPORT_SYMBOL_GPL(ata_host_activate); | ||
6352 | EXPORT_SYMBOL_GPL(ata_host_detach); | 6743 | EXPORT_SYMBOL_GPL(ata_host_detach); |
6353 | EXPORT_SYMBOL_GPL(ata_sg_init); | 6744 | EXPORT_SYMBOL_GPL(ata_sg_init); |
6354 | EXPORT_SYMBOL_GPL(ata_sg_init_one); | 6745 | EXPORT_SYMBOL_GPL(ata_sg_init_one); |
@@ -6360,6 +6751,7 @@ EXPORT_SYMBOL_GPL(ata_tf_load); | |||
6360 | EXPORT_SYMBOL_GPL(ata_tf_read); | 6751 | EXPORT_SYMBOL_GPL(ata_tf_read); |
6361 | EXPORT_SYMBOL_GPL(ata_noop_dev_select); | 6752 | EXPORT_SYMBOL_GPL(ata_noop_dev_select); |
6362 | EXPORT_SYMBOL_GPL(ata_std_dev_select); | 6753 | EXPORT_SYMBOL_GPL(ata_std_dev_select); |
6754 | EXPORT_SYMBOL_GPL(sata_print_link_status); | ||
6363 | EXPORT_SYMBOL_GPL(ata_tf_to_fis); | 6755 | EXPORT_SYMBOL_GPL(ata_tf_to_fis); |
6364 | EXPORT_SYMBOL_GPL(ata_tf_from_fis); | 6756 | EXPORT_SYMBOL_GPL(ata_tf_from_fis); |
6365 | EXPORT_SYMBOL_GPL(ata_check_status); | 6757 | EXPORT_SYMBOL_GPL(ata_check_status); |
@@ -6367,6 +6759,7 @@ EXPORT_SYMBOL_GPL(ata_altstatus); | |||
6367 | EXPORT_SYMBOL_GPL(ata_exec_command); | 6759 | EXPORT_SYMBOL_GPL(ata_exec_command); |
6368 | EXPORT_SYMBOL_GPL(ata_port_start); | 6760 | EXPORT_SYMBOL_GPL(ata_port_start); |
6369 | EXPORT_SYMBOL_GPL(ata_interrupt); | 6761 | EXPORT_SYMBOL_GPL(ata_interrupt); |
6762 | EXPORT_SYMBOL_GPL(ata_do_set_mode); | ||
6370 | EXPORT_SYMBOL_GPL(ata_data_xfer); | 6763 | EXPORT_SYMBOL_GPL(ata_data_xfer); |
6371 | EXPORT_SYMBOL_GPL(ata_data_xfer_noirq); | 6764 | EXPORT_SYMBOL_GPL(ata_data_xfer_noirq); |
6372 | EXPORT_SYMBOL_GPL(ata_qc_prep); | 6765 | EXPORT_SYMBOL_GPL(ata_qc_prep); |
@@ -6429,7 +6822,8 @@ EXPORT_SYMBOL_GPL(ata_timing_merge); | |||
6429 | 6822 | ||
6430 | #ifdef CONFIG_PCI | 6823 | #ifdef CONFIG_PCI |
6431 | EXPORT_SYMBOL_GPL(pci_test_config_bits); | 6824 | EXPORT_SYMBOL_GPL(pci_test_config_bits); |
6432 | EXPORT_SYMBOL_GPL(ata_pci_init_native_mode); | 6825 | EXPORT_SYMBOL_GPL(ata_pci_init_native_host); |
6826 | EXPORT_SYMBOL_GPL(ata_pci_prepare_native_host); | ||
6433 | EXPORT_SYMBOL_GPL(ata_pci_init_one); | 6827 | EXPORT_SYMBOL_GPL(ata_pci_init_one); |
6434 | EXPORT_SYMBOL_GPL(ata_pci_remove_one); | 6828 | EXPORT_SYMBOL_GPL(ata_pci_remove_one); |
6435 | #ifdef CONFIG_PM | 6829 | #ifdef CONFIG_PM |
@@ -6461,3 +6855,8 @@ EXPORT_SYMBOL_GPL(ata_dummy_irq_on); | |||
6461 | EXPORT_SYMBOL_GPL(ata_irq_ack); | 6855 | EXPORT_SYMBOL_GPL(ata_irq_ack); |
6462 | EXPORT_SYMBOL_GPL(ata_dummy_irq_ack); | 6856 | EXPORT_SYMBOL_GPL(ata_dummy_irq_ack); |
6463 | EXPORT_SYMBOL_GPL(ata_dev_try_classify); | 6857 | EXPORT_SYMBOL_GPL(ata_dev_try_classify); |
6858 | |||
6859 | EXPORT_SYMBOL_GPL(ata_cable_40wire); | ||
6860 | EXPORT_SYMBOL_GPL(ata_cable_80wire); | ||
6861 | EXPORT_SYMBOL_GPL(ata_cable_unknown); | ||
6862 | EXPORT_SYMBOL_GPL(ata_cable_sata); | ||
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c index 39f556c0299..2bff9adcacf 100644 --- a/drivers/ata/libata-eh.c +++ b/drivers/ata/libata-eh.c | |||
@@ -1056,7 +1056,7 @@ static void ata_eh_analyze_serror(struct ata_port *ap) | |||
1056 | } | 1056 | } |
1057 | if (serror & SERR_INTERNAL) { | 1057 | if (serror & SERR_INTERNAL) { |
1058 | err_mask |= AC_ERR_SYSTEM; | 1058 | err_mask |= AC_ERR_SYSTEM; |
1059 | action |= ATA_EH_SOFTRESET; | 1059 | action |= ATA_EH_HARDRESET; |
1060 | } | 1060 | } |
1061 | if (serror & (SERR_PHYRDY_CHG | SERR_DEV_XCHG)) | 1061 | if (serror & (SERR_PHYRDY_CHG | SERR_DEV_XCHG)) |
1062 | ata_ehi_hotplugged(&ehc->i); | 1062 | ata_ehi_hotplugged(&ehc->i); |
@@ -1151,7 +1151,9 @@ static unsigned int ata_eh_analyze_tf(struct ata_queued_cmd *qc, | |||
1151 | return ATA_EH_SOFTRESET; | 1151 | return ATA_EH_SOFTRESET; |
1152 | } | 1152 | } |
1153 | 1153 | ||
1154 | if (!(qc->err_mask & AC_ERR_DEV)) | 1154 | if (stat & (ATA_ERR | ATA_DF)) |
1155 | qc->err_mask |= AC_ERR_DEV; | ||
1156 | else | ||
1155 | return 0; | 1157 | return 0; |
1156 | 1158 | ||
1157 | switch (qc->dev->class) { | 1159 | switch (qc->dev->class) { |
@@ -1669,7 +1671,10 @@ static int ata_eh_reset(struct ata_port *ap, int classify, | |||
1669 | reset == softreset ? "soft" : "hard"); | 1671 | reset == softreset ? "soft" : "hard"); |
1670 | 1672 | ||
1671 | /* mark that this EH session started with reset */ | 1673 | /* mark that this EH session started with reset */ |
1672 | ehc->i.flags |= ATA_EHI_DID_RESET; | 1674 | if (reset == hardreset) |
1675 | ehc->i.flags |= ATA_EHI_DID_HARDRESET; | ||
1676 | else | ||
1677 | ehc->i.flags |= ATA_EHI_DID_SOFTRESET; | ||
1673 | 1678 | ||
1674 | rc = ata_do_reset(ap, reset, classes); | 1679 | rc = ata_do_reset(ap, reset, classes); |
1675 | 1680 | ||
@@ -1808,6 +1813,10 @@ static int ata_eh_revalidate_and_attach(struct ata_port *ap, | |||
1808 | } | 1813 | } |
1809 | } | 1814 | } |
1810 | 1815 | ||
1816 | /* PDIAG- should have been released, ask cable type if post-reset */ | ||
1817 | if ((ehc->i.flags & ATA_EHI_DID_RESET) && ap->ops->cable_detect) | ||
1818 | ap->cbl = ap->ops->cable_detect(ap); | ||
1819 | |||
1811 | /* Configure new devices forward such that user doesn't see | 1820 | /* Configure new devices forward such that user doesn't see |
1812 | * device detection messages backwards. | 1821 | * device detection messages backwards. |
1813 | */ | 1822 | */ |
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c index e9364434182..9afba2ba489 100644 --- a/drivers/ata/libata-scsi.c +++ b/drivers/ata/libata-scsi.c | |||
@@ -104,7 +104,7 @@ static const u8 def_control_mpage[CONTROL_MPAGE_LEN] = { | |||
104 | * libata transport template. libata doesn't do real transport stuff. | 104 | * libata transport template. libata doesn't do real transport stuff. |
105 | * It just needs the eh_timed_out hook. | 105 | * It just needs the eh_timed_out hook. |
106 | */ | 106 | */ |
107 | struct scsi_transport_template ata_scsi_transport_template = { | 107 | static struct scsi_transport_template ata_scsi_transport_template = { |
108 | .eh_strategy_handler = ata_scsi_error, | 108 | .eh_strategy_handler = ata_scsi_error, |
109 | .eh_timed_out = ata_scsi_timed_out, | 109 | .eh_timed_out = ata_scsi_timed_out, |
110 | .user_scan = ata_scsi_user_scan, | 110 | .user_scan = ata_scsi_user_scan, |
@@ -2678,6 +2678,18 @@ static unsigned int ata_scsi_pass_thru(struct ata_queued_cmd *qc) | |||
2678 | tf->device = qc->dev->devno ? | 2678 | tf->device = qc->dev->devno ? |
2679 | tf->device | ATA_DEV1 : tf->device & ~ATA_DEV1; | 2679 | tf->device | ATA_DEV1 : tf->device & ~ATA_DEV1; |
2680 | 2680 | ||
2681 | /* READ/WRITE LONG use a non-standard sect_size */ | ||
2682 | qc->sect_size = ATA_SECT_SIZE; | ||
2683 | switch (tf->command) { | ||
2684 | case ATA_CMD_READ_LONG: | ||
2685 | case ATA_CMD_READ_LONG_ONCE: | ||
2686 | case ATA_CMD_WRITE_LONG: | ||
2687 | case ATA_CMD_WRITE_LONG_ONCE: | ||
2688 | if (tf->protocol != ATA_PROT_PIO || tf->nsect != 1) | ||
2689 | goto invalid_fld; | ||
2690 | qc->sect_size = scmd->request_bufflen; | ||
2691 | } | ||
2692 | |||
2681 | /* | 2693 | /* |
2682 | * Filter SET_FEATURES - XFER MODE command -- otherwise, | 2694 | * Filter SET_FEATURES - XFER MODE command -- otherwise, |
2683 | * SET_FEATURES - XFER MODE must be preceded/succeeded | 2695 | * SET_FEATURES - XFER MODE must be preceded/succeeded |
@@ -2792,8 +2804,9 @@ static inline int __ata_scsi_queuecmd(struct scsi_cmnd *scmd, | |||
2792 | { | 2804 | { |
2793 | int rc = 0; | 2805 | int rc = 0; |
2794 | 2806 | ||
2795 | if (unlikely(!scmd->cmd_len)) { | 2807 | if (unlikely(!scmd->cmd_len || scmd->cmd_len > dev->cdb_len)) { |
2796 | ata_dev_printk(dev, KERN_WARNING, "WARNING: zero len CDB\n"); | 2808 | DPRINTK("bad CDB len=%u, max=%u\n", |
2809 | scmd->cmd_len, dev->cdb_len); | ||
2797 | scmd->result = DID_ERROR << 16; | 2810 | scmd->result = DID_ERROR << 16; |
2798 | done(scmd); | 2811 | done(scmd); |
2799 | return 0; | 2812 | return 0; |
@@ -2948,6 +2961,48 @@ void ata_scsi_simulate(struct ata_device *dev, struct scsi_cmnd *cmd, | |||
2948 | } | 2961 | } |
2949 | } | 2962 | } |
2950 | 2963 | ||
2964 | int ata_scsi_add_hosts(struct ata_host *host, struct scsi_host_template *sht) | ||
2965 | { | ||
2966 | int i, rc; | ||
2967 | |||
2968 | for (i = 0; i < host->n_ports; i++) { | ||
2969 | struct ata_port *ap = host->ports[i]; | ||
2970 | struct Scsi_Host *shost; | ||
2971 | |||
2972 | rc = -ENOMEM; | ||
2973 | shost = scsi_host_alloc(sht, sizeof(struct ata_port *)); | ||
2974 | if (!shost) | ||
2975 | goto err_alloc; | ||
2976 | |||
2977 | *(struct ata_port **)&shost->hostdata[0] = ap; | ||
2978 | ap->scsi_host = shost; | ||
2979 | |||
2980 | shost->transportt = &ata_scsi_transport_template; | ||
2981 | shost->unique_id = ap->print_id; | ||
2982 | shost->max_id = 16; | ||
2983 | shost->max_lun = 1; | ||
2984 | shost->max_channel = 1; | ||
2985 | shost->max_cmd_len = 16; | ||
2986 | |||
2987 | rc = scsi_add_host(ap->scsi_host, ap->host->dev); | ||
2988 | if (rc) | ||
2989 | goto err_add; | ||
2990 | } | ||
2991 | |||
2992 | return 0; | ||
2993 | |||
2994 | err_add: | ||
2995 | scsi_host_put(host->ports[i]->scsi_host); | ||
2996 | err_alloc: | ||
2997 | while (--i >= 0) { | ||
2998 | struct Scsi_Host *shost = host->ports[i]->scsi_host; | ||
2999 | |||
3000 | scsi_remove_host(shost); | ||
3001 | scsi_host_put(shost); | ||
3002 | } | ||
3003 | return rc; | ||
3004 | } | ||
3005 | |||
2951 | void ata_scsi_scan_host(struct ata_port *ap) | 3006 | void ata_scsi_scan_host(struct ata_port *ap) |
2952 | { | 3007 | { |
2953 | unsigned int i; | 3008 | unsigned int i; |
@@ -3224,21 +3279,21 @@ struct ata_port *ata_sas_port_alloc(struct ata_host *host, | |||
3224 | struct ata_port_info *port_info, | 3279 | struct ata_port_info *port_info, |
3225 | struct Scsi_Host *shost) | 3280 | struct Scsi_Host *shost) |
3226 | { | 3281 | { |
3227 | struct ata_port *ap = kzalloc(sizeof(*ap), GFP_KERNEL); | 3282 | struct ata_port *ap; |
3228 | struct ata_probe_ent *ent; | ||
3229 | 3283 | ||
3284 | ap = ata_port_alloc(host); | ||
3230 | if (!ap) | 3285 | if (!ap) |
3231 | return NULL; | 3286 | return NULL; |
3232 | 3287 | ||
3233 | ent = ata_probe_ent_alloc(host->dev, port_info); | 3288 | ap->port_no = 0; |
3234 | if (!ent) { | ||
3235 | kfree(ap); | ||
3236 | return NULL; | ||
3237 | } | ||
3238 | |||
3239 | ata_port_init(ap, host, ent, 0); | ||
3240 | ap->lock = shost->host_lock; | 3289 | ap->lock = shost->host_lock; |
3241 | devm_kfree(host->dev, ent); | 3290 | ap->pio_mask = port_info->pio_mask; |
3291 | ap->mwdma_mask = port_info->mwdma_mask; | ||
3292 | ap->udma_mask = port_info->udma_mask; | ||
3293 | ap->flags |= port_info->flags; | ||
3294 | ap->ops = port_info->port_ops; | ||
3295 | ap->cbl = ATA_CBL_SATA; | ||
3296 | |||
3242 | return ap; | 3297 | return ap; |
3243 | } | 3298 | } |
3244 | EXPORT_SYMBOL_GPL(ata_sas_port_alloc); | 3299 | EXPORT_SYMBOL_GPL(ata_sas_port_alloc); |
@@ -3294,8 +3349,10 @@ int ata_sas_port_init(struct ata_port *ap) | |||
3294 | { | 3349 | { |
3295 | int rc = ap->ops->port_start(ap); | 3350 | int rc = ap->ops->port_start(ap); |
3296 | 3351 | ||
3297 | if (!rc) | 3352 | if (!rc) { |
3353 | ap->print_id = ata_print_id++; | ||
3298 | rc = ata_bus_probe(ap); | 3354 | rc = ata_bus_probe(ap); |
3355 | } | ||
3299 | 3356 | ||
3300 | return rc; | 3357 | return rc; |
3301 | } | 3358 | } |
diff --git a/drivers/ata/libata-sff.c b/drivers/ata/libata-sff.c index 2ffcca063d8..8af18ad1ca7 100644 --- a/drivers/ata/libata-sff.c +++ b/drivers/ata/libata-sff.c | |||
@@ -526,168 +526,399 @@ static int ata_resources_present(struct pci_dev *pdev, int port) | |||
526 | port = port * 2; | 526 | port = port * 2; |
527 | for (i = 0; i < 2; i ++) { | 527 | for (i = 0; i < 2; i ++) { |
528 | if (pci_resource_start(pdev, port + i) == 0 || | 528 | if (pci_resource_start(pdev, port + i) == 0 || |
529 | pci_resource_len(pdev, port + i) == 0) | 529 | pci_resource_len(pdev, port + i) == 0) |
530 | return 0; | 530 | return 0; |
531 | } | 531 | } |
532 | return 1; | 532 | return 1; |
533 | } | 533 | } |
534 | 534 | ||
535 | /** | 535 | /** |
536 | * ata_pci_init_native_mode - Initialize native-mode driver | 536 | * ata_pci_init_bmdma - acquire PCI BMDMA resources and init ATA host |
537 | * @pdev: pci device to be initialized | 537 | * @host: target ATA host |
538 | * @port: array[2] of pointers to port info structures. | 538 | * |
539 | * @ports: bitmap of ports present | 539 | * Acquire PCI BMDMA resources and initialize @host accordingly. |
540 | * | 540 | * |
541 | * Utility function which allocates and initializes an | 541 | * LOCKING: |
542 | * ata_probe_ent structure for a standard dual-port | 542 | * Inherited from calling layer (may sleep). |
543 | * PIO-based IDE controller. The returned ata_probe_ent | 543 | * |
544 | * structure can be passed to ata_device_add(). The returned | 544 | * RETURNS: |
545 | * ata_probe_ent structure should then be freed with kfree(). | 545 | * 0 on success, -errno otherwise. |
546 | * | ||
547 | * The caller need only pass the address of the primary port, the | ||
548 | * secondary will be deduced automatically. If the device has non | ||
549 | * standard secondary port mappings this function can be called twice, | ||
550 | * once for each interface. | ||
551 | */ | 546 | */ |
547 | static int ata_pci_init_bmdma(struct ata_host *host) | ||
548 | { | ||
549 | struct device *gdev = host->dev; | ||
550 | struct pci_dev *pdev = to_pci_dev(gdev); | ||
551 | int i, rc; | ||
552 | |||
553 | /* TODO: If we get no DMA mask we should fall back to PIO */ | ||
554 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | ||
555 | if (rc) | ||
556 | return rc; | ||
557 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | ||
558 | if (rc) | ||
559 | return rc; | ||
560 | |||
561 | /* request and iomap DMA region */ | ||
562 | rc = pcim_iomap_regions(pdev, 1 << 4, DRV_NAME); | ||
563 | if (rc) { | ||
564 | dev_printk(KERN_ERR, gdev, "failed to request/iomap BAR4\n"); | ||
565 | return -ENOMEM; | ||
566 | } | ||
567 | host->iomap = pcim_iomap_table(pdev); | ||
568 | |||
569 | for (i = 0; i < 2; i++) { | ||
570 | struct ata_port *ap = host->ports[i]; | ||
571 | void __iomem *bmdma = host->iomap[4] + 8 * i; | ||
572 | |||
573 | if (ata_port_is_dummy(ap)) | ||
574 | continue; | ||
575 | |||
576 | ap->ioaddr.bmdma_addr = bmdma; | ||
577 | if ((!(ap->flags & ATA_FLAG_IGN_SIMPLEX)) && | ||
578 | (ioread8(bmdma + 2) & 0x80)) | ||
579 | host->flags |= ATA_HOST_SIMPLEX; | ||
580 | } | ||
581 | |||
582 | return 0; | ||
583 | } | ||
552 | 584 | ||
553 | struct ata_probe_ent * | 585 | /** |
554 | ata_pci_init_native_mode(struct pci_dev *pdev, struct ata_port_info **port, int ports) | 586 | * ata_pci_init_native_host - acquire native ATA resources and init host |
587 | * @host: target ATA host | ||
588 | * @port_mask: ports to consider | ||
589 | * | ||
590 | * Acquire native PCI ATA resources for @host and initialize | ||
591 | * @host accordoingly. | ||
592 | * | ||
593 | * LOCKING: | ||
594 | * Inherited from calling layer (may sleep). | ||
595 | * | ||
596 | * RETURNS: | ||
597 | * 0 on success, -errno otherwise. | ||
598 | */ | ||
599 | int ata_pci_init_native_host(struct ata_host *host, unsigned int port_mask) | ||
555 | { | 600 | { |
556 | struct ata_probe_ent *probe_ent; | 601 | struct device *gdev = host->dev; |
557 | int i, p = 0; | 602 | struct pci_dev *pdev = to_pci_dev(gdev); |
558 | void __iomem * const *iomap; | 603 | int i, rc; |
559 | 604 | ||
560 | /* iomap BARs */ | 605 | /* Discard disabled ports. Some controllers show their unused |
561 | for (i = 0; i < 4; i++) { | 606 | * channels this way. Disabled ports are made dummy. |
562 | if (pcim_iomap(pdev, i, 0) == NULL) { | 607 | */ |
563 | dev_printk(KERN_ERR, &pdev->dev, | 608 | for (i = 0; i < 2; i++) { |
564 | "failed to iomap PCI BAR %d\n", i); | 609 | if ((port_mask & (1 << i)) && !ata_resources_present(pdev, i)) { |
565 | return NULL; | 610 | host->ports[i]->ops = &ata_dummy_port_ops; |
611 | port_mask &= ~(1 << i); | ||
566 | } | 612 | } |
567 | } | 613 | } |
568 | 614 | ||
569 | pcim_iomap(pdev, 4, 0); /* may fail */ | 615 | if (!port_mask) { |
570 | iomap = pcim_iomap_table(pdev); | 616 | dev_printk(KERN_ERR, gdev, "no available port\n"); |
571 | 617 | return -ENODEV; | |
572 | /* alloc and init probe_ent */ | ||
573 | probe_ent = ata_probe_ent_alloc(pci_dev_to_dev(pdev), port[0]); | ||
574 | if (!probe_ent) | ||
575 | return NULL; | ||
576 | |||
577 | probe_ent->irq = pdev->irq; | ||
578 | probe_ent->irq_flags = IRQF_SHARED; | ||
579 | |||
580 | /* Discard disabled ports. Some controllers show their | ||
581 | unused channels this way */ | ||
582 | if (ata_resources_present(pdev, 0) == 0) | ||
583 | ports &= ~ATA_PORT_PRIMARY; | ||
584 | if (ata_resources_present(pdev, 1) == 0) | ||
585 | ports &= ~ATA_PORT_SECONDARY; | ||
586 | |||
587 | if (ports & ATA_PORT_PRIMARY) { | ||
588 | probe_ent->port[p].cmd_addr = iomap[0]; | ||
589 | probe_ent->port[p].altstatus_addr = | ||
590 | probe_ent->port[p].ctl_addr = (void __iomem *) | ||
591 | ((unsigned long)iomap[1] | ATA_PCI_CTL_OFS); | ||
592 | if (iomap[4]) { | ||
593 | if ((!(port[p]->flags & ATA_FLAG_IGN_SIMPLEX)) && | ||
594 | (ioread8(iomap[4] + 2) & 0x80)) | ||
595 | probe_ent->_host_flags |= ATA_HOST_SIMPLEX; | ||
596 | probe_ent->port[p].bmdma_addr = iomap[4]; | ||
597 | } | ||
598 | ata_std_ports(&probe_ent->port[p]); | ||
599 | p++; | ||
600 | } | 618 | } |
601 | 619 | ||
602 | if (ports & ATA_PORT_SECONDARY) { | 620 | /* request, iomap BARs and init port addresses accordingly */ |
603 | probe_ent->port[p].cmd_addr = iomap[2]; | 621 | for (i = 0; i < 2; i++) { |
604 | probe_ent->port[p].altstatus_addr = | 622 | struct ata_port *ap = host->ports[i]; |
605 | probe_ent->port[p].ctl_addr = (void __iomem *) | 623 | int base = i * 2; |
606 | ((unsigned long)iomap[3] | ATA_PCI_CTL_OFS); | 624 | void __iomem * const *iomap; |
607 | if (iomap[4]) { | 625 | |
608 | if ((!(port[p]->flags & ATA_FLAG_IGN_SIMPLEX)) && | 626 | if (!(port_mask & (1 << i))) |
609 | (ioread8(iomap[4] + 10) & 0x80)) | 627 | continue; |
610 | probe_ent->_host_flags |= ATA_HOST_SIMPLEX; | 628 | |
611 | probe_ent->port[p].bmdma_addr = iomap[4] + 8; | 629 | rc = pcim_iomap_regions(pdev, 0x3 << base, DRV_NAME); |
630 | if (rc) { | ||
631 | dev_printk(KERN_ERR, gdev, "failed to request/iomap " | ||
632 | "BARs for port %d (errno=%d)\n", i, rc); | ||
633 | if (rc == -EBUSY) | ||
634 | pcim_pin_device(pdev); | ||
635 | return rc; | ||
612 | } | 636 | } |
613 | ata_std_ports(&probe_ent->port[p]); | 637 | host->iomap = iomap = pcim_iomap_table(pdev); |
614 | probe_ent->pinfo2 = port[1]; | 638 | |
615 | p++; | 639 | ap->ioaddr.cmd_addr = iomap[base]; |
640 | ap->ioaddr.altstatus_addr = | ||
641 | ap->ioaddr.ctl_addr = (void __iomem *) | ||
642 | ((unsigned long)iomap[base + 1] | ATA_PCI_CTL_OFS); | ||
643 | ata_std_ports(&ap->ioaddr); | ||
616 | } | 644 | } |
617 | 645 | ||
618 | probe_ent->n_ports = p; | 646 | return 0; |
619 | return probe_ent; | ||
620 | } | 647 | } |
621 | 648 | ||
622 | static struct ata_probe_ent *ata_pci_init_legacy_port(struct pci_dev *pdev, | 649 | /** |
623 | struct ata_port_info **port, int port_mask) | 650 | * ata_pci_prepare_native_host - helper to prepare native PCI ATA host |
651 | * @pdev: target PCI device | ||
652 | * @ppi: array of port_info | ||
653 | * @n_ports: number of ports to allocate | ||
654 | * @r_host: out argument for the initialized ATA host | ||
655 | * | ||
656 | * Helper to allocate ATA host for @pdev, acquire all native PCI | ||
657 | * resources and initialize it accordingly in one go. | ||
658 | * | ||
659 | * LOCKING: | ||
660 | * Inherited from calling layer (may sleep). | ||
661 | * | ||
662 | * RETURNS: | ||
663 | * 0 on success, -errno otherwise. | ||
664 | */ | ||
665 | int ata_pci_prepare_native_host(struct pci_dev *pdev, | ||
666 | const struct ata_port_info * const * ppi, | ||
667 | int n_ports, struct ata_host **r_host) | ||
668 | { | ||
669 | struct ata_host *host; | ||
670 | unsigned int port_mask; | ||
671 | int rc; | ||
672 | |||
673 | if (!devres_open_group(&pdev->dev, NULL, GFP_KERNEL)) | ||
674 | return -ENOMEM; | ||
675 | |||
676 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, 2); | ||
677 | if (!host) { | ||
678 | dev_printk(KERN_ERR, &pdev->dev, | ||
679 | "failed to allocate ATA host\n"); | ||
680 | rc = -ENOMEM; | ||
681 | goto err_out; | ||
682 | } | ||
683 | |||
684 | port_mask = ATA_PORT_PRIMARY; | ||
685 | if (n_ports > 1) | ||
686 | port_mask |= ATA_PORT_SECONDARY; | ||
687 | |||
688 | rc = ata_pci_init_native_host(host, port_mask); | ||
689 | if (rc) | ||
690 | goto err_out; | ||
691 | |||
692 | /* init DMA related stuff */ | ||
693 | rc = ata_pci_init_bmdma(host); | ||
694 | if (rc) | ||
695 | goto err_bmdma; | ||
696 | |||
697 | devres_remove_group(&pdev->dev, NULL); | ||
698 | *r_host = host; | ||
699 | return 0; | ||
700 | |||
701 | err_bmdma: | ||
702 | /* This is necessary because PCI and iomap resources are | ||
703 | * merged and releasing the top group won't release the | ||
704 | * acquired resources if some of those have been acquired | ||
705 | * before entering this function. | ||
706 | */ | ||
707 | pcim_iounmap_regions(pdev, 0xf); | ||
708 | err_out: | ||
709 | devres_release_group(&pdev->dev, NULL); | ||
710 | return rc; | ||
711 | } | ||
712 | |||
713 | struct ata_legacy_devres { | ||
714 | unsigned int mask; | ||
715 | unsigned long cmd_port[2]; | ||
716 | void __iomem * cmd_addr[2]; | ||
717 | void __iomem * ctl_addr[2]; | ||
718 | unsigned int irq[2]; | ||
719 | void * irq_dev_id[2]; | ||
720 | }; | ||
721 | |||
722 | static void ata_legacy_free_irqs(struct ata_legacy_devres *legacy_dr) | ||
624 | { | 723 | { |
625 | struct ata_probe_ent *probe_ent; | 724 | int i; |
626 | void __iomem *iomap[5] = { }, *bmdma; | 725 | |
627 | 726 | for (i = 0; i < 2; i++) { | |
628 | if (port_mask & ATA_PORT_PRIMARY) { | 727 | if (!legacy_dr->irq[i]) |
629 | iomap[0] = devm_ioport_map(&pdev->dev, ATA_PRIMARY_CMD, 8); | 728 | continue; |
630 | iomap[1] = devm_ioport_map(&pdev->dev, ATA_PRIMARY_CTL, 1); | 729 | |
631 | if (!iomap[0] || !iomap[1]) | 730 | free_irq(legacy_dr->irq[i], legacy_dr->irq_dev_id[i]); |
632 | return NULL; | 731 | legacy_dr->irq[i] = 0; |
732 | legacy_dr->irq_dev_id[i] = NULL; | ||
633 | } | 733 | } |
734 | } | ||
735 | |||
736 | static void ata_legacy_release(struct device *gdev, void *res) | ||
737 | { | ||
738 | struct ata_legacy_devres *this = res; | ||
739 | int i; | ||
634 | 740 | ||
635 | if (port_mask & ATA_PORT_SECONDARY) { | 741 | ata_legacy_free_irqs(this); |
636 | iomap[2] = devm_ioport_map(&pdev->dev, ATA_SECONDARY_CMD, 8); | 742 | |
637 | iomap[3] = devm_ioport_map(&pdev->dev, ATA_SECONDARY_CTL, 1); | 743 | for (i = 0; i < 2; i++) { |
638 | if (!iomap[2] || !iomap[3]) | 744 | if (this->cmd_addr[i]) |
639 | return NULL; | 745 | ioport_unmap(this->cmd_addr[i]); |
746 | if (this->ctl_addr[i]) | ||
747 | ioport_unmap(this->ctl_addr[i]); | ||
748 | if (this->cmd_port[i]) | ||
749 | release_region(this->cmd_port[i], 8); | ||
640 | } | 750 | } |
751 | } | ||
641 | 752 | ||
642 | bmdma = pcim_iomap(pdev, 4, 16); /* may fail */ | 753 | static int ata_init_legacy_port(struct ata_port *ap, |
643 | 754 | struct ata_legacy_devres *legacy_dr) | |
644 | /* alloc and init probe_ent */ | 755 | { |
645 | probe_ent = ata_probe_ent_alloc(pci_dev_to_dev(pdev), port[0]); | 756 | struct ata_host *host = ap->host; |
646 | if (!probe_ent) | 757 | int port_no = ap->port_no; |
647 | return NULL; | 758 | unsigned long cmd_port, ctl_port; |
648 | 759 | ||
649 | probe_ent->n_ports = 2; | 760 | if (port_no == 0) { |
650 | probe_ent->irq_flags = IRQF_SHARED; | 761 | cmd_port = ATA_PRIMARY_CMD; |
651 | 762 | ctl_port = ATA_PRIMARY_CTL; | |
652 | if (port_mask & ATA_PORT_PRIMARY) { | 763 | } else { |
653 | probe_ent->irq = ATA_PRIMARY_IRQ(pdev); | 764 | cmd_port = ATA_SECONDARY_CMD; |
654 | probe_ent->port[0].cmd_addr = iomap[0]; | 765 | ctl_port = ATA_SECONDARY_CTL; |
655 | probe_ent->port[0].altstatus_addr = | 766 | } |
656 | probe_ent->port[0].ctl_addr = iomap[1]; | ||
657 | if (bmdma) { | ||
658 | probe_ent->port[0].bmdma_addr = bmdma; | ||
659 | if ((!(port[0]->flags & ATA_FLAG_IGN_SIMPLEX)) && | ||
660 | (ioread8(bmdma + 2) & 0x80)) | ||
661 | probe_ent->_host_flags |= ATA_HOST_SIMPLEX; | ||
662 | } | ||
663 | ata_std_ports(&probe_ent->port[0]); | ||
664 | } else | ||
665 | probe_ent->dummy_port_mask |= ATA_PORT_PRIMARY; | ||
666 | 767 | ||
667 | if (port_mask & ATA_PORT_SECONDARY) { | 768 | /* request cmd_port */ |
668 | if (probe_ent->irq) | 769 | if (request_region(cmd_port, 8, "libata")) |
669 | probe_ent->irq2 = ATA_SECONDARY_IRQ(pdev); | 770 | legacy_dr->cmd_port[port_no] = cmd_port; |
771 | else { | ||
772 | dev_printk(KERN_WARNING, host->dev, | ||
773 | "0x%0lX IDE port busy\n", cmd_port); | ||
774 | return -EBUSY; | ||
775 | } | ||
776 | |||
777 | /* iomap cmd and ctl ports */ | ||
778 | legacy_dr->cmd_addr[port_no] = ioport_map(cmd_port, 8); | ||
779 | legacy_dr->ctl_addr[port_no] = ioport_map(ctl_port, 1); | ||
780 | if (!legacy_dr->cmd_addr[port_no] || !legacy_dr->ctl_addr[port_no]) | ||
781 | return -ENOMEM; | ||
782 | |||
783 | /* init IO addresses */ | ||
784 | ap->ioaddr.cmd_addr = legacy_dr->cmd_addr[port_no]; | ||
785 | ap->ioaddr.altstatus_addr = legacy_dr->ctl_addr[port_no]; | ||
786 | ap->ioaddr.ctl_addr = legacy_dr->ctl_addr[port_no]; | ||
787 | ata_std_ports(&ap->ioaddr); | ||
788 | |||
789 | return 0; | ||
790 | } | ||
791 | |||
792 | /** | ||
793 | * ata_init_legacy_host - acquire legacy ATA resources and init ATA host | ||
794 | * @host: target ATA host | ||
795 | * @legacy_mask: out parameter, mask indicating ports is in legacy mode | ||
796 | * @was_busy: out parameter, indicates whether any port was busy | ||
797 | * | ||
798 | * Acquire legacy ATA resources for ports. | ||
799 | * | ||
800 | * LOCKING: | ||
801 | * Inherited from calling layer (may sleep). | ||
802 | * | ||
803 | * RETURNS: | ||
804 | * 0 on success, -errno otherwise. | ||
805 | */ | ||
806 | static int ata_init_legacy_host(struct ata_host *host, | ||
807 | unsigned int *legacy_mask, int *was_busy) | ||
808 | { | ||
809 | struct device *gdev = host->dev; | ||
810 | struct ata_legacy_devres *legacy_dr; | ||
811 | int i, rc; | ||
812 | |||
813 | if (!devres_open_group(gdev, NULL, GFP_KERNEL)) | ||
814 | return -ENOMEM; | ||
815 | |||
816 | rc = -ENOMEM; | ||
817 | legacy_dr = devres_alloc(ata_legacy_release, sizeof(*legacy_dr), | ||
818 | GFP_KERNEL); | ||
819 | if (!legacy_dr) | ||
820 | goto err_out; | ||
821 | devres_add(gdev, legacy_dr); | ||
822 | |||
823 | for (i = 0; i < 2; i++) { | ||
824 | *legacy_mask &= ~(1 << i); | ||
825 | rc = ata_init_legacy_port(host->ports[i], legacy_dr); | ||
826 | if (rc == 0) | ||
827 | legacy_dr->mask |= 1 << i; | ||
828 | else if (rc == -EBUSY) | ||
829 | (*was_busy)++; | ||
830 | } | ||
831 | |||
832 | if (!legacy_dr->mask) | ||
833 | return -EBUSY; | ||
834 | |||
835 | for (i = 0; i < 2; i++) | ||
836 | if (!(legacy_dr->mask & (1 << i))) | ||
837 | host->ports[i]->ops = &ata_dummy_port_ops; | ||
838 | |||
839 | *legacy_mask |= legacy_dr->mask; | ||
840 | |||
841 | devres_remove_group(gdev, NULL); | ||
842 | return 0; | ||
843 | |||
844 | err_out: | ||
845 | devres_release_group(gdev, NULL); | ||
846 | return rc; | ||
847 | } | ||
848 | |||
849 | /** | ||
850 | * ata_request_legacy_irqs - request legacy ATA IRQs | ||
851 | * @host: target ATA host | ||
852 | * @handler: array of IRQ handlers | ||
853 | * @irq_flags: array of IRQ flags | ||
854 | * @dev_id: array of IRQ dev_ids | ||
855 | * | ||
856 | * Request legacy IRQs for non-dummy legacy ports in @host. All | ||
857 | * IRQ parameters are passed as array to allow ports to have | ||
858 | * separate IRQ handlers. | ||
859 | * | ||
860 | * LOCKING: | ||
861 | * Inherited from calling layer (may sleep). | ||
862 | * | ||
863 | * RETURNS: | ||
864 | * 0 on success, -errno otherwise. | ||
865 | */ | ||
866 | static int ata_request_legacy_irqs(struct ata_host *host, | ||
867 | irq_handler_t const *handler, | ||
868 | const unsigned int *irq_flags, | ||
869 | void * const *dev_id) | ||
870 | { | ||
871 | struct device *gdev = host->dev; | ||
872 | struct ata_legacy_devres *legacy_dr; | ||
873 | int i, rc; | ||
874 | |||
875 | legacy_dr = devres_find(host->dev, ata_legacy_release, NULL, NULL); | ||
876 | BUG_ON(!legacy_dr); | ||
877 | |||
878 | for (i = 0; i < 2; i++) { | ||
879 | unsigned int irq; | ||
880 | |||
881 | /* FIXME: ATA_*_IRQ() should take generic device not pci_dev */ | ||
882 | if (i == 0) | ||
883 | irq = ATA_PRIMARY_IRQ(to_pci_dev(gdev)); | ||
670 | else | 884 | else |
671 | probe_ent->irq = ATA_SECONDARY_IRQ(pdev); | 885 | irq = ATA_SECONDARY_IRQ(to_pci_dev(gdev)); |
672 | probe_ent->port[1].cmd_addr = iomap[2]; | 886 | |
673 | probe_ent->port[1].altstatus_addr = | 887 | if (!(legacy_dr->mask & (1 << i))) |
674 | probe_ent->port[1].ctl_addr = iomap[3]; | 888 | continue; |
675 | if (bmdma) { | 889 | |
676 | probe_ent->port[1].bmdma_addr = bmdma + 8; | 890 | if (!handler[i]) { |
677 | if ((!(port[1]->flags & ATA_FLAG_IGN_SIMPLEX)) && | 891 | dev_printk(KERN_ERR, gdev, |
678 | (ioread8(bmdma + 10) & 0x80)) | 892 | "NULL handler specified for port %d\n", i); |
679 | probe_ent->_host_flags |= ATA_HOST_SIMPLEX; | 893 | rc = -EINVAL; |
894 | goto err_out; | ||
895 | } | ||
896 | |||
897 | rc = request_irq(irq, handler[i], irq_flags[i], DRV_NAME, | ||
898 | dev_id[i]); | ||
899 | if (rc) { | ||
900 | dev_printk(KERN_ERR, gdev, | ||
901 | "irq %u request failed (errno=%d)\n", irq, rc); | ||
902 | goto err_out; | ||
680 | } | 903 | } |
681 | ata_std_ports(&probe_ent->port[1]); | ||
682 | 904 | ||
683 | /* FIXME: could be pointing to stack area; must copy */ | 905 | /* record irq allocation in legacy_dr */ |
684 | probe_ent->pinfo2 = port[1]; | 906 | legacy_dr->irq[i] = irq; |
685 | } else | 907 | legacy_dr->irq_dev_id[i] = dev_id[i]; |
686 | probe_ent->dummy_port_mask |= ATA_PORT_SECONDARY; | ||
687 | 908 | ||
688 | return probe_ent; | 909 | /* only used to print info */ |
689 | } | 910 | if (i == 0) |
911 | host->irq = irq; | ||
912 | else | ||
913 | host->irq2 = irq; | ||
914 | } | ||
690 | 915 | ||
916 | return 0; | ||
917 | |||
918 | err_out: | ||
919 | ata_legacy_free_irqs(legacy_dr); | ||
920 | return rc; | ||
921 | } | ||
691 | 922 | ||
692 | /** | 923 | /** |
693 | * ata_pci_init_one - Initialize/register PCI IDE host controller | 924 | * ata_pci_init_one - Initialize/register PCI IDE host controller |
@@ -718,8 +949,8 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info, | |||
718 | unsigned int n_ports) | 949 | unsigned int n_ports) |
719 | { | 950 | { |
720 | struct device *dev = &pdev->dev; | 951 | struct device *dev = &pdev->dev; |
721 | struct ata_probe_ent *probe_ent = NULL; | 952 | struct ata_host *host = NULL; |
722 | struct ata_port_info *port[2]; | 953 | const struct ata_port_info *port[2]; |
723 | u8 mask; | 954 | u8 mask; |
724 | unsigned int legacy_mode = 0; | 955 | unsigned int legacy_mode = 0; |
725 | int rc; | 956 | int rc; |
@@ -743,7 +974,7 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info, | |||
743 | 974 | ||
744 | Checking dev->is_enabled is insufficient as this is not set at | 975 | Checking dev->is_enabled is insufficient as this is not set at |
745 | boot for the primary video which is BIOS enabled | 976 | boot for the primary video which is BIOS enabled |
746 | */ | 977 | */ |
747 | 978 | ||
748 | rc = pcim_enable_device(pdev); | 979 | rc = pcim_enable_device(pdev); |
749 | if (rc) | 980 | if (rc) |
@@ -769,96 +1000,68 @@ int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_info, | |||
769 | #endif | 1000 | #endif |
770 | } | 1001 | } |
771 | 1002 | ||
1003 | /* alloc and init host */ | ||
1004 | host = ata_host_alloc_pinfo(dev, port, 2); | ||
1005 | if (!host) { | ||
1006 | dev_printk(KERN_ERR, &pdev->dev, | ||
1007 | "failed to allocate ATA host\n"); | ||
1008 | rc = -ENOMEM; | ||
1009 | goto err_out; | ||
1010 | } | ||
1011 | |||
772 | if (!legacy_mode) { | 1012 | if (!legacy_mode) { |
773 | rc = pci_request_regions(pdev, DRV_NAME); | 1013 | unsigned int port_mask; |
774 | if (rc) { | 1014 | |
775 | pcim_pin_device(pdev); | 1015 | port_mask = ATA_PORT_PRIMARY; |
1016 | if (n_ports > 1) | ||
1017 | port_mask |= ATA_PORT_SECONDARY; | ||
1018 | |||
1019 | rc = ata_pci_init_native_host(host, port_mask); | ||
1020 | if (rc) | ||
776 | goto err_out; | 1021 | goto err_out; |
777 | } | ||
778 | } else { | 1022 | } else { |
779 | /* Deal with combined mode hack. This side of the logic all | 1023 | int was_busy = 0; |
780 | goes away once the combined mode hack is killed in 2.6.21 */ | ||
781 | if (!devm_request_region(dev, ATA_PRIMARY_CMD, 8, "libata")) { | ||
782 | struct resource *conflict, res; | ||
783 | res.start = ATA_PRIMARY_CMD; | ||
784 | res.end = ATA_PRIMARY_CMD + 8 - 1; | ||
785 | conflict = ____request_resource(&ioport_resource, &res); | ||
786 | while (conflict->child) | ||
787 | conflict = ____request_resource(conflict, &res); | ||
788 | if (!strcmp(conflict->name, "libata")) | ||
789 | legacy_mode |= ATA_PORT_PRIMARY; | ||
790 | else { | ||
791 | pcim_pin_device(pdev); | ||
792 | printk(KERN_WARNING "ata: 0x%0X IDE port busy\n" \ | ||
793 | "ata: conflict with %s\n", | ||
794 | ATA_PRIMARY_CMD, | ||
795 | conflict->name); | ||
796 | } | ||
797 | } else | ||
798 | legacy_mode |= ATA_PORT_PRIMARY; | ||
799 | |||
800 | if (!devm_request_region(dev, ATA_SECONDARY_CMD, 8, "libata")) { | ||
801 | struct resource *conflict, res; | ||
802 | res.start = ATA_SECONDARY_CMD; | ||
803 | res.end = ATA_SECONDARY_CMD + 8 - 1; | ||
804 | conflict = ____request_resource(&ioport_resource, &res); | ||
805 | while (conflict->child) | ||
806 | conflict = ____request_resource(conflict, &res); | ||
807 | if (!strcmp(conflict->name, "libata")) | ||
808 | legacy_mode |= ATA_PORT_SECONDARY; | ||
809 | else { | ||
810 | pcim_pin_device(pdev); | ||
811 | printk(KERN_WARNING "ata: 0x%X IDE port busy\n" \ | ||
812 | "ata: conflict with %s\n", | ||
813 | ATA_SECONDARY_CMD, | ||
814 | conflict->name); | ||
815 | } | ||
816 | } else | ||
817 | legacy_mode |= ATA_PORT_SECONDARY; | ||
818 | |||
819 | if (legacy_mode & ATA_PORT_PRIMARY) | ||
820 | pci_request_region(pdev, 1, DRV_NAME); | ||
821 | if (legacy_mode & ATA_PORT_SECONDARY) | ||
822 | pci_request_region(pdev, 3, DRV_NAME); | ||
823 | /* If there is a DMA resource, allocate it */ | ||
824 | pci_request_region(pdev, 4, DRV_NAME); | ||
825 | } | ||
826 | 1024 | ||
827 | /* we have legacy mode, but all ports are unavailable */ | 1025 | rc = ata_init_legacy_host(host, &legacy_mode, &was_busy); |
828 | if (legacy_mode == (1 << 3)) { | 1026 | if (was_busy) |
829 | rc = -EBUSY; | 1027 | pcim_pin_device(pdev); |
830 | goto err_out; | 1028 | if (rc) |
1029 | goto err_out; | ||
1030 | |||
1031 | /* request respective PCI regions, may fail */ | ||
1032 | rc = pci_request_region(pdev, 1, DRV_NAME); | ||
1033 | rc = pci_request_region(pdev, 3, DRV_NAME); | ||
831 | } | 1034 | } |
832 | 1035 | ||
833 | /* TODO: If we get no DMA mask we should fall back to PIO */ | 1036 | /* init BMDMA, may fail */ |
834 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | 1037 | ata_pci_init_bmdma(host); |
835 | if (rc) | 1038 | pci_set_master(pdev); |
836 | goto err_out; | 1039 | |
837 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | 1040 | /* start host and request IRQ */ |
1041 | rc = ata_host_start(host); | ||
838 | if (rc) | 1042 | if (rc) |
839 | goto err_out; | 1043 | goto err_out; |
840 | 1044 | ||
841 | if (legacy_mode) { | 1045 | if (!legacy_mode) |
842 | probe_ent = ata_pci_init_legacy_port(pdev, port, legacy_mode); | 1046 | rc = devm_request_irq(dev, pdev->irq, |
843 | } else { | 1047 | port_info[0]->port_ops->irq_handler, |
844 | if (n_ports == 2) | 1048 | IRQF_SHARED, DRV_NAME, host); |
845 | probe_ent = ata_pci_init_native_mode(pdev, port, ATA_PORT_PRIMARY | ATA_PORT_SECONDARY); | 1049 | else { |
846 | else | 1050 | irq_handler_t handler[2] = { host->ops->irq_handler, |
847 | probe_ent = ata_pci_init_native_mode(pdev, port, ATA_PORT_PRIMARY); | 1051 | host->ops->irq_handler }; |
1052 | unsigned int irq_flags[2] = { IRQF_SHARED, IRQF_SHARED }; | ||
1053 | void *dev_id[2] = { host, host }; | ||
1054 | |||
1055 | rc = ata_request_legacy_irqs(host, handler, irq_flags, dev_id); | ||
848 | } | 1056 | } |
849 | if (!probe_ent) { | 1057 | if (rc) |
850 | rc = -ENOMEM; | ||
851 | goto err_out; | 1058 | goto err_out; |
852 | } | ||
853 | |||
854 | pci_set_master(pdev); | ||
855 | 1059 | ||
856 | if (!ata_device_add(probe_ent)) { | 1060 | /* register */ |
857 | rc = -ENODEV; | 1061 | rc = ata_host_register(host, port_info[0]->sht); |
1062 | if (rc) | ||
858 | goto err_out; | 1063 | goto err_out; |
859 | } | ||
860 | 1064 | ||
861 | devm_kfree(dev, probe_ent); | ||
862 | devres_remove_group(dev, NULL); | 1065 | devres_remove_group(dev, NULL); |
863 | return 0; | 1066 | return 0; |
864 | 1067 | ||
@@ -893,12 +1096,12 @@ int ata_pci_clear_simplex(struct pci_dev *pdev) | |||
893 | return 0; | 1096 | return 0; |
894 | } | 1097 | } |
895 | 1098 | ||
896 | unsigned long ata_pci_default_filter(const struct ata_port *ap, struct ata_device *adev, unsigned long xfer_mask) | 1099 | unsigned long ata_pci_default_filter(struct ata_device *adev, unsigned long xfer_mask) |
897 | { | 1100 | { |
898 | /* Filter out DMA modes if the device has been configured by | 1101 | /* Filter out DMA modes if the device has been configured by |
899 | the BIOS as PIO only */ | 1102 | the BIOS as PIO only */ |
900 | 1103 | ||
901 | if (ap->ioaddr.bmdma_addr == 0) | 1104 | if (adev->ap->ioaddr.bmdma_addr == 0) |
902 | xfer_mask &= ~(ATA_MASK_MWDMA | ATA_MASK_UDMA); | 1105 | xfer_mask &= ~(ATA_MASK_MWDMA | ATA_MASK_UDMA); |
903 | return xfer_mask; | 1106 | return xfer_mask; |
904 | } | 1107 | } |
diff --git a/drivers/ata/libata.h b/drivers/ata/libata.h index 1f1e3a51f85..5f4d40cd328 100644 --- a/drivers/ata/libata.h +++ b/drivers/ata/libata.h | |||
@@ -52,6 +52,7 @@ enum { | |||
52 | ATA_DNXFER_QUIET = (1 << 31), | 52 | ATA_DNXFER_QUIET = (1 << 31), |
53 | }; | 53 | }; |
54 | 54 | ||
55 | extern unsigned int ata_print_id; | ||
55 | extern struct workqueue_struct *ata_aux_wq; | 56 | extern struct workqueue_struct *ata_aux_wq; |
56 | extern int atapi_enabled; | 57 | extern int atapi_enabled; |
57 | extern int atapi_dmadir; | 58 | extern int atapi_dmadir; |
@@ -92,10 +93,7 @@ extern int ata_flush_cache(struct ata_device *dev); | |||
92 | extern void ata_dev_init(struct ata_device *dev); | 93 | extern void ata_dev_init(struct ata_device *dev); |
93 | extern int ata_task_ioctl(struct scsi_device *scsidev, void __user *arg); | 94 | extern int ata_task_ioctl(struct scsi_device *scsidev, void __user *arg); |
94 | extern int ata_cmd_ioctl(struct scsi_device *scsidev, void __user *arg); | 95 | extern int ata_cmd_ioctl(struct scsi_device *scsidev, void __user *arg); |
95 | extern void ata_port_init(struct ata_port *ap, struct ata_host *host, | 96 | extern struct ata_port *ata_port_alloc(struct ata_host *host); |
96 | const struct ata_probe_ent *ent, unsigned int port_no); | ||
97 | extern struct ata_probe_ent *ata_probe_ent_alloc(struct device *dev, | ||
98 | const struct ata_port_info *port); | ||
99 | 97 | ||
100 | /* libata-acpi.c */ | 98 | /* libata-acpi.c */ |
101 | #ifdef CONFIG_SATA_ACPI | 99 | #ifdef CONFIG_SATA_ACPI |
@@ -113,8 +111,8 @@ static inline int ata_acpi_push_id(struct ata_port *ap, unsigned int ix) | |||
113 | #endif | 111 | #endif |
114 | 112 | ||
115 | /* libata-scsi.c */ | 113 | /* libata-scsi.c */ |
116 | extern struct scsi_transport_template ata_scsi_transport_template; | 114 | extern int ata_scsi_add_hosts(struct ata_host *host, |
117 | 115 | struct scsi_host_template *sht); | |
118 | extern void ata_scsi_scan_host(struct ata_port *ap); | 116 | extern void ata_scsi_scan_host(struct ata_port *ap); |
119 | extern int ata_scsi_offline_dev(struct ata_device *dev); | 117 | extern int ata_scsi_offline_dev(struct ata_device *dev); |
120 | extern void ata_scsi_hotplug(struct work_struct *work); | 118 | extern void ata_scsi_hotplug(struct work_struct *work); |
diff --git a/drivers/ata/pata_ali.c b/drivers/ata/pata_ali.c index 11ea552a58c..d40edebb510 100644 --- a/drivers/ata/pata_ali.c +++ b/drivers/ata/pata_ali.c | |||
@@ -34,7 +34,7 @@ | |||
34 | #include <linux/dmi.h> | 34 | #include <linux/dmi.h> |
35 | 35 | ||
36 | #define DRV_NAME "pata_ali" | 36 | #define DRV_NAME "pata_ali" |
37 | #define DRV_VERSION "0.7.3" | 37 | #define DRV_VERSION "0.7.4" |
38 | 38 | ||
39 | /* | 39 | /* |
40 | * Cable special cases | 40 | * Cable special cases |
@@ -90,59 +90,6 @@ static int ali_c2_cable_detect(struct ata_port *ap) | |||
90 | } | 90 | } |
91 | 91 | ||
92 | /** | 92 | /** |
93 | * ali_early_error_handler - reset for eary chip | ||
94 | * @ap: ATA port | ||
95 | * | ||
96 | * Handle the reset callback for the later chips with cable detect | ||
97 | */ | ||
98 | |||
99 | static int ali_c2_pre_reset(struct ata_port *ap) | ||
100 | { | ||
101 | ap->cbl = ali_c2_cable_detect(ap); | ||
102 | return ata_std_prereset(ap); | ||
103 | } | ||
104 | |||
105 | static void ali_c2_error_handler(struct ata_port *ap) | ||
106 | { | ||
107 | ata_bmdma_drive_eh(ap, ali_c2_pre_reset, | ||
108 | ata_std_softreset, NULL, | ||
109 | ata_std_postreset); | ||
110 | } | ||
111 | |||
112 | /** | ||
113 | * ali_early_cable_detect - cable detection | ||
114 | * @ap: ATA port | ||
115 | * | ||
116 | * Perform cable detection for older chipsets. This turns out to be | ||
117 | * rather easy to implement | ||
118 | */ | ||
119 | |||
120 | static int ali_early_cable_detect(struct ata_port *ap) | ||
121 | { | ||
122 | return ATA_CBL_PATA40; | ||
123 | } | ||
124 | |||
125 | /** | ||
126 | * ali_early_probe_init - reset for early chip | ||
127 | * @ap: ATA port | ||
128 | * | ||
129 | * Handle the reset callback for the early (pre cable detect) chips. | ||
130 | */ | ||
131 | |||
132 | static int ali_early_pre_reset(struct ata_port *ap) | ||
133 | { | ||
134 | ap->cbl = ali_early_cable_detect(ap); | ||
135 | return ata_std_prereset(ap); | ||
136 | } | ||
137 | |||
138 | static void ali_early_error_handler(struct ata_port *ap) | ||
139 | { | ||
140 | return ata_bmdma_drive_eh(ap, ali_early_pre_reset, | ||
141 | ata_std_softreset, NULL, | ||
142 | ata_std_postreset); | ||
143 | } | ||
144 | |||
145 | /** | ||
146 | * ali_20_filter - filter for earlier ALI DMA | 93 | * ali_20_filter - filter for earlier ALI DMA |
147 | * @ap: ALi ATA port | 94 | * @ap: ALi ATA port |
148 | * @adev: attached device | 95 | * @adev: attached device |
@@ -151,7 +98,7 @@ static void ali_early_error_handler(struct ata_port *ap) | |||
151 | * fix that later on. Also ensure we do not do UDMA on WDC drives | 98 | * fix that later on. Also ensure we do not do UDMA on WDC drives |
152 | */ | 99 | */ |
153 | 100 | ||
154 | static unsigned long ali_20_filter(const struct ata_port *ap, struct ata_device *adev, unsigned long mask) | 101 | static unsigned long ali_20_filter(struct ata_device *adev, unsigned long mask) |
155 | { | 102 | { |
156 | char model_num[ATA_ID_PROD_LEN + 1]; | 103 | char model_num[ATA_ID_PROD_LEN + 1]; |
157 | /* No DMA on anything but a disk for now */ | 104 | /* No DMA on anything but a disk for now */ |
@@ -160,7 +107,7 @@ static unsigned long ali_20_filter(const struct ata_port *ap, struct ata_device | |||
160 | ata_id_c_string(adev->id, model_num, ATA_ID_PROD, sizeof(model_num)); | 107 | ata_id_c_string(adev->id, model_num, ATA_ID_PROD, sizeof(model_num)); |
161 | if (strstr(model_num, "WDC")) | 108 | if (strstr(model_num, "WDC")) |
162 | return mask &= ~ATA_MASK_UDMA; | 109 | return mask &= ~ATA_MASK_UDMA; |
163 | return ata_pci_default_filter(ap, adev, mask); | 110 | return ata_pci_default_filter(adev, mask); |
164 | } | 111 | } |
165 | 112 | ||
166 | /** | 113 | /** |
@@ -314,7 +261,6 @@ static void ali_set_dmamode(struct ata_port *ap, struct ata_device *adev) | |||
314 | 261 | ||
315 | /** | 262 | /** |
316 | * ali_lock_sectors - Keep older devices to 255 sector mode | 263 | * ali_lock_sectors - Keep older devices to 255 sector mode |
317 | * @ap: ATA port | ||
318 | * @adev: Device | 264 | * @adev: Device |
319 | * | 265 | * |
320 | * Called during the bus probe for each device that is found. We use | 266 | * Called during the bus probe for each device that is found. We use |
@@ -324,7 +270,7 @@ static void ali_set_dmamode(struct ata_port *ap, struct ata_device *adev) | |||
324 | * slower PIO methods | 270 | * slower PIO methods |
325 | */ | 271 | */ |
326 | 272 | ||
327 | static void ali_lock_sectors(struct ata_port *ap, struct ata_device *adev) | 273 | static void ali_lock_sectors(struct ata_device *adev) |
328 | { | 274 | { |
329 | adev->max_sectors = 255; | 275 | adev->max_sectors = 255; |
330 | } | 276 | } |
@@ -366,8 +312,9 @@ static struct ata_port_operations ali_early_port_ops = { | |||
366 | 312 | ||
367 | .freeze = ata_bmdma_freeze, | 313 | .freeze = ata_bmdma_freeze, |
368 | .thaw = ata_bmdma_thaw, | 314 | .thaw = ata_bmdma_thaw, |
369 | .error_handler = ali_early_error_handler, | 315 | .error_handler = ata_bmdma_error_handler, |
370 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 316 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
317 | .cable_detect = ata_cable_40wire, | ||
371 | 318 | ||
372 | .qc_prep = ata_qc_prep, | 319 | .qc_prep = ata_qc_prep, |
373 | .qc_issue = ata_qc_issue_prot, | 320 | .qc_issue = ata_qc_issue_prot, |
@@ -402,8 +349,9 @@ static struct ata_port_operations ali_20_port_ops = { | |||
402 | 349 | ||
403 | .freeze = ata_bmdma_freeze, | 350 | .freeze = ata_bmdma_freeze, |
404 | .thaw = ata_bmdma_thaw, | 351 | .thaw = ata_bmdma_thaw, |
405 | .error_handler = ali_early_error_handler, | 352 | .error_handler = ata_bmdma_error_handler, |
406 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 353 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
354 | .cable_detect = ata_cable_40wire, | ||
407 | 355 | ||
408 | .bmdma_setup = ata_bmdma_setup, | 356 | .bmdma_setup = ata_bmdma_setup, |
409 | .bmdma_start = ata_bmdma_start, | 357 | .bmdma_start = ata_bmdma_start, |
@@ -440,8 +388,9 @@ static struct ata_port_operations ali_c2_port_ops = { | |||
440 | 388 | ||
441 | .freeze = ata_bmdma_freeze, | 389 | .freeze = ata_bmdma_freeze, |
442 | .thaw = ata_bmdma_thaw, | 390 | .thaw = ata_bmdma_thaw, |
443 | .error_handler = ali_c2_error_handler, | 391 | .error_handler = ata_bmdma_error_handler, |
444 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 392 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
393 | .cable_detect = ali_c2_cable_detect, | ||
445 | 394 | ||
446 | .bmdma_setup = ata_bmdma_setup, | 395 | .bmdma_setup = ata_bmdma_setup, |
447 | .bmdma_start = ata_bmdma_start, | 396 | .bmdma_start = ata_bmdma_start, |
@@ -477,8 +426,9 @@ static struct ata_port_operations ali_c5_port_ops = { | |||
477 | 426 | ||
478 | .freeze = ata_bmdma_freeze, | 427 | .freeze = ata_bmdma_freeze, |
479 | .thaw = ata_bmdma_thaw, | 428 | .thaw = ata_bmdma_thaw, |
480 | .error_handler = ali_c2_error_handler, | 429 | .error_handler = ata_bmdma_error_handler, |
481 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 430 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
431 | .cable_detect = ali_c2_cable_detect, | ||
482 | 432 | ||
483 | .bmdma_setup = ata_bmdma_setup, | 433 | .bmdma_setup = ata_bmdma_setup, |
484 | .bmdma_start = ata_bmdma_start, | 434 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_amd.c b/drivers/ata/pata_amd.c index 18381762908..536ee892ab7 100644 --- a/drivers/ata/pata_amd.c +++ b/drivers/ata/pata_amd.c | |||
@@ -25,7 +25,7 @@ | |||
25 | #include <linux/libata.h> | 25 | #include <linux/libata.h> |
26 | 26 | ||
27 | #define DRV_NAME "pata_amd" | 27 | #define DRV_NAME "pata_amd" |
28 | #define DRV_VERSION "0.2.8" | 28 | #define DRV_VERSION "0.3.8" |
29 | 29 | ||
30 | /** | 30 | /** |
31 | * timing_setup - shared timing computation and load | 31 | * timing_setup - shared timing computation and load |
@@ -119,32 +119,25 @@ static void timing_setup(struct ata_port *ap, struct ata_device *adev, int offse | |||
119 | } | 119 | } |
120 | 120 | ||
121 | /** | 121 | /** |
122 | * amd_probe_init - cable detection | 122 | * amd_probe_init - perform reset handling |
123 | * @ap: ATA port | 123 | * @ap: ATA port |
124 | * | 124 | * |
125 | * Perform cable detection. The BIOS stores this in PCI config | 125 | * Reset sequence checking enable bits to see which ports are |
126 | * space for us. | 126 | * active. |
127 | */ | 127 | */ |
128 | 128 | ||
129 | static int amd_pre_reset(struct ata_port *ap) | 129 | static int amd_pre_reset(struct ata_port *ap) |
130 | { | 130 | { |
131 | static const u32 bitmask[2] = {0x03, 0x0C}; | ||
132 | static const struct pci_bits amd_enable_bits[] = { | 131 | static const struct pci_bits amd_enable_bits[] = { |
133 | { 0x40, 1, 0x02, 0x02 }, | 132 | { 0x40, 1, 0x02, 0x02 }, |
134 | { 0x40, 1, 0x01, 0x01 } | 133 | { 0x40, 1, 0x01, 0x01 } |
135 | }; | 134 | }; |
136 | 135 | ||
137 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 136 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
138 | u8 ata66; | ||
139 | 137 | ||
140 | if (!pci_test_config_bits(pdev, &amd_enable_bits[ap->port_no])) | 138 | if (!pci_test_config_bits(pdev, &amd_enable_bits[ap->port_no])) |
141 | return -ENOENT; | 139 | return -ENOENT; |
142 | 140 | ||
143 | pci_read_config_byte(pdev, 0x42, &ata66); | ||
144 | if (ata66 & bitmask[ap->port_no]) | ||
145 | ap->cbl = ATA_CBL_PATA80; | ||
146 | else | ||
147 | ap->cbl = ATA_CBL_PATA40; | ||
148 | return ata_std_prereset(ap); | 141 | return ata_std_prereset(ap); |
149 | 142 | ||
150 | } | 143 | } |
@@ -156,28 +149,16 @@ static void amd_error_handler(struct ata_port *ap) | |||
156 | ata_std_postreset); | 149 | ata_std_postreset); |
157 | } | 150 | } |
158 | 151 | ||
159 | static int amd_early_pre_reset(struct ata_port *ap) | 152 | static int amd_cable_detect(struct ata_port *ap) |
160 | { | 153 | { |
154 | static const u32 bitmask[2] = {0x03, 0x0C}; | ||
161 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 155 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
162 | static struct pci_bits amd_enable_bits[] = { | 156 | u8 ata66; |
163 | { 0x40, 1, 0x02, 0x02 }, | ||
164 | { 0x40, 1, 0x01, 0x01 } | ||
165 | }; | ||
166 | |||
167 | if (!pci_test_config_bits(pdev, &amd_enable_bits[ap->port_no])) | ||
168 | return -ENOENT; | ||
169 | |||
170 | /* No host side cable detection */ | ||
171 | ap->cbl = ATA_CBL_PATA80; | ||
172 | return ata_std_prereset(ap); | ||
173 | |||
174 | } | ||
175 | 157 | ||
176 | static void amd_early_error_handler(struct ata_port *ap) | 158 | pci_read_config_byte(pdev, 0x42, &ata66); |
177 | { | 159 | if (ata66 & bitmask[ap->port_no]) |
178 | ata_bmdma_drive_eh(ap, amd_early_pre_reset, | 160 | return ATA_CBL_PATA80; |
179 | ata_std_softreset, NULL, | 161 | return ATA_CBL_PATA40; |
180 | ata_std_postreset); | ||
181 | } | 162 | } |
182 | 163 | ||
183 | /** | 164 | /** |
@@ -247,31 +228,16 @@ static void amd133_set_dmamode(struct ata_port *ap, struct ata_device *adev) | |||
247 | */ | 228 | */ |
248 | 229 | ||
249 | static int nv_pre_reset(struct ata_port *ap) { | 230 | static int nv_pre_reset(struct ata_port *ap) { |
250 | static const u8 bitmask[2] = {0x03, 0x0C}; | ||
251 | static const struct pci_bits nv_enable_bits[] = { | 231 | static const struct pci_bits nv_enable_bits[] = { |
252 | { 0x50, 1, 0x02, 0x02 }, | 232 | { 0x50, 1, 0x02, 0x02 }, |
253 | { 0x50, 1, 0x01, 0x01 } | 233 | { 0x50, 1, 0x01, 0x01 } |
254 | }; | 234 | }; |
255 | 235 | ||
256 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 236 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
257 | u8 ata66; | ||
258 | u16 udma; | ||
259 | 237 | ||
260 | if (!pci_test_config_bits(pdev, &nv_enable_bits[ap->port_no])) | 238 | if (!pci_test_config_bits(pdev, &nv_enable_bits[ap->port_no])) |
261 | return -ENOENT; | 239 | return -ENOENT; |
262 | 240 | ||
263 | pci_read_config_byte(pdev, 0x52, &ata66); | ||
264 | if (ata66 & bitmask[ap->port_no]) | ||
265 | ap->cbl = ATA_CBL_PATA80; | ||
266 | else | ||
267 | ap->cbl = ATA_CBL_PATA40; | ||
268 | |||
269 | /* We now have to double check because the Nvidia boxes BIOS | ||
270 | doesn't always set the cable bits but does set mode bits */ | ||
271 | |||
272 | pci_read_config_word(pdev, 0x62 - 2 * ap->port_no, &udma); | ||
273 | if ((udma & 0xC4) == 0xC4 || (udma & 0xC400) == 0xC400) | ||
274 | ap->cbl = ATA_CBL_PATA80; | ||
275 | return ata_std_prereset(ap); | 241 | return ata_std_prereset(ap); |
276 | } | 242 | } |
277 | 243 | ||
@@ -281,6 +247,29 @@ static void nv_error_handler(struct ata_port *ap) | |||
281 | ata_std_softreset, NULL, | 247 | ata_std_softreset, NULL, |
282 | ata_std_postreset); | 248 | ata_std_postreset); |
283 | } | 249 | } |
250 | |||
251 | static int nv_cable_detect(struct ata_port *ap) | ||
252 | { | ||
253 | static const u8 bitmask[2] = {0x03, 0x0C}; | ||
254 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
255 | u8 ata66; | ||
256 | u16 udma; | ||
257 | int cbl; | ||
258 | |||
259 | pci_read_config_byte(pdev, 0x52, &ata66); | ||
260 | if (ata66 & bitmask[ap->port_no]) | ||
261 | cbl = ATA_CBL_PATA80; | ||
262 | else | ||
263 | cbl = ATA_CBL_PATA40; | ||
264 | |||
265 | /* We now have to double check because the Nvidia boxes BIOS | ||
266 | doesn't always set the cable bits but does set mode bits */ | ||
267 | pci_read_config_word(pdev, 0x62 - 2 * ap->port_no, &udma); | ||
268 | if ((udma & 0xC4) == 0xC4 || (udma & 0xC400) == 0xC400) | ||
269 | cbl = ATA_CBL_PATA80; | ||
270 | return cbl; | ||
271 | } | ||
272 | |||
284 | /** | 273 | /** |
285 | * nv100_set_piomode - set initial PIO mode data | 274 | * nv100_set_piomode - set initial PIO mode data |
286 | * @ap: ATA interface | 275 | * @ap: ATA interface |
@@ -353,8 +342,9 @@ static struct ata_port_operations amd33_port_ops = { | |||
353 | 342 | ||
354 | .freeze = ata_bmdma_freeze, | 343 | .freeze = ata_bmdma_freeze, |
355 | .thaw = ata_bmdma_thaw, | 344 | .thaw = ata_bmdma_thaw, |
356 | .error_handler = amd_early_error_handler, | 345 | .error_handler = amd_error_handler, |
357 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 346 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
347 | .cable_detect = ata_cable_40wire, | ||
358 | 348 | ||
359 | .bmdma_setup = ata_bmdma_setup, | 349 | .bmdma_setup = ata_bmdma_setup, |
360 | .bmdma_start = ata_bmdma_start, | 350 | .bmdma_start = ata_bmdma_start, |
@@ -387,8 +377,9 @@ static struct ata_port_operations amd66_port_ops = { | |||
387 | 377 | ||
388 | .freeze = ata_bmdma_freeze, | 378 | .freeze = ata_bmdma_freeze, |
389 | .thaw = ata_bmdma_thaw, | 379 | .thaw = ata_bmdma_thaw, |
390 | .error_handler = amd_early_error_handler, | 380 | .error_handler = amd_error_handler, |
391 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 381 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
382 | .cable_detect = ata_cable_unknown, | ||
392 | 383 | ||
393 | .bmdma_setup = ata_bmdma_setup, | 384 | .bmdma_setup = ata_bmdma_setup, |
394 | .bmdma_start = ata_bmdma_start, | 385 | .bmdma_start = ata_bmdma_start, |
@@ -423,6 +414,7 @@ static struct ata_port_operations amd100_port_ops = { | |||
423 | .thaw = ata_bmdma_thaw, | 414 | .thaw = ata_bmdma_thaw, |
424 | .error_handler = amd_error_handler, | 415 | .error_handler = amd_error_handler, |
425 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 416 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
417 | .cable_detect = ata_cable_unknown, | ||
426 | 418 | ||
427 | .bmdma_setup = ata_bmdma_setup, | 419 | .bmdma_setup = ata_bmdma_setup, |
428 | .bmdma_start = ata_bmdma_start, | 420 | .bmdma_start = ata_bmdma_start, |
@@ -457,6 +449,7 @@ static struct ata_port_operations amd133_port_ops = { | |||
457 | .thaw = ata_bmdma_thaw, | 449 | .thaw = ata_bmdma_thaw, |
458 | .error_handler = amd_error_handler, | 450 | .error_handler = amd_error_handler, |
459 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 451 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
452 | .cable_detect = amd_cable_detect, | ||
460 | 453 | ||
461 | .bmdma_setup = ata_bmdma_setup, | 454 | .bmdma_setup = ata_bmdma_setup, |
462 | .bmdma_start = ata_bmdma_start, | 455 | .bmdma_start = ata_bmdma_start, |
@@ -491,6 +484,7 @@ static struct ata_port_operations nv100_port_ops = { | |||
491 | .thaw = ata_bmdma_thaw, | 484 | .thaw = ata_bmdma_thaw, |
492 | .error_handler = nv_error_handler, | 485 | .error_handler = nv_error_handler, |
493 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 486 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
487 | .cable_detect = nv_cable_detect, | ||
494 | 488 | ||
495 | .bmdma_setup = ata_bmdma_setup, | 489 | .bmdma_setup = ata_bmdma_setup, |
496 | .bmdma_start = ata_bmdma_start, | 490 | .bmdma_start = ata_bmdma_start, |
@@ -525,6 +519,7 @@ static struct ata_port_operations nv133_port_ops = { | |||
525 | .thaw = ata_bmdma_thaw, | 519 | .thaw = ata_bmdma_thaw, |
526 | .error_handler = nv_error_handler, | 520 | .error_handler = nv_error_handler, |
527 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 521 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
522 | .cable_detect = nv_cable_detect, | ||
528 | 523 | ||
529 | .bmdma_setup = ata_bmdma_setup, | 524 | .bmdma_setup = ata_bmdma_setup, |
530 | .bmdma_start = ata_bmdma_start, | 525 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_artop.c b/drivers/ata/pata_artop.c index 21c30282717..00e9ec342db 100644 --- a/drivers/ata/pata_artop.c +++ b/drivers/ata/pata_artop.c | |||
@@ -49,8 +49,6 @@ static int artop6210_pre_reset(struct ata_port *ap) | |||
49 | 49 | ||
50 | if (!pci_test_config_bits(pdev, &artop_enable_bits[ap->port_no])) | 50 | if (!pci_test_config_bits(pdev, &artop_enable_bits[ap->port_no])) |
51 | return -ENOENT; | 51 | return -ENOENT; |
52 | |||
53 | ap->cbl = ATA_CBL_PATA40; | ||
54 | return ata_std_prereset(ap); | 52 | return ata_std_prereset(ap); |
55 | } | 53 | } |
56 | 54 | ||
@@ -85,18 +83,28 @@ static int artop6260_pre_reset(struct ata_port *ap) | |||
85 | }; | 83 | }; |
86 | 84 | ||
87 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 85 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
88 | u8 tmp; | ||
89 | 86 | ||
90 | /* Odd numbered device ids are the units with enable bits (the -R cards) */ | 87 | /* Odd numbered device ids are the units with enable bits (the -R cards) */ |
91 | if (pdev->device % 1 && !pci_test_config_bits(pdev, &artop_enable_bits[ap->port_no])) | 88 | if (pdev->device % 1 && !pci_test_config_bits(pdev, &artop_enable_bits[ap->port_no])) |
92 | return -ENOENT; | 89 | return -ENOENT; |
90 | return ata_std_prereset(ap); | ||
91 | } | ||
93 | 92 | ||
93 | /** | ||
94 | * artop6260_cable_detect - identify cable type | ||
95 | * @ap: Port | ||
96 | * | ||
97 | * Identify the cable type for the ARTOp interface in question | ||
98 | */ | ||
99 | |||
100 | static int artop6260_cable_detect(struct ata_port *ap) | ||
101 | { | ||
102 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
103 | u8 tmp; | ||
94 | pci_read_config_byte(pdev, 0x49, &tmp); | 104 | pci_read_config_byte(pdev, 0x49, &tmp); |
95 | if (tmp & (1 << ap->port_no)) | 105 | if (tmp & (1 << ap->port_no)) |
96 | ap->cbl = ATA_CBL_PATA40; | 106 | return ATA_CBL_PATA40; |
97 | else | 107 | return ATA_CBL_PATA80; |
98 | ap->cbl = ATA_CBL_PATA80; | ||
99 | return ata_std_prereset(ap); | ||
100 | } | 108 | } |
101 | 109 | ||
102 | /** | 110 | /** |
@@ -225,7 +233,7 @@ static void artop6260_set_piomode(struct ata_port *ap, struct ata_device *adev) | |||
225 | /** | 233 | /** |
226 | * artop6210_set_dmamode - Initialize host controller PATA PIO timings | 234 | * artop6210_set_dmamode - Initialize host controller PATA PIO timings |
227 | * @ap: Port whose timings we are configuring | 235 | * @ap: Port whose timings we are configuring |
228 | * @adev: um | 236 | * @adev: Device whose timings we are configuring |
229 | * | 237 | * |
230 | * Set DMA mode for device, in host controller PCI config space. | 238 | * Set DMA mode for device, in host controller PCI config space. |
231 | * | 239 | * |
@@ -333,6 +341,7 @@ static const struct ata_port_operations artop6210_ops = { | |||
333 | .thaw = ata_bmdma_thaw, | 341 | .thaw = ata_bmdma_thaw, |
334 | .error_handler = artop6210_error_handler, | 342 | .error_handler = artop6210_error_handler, |
335 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 343 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
344 | .cable_detect = ata_cable_40wire, | ||
336 | 345 | ||
337 | .bmdma_setup = ata_bmdma_setup, | 346 | .bmdma_setup = ata_bmdma_setup, |
338 | .bmdma_start = ata_bmdma_start, | 347 | .bmdma_start = ata_bmdma_start, |
@@ -366,6 +375,7 @@ static const struct ata_port_operations artop6260_ops = { | |||
366 | .thaw = ata_bmdma_thaw, | 375 | .thaw = ata_bmdma_thaw, |
367 | .error_handler = artop6260_error_handler, | 376 | .error_handler = artop6260_error_handler, |
368 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 377 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
378 | .cable_detect = artop6260_cable_detect, | ||
369 | 379 | ||
370 | .bmdma_setup = ata_bmdma_setup, | 380 | .bmdma_setup = ata_bmdma_setup, |
371 | .bmdma_start = ata_bmdma_start, | 381 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_atiixp.c b/drivers/ata/pata_atiixp.c index 51d9923be02..39c871a3dda 100644 --- a/drivers/ata/pata_atiixp.c +++ b/drivers/ata/pata_atiixp.c | |||
@@ -22,7 +22,7 @@ | |||
22 | #include <linux/libata.h> | 22 | #include <linux/libata.h> |
23 | 23 | ||
24 | #define DRV_NAME "pata_atiixp" | 24 | #define DRV_NAME "pata_atiixp" |
25 | #define DRV_VERSION "0.4.4" | 25 | #define DRV_VERSION "0.4.5" |
26 | 26 | ||
27 | enum { | 27 | enum { |
28 | ATIIXP_IDE_PIO_TIMING = 0x40, | 28 | ATIIXP_IDE_PIO_TIMING = 0x40, |
@@ -35,23 +35,15 @@ enum { | |||
35 | 35 | ||
36 | static int atiixp_pre_reset(struct ata_port *ap) | 36 | static int atiixp_pre_reset(struct ata_port *ap) |
37 | { | 37 | { |
38 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
39 | static const struct pci_bits atiixp_enable_bits[] = { | 38 | static const struct pci_bits atiixp_enable_bits[] = { |
40 | { 0x48, 1, 0x01, 0x00 }, | 39 | { 0x48, 1, 0x01, 0x00 }, |
41 | { 0x48, 1, 0x08, 0x00 } | 40 | { 0x48, 1, 0x08, 0x00 } |
42 | }; | 41 | }; |
43 | u8 udma; | 42 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
44 | 43 | ||
45 | if (!pci_test_config_bits(pdev, &atiixp_enable_bits[ap->port_no])) | 44 | if (!pci_test_config_bits(pdev, &atiixp_enable_bits[ap->port_no])) |
46 | return -ENOENT; | 45 | return -ENOENT; |
47 | 46 | ||
48 | /* Hack from drivers/ide/pci. Really we want to know how to do the | ||
49 | raw detection not play follow the bios mode guess */ | ||
50 | pci_read_config_byte(pdev, ATIIXP_IDE_UDMA_MODE + ap->port_no, &udma); | ||
51 | if ((udma & 0x07) >= 0x04 || (udma & 0x70) >= 0x40) | ||
52 | ap->cbl = ATA_CBL_PATA80; | ||
53 | else | ||
54 | ap->cbl = ATA_CBL_PATA40; | ||
55 | return ata_std_prereset(ap); | 47 | return ata_std_prereset(ap); |
56 | } | 48 | } |
57 | 49 | ||
@@ -60,6 +52,19 @@ static void atiixp_error_handler(struct ata_port *ap) | |||
60 | ata_bmdma_drive_eh(ap, atiixp_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | 52 | ata_bmdma_drive_eh(ap, atiixp_pre_reset, ata_std_softreset, NULL, ata_std_postreset); |
61 | } | 53 | } |
62 | 54 | ||
55 | static int atiixp_cable_detect(struct ata_port *ap) | ||
56 | { | ||
57 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
58 | u8 udma; | ||
59 | |||
60 | /* Hack from drivers/ide/pci. Really we want to know how to do the | ||
61 | raw detection not play follow the bios mode guess */ | ||
62 | pci_read_config_byte(pdev, ATIIXP_IDE_UDMA_MODE + ap->port_no, &udma); | ||
63 | if ((udma & 0x07) >= 0x04 || (udma & 0x70) >= 0x40) | ||
64 | return ATA_CBL_PATA80; | ||
65 | return ATA_CBL_PATA40; | ||
66 | } | ||
67 | |||
63 | /** | 68 | /** |
64 | * atiixp_set_pio_timing - set initial PIO mode data | 69 | * atiixp_set_pio_timing - set initial PIO mode data |
65 | * @ap: ATA interface | 70 | * @ap: ATA interface |
@@ -245,6 +250,7 @@ static struct ata_port_operations atiixp_port_ops = { | |||
245 | .thaw = ata_bmdma_thaw, | 250 | .thaw = ata_bmdma_thaw, |
246 | .error_handler = atiixp_error_handler, | 251 | .error_handler = atiixp_error_handler, |
247 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 252 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
253 | .cable_detect = atiixp_cable_detect, | ||
248 | 254 | ||
249 | .bmdma_setup = ata_bmdma_setup, | 255 | .bmdma_setup = ata_bmdma_setup, |
250 | .bmdma_start = atiixp_bmdma_start, | 256 | .bmdma_start = atiixp_bmdma_start, |
diff --git a/drivers/ata/pata_cmd640.c b/drivers/ata/pata_cmd640.c new file mode 100644 index 00000000000..2105985a801 --- /dev/null +++ b/drivers/ata/pata_cmd640.c | |||
@@ -0,0 +1,312 @@ | |||
1 | /* | ||
2 | * pata_cmd640.c - CMD640 PCI PATA for new ATA layer | ||
3 | * (C) 2007 Red Hat Inc | ||
4 | * Alan Cox <alan@redhat.com> | ||
5 | * | ||
6 | * Based upon | ||
7 | * linux/drivers/ide/pci/cmd640.c Version 1.02 Sep 01, 1996 | ||
8 | * | ||
9 | * Copyright (C) 1995-1996 Linus Torvalds & authors (see driver) | ||
10 | * | ||
11 | * This drives only the PCI version of the controller. If you have a | ||
12 | * VLB one then we have enough docs to support it but you can write | ||
13 | * your own code. | ||
14 | */ | ||
15 | |||
16 | #include <linux/kernel.h> | ||
17 | #include <linux/module.h> | ||
18 | #include <linux/pci.h> | ||
19 | #include <linux/init.h> | ||
20 | #include <linux/blkdev.h> | ||
21 | #include <linux/delay.h> | ||
22 | #include <scsi/scsi_host.h> | ||
23 | #include <linux/libata.h> | ||
24 | |||
25 | #define DRV_NAME "pata_cmd640" | ||
26 | #define DRV_VERSION "0.0.5" | ||
27 | |||
28 | struct cmd640_reg { | ||
29 | int last; | ||
30 | u8 reg58[ATA_MAX_DEVICES]; | ||
31 | }; | ||
32 | |||
33 | enum { | ||
34 | CFR = 0x50, | ||
35 | CNTRL = 0x51, | ||
36 | CMDTIM = 0x52, | ||
37 | ARTIM0 = 0x53, | ||
38 | DRWTIM0 = 0x54, | ||
39 | ARTIM23 = 0x57, | ||
40 | DRWTIM23 = 0x58, | ||
41 | BRST = 0x59 | ||
42 | }; | ||
43 | |||
44 | /** | ||
45 | * cmd640_set_piomode - set initial PIO mode data | ||
46 | * @ap: ATA port | ||
47 | * @adev: ATA device | ||
48 | * | ||
49 | * Called to do the PIO mode setup. | ||
50 | */ | ||
51 | |||
52 | static void cmd640_set_piomode(struct ata_port *ap, struct ata_device *adev) | ||
53 | { | ||
54 | struct cmd640_reg *timing = ap->private_data; | ||
55 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
56 | struct ata_timing t; | ||
57 | const unsigned long T = 1000000 / 33; | ||
58 | const u8 setup_data[] = { 0x40, 0x40, 0x40, 0x80, 0x00 }; | ||
59 | u8 reg; | ||
60 | int arttim = ARTIM0 + 2 * adev->devno; | ||
61 | struct ata_device *pair = ata_dev_pair(adev); | ||
62 | |||
63 | if (ata_timing_compute(adev, adev->pio_mode, &t, T, 0) < 0) { | ||
64 | printk(KERN_ERR DRV_NAME ": mode computation failed.\n"); | ||
65 | return; | ||
66 | } | ||
67 | |||
68 | /* The second channel has shared timings and the setup timing is | ||
69 | messy to switch to merge it for worst case */ | ||
70 | if (ap->port_no && pair) { | ||
71 | struct ata_timing p; | ||
72 | ata_timing_compute(pair, pair->pio_mode, &p, T, 1); | ||
73 | ata_timing_merge(&p, &t, &t, ATA_TIMING_SETUP); | ||
74 | } | ||
75 | |||
76 | /* Make the timings fit */ | ||
77 | if (t.recover > 16) { | ||
78 | t.active += t.recover - 16; | ||
79 | t.recover = 16; | ||
80 | } | ||
81 | if (t.active > 16) | ||
82 | t.active = 16; | ||
83 | |||
84 | /* Now convert the clocks into values we can actually stuff into | ||
85 | the chip */ | ||
86 | |||
87 | if (t.recover > 1) | ||
88 | t.recover--; /* 640B only */ | ||
89 | else | ||
90 | t.recover = 15; | ||
91 | |||
92 | if (t.setup > 4) | ||
93 | t.setup = 0xC0; | ||
94 | else | ||
95 | t.setup = setup_data[t.setup]; | ||
96 | |||
97 | if (ap->port_no == 0) { | ||
98 | t.active &= 0x0F; /* 0 = 16 */ | ||
99 | |||
100 | /* Load setup timing */ | ||
101 | pci_read_config_byte(pdev, arttim, ®); | ||
102 | reg &= 0x3F; | ||
103 | reg |= t.setup; | ||
104 | pci_write_config_byte(pdev, arttim, reg); | ||
105 | |||
106 | /* Load active/recovery */ | ||
107 | pci_write_config_byte(pdev, arttim + 1, (t.active << 4) | t.recover); | ||
108 | } else { | ||
109 | /* Save the shared timings for channel, they will be loaded | ||
110 | by qc_issue_prot. Reloading the setup time is expensive | ||
111 | so we keep a merged one loaded */ | ||
112 | pci_read_config_byte(pdev, ARTIM23, ®); | ||
113 | reg &= 0x3F; | ||
114 | reg |= t.setup; | ||
115 | pci_write_config_byte(pdev, ARTIM23, reg); | ||
116 | timing->reg58[adev->devno] = (t.active << 4) | t.recover; | ||
117 | } | ||
118 | } | ||
119 | |||
120 | |||
121 | /** | ||
122 | * cmd640_qc_issue_prot - command preparation hook | ||
123 | * @qc: Command to be issued | ||
124 | * | ||
125 | * Channel 1 has shared timings. We must reprogram the | ||
126 | * clock each drive 2/3 switch we do. | ||
127 | */ | ||
128 | |||
129 | static unsigned int cmd640_qc_issue_prot(struct ata_queued_cmd *qc) | ||
130 | { | ||
131 | struct ata_port *ap = qc->ap; | ||
132 | struct ata_device *adev = qc->dev; | ||
133 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
134 | struct cmd640_reg *timing = ap->private_data; | ||
135 | |||
136 | if (ap->port_no != 0 && adev->devno != timing->last) { | ||
137 | pci_write_config_byte(pdev, DRWTIM23, timing->reg58[adev->devno]); | ||
138 | timing->last = adev->devno; | ||
139 | } | ||
140 | return ata_qc_issue_prot(qc); | ||
141 | } | ||
142 | |||
143 | /** | ||
144 | * cmd640_port_start - port setup | ||
145 | * @ap: ATA port being set up | ||
146 | * | ||
147 | * The CMD640 needs to maintain private data structures so we | ||
148 | * allocate space here. | ||
149 | */ | ||
150 | |||
151 | static int cmd640_port_start(struct ata_port *ap) | ||
152 | { | ||
153 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
154 | struct cmd640_reg *timing; | ||
155 | |||
156 | int ret = ata_port_start(ap); | ||
157 | if (ret < 0) | ||
158 | return ret; | ||
159 | |||
160 | timing = devm_kzalloc(&pdev->dev, sizeof(struct cmd640_reg), GFP_KERNEL); | ||
161 | if (timing == NULL) | ||
162 | return -ENOMEM; | ||
163 | timing->last = -1; /* Force a load */ | ||
164 | ap->private_data = timing; | ||
165 | return ret; | ||
166 | } | ||
167 | |||
168 | static struct scsi_host_template cmd640_sht = { | ||
169 | .module = THIS_MODULE, | ||
170 | .name = DRV_NAME, | ||
171 | .ioctl = ata_scsi_ioctl, | ||
172 | .queuecommand = ata_scsi_queuecmd, | ||
173 | .can_queue = ATA_DEF_QUEUE, | ||
174 | .this_id = ATA_SHT_THIS_ID, | ||
175 | .sg_tablesize = LIBATA_MAX_PRD, | ||
176 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | ||
177 | .emulated = ATA_SHT_EMULATED, | ||
178 | .use_clustering = ATA_SHT_USE_CLUSTERING, | ||
179 | .proc_name = DRV_NAME, | ||
180 | .dma_boundary = ATA_DMA_BOUNDARY, | ||
181 | .slave_configure = ata_scsi_slave_config, | ||
182 | .slave_destroy = ata_scsi_slave_destroy, | ||
183 | .bios_param = ata_std_bios_param, | ||
184 | #ifdef CONFIG_PM | ||
185 | .resume = ata_scsi_device_resume, | ||
186 | .suspend = ata_scsi_device_suspend, | ||
187 | #endif | ||
188 | }; | ||
189 | |||
190 | static struct ata_port_operations cmd640_port_ops = { | ||
191 | .port_disable = ata_port_disable, | ||
192 | .set_piomode = cmd640_set_piomode, | ||
193 | .mode_filter = ata_pci_default_filter, | ||
194 | .tf_load = ata_tf_load, | ||
195 | .tf_read = ata_tf_read, | ||
196 | .check_status = ata_check_status, | ||
197 | .exec_command = ata_exec_command, | ||
198 | .dev_select = ata_std_dev_select, | ||
199 | |||
200 | .freeze = ata_bmdma_freeze, | ||
201 | .thaw = ata_bmdma_thaw, | ||
202 | .error_handler = ata_bmdma_error_handler, | ||
203 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | ||
204 | .cable_detect = ata_cable_40wire, | ||
205 | |||
206 | .bmdma_setup = ata_bmdma_setup, | ||
207 | .bmdma_start = ata_bmdma_start, | ||
208 | .bmdma_stop = ata_bmdma_stop, | ||
209 | .bmdma_status = ata_bmdma_status, | ||
210 | |||
211 | .qc_prep = ata_qc_prep, | ||
212 | .qc_issue = cmd640_qc_issue_prot, | ||
213 | |||
214 | /* In theory this is not needed once we kill the prefetcher */ | ||
215 | .data_xfer = ata_data_xfer_noirq, | ||
216 | |||
217 | .irq_handler = ata_interrupt, | ||
218 | .irq_clear = ata_bmdma_irq_clear, | ||
219 | .irq_on = ata_irq_on, | ||
220 | .irq_ack = ata_irq_ack, | ||
221 | |||
222 | .port_start = cmd640_port_start, | ||
223 | }; | ||
224 | |||
225 | static void cmd640_hardware_init(struct pci_dev *pdev) | ||
226 | { | ||
227 | u8 r; | ||
228 | u8 ctrl; | ||
229 | |||
230 | /* CMD640 detected, commiserations */ | ||
231 | pci_write_config_byte(pdev, 0x5B, 0x00); | ||
232 | /* Get version info */ | ||
233 | pci_read_config_byte(pdev, CFR, &r); | ||
234 | /* PIO0 command cycles */ | ||
235 | pci_write_config_byte(pdev, CMDTIM, 0); | ||
236 | /* 512 byte bursts (sector) */ | ||
237 | pci_write_config_byte(pdev, BRST, 0x40); | ||
238 | /* | ||
239 | * A reporter a long time ago | ||
240 | * Had problems with the data fifo | ||
241 | * So don't run the risk | ||
242 | * Of putting crap on the disk | ||
243 | * For its better just to go slow | ||
244 | */ | ||
245 | /* Do channel 0 */ | ||
246 | pci_read_config_byte(pdev, CNTRL, &ctrl); | ||
247 | pci_write_config_byte(pdev, CNTRL, ctrl | 0xC0); | ||
248 | /* Ditto for channel 1 */ | ||
249 | pci_read_config_byte(pdev, ARTIM23, &ctrl); | ||
250 | ctrl |= 0x0C; | ||
251 | pci_write_config_byte(pdev, ARTIM23, ctrl); | ||
252 | } | ||
253 | |||
254 | static int cmd640_init_one(struct pci_dev *pdev, const struct pci_device_id *id) | ||
255 | { | ||
256 | static struct ata_port_info info = { | ||
257 | .sht = &cmd640_sht, | ||
258 | .flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST, | ||
259 | .pio_mask = 0x1f, | ||
260 | .port_ops = &cmd640_port_ops | ||
261 | }; | ||
262 | |||
263 | static struct ata_port_info *port_info[2] = { &info, &info }; | ||
264 | |||
265 | cmd640_hardware_init(pdev); | ||
266 | return ata_pci_init_one(pdev, port_info, 2); | ||
267 | } | ||
268 | |||
269 | static int cmd640_reinit_one(struct pci_dev *pdev) | ||
270 | { | ||
271 | cmd640_hardware_init(pdev); | ||
272 | #ifdef CONFIG_PM | ||
273 | return ata_pci_device_resume(pdev); | ||
274 | #else | ||
275 | return 0; | ||
276 | #endif | ||
277 | } | ||
278 | |||
279 | static const struct pci_device_id cmd640[] = { | ||
280 | { PCI_VDEVICE(CMD, 0x640), 0 }, | ||
281 | { }, | ||
282 | }; | ||
283 | |||
284 | static struct pci_driver cmd640_pci_driver = { | ||
285 | .name = DRV_NAME, | ||
286 | .id_table = cmd640, | ||
287 | .probe = cmd640_init_one, | ||
288 | .remove = ata_pci_remove_one, | ||
289 | #ifdef CONFIG_PM | ||
290 | .suspend = ata_pci_device_suspend, | ||
291 | #endif | ||
292 | .resume = cmd640_reinit_one, | ||
293 | }; | ||
294 | |||
295 | static int __init cmd640_init(void) | ||
296 | { | ||
297 | return pci_register_driver(&cmd640_pci_driver); | ||
298 | } | ||
299 | |||
300 | static void __exit cmd640_exit(void) | ||
301 | { | ||
302 | pci_unregister_driver(&cmd640_pci_driver); | ||
303 | } | ||
304 | |||
305 | MODULE_AUTHOR("Alan Cox"); | ||
306 | MODULE_DESCRIPTION("low-level driver for CMD640 PATA controllers"); | ||
307 | MODULE_LICENSE("GPL"); | ||
308 | MODULE_DEVICE_TABLE(pci, cmd640); | ||
309 | MODULE_VERSION(DRV_VERSION); | ||
310 | |||
311 | module_init(cmd640_init); | ||
312 | module_exit(cmd640_exit); | ||
diff --git a/drivers/ata/pata_cmd64x.c b/drivers/ata/pata_cmd64x.c index 5b13bdd1edc..3989cc577fc 100644 --- a/drivers/ata/pata_cmd64x.c +++ b/drivers/ata/pata_cmd64x.c | |||
@@ -75,13 +75,7 @@ enum { | |||
75 | DTPR1 = 0x7C | 75 | DTPR1 = 0x7C |
76 | }; | 76 | }; |
77 | 77 | ||
78 | static int cmd64x_pre_reset(struct ata_port *ap) | 78 | static int cmd648_cable_detect(struct ata_port *ap) |
79 | { | ||
80 | ap->cbl = ATA_CBL_PATA40; | ||
81 | return ata_std_prereset(ap); | ||
82 | } | ||
83 | |||
84 | static int cmd648_pre_reset(struct ata_port *ap) | ||
85 | { | 79 | { |
86 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 80 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
87 | u8 r; | 81 | u8 r; |
@@ -89,21 +83,8 @@ static int cmd648_pre_reset(struct ata_port *ap) | |||
89 | /* Check cable detect bits */ | 83 | /* Check cable detect bits */ |
90 | pci_read_config_byte(pdev, BMIDECSR, &r); | 84 | pci_read_config_byte(pdev, BMIDECSR, &r); |
91 | if (r & (1 << ap->port_no)) | 85 | if (r & (1 << ap->port_no)) |
92 | ap->cbl = ATA_CBL_PATA80; | 86 | return ATA_CBL_PATA80; |
93 | else | 87 | return ATA_CBL_PATA40; |
94 | ap->cbl = ATA_CBL_PATA40; | ||
95 | |||
96 | return ata_std_prereset(ap); | ||
97 | } | ||
98 | |||
99 | static void cmd64x_error_handler(struct ata_port *ap) | ||
100 | { | ||
101 | return ata_bmdma_drive_eh(ap, cmd64x_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
102 | } | ||
103 | |||
104 | static void cmd648_error_handler(struct ata_port *ap) | ||
105 | { | ||
106 | ata_bmdma_drive_eh(ap, cmd648_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
107 | } | 88 | } |
108 | 89 | ||
109 | /** | 90 | /** |
@@ -304,8 +285,9 @@ static struct ata_port_operations cmd64x_port_ops = { | |||
304 | 285 | ||
305 | .freeze = ata_bmdma_freeze, | 286 | .freeze = ata_bmdma_freeze, |
306 | .thaw = ata_bmdma_thaw, | 287 | .thaw = ata_bmdma_thaw, |
307 | .error_handler = cmd64x_error_handler, | 288 | .error_handler = ata_bmdma_error_handler, |
308 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 289 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
290 | .cable_detect = ata_cable_40wire, | ||
309 | 291 | ||
310 | .bmdma_setup = ata_bmdma_setup, | 292 | .bmdma_setup = ata_bmdma_setup, |
311 | .bmdma_start = ata_bmdma_start, | 293 | .bmdma_start = ata_bmdma_start, |
@@ -338,8 +320,9 @@ static struct ata_port_operations cmd646r1_port_ops = { | |||
338 | 320 | ||
339 | .freeze = ata_bmdma_freeze, | 321 | .freeze = ata_bmdma_freeze, |
340 | .thaw = ata_bmdma_thaw, | 322 | .thaw = ata_bmdma_thaw, |
341 | .error_handler = cmd64x_error_handler, | 323 | .error_handler = ata_bmdma_error_handler, |
342 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 324 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
325 | .cable_detect = ata_cable_40wire, | ||
343 | 326 | ||
344 | .bmdma_setup = ata_bmdma_setup, | 327 | .bmdma_setup = ata_bmdma_setup, |
345 | .bmdma_start = ata_bmdma_start, | 328 | .bmdma_start = ata_bmdma_start, |
@@ -372,8 +355,9 @@ static struct ata_port_operations cmd648_port_ops = { | |||
372 | 355 | ||
373 | .freeze = ata_bmdma_freeze, | 356 | .freeze = ata_bmdma_freeze, |
374 | .thaw = ata_bmdma_thaw, | 357 | .thaw = ata_bmdma_thaw, |
375 | .error_handler = cmd648_error_handler, | 358 | .error_handler = ata_bmdma_error_handler, |
376 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 359 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
360 | .cable_detect = cmd648_cable_detect, | ||
377 | 361 | ||
378 | .bmdma_setup = ata_bmdma_setup, | 362 | .bmdma_setup = ata_bmdma_setup, |
379 | .bmdma_start = ata_bmdma_start, | 363 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_cs5520.c b/drivers/ata/pata_cs5520.c index 55cc293e748..79bef0d1fad 100644 --- a/drivers/ata/pata_cs5520.c +++ b/drivers/ata/pata_cs5520.c | |||
@@ -139,18 +139,6 @@ static void cs5520_set_piomode(struct ata_port *ap, struct ata_device *adev) | |||
139 | cs5520_set_timings(ap, adev, adev->pio_mode); | 139 | cs5520_set_timings(ap, adev, adev->pio_mode); |
140 | } | 140 | } |
141 | 141 | ||
142 | |||
143 | static int cs5520_pre_reset(struct ata_port *ap) | ||
144 | { | ||
145 | ap->cbl = ATA_CBL_PATA40; | ||
146 | return ata_std_prereset(ap); | ||
147 | } | ||
148 | |||
149 | static void cs5520_error_handler(struct ata_port *ap) | ||
150 | { | ||
151 | return ata_bmdma_drive_eh(ap, cs5520_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
152 | } | ||
153 | |||
154 | static struct scsi_host_template cs5520_sht = { | 142 | static struct scsi_host_template cs5520_sht = { |
155 | .module = THIS_MODULE, | 143 | .module = THIS_MODULE, |
156 | .name = DRV_NAME, | 144 | .name = DRV_NAME, |
@@ -186,8 +174,9 @@ static struct ata_port_operations cs5520_port_ops = { | |||
186 | 174 | ||
187 | .freeze = ata_bmdma_freeze, | 175 | .freeze = ata_bmdma_freeze, |
188 | .thaw = ata_bmdma_thaw, | 176 | .thaw = ata_bmdma_thaw, |
189 | .error_handler = cs5520_error_handler, | 177 | .error_handler = ata_bmdma_error_handler, |
190 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 178 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
179 | .cable_detect = ata_cable_40wire, | ||
191 | 180 | ||
192 | .bmdma_setup = ata_bmdma_setup, | 181 | .bmdma_setup = ata_bmdma_setup, |
193 | .bmdma_start = ata_bmdma_start, | 182 | .bmdma_start = ata_bmdma_start, |
@@ -197,7 +186,6 @@ static struct ata_port_operations cs5520_port_ops = { | |||
197 | .qc_issue = ata_qc_issue_prot, | 186 | .qc_issue = ata_qc_issue_prot, |
198 | .data_xfer = ata_data_xfer, | 187 | .data_xfer = ata_data_xfer, |
199 | 188 | ||
200 | .irq_handler = ata_interrupt, | ||
201 | .irq_clear = ata_bmdma_irq_clear, | 189 | .irq_clear = ata_bmdma_irq_clear, |
202 | .irq_on = ata_irq_on, | 190 | .irq_on = ata_irq_on, |
203 | .irq_ack = ata_irq_ack, | 191 | .irq_ack = ata_irq_ack, |
@@ -205,91 +193,104 @@ static struct ata_port_operations cs5520_port_ops = { | |||
205 | .port_start = ata_port_start, | 193 | .port_start = ata_port_start, |
206 | }; | 194 | }; |
207 | 195 | ||
208 | static int __devinit cs5520_init_one(struct pci_dev *dev, const struct pci_device_id *id) | 196 | static int __devinit cs5520_init_one(struct pci_dev *pdev, const struct pci_device_id *id) |
209 | { | 197 | { |
198 | struct ata_port_info pi = { | ||
199 | .flags = ATA_FLAG_SLAVE_POSS, | ||
200 | .pio_mask = 0x1f, | ||
201 | .port_ops = &cs5520_port_ops, | ||
202 | }; | ||
203 | const struct ata_port_info *ppi[2]; | ||
210 | u8 pcicfg; | 204 | u8 pcicfg; |
211 | void __iomem *iomap[5]; | 205 | void *iomap[5]; |
212 | static struct ata_probe_ent probe[2]; | 206 | struct ata_host *host; |
213 | int ports = 0; | 207 | struct ata_ioports *ioaddr; |
208 | int i, rc; | ||
214 | 209 | ||
215 | /* IDE port enable bits */ | 210 | /* IDE port enable bits */ |
216 | pci_read_config_byte(dev, 0x60, &pcicfg); | 211 | pci_read_config_byte(pdev, 0x60, &pcicfg); |
217 | 212 | ||
218 | /* Check if the ATA ports are enabled */ | 213 | /* Check if the ATA ports are enabled */ |
219 | if ((pcicfg & 3) == 0) | 214 | if ((pcicfg & 3) == 0) |
220 | return -ENODEV; | 215 | return -ENODEV; |
221 | 216 | ||
217 | ppi[0] = ppi[1] = &ata_dummy_port_info; | ||
218 | if (pcicfg & 1) | ||
219 | ppi[0] = π | ||
220 | if (pcicfg & 2) | ||
221 | ppi[1] = π | ||
222 | |||
222 | if ((pcicfg & 0x40) == 0) { | 223 | if ((pcicfg & 0x40) == 0) { |
223 | printk(KERN_WARNING DRV_NAME ": DMA mode disabled. Enabling.\n"); | 224 | dev_printk(KERN_WARNING, &pdev->dev, |
224 | pci_write_config_byte(dev, 0x60, pcicfg | 0x40); | 225 | "DMA mode disabled. Enabling.\n"); |
226 | pci_write_config_byte(pdev, 0x60, pcicfg | 0x40); | ||
225 | } | 227 | } |
226 | 228 | ||
229 | pi.mwdma_mask = id->driver_data; | ||
230 | |||
231 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, 2); | ||
232 | if (!host) | ||
233 | return -ENOMEM; | ||
234 | |||
227 | /* Perform set up for DMA */ | 235 | /* Perform set up for DMA */ |
228 | if (pci_enable_device_bars(dev, 1<<2)) { | 236 | if (pci_enable_device_bars(pdev, 1<<2)) { |
229 | printk(KERN_ERR DRV_NAME ": unable to configure BAR2.\n"); | 237 | printk(KERN_ERR DRV_NAME ": unable to configure BAR2.\n"); |
230 | return -ENODEV; | 238 | return -ENODEV; |
231 | } | 239 | } |
232 | pci_set_master(dev); | 240 | |
233 | if (pci_set_dma_mask(dev, DMA_32BIT_MASK)) { | 241 | if (pci_set_dma_mask(pdev, DMA_32BIT_MASK)) { |
234 | printk(KERN_ERR DRV_NAME ": unable to configure DMA mask.\n"); | 242 | printk(KERN_ERR DRV_NAME ": unable to configure DMA mask.\n"); |
235 | return -ENODEV; | 243 | return -ENODEV; |
236 | } | 244 | } |
237 | if (pci_set_consistent_dma_mask(dev, DMA_32BIT_MASK)) { | 245 | if (pci_set_consistent_dma_mask(pdev, DMA_32BIT_MASK)) { |
238 | printk(KERN_ERR DRV_NAME ": unable to configure consistent DMA mask.\n"); | 246 | printk(KERN_ERR DRV_NAME ": unable to configure consistent DMA mask.\n"); |
239 | return -ENODEV; | 247 | return -ENODEV; |
240 | } | 248 | } |
241 | 249 | ||
242 | /* Map IO ports */ | 250 | /* Map IO ports and initialize host accordingly */ |
243 | iomap[0] = devm_ioport_map(&dev->dev, 0x1F0, 8); | 251 | iomap[0] = devm_ioport_map(&pdev->dev, 0x1F0, 8); |
244 | iomap[1] = devm_ioport_map(&dev->dev, 0x3F6, 1); | 252 | iomap[1] = devm_ioport_map(&pdev->dev, 0x3F6, 1); |
245 | iomap[2] = devm_ioport_map(&dev->dev, 0x170, 8); | 253 | iomap[2] = devm_ioport_map(&pdev->dev, 0x170, 8); |
246 | iomap[3] = devm_ioport_map(&dev->dev, 0x376, 1); | 254 | iomap[3] = devm_ioport_map(&pdev->dev, 0x376, 1); |
247 | iomap[4] = pcim_iomap(dev, 2, 0); | 255 | iomap[4] = pcim_iomap(pdev, 2, 0); |
248 | 256 | ||
249 | if (!iomap[0] || !iomap[1] || !iomap[2] || !iomap[3] || !iomap[4]) | 257 | if (!iomap[0] || !iomap[1] || !iomap[2] || !iomap[3] || !iomap[4]) |
250 | return -ENOMEM; | 258 | return -ENOMEM; |
251 | 259 | ||
252 | /* We have to do our own plumbing as the PCI setup for this | 260 | ioaddr = &host->ports[0]->ioaddr; |
253 | chipset is non-standard so we can't punt to the libata code */ | 261 | ioaddr->cmd_addr = iomap[0]; |
254 | 262 | ioaddr->ctl_addr = iomap[1]; | |
255 | INIT_LIST_HEAD(&probe[0].node); | 263 | ioaddr->altstatus_addr = iomap[1]; |
256 | probe[0].dev = pci_dev_to_dev(dev); | 264 | ioaddr->bmdma_addr = iomap[4]; |
257 | probe[0].port_ops = &cs5520_port_ops; | 265 | ata_std_ports(ioaddr); |
258 | probe[0].sht = &cs5520_sht; | 266 | |
259 | probe[0].pio_mask = 0x1F; | 267 | ioaddr = &host->ports[1]->ioaddr; |
260 | probe[0].mwdma_mask = id->driver_data; | 268 | ioaddr->cmd_addr = iomap[2]; |
261 | probe[0].irq = 14; | 269 | ioaddr->ctl_addr = iomap[3]; |
262 | probe[0].irq_flags = 0; | 270 | ioaddr->altstatus_addr = iomap[3]; |
263 | probe[0].port_flags = ATA_FLAG_SLAVE_POSS|ATA_FLAG_SRST; | 271 | ioaddr->bmdma_addr = iomap[4] + 8; |
264 | probe[0].n_ports = 1; | 272 | ata_std_ports(ioaddr); |
265 | probe[0].port[0].cmd_addr = iomap[0]; | 273 | |
266 | probe[0].port[0].ctl_addr = iomap[1]; | 274 | /* activate the host */ |
267 | probe[0].port[0].altstatus_addr = iomap[1]; | 275 | pci_set_master(pdev); |
268 | probe[0].port[0].bmdma_addr = iomap[4]; | 276 | rc = ata_host_start(host); |
269 | 277 | if (rc) | |
270 | /* The secondary lurks at different addresses but is otherwise | 278 | return rc; |
271 | the same beastie */ | 279 | |
272 | 280 | for (i = 0; i < 2; i++) { | |
273 | probe[1] = probe[0]; | 281 | static const int irq[] = { 14, 15 }; |
274 | INIT_LIST_HEAD(&probe[1].node); | 282 | struct ata_port *ap = host->ports[0]; |
275 | probe[1].irq = 15; | 283 | |
276 | probe[1].port[0].cmd_addr = iomap[2]; | 284 | if (ata_port_is_dummy(ap)) |
277 | probe[1].port[0].ctl_addr = iomap[3]; | 285 | continue; |
278 | probe[1].port[0].altstatus_addr = iomap[3]; | 286 | |
279 | probe[1].port[0].bmdma_addr = iomap[4] + 8; | 287 | rc = devm_request_irq(&pdev->dev, irq[ap->port_no], |
280 | 288 | ata_interrupt, 0, DRV_NAME, host); | |
281 | /* Let libata fill in the port details */ | 289 | if (rc) |
282 | ata_std_ports(&probe[0].port[0]); | 290 | return rc; |
283 | ata_std_ports(&probe[1].port[0]); | 291 | } |
284 | 292 | ||
285 | /* Now add the ports that are active */ | 293 | return ata_host_register(host, &cs5520_sht); |
286 | if (pcicfg & 1) | ||
287 | ports += ata_device_add(&probe[0]); | ||
288 | if (pcicfg & 2) | ||
289 | ports += ata_device_add(&probe[1]); | ||
290 | if (ports) | ||
291 | return 0; | ||
292 | return -ENODEV; | ||
293 | } | 294 | } |
294 | 295 | ||
295 | /** | 296 | /** |
diff --git a/drivers/ata/pata_cs5530.c b/drivers/ata/pata_cs5530.c index db63e80e608..29642d5ee18 100644 --- a/drivers/ata/pata_cs5530.c +++ b/drivers/ata/pata_cs5530.c | |||
@@ -160,18 +160,6 @@ static unsigned int cs5530_qc_issue_prot(struct ata_queued_cmd *qc) | |||
160 | return ata_qc_issue_prot(qc); | 160 | return ata_qc_issue_prot(qc); |
161 | } | 161 | } |
162 | 162 | ||
163 | static int cs5530_pre_reset(struct ata_port *ap) | ||
164 | { | ||
165 | ap->cbl = ATA_CBL_PATA40; | ||
166 | return ata_std_prereset(ap); | ||
167 | } | ||
168 | |||
169 | static void cs5530_error_handler(struct ata_port *ap) | ||
170 | { | ||
171 | return ata_bmdma_drive_eh(ap, cs5530_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
172 | } | ||
173 | |||
174 | |||
175 | static struct scsi_host_template cs5530_sht = { | 163 | static struct scsi_host_template cs5530_sht = { |
176 | .module = THIS_MODULE, | 164 | .module = THIS_MODULE, |
177 | .name = DRV_NAME, | 165 | .name = DRV_NAME, |
@@ -213,8 +201,9 @@ static struct ata_port_operations cs5530_port_ops = { | |||
213 | 201 | ||
214 | .freeze = ata_bmdma_freeze, | 202 | .freeze = ata_bmdma_freeze, |
215 | .thaw = ata_bmdma_thaw, | 203 | .thaw = ata_bmdma_thaw, |
216 | .error_handler = cs5530_error_handler, | 204 | .error_handler = ata_bmdma_error_handler, |
217 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 205 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
206 | .cable_detect = ata_cable_40wire, | ||
218 | 207 | ||
219 | .qc_prep = ata_qc_prep, | 208 | .qc_prep = ata_qc_prep, |
220 | .qc_issue = cs5530_qc_issue_prot, | 209 | .qc_issue = cs5530_qc_issue_prot, |
diff --git a/drivers/ata/pata_cs5535.c b/drivers/ata/pata_cs5535.c index 1572e5c9031..08cccc9c659 100644 --- a/drivers/ata/pata_cs5535.c +++ b/drivers/ata/pata_cs5535.c | |||
@@ -70,36 +70,23 @@ | |||
70 | #define CS5535_BAD_PIO(timings) ( (timings&~0x80000000UL)==0x00009172 ) | 70 | #define CS5535_BAD_PIO(timings) ( (timings&~0x80000000UL)==0x00009172 ) |
71 | 71 | ||
72 | /** | 72 | /** |
73 | * cs5535_pre_reset - detect cable type | 73 | * cs5535_cable_detect - detect cable type |
74 | * @ap: Port to detect on | 74 | * @ap: Port to detect on |
75 | * | 75 | * |
76 | * Perform cable detection for ATA66 capable cable. Return a libata | 76 | * Perform cable detection for ATA66 capable cable. Return a libata |
77 | * cable type. | 77 | * cable type. |
78 | */ | 78 | */ |
79 | 79 | ||
80 | static int cs5535_pre_reset(struct ata_port *ap) | 80 | static int cs5535_cable_detect(struct ata_port *ap) |
81 | { | 81 | { |
82 | u8 cable; | 82 | u8 cable; |
83 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 83 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
84 | 84 | ||
85 | pci_read_config_byte(pdev, CS5535_CABLE_DETECT, &cable); | 85 | pci_read_config_byte(pdev, CS5535_CABLE_DETECT, &cable); |
86 | if (cable & 1) | 86 | if (cable & 1) |
87 | ap->cbl = ATA_CBL_PATA80; | 87 | return ATA_CBL_PATA80; |
88 | else | 88 | else |
89 | ap->cbl = ATA_CBL_PATA40; | 89 | return ATA_CBL_PATA40; |
90 | return ata_std_prereset(ap); | ||
91 | } | ||
92 | |||
93 | /** | ||
94 | * cs5535_error_handler - reset/probe | ||
95 | * @ap: Port to reset | ||
96 | * | ||
97 | * Reset and configure a port | ||
98 | */ | ||
99 | |||
100 | static void cs5535_error_handler(struct ata_port *ap) | ||
101 | { | ||
102 | ata_bmdma_drive_eh(ap, cs5535_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
103 | } | 90 | } |
104 | 91 | ||
105 | /** | 92 | /** |
@@ -205,8 +192,9 @@ static struct ata_port_operations cs5535_port_ops = { | |||
205 | 192 | ||
206 | .freeze = ata_bmdma_freeze, | 193 | .freeze = ata_bmdma_freeze, |
207 | .thaw = ata_bmdma_thaw, | 194 | .thaw = ata_bmdma_thaw, |
208 | .error_handler = cs5535_error_handler, | 195 | .error_handler = ata_bmdma_error_handler, |
209 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 196 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
197 | .cable_detect = cs5535_cable_detect, | ||
210 | 198 | ||
211 | .bmdma_setup = ata_bmdma_setup, | 199 | .bmdma_setup = ata_bmdma_setup, |
212 | .bmdma_start = ata_bmdma_start, | 200 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_cypress.c b/drivers/ata/pata_cypress.c index f69dde5f706..6ec049c3b1d 100644 --- a/drivers/ata/pata_cypress.c +++ b/drivers/ata/pata_cypress.c | |||
@@ -41,17 +41,6 @@ enum { | |||
41 | CY82_INDEX_TIMEOUT = 0x32 | 41 | CY82_INDEX_TIMEOUT = 0x32 |
42 | }; | 42 | }; |
43 | 43 | ||
44 | static int cy82c693_pre_reset(struct ata_port *ap) | ||
45 | { | ||
46 | ap->cbl = ATA_CBL_PATA40; | ||
47 | return ata_std_prereset(ap); | ||
48 | } | ||
49 | |||
50 | static void cy82c693_error_handler(struct ata_port *ap) | ||
51 | { | ||
52 | ata_bmdma_drive_eh(ap, cy82c693_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
53 | } | ||
54 | |||
55 | /** | 44 | /** |
56 | * cy82c693_set_piomode - set initial PIO mode data | 45 | * cy82c693_set_piomode - set initial PIO mode data |
57 | * @ap: ATA interface | 46 | * @ap: ATA interface |
@@ -156,8 +145,9 @@ static struct ata_port_operations cy82c693_port_ops = { | |||
156 | 145 | ||
157 | .freeze = ata_bmdma_freeze, | 146 | .freeze = ata_bmdma_freeze, |
158 | .thaw = ata_bmdma_thaw, | 147 | .thaw = ata_bmdma_thaw, |
159 | .error_handler = cy82c693_error_handler, | 148 | .error_handler = ata_bmdma_error_handler, |
160 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 149 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
150 | .cable_detect = ata_cable_40wire, | ||
161 | 151 | ||
162 | .bmdma_setup = ata_bmdma_setup, | 152 | .bmdma_setup = ata_bmdma_setup, |
163 | .bmdma_start = ata_bmdma_start, | 153 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_efar.c b/drivers/ata/pata_efar.c index dac7a6554f6..a3216850bba 100644 --- a/drivers/ata/pata_efar.c +++ b/drivers/ata/pata_efar.c | |||
@@ -22,10 +22,10 @@ | |||
22 | #include <linux/ata.h> | 22 | #include <linux/ata.h> |
23 | 23 | ||
24 | #define DRV_NAME "pata_efar" | 24 | #define DRV_NAME "pata_efar" |
25 | #define DRV_VERSION "0.4.3" | 25 | #define DRV_VERSION "0.4.4" |
26 | 26 | ||
27 | /** | 27 | /** |
28 | * efar_pre_reset - check for 40/80 pin | 28 | * efar_pre_reset - Enable bits |
29 | * @ap: Port | 29 | * @ap: Port |
30 | * | 30 | * |
31 | * Perform cable detection for the EFAR ATA interface. This is | 31 | * Perform cable detection for the EFAR ATA interface. This is |
@@ -38,18 +38,11 @@ static int efar_pre_reset(struct ata_port *ap) | |||
38 | { 0x41U, 1U, 0x80UL, 0x80UL }, /* port 0 */ | 38 | { 0x41U, 1U, 0x80UL, 0x80UL }, /* port 0 */ |
39 | { 0x43U, 1U, 0x80UL, 0x80UL }, /* port 1 */ | 39 | { 0x43U, 1U, 0x80UL, 0x80UL }, /* port 1 */ |
40 | }; | 40 | }; |
41 | |||
42 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 41 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
43 | u8 tmp; | ||
44 | 42 | ||
45 | if (!pci_test_config_bits(pdev, &efar_enable_bits[ap->port_no])) | 43 | if (!pci_test_config_bits(pdev, &efar_enable_bits[ap->port_no])) |
46 | return -ENOENT; | 44 | return -ENOENT; |
47 | 45 | ||
48 | pci_read_config_byte(pdev, 0x47, &tmp); | ||
49 | if (tmp & (2 >> ap->port_no)) | ||
50 | ap->cbl = ATA_CBL_PATA40; | ||
51 | else | ||
52 | ap->cbl = ATA_CBL_PATA80; | ||
53 | return ata_std_prereset(ap); | 46 | return ata_std_prereset(ap); |
54 | } | 47 | } |
55 | 48 | ||
@@ -67,6 +60,25 @@ static void efar_error_handler(struct ata_port *ap) | |||
67 | } | 60 | } |
68 | 61 | ||
69 | /** | 62 | /** |
63 | * efar_cable_detect - check for 40/80 pin | ||
64 | * @ap: Port | ||
65 | * | ||
66 | * Perform cable detection for the EFAR ATA interface. This is | ||
67 | * different to the PIIX arrangement | ||
68 | */ | ||
69 | |||
70 | static int efar_cable_detect(struct ata_port *ap) | ||
71 | { | ||
72 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
73 | u8 tmp; | ||
74 | |||
75 | pci_read_config_byte(pdev, 0x47, &tmp); | ||
76 | if (tmp & (2 >> ap->port_no)) | ||
77 | return ATA_CBL_PATA40; | ||
78 | return ATA_CBL_PATA80; | ||
79 | } | ||
80 | |||
81 | /** | ||
70 | * efar_set_piomode - Initialize host controller PATA PIO timings | 82 | * efar_set_piomode - Initialize host controller PATA PIO timings |
71 | * @ap: Port whose timings we are configuring | 83 | * @ap: Port whose timings we are configuring |
72 | * @adev: um | 84 | * @adev: um |
@@ -256,6 +268,7 @@ static const struct ata_port_operations efar_ops = { | |||
256 | .thaw = ata_bmdma_thaw, | 268 | .thaw = ata_bmdma_thaw, |
257 | .error_handler = efar_error_handler, | 269 | .error_handler = efar_error_handler, |
258 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 270 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
271 | .cable_detect = efar_cable_detect, | ||
259 | 272 | ||
260 | .bmdma_setup = ata_bmdma_setup, | 273 | .bmdma_setup = ata_bmdma_setup, |
261 | .bmdma_start = ata_bmdma_start, | 274 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_hpt366.c b/drivers/ata/pata_hpt366.c index baf35f87603..93cfa6d300a 100644 --- a/drivers/ata/pata_hpt366.c +++ b/drivers/ata/pata_hpt366.c | |||
@@ -27,7 +27,7 @@ | |||
27 | #include <linux/libata.h> | 27 | #include <linux/libata.h> |
28 | 28 | ||
29 | #define DRV_NAME "pata_hpt366" | 29 | #define DRV_NAME "pata_hpt366" |
30 | #define DRV_VERSION "0.6.0" | 30 | #define DRV_VERSION "0.6.1" |
31 | 31 | ||
32 | struct hpt_clock { | 32 | struct hpt_clock { |
33 | u8 xfer_speed; | 33 | u8 xfer_speed; |
@@ -169,13 +169,12 @@ static int hpt_dma_blacklisted(const struct ata_device *dev, char *modestr, cons | |||
169 | 169 | ||
170 | /** | 170 | /** |
171 | * hpt366_filter - mode selection filter | 171 | * hpt366_filter - mode selection filter |
172 | * @ap: ATA interface | ||
173 | * @adev: ATA device | 172 | * @adev: ATA device |
174 | * | 173 | * |
175 | * Block UDMA on devices that cause trouble with this controller. | 174 | * Block UDMA on devices that cause trouble with this controller. |
176 | */ | 175 | */ |
177 | 176 | ||
178 | static unsigned long hpt366_filter(const struct ata_port *ap, struct ata_device *adev, unsigned long mask) | 177 | static unsigned long hpt366_filter(struct ata_device *adev, unsigned long mask) |
179 | { | 178 | { |
180 | if (adev->class == ATA_DEV_ATA) { | 179 | if (adev->class == ATA_DEV_ATA) { |
181 | if (hpt_dma_blacklisted(adev, "UDMA", bad_ata33)) | 180 | if (hpt_dma_blacklisted(adev, "UDMA", bad_ata33)) |
@@ -185,7 +184,7 @@ static unsigned long hpt366_filter(const struct ata_port *ap, struct ata_device | |||
185 | if (hpt_dma_blacklisted(adev, "UDMA4", bad_ata66_4)) | 184 | if (hpt_dma_blacklisted(adev, "UDMA4", bad_ata66_4)) |
186 | mask &= ~(0x0F << ATA_SHIFT_UDMA); | 185 | mask &= ~(0x0F << ATA_SHIFT_UDMA); |
187 | } | 186 | } |
188 | return ata_pci_default_filter(ap, adev, mask); | 187 | return ata_pci_default_filter(adev, mask); |
189 | } | 188 | } |
190 | 189 | ||
191 | /** | 190 | /** |
@@ -210,24 +209,28 @@ static u32 hpt36x_find_mode(struct ata_port *ap, int speed) | |||
210 | return 0xffffffffU; /* silence compiler warning */ | 209 | return 0xffffffffU; /* silence compiler warning */ |
211 | } | 210 | } |
212 | 211 | ||
212 | static int hpt36x_cable_detect(struct ata_port *ap) | ||
213 | { | ||
214 | u8 ata66; | ||
215 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
216 | |||
217 | pci_read_config_byte(pdev, 0x5A, &ata66); | ||
218 | if (ata66 & (1 << ap->port_no)) | ||
219 | return ATA_CBL_PATA40; | ||
220 | return ATA_CBL_PATA80; | ||
221 | } | ||
222 | |||
213 | static int hpt36x_pre_reset(struct ata_port *ap) | 223 | static int hpt36x_pre_reset(struct ata_port *ap) |
214 | { | 224 | { |
215 | static const struct pci_bits hpt36x_enable_bits[] = { | 225 | static const struct pci_bits hpt36x_enable_bits[] = { |
216 | { 0x50, 1, 0x04, 0x04 }, | 226 | { 0x50, 1, 0x04, 0x04 }, |
217 | { 0x54, 1, 0x04, 0x04 } | 227 | { 0x54, 1, 0x04, 0x04 } |
218 | }; | 228 | }; |
219 | |||
220 | u8 ata66; | ||
221 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 229 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
222 | 230 | ||
223 | if (!pci_test_config_bits(pdev, &hpt36x_enable_bits[ap->port_no])) | 231 | if (!pci_test_config_bits(pdev, &hpt36x_enable_bits[ap->port_no])) |
224 | return -ENOENT; | 232 | return -ENOENT; |
225 | 233 | ||
226 | pci_read_config_byte(pdev, 0x5A, &ata66); | ||
227 | if (ata66 & (1 << ap->port_no)) | ||
228 | ap->cbl = ATA_CBL_PATA40; | ||
229 | else | ||
230 | ap->cbl = ATA_CBL_PATA80; | ||
231 | return ata_std_prereset(ap); | 234 | return ata_std_prereset(ap); |
232 | } | 235 | } |
233 | 236 | ||
@@ -354,6 +357,7 @@ static struct ata_port_operations hpt366_port_ops = { | |||
354 | .thaw = ata_bmdma_thaw, | 357 | .thaw = ata_bmdma_thaw, |
355 | .error_handler = hpt36x_error_handler, | 358 | .error_handler = hpt36x_error_handler, |
356 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 359 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
360 | .cable_detect = hpt36x_cable_detect, | ||
357 | 361 | ||
358 | .bmdma_setup = ata_bmdma_setup, | 362 | .bmdma_setup = ata_bmdma_setup, |
359 | .bmdma_start = ata_bmdma_start, | 363 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_hpt37x.c b/drivers/ata/pata_hpt37x.c index f331eeeafa0..41d83129634 100644 --- a/drivers/ata/pata_hpt37x.c +++ b/drivers/ata/pata_hpt37x.c | |||
@@ -8,6 +8,7 @@ | |||
8 | * Copyright (C) 1999-2003 Andre Hedrick <andre@linux-ide.org> | 8 | * Copyright (C) 1999-2003 Andre Hedrick <andre@linux-ide.org> |
9 | * Portions Copyright (C) 2001 Sun Microsystems, Inc. | 9 | * Portions Copyright (C) 2001 Sun Microsystems, Inc. |
10 | * Portions Copyright (C) 2003 Red Hat Inc | 10 | * Portions Copyright (C) 2003 Red Hat Inc |
11 | * Portions Copyright (C) 2005-2006 MontaVista Software, Inc. | ||
11 | * | 12 | * |
12 | * TODO | 13 | * TODO |
13 | * PLL mode | 14 | * PLL mode |
@@ -25,7 +26,7 @@ | |||
25 | #include <linux/libata.h> | 26 | #include <linux/libata.h> |
26 | 27 | ||
27 | #define DRV_NAME "pata_hpt37x" | 28 | #define DRV_NAME "pata_hpt37x" |
28 | #define DRV_VERSION "0.6.0" | 29 | #define DRV_VERSION "0.6.5" |
29 | 30 | ||
30 | struct hpt_clock { | 31 | struct hpt_clock { |
31 | u8 xfer_speed; | 32 | u8 xfer_speed; |
@@ -61,201 +62,75 @@ struct hpt_chip { | |||
61 | * 31 FIFO enable. | 62 | * 31 FIFO enable. |
62 | */ | 63 | */ |
63 | 64 | ||
64 | /* from highpoint documentation. these are old values */ | 65 | static struct hpt_clock hpt37x_timings_33[] = { |
65 | static const struct hpt_clock hpt370_timings_33[] = { | 66 | { XFER_UDMA_6, 0x12446231 }, /* 0x12646231 ?? */ |
66 | /* { XFER_UDMA_5, 0x1A85F442, 0x16454e31 }, */ | 67 | { XFER_UDMA_5, 0x12446231 }, |
67 | { XFER_UDMA_5, 0x16454e31 }, | 68 | { XFER_UDMA_4, 0x12446231 }, |
68 | { XFER_UDMA_4, 0x16454e31 }, | 69 | { XFER_UDMA_3, 0x126c6231 }, |
69 | { XFER_UDMA_3, 0x166d4e31 }, | 70 | { XFER_UDMA_2, 0x12486231 }, |
70 | { XFER_UDMA_2, 0x16494e31 }, | 71 | { XFER_UDMA_1, 0x124c6233 }, |
71 | { XFER_UDMA_1, 0x164d4e31 }, | 72 | { XFER_UDMA_0, 0x12506297 }, |
72 | { XFER_UDMA_0, 0x16514e31 }, | 73 | |
73 | 74 | { XFER_MW_DMA_2, 0x22406c31 }, | |
74 | { XFER_MW_DMA_2, 0x26514e21 }, | 75 | { XFER_MW_DMA_1, 0x22406c33 }, |
75 | { XFER_MW_DMA_1, 0x26514e33 }, | 76 | { XFER_MW_DMA_0, 0x22406c97 }, |
76 | { XFER_MW_DMA_0, 0x26514e97 }, | 77 | |
77 | 78 | { XFER_PIO_4, 0x06414e31 }, | |
78 | { XFER_PIO_4, 0x06514e21 }, | 79 | { XFER_PIO_3, 0x06414e42 }, |
79 | { XFER_PIO_3, 0x06514e22 }, | 80 | { XFER_PIO_2, 0x06414e53 }, |
80 | { XFER_PIO_2, 0x06514e33 }, | 81 | { XFER_PIO_1, 0x06814e93 }, |
81 | { XFER_PIO_1, 0x06914e43 }, | 82 | { XFER_PIO_0, 0x06814ea7 } |
82 | { XFER_PIO_0, 0x06914e57 }, | ||
83 | { 0, 0x06514e57 } | ||
84 | }; | 83 | }; |
85 | 84 | ||
86 | static const struct hpt_clock hpt370_timings_66[] = { | 85 | static struct hpt_clock hpt37x_timings_50[] = { |
87 | { XFER_UDMA_5, 0x14846231 }, | 86 | { XFER_UDMA_6, 0x12848242 }, |
88 | { XFER_UDMA_4, 0x14886231 }, | 87 | { XFER_UDMA_5, 0x12848242 }, |
89 | { XFER_UDMA_3, 0x148c6231 }, | 88 | { XFER_UDMA_4, 0x12ac8242 }, |
90 | { XFER_UDMA_2, 0x148c6231 }, | 89 | { XFER_UDMA_3, 0x128c8242 }, |
91 | { XFER_UDMA_1, 0x14906231 }, | 90 | { XFER_UDMA_2, 0x120c8242 }, |
92 | { XFER_UDMA_0, 0x14986231 }, | 91 | { XFER_UDMA_1, 0x12148254 }, |
93 | 92 | { XFER_UDMA_0, 0x121882ea }, | |
94 | { XFER_MW_DMA_2, 0x26514e21 }, | 93 | |
95 | { XFER_MW_DMA_1, 0x26514e33 }, | 94 | { XFER_MW_DMA_2, 0x22808242 }, |
96 | { XFER_MW_DMA_0, 0x26514e97 }, | 95 | { XFER_MW_DMA_1, 0x22808254 }, |
97 | 96 | { XFER_MW_DMA_0, 0x228082ea }, | |
98 | { XFER_PIO_4, 0x06514e21 }, | 97 | |
99 | { XFER_PIO_3, 0x06514e22 }, | 98 | { XFER_PIO_4, 0x0a81f442 }, |
100 | { XFER_PIO_2, 0x06514e33 }, | 99 | { XFER_PIO_3, 0x0a81f443 }, |
101 | { XFER_PIO_1, 0x06914e43 }, | 100 | { XFER_PIO_2, 0x0a81f454 }, |
102 | { XFER_PIO_0, 0x06914e57 }, | 101 | { XFER_PIO_1, 0x0ac1f465 }, |
103 | { 0, 0x06514e57 } | 102 | { XFER_PIO_0, 0x0ac1f48a } |
104 | }; | 103 | }; |
105 | 104 | ||
106 | /* these are the current (4 sep 2001) timings from highpoint */ | 105 | static struct hpt_clock hpt37x_timings_66[] = { |
107 | static const struct hpt_clock hpt370a_timings_33[] = { | 106 | { XFER_UDMA_6, 0x1c869c62 }, |
108 | { XFER_UDMA_5, 0x12446231 }, | 107 | { XFER_UDMA_5, 0x1cae9c62 }, /* 0x1c8a9c62 */ |
109 | { XFER_UDMA_4, 0x12446231 }, | 108 | { XFER_UDMA_4, 0x1c8a9c62 }, |
110 | { XFER_UDMA_3, 0x126c6231 }, | 109 | { XFER_UDMA_3, 0x1c8e9c62 }, |
111 | { XFER_UDMA_2, 0x12486231 }, | 110 | { XFER_UDMA_2, 0x1c929c62 }, |
112 | { XFER_UDMA_1, 0x124c6233 }, | 111 | { XFER_UDMA_1, 0x1c9a9c62 }, |
113 | { XFER_UDMA_0, 0x12506297 }, | 112 | { XFER_UDMA_0, 0x1c829c62 }, |
114 | 113 | ||
115 | { XFER_MW_DMA_2, 0x22406c31 }, | 114 | { XFER_MW_DMA_2, 0x2c829c62 }, |
116 | { XFER_MW_DMA_1, 0x22406c33 }, | 115 | { XFER_MW_DMA_1, 0x2c829c66 }, |
117 | { XFER_MW_DMA_0, 0x22406c97 }, | 116 | { XFER_MW_DMA_0, 0x2c829d2e }, |
118 | 117 | ||
119 | { XFER_PIO_4, 0x06414e31 }, | 118 | { XFER_PIO_4, 0x0c829c62 }, |
120 | { XFER_PIO_3, 0x06414e42 }, | 119 | { XFER_PIO_3, 0x0c829c84 }, |
121 | { XFER_PIO_2, 0x06414e53 }, | 120 | { XFER_PIO_2, 0x0c829ca6 }, |
122 | { XFER_PIO_1, 0x06814e93 }, | 121 | { XFER_PIO_1, 0x0d029d26 }, |
123 | { XFER_PIO_0, 0x06814ea7 }, | 122 | { XFER_PIO_0, 0x0d029d5e } |
124 | { 0, 0x06814ea7 } | ||
125 | }; | 123 | }; |
126 | 124 | ||
127 | /* 2x 33MHz timings */ | ||
128 | static const struct hpt_clock hpt370a_timings_66[] = { | ||
129 | { XFER_UDMA_5, 0x1488e673 }, | ||
130 | { XFER_UDMA_4, 0x1488e673 }, | ||
131 | { XFER_UDMA_3, 0x1498e673 }, | ||
132 | { XFER_UDMA_2, 0x1490e673 }, | ||
133 | { XFER_UDMA_1, 0x1498e677 }, | ||
134 | { XFER_UDMA_0, 0x14a0e73f }, | ||
135 | |||
136 | { XFER_MW_DMA_2, 0x2480fa73 }, | ||
137 | { XFER_MW_DMA_1, 0x2480fa77 }, | ||
138 | { XFER_MW_DMA_0, 0x2480fb3f }, | ||
139 | |||
140 | { XFER_PIO_4, 0x0c82be73 }, | ||
141 | { XFER_PIO_3, 0x0c82be95 }, | ||
142 | { XFER_PIO_2, 0x0c82beb7 }, | ||
143 | { XFER_PIO_1, 0x0d02bf37 }, | ||
144 | { XFER_PIO_0, 0x0d02bf5f }, | ||
145 | { 0, 0x0d02bf5f } | ||
146 | }; | ||
147 | |||
148 | static const struct hpt_clock hpt370a_timings_50[] = { | ||
149 | { XFER_UDMA_5, 0x12848242 }, | ||
150 | { XFER_UDMA_4, 0x12ac8242 }, | ||
151 | { XFER_UDMA_3, 0x128c8242 }, | ||
152 | { XFER_UDMA_2, 0x120c8242 }, | ||
153 | { XFER_UDMA_1, 0x12148254 }, | ||
154 | { XFER_UDMA_0, 0x121882ea }, | ||
155 | |||
156 | { XFER_MW_DMA_2, 0x22808242 }, | ||
157 | { XFER_MW_DMA_1, 0x22808254 }, | ||
158 | { XFER_MW_DMA_0, 0x228082ea }, | ||
159 | |||
160 | { XFER_PIO_4, 0x0a81f442 }, | ||
161 | { XFER_PIO_3, 0x0a81f443 }, | ||
162 | { XFER_PIO_2, 0x0a81f454 }, | ||
163 | { XFER_PIO_1, 0x0ac1f465 }, | ||
164 | { XFER_PIO_0, 0x0ac1f48a }, | ||
165 | { 0, 0x0ac1f48a } | ||
166 | }; | ||
167 | |||
168 | static const struct hpt_clock hpt372_timings_33[] = { | ||
169 | { XFER_UDMA_6, 0x1c81dc62 }, | ||
170 | { XFER_UDMA_5, 0x1c6ddc62 }, | ||
171 | { XFER_UDMA_4, 0x1c8ddc62 }, | ||
172 | { XFER_UDMA_3, 0x1c8edc62 }, /* checkme */ | ||
173 | { XFER_UDMA_2, 0x1c91dc62 }, | ||
174 | { XFER_UDMA_1, 0x1c9adc62 }, /* checkme */ | ||
175 | { XFER_UDMA_0, 0x1c82dc62 }, /* checkme */ | ||
176 | |||
177 | { XFER_MW_DMA_2, 0x2c829262 }, | ||
178 | { XFER_MW_DMA_1, 0x2c829266 }, /* checkme */ | ||
179 | { XFER_MW_DMA_0, 0x2c82922e }, /* checkme */ | ||
180 | |||
181 | { XFER_PIO_4, 0x0c829c62 }, | ||
182 | { XFER_PIO_3, 0x0c829c84 }, | ||
183 | { XFER_PIO_2, 0x0c829ca6 }, | ||
184 | { XFER_PIO_1, 0x0d029d26 }, | ||
185 | { XFER_PIO_0, 0x0d029d5e }, | ||
186 | { 0, 0x0d029d5e } | ||
187 | }; | ||
188 | |||
189 | static const struct hpt_clock hpt372_timings_50[] = { | ||
190 | { XFER_UDMA_5, 0x12848242 }, | ||
191 | { XFER_UDMA_4, 0x12ac8242 }, | ||
192 | { XFER_UDMA_3, 0x128c8242 }, | ||
193 | { XFER_UDMA_2, 0x120c8242 }, | ||
194 | { XFER_UDMA_1, 0x12148254 }, | ||
195 | { XFER_UDMA_0, 0x121882ea }, | ||
196 | |||
197 | { XFER_MW_DMA_2, 0x22808242 }, | ||
198 | { XFER_MW_DMA_1, 0x22808254 }, | ||
199 | { XFER_MW_DMA_0, 0x228082ea }, | ||
200 | |||
201 | { XFER_PIO_4, 0x0a81f442 }, | ||
202 | { XFER_PIO_3, 0x0a81f443 }, | ||
203 | { XFER_PIO_2, 0x0a81f454 }, | ||
204 | { XFER_PIO_1, 0x0ac1f465 }, | ||
205 | { XFER_PIO_0, 0x0ac1f48a }, | ||
206 | { 0, 0x0a81f443 } | ||
207 | }; | ||
208 | |||
209 | static const struct hpt_clock hpt372_timings_66[] = { | ||
210 | { XFER_UDMA_6, 0x1c869c62 }, | ||
211 | { XFER_UDMA_5, 0x1cae9c62 }, | ||
212 | { XFER_UDMA_4, 0x1c8a9c62 }, | ||
213 | { XFER_UDMA_3, 0x1c8e9c62 }, | ||
214 | { XFER_UDMA_2, 0x1c929c62 }, | ||
215 | { XFER_UDMA_1, 0x1c9a9c62 }, | ||
216 | { XFER_UDMA_0, 0x1c829c62 }, | ||
217 | |||
218 | { XFER_MW_DMA_2, 0x2c829c62 }, | ||
219 | { XFER_MW_DMA_1, 0x2c829c66 }, | ||
220 | { XFER_MW_DMA_0, 0x2c829d2e }, | ||
221 | |||
222 | { XFER_PIO_4, 0x0c829c62 }, | ||
223 | { XFER_PIO_3, 0x0c829c84 }, | ||
224 | { XFER_PIO_2, 0x0c829ca6 }, | ||
225 | { XFER_PIO_1, 0x0d029d26 }, | ||
226 | { XFER_PIO_0, 0x0d029d5e }, | ||
227 | { 0, 0x0d029d26 } | ||
228 | }; | ||
229 | |||
230 | static const struct hpt_clock hpt374_timings_33[] = { | ||
231 | { XFER_UDMA_6, 0x12808242 }, | ||
232 | { XFER_UDMA_5, 0x12848242 }, | ||
233 | { XFER_UDMA_4, 0x12ac8242 }, | ||
234 | { XFER_UDMA_3, 0x128c8242 }, | ||
235 | { XFER_UDMA_2, 0x120c8242 }, | ||
236 | { XFER_UDMA_1, 0x12148254 }, | ||
237 | { XFER_UDMA_0, 0x121882ea }, | ||
238 | |||
239 | { XFER_MW_DMA_2, 0x22808242 }, | ||
240 | { XFER_MW_DMA_1, 0x22808254 }, | ||
241 | { XFER_MW_DMA_0, 0x228082ea }, | ||
242 | |||
243 | { XFER_PIO_4, 0x0a81f442 }, | ||
244 | { XFER_PIO_3, 0x0a81f443 }, | ||
245 | { XFER_PIO_2, 0x0a81f454 }, | ||
246 | { XFER_PIO_1, 0x0ac1f465 }, | ||
247 | { XFER_PIO_0, 0x0ac1f48a }, | ||
248 | { 0, 0x06814e93 } | ||
249 | }; | ||
250 | 125 | ||
251 | static const struct hpt_chip hpt370 = { | 126 | static const struct hpt_chip hpt370 = { |
252 | "HPT370", | 127 | "HPT370", |
253 | 48, | 128 | 48, |
254 | { | 129 | { |
255 | hpt370_timings_33, | 130 | hpt37x_timings_33, |
256 | NULL, | 131 | NULL, |
257 | NULL, | 132 | NULL, |
258 | hpt370_timings_66 | 133 | NULL |
259 | } | 134 | } |
260 | }; | 135 | }; |
261 | 136 | ||
@@ -263,10 +138,10 @@ static const struct hpt_chip hpt370a = { | |||
263 | "HPT370A", | 138 | "HPT370A", |
264 | 48, | 139 | 48, |
265 | { | 140 | { |
266 | hpt370a_timings_33, | 141 | hpt37x_timings_33, |
267 | NULL, | 142 | NULL, |
268 | hpt370a_timings_50, | 143 | hpt37x_timings_50, |
269 | hpt370a_timings_66 | 144 | NULL |
270 | } | 145 | } |
271 | }; | 146 | }; |
272 | 147 | ||
@@ -274,10 +149,10 @@ static const struct hpt_chip hpt372 = { | |||
274 | "HPT372", | 149 | "HPT372", |
275 | 55, | 150 | 55, |
276 | { | 151 | { |
277 | hpt372_timings_33, | 152 | hpt37x_timings_33, |
278 | NULL, | 153 | NULL, |
279 | hpt372_timings_50, | 154 | hpt37x_timings_50, |
280 | hpt372_timings_66 | 155 | hpt37x_timings_66 |
281 | } | 156 | } |
282 | }; | 157 | }; |
283 | 158 | ||
@@ -285,10 +160,10 @@ static const struct hpt_chip hpt302 = { | |||
285 | "HPT302", | 160 | "HPT302", |
286 | 66, | 161 | 66, |
287 | { | 162 | { |
288 | hpt372_timings_33, | 163 | hpt37x_timings_33, |
289 | NULL, | 164 | NULL, |
290 | hpt372_timings_50, | 165 | hpt37x_timings_50, |
291 | hpt372_timings_66 | 166 | hpt37x_timings_66 |
292 | } | 167 | } |
293 | }; | 168 | }; |
294 | 169 | ||
@@ -296,10 +171,10 @@ static const struct hpt_chip hpt371 = { | |||
296 | "HPT371", | 171 | "HPT371", |
297 | 66, | 172 | 66, |
298 | { | 173 | { |
299 | hpt372_timings_33, | 174 | hpt37x_timings_33, |
300 | NULL, | 175 | NULL, |
301 | hpt372_timings_50, | 176 | hpt37x_timings_50, |
302 | hpt372_timings_66 | 177 | hpt37x_timings_66 |
303 | } | 178 | } |
304 | }; | 179 | }; |
305 | 180 | ||
@@ -307,10 +182,10 @@ static const struct hpt_chip hpt372a = { | |||
307 | "HPT372A", | 182 | "HPT372A", |
308 | 66, | 183 | 66, |
309 | { | 184 | { |
310 | hpt372_timings_33, | 185 | hpt37x_timings_33, |
311 | NULL, | 186 | NULL, |
312 | hpt372_timings_50, | 187 | hpt37x_timings_50, |
313 | hpt372_timings_66 | 188 | hpt37x_timings_66 |
314 | } | 189 | } |
315 | }; | 190 | }; |
316 | 191 | ||
@@ -318,7 +193,7 @@ static const struct hpt_chip hpt374 = { | |||
318 | "HPT374", | 193 | "HPT374", |
319 | 48, | 194 | 48, |
320 | { | 195 | { |
321 | hpt374_timings_33, | 196 | hpt37x_timings_33, |
322 | NULL, | 197 | NULL, |
323 | NULL, | 198 | NULL, |
324 | NULL | 199 | NULL |
@@ -397,13 +272,12 @@ static const char *bad_ata100_5[] = { | |||
397 | 272 | ||
398 | /** | 273 | /** |
399 | * hpt370_filter - mode selection filter | 274 | * hpt370_filter - mode selection filter |
400 | * @ap: ATA interface | ||
401 | * @adev: ATA device | 275 | * @adev: ATA device |
402 | * | 276 | * |
403 | * Block UDMA on devices that cause trouble with this controller. | 277 | * Block UDMA on devices that cause trouble with this controller. |
404 | */ | 278 | */ |
405 | 279 | ||
406 | static unsigned long hpt370_filter(const struct ata_port *ap, struct ata_device *adev, unsigned long mask) | 280 | static unsigned long hpt370_filter(struct ata_device *adev, unsigned long mask) |
407 | { | 281 | { |
408 | if (adev->class == ATA_DEV_ATA) { | 282 | if (adev->class == ATA_DEV_ATA) { |
409 | if (hpt_dma_blacklisted(adev, "UDMA", bad_ata33)) | 283 | if (hpt_dma_blacklisted(adev, "UDMA", bad_ata33)) |
@@ -411,24 +285,23 @@ static unsigned long hpt370_filter(const struct ata_port *ap, struct ata_device | |||
411 | if (hpt_dma_blacklisted(adev, "UDMA100", bad_ata100_5)) | 285 | if (hpt_dma_blacklisted(adev, "UDMA100", bad_ata100_5)) |
412 | mask &= ~(0x1F << ATA_SHIFT_UDMA); | 286 | mask &= ~(0x1F << ATA_SHIFT_UDMA); |
413 | } | 287 | } |
414 | return ata_pci_default_filter(ap, adev, mask); | 288 | return ata_pci_default_filter(adev, mask); |
415 | } | 289 | } |
416 | 290 | ||
417 | /** | 291 | /** |
418 | * hpt370a_filter - mode selection filter | 292 | * hpt370a_filter - mode selection filter |
419 | * @ap: ATA interface | ||
420 | * @adev: ATA device | 293 | * @adev: ATA device |
421 | * | 294 | * |
422 | * Block UDMA on devices that cause trouble with this controller. | 295 | * Block UDMA on devices that cause trouble with this controller. |
423 | */ | 296 | */ |
424 | 297 | ||
425 | static unsigned long hpt370a_filter(const struct ata_port *ap, struct ata_device *adev, unsigned long mask) | 298 | static unsigned long hpt370a_filter(struct ata_device *adev, unsigned long mask) |
426 | { | 299 | { |
427 | if (adev->class != ATA_DEV_ATA) { | 300 | if (adev->class != ATA_DEV_ATA) { |
428 | if (hpt_dma_blacklisted(adev, "UDMA100", bad_ata100_5)) | 301 | if (hpt_dma_blacklisted(adev, "UDMA100", bad_ata100_5)) |
429 | mask &= ~ (0x1F << ATA_SHIFT_UDMA); | 302 | mask &= ~ (0x1F << ATA_SHIFT_UDMA); |
430 | } | 303 | } |
431 | return ata_pci_default_filter(ap, adev, mask); | 304 | return ata_pci_default_filter(adev, mask); |
432 | } | 305 | } |
433 | 306 | ||
434 | /** | 307 | /** |
@@ -462,8 +335,7 @@ static int hpt37x_pre_reset(struct ata_port *ap) | |||
462 | ap->cbl = ATA_CBL_PATA80; | 335 | ap->cbl = ATA_CBL_PATA80; |
463 | 336 | ||
464 | /* Reset the state machine */ | 337 | /* Reset the state machine */ |
465 | pci_write_config_byte(pdev, 0x50, 0x37); | 338 | pci_write_config_byte(pdev, 0x50 + 4 * ap->port_no, 0x37); |
466 | pci_write_config_byte(pdev, 0x54, 0x37); | ||
467 | udelay(100); | 339 | udelay(100); |
468 | 340 | ||
469 | return ata_std_prereset(ap); | 341 | return ata_std_prereset(ap); |
@@ -513,8 +385,7 @@ static int hpt374_pre_reset(struct ata_port *ap) | |||
513 | ap->cbl = ATA_CBL_PATA80; | 385 | ap->cbl = ATA_CBL_PATA80; |
514 | 386 | ||
515 | /* Reset the state machine */ | 387 | /* Reset the state machine */ |
516 | pci_write_config_byte(pdev, 0x50, 0x37); | 388 | pci_write_config_byte(pdev, 0x50 + 4 * ap->port_no, 0x37); |
517 | pci_write_config_byte(pdev, 0x54, 0x37); | ||
518 | udelay(100); | 389 | udelay(100); |
519 | 390 | ||
520 | return ata_std_prereset(ap); | 391 | return ata_std_prereset(ap); |
@@ -1032,6 +903,24 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1032 | .udma_mask = 0x3f, | 903 | .udma_mask = 0x3f, |
1033 | .port_ops = &hpt370a_port_ops | 904 | .port_ops = &hpt370a_port_ops |
1034 | }; | 905 | }; |
906 | /* HPT370 - UDMA100 */ | ||
907 | static struct ata_port_info info_hpt370_33 = { | ||
908 | .sht = &hpt37x_sht, | ||
909 | .flags = ATA_FLAG_SLAVE_POSS|ATA_FLAG_SRST, | ||
910 | .pio_mask = 0x1f, | ||
911 | .mwdma_mask = 0x07, | ||
912 | .udma_mask = 0x0f, | ||
913 | .port_ops = &hpt370_port_ops | ||
914 | }; | ||
915 | /* HPT370A - UDMA100 */ | ||
916 | static struct ata_port_info info_hpt370a_33 = { | ||
917 | .sht = &hpt37x_sht, | ||
918 | .flags = ATA_FLAG_SLAVE_POSS|ATA_FLAG_SRST, | ||
919 | .pio_mask = 0x1f, | ||
920 | .mwdma_mask = 0x07, | ||
921 | .udma_mask = 0x0f, | ||
922 | .port_ops = &hpt370a_port_ops | ||
923 | }; | ||
1035 | /* HPT371, 372 and friends - UDMA133 */ | 924 | /* HPT371, 372 and friends - UDMA133 */ |
1036 | static struct ata_port_info info_hpt372 = { | 925 | static struct ata_port_info info_hpt372 = { |
1037 | .sht = &hpt37x_sht, | 926 | .sht = &hpt37x_sht, |
@@ -1067,7 +956,11 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1067 | 956 | ||
1068 | u8 irqmask; | 957 | u8 irqmask; |
1069 | u32 class_rev; | 958 | u32 class_rev; |
959 | u8 mcr1; | ||
1070 | u32 freq; | 960 | u32 freq; |
961 | int prefer_dpll = 1; | ||
962 | |||
963 | unsigned long iobase = pci_resource_start(dev, 4); | ||
1071 | 964 | ||
1072 | const struct hpt_chip *chip_table; | 965 | const struct hpt_chip *chip_table; |
1073 | int clock_slot; | 966 | int clock_slot; |
@@ -1088,10 +981,12 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1088 | case 3: | 981 | case 3: |
1089 | port = &info_hpt370; | 982 | port = &info_hpt370; |
1090 | chip_table = &hpt370; | 983 | chip_table = &hpt370; |
984 | prefer_dpll = 0; | ||
1091 | break; | 985 | break; |
1092 | case 4: | 986 | case 4: |
1093 | port = &info_hpt370a; | 987 | port = &info_hpt370a; |
1094 | chip_table = &hpt370a; | 988 | chip_table = &hpt370a; |
989 | prefer_dpll = 0; | ||
1095 | break; | 990 | break; |
1096 | case 5: | 991 | case 5: |
1097 | port = &info_hpt372; | 992 | port = &info_hpt372; |
@@ -1119,8 +1014,16 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1119 | chip_table = &hpt302; | 1014 | chip_table = &hpt302; |
1120 | break; | 1015 | break; |
1121 | case PCI_DEVICE_ID_TTI_HPT371: | 1016 | case PCI_DEVICE_ID_TTI_HPT371: |
1017 | if (class_rev > 1) | ||
1018 | return -ENODEV; | ||
1122 | port = &info_hpt372; | 1019 | port = &info_hpt372; |
1123 | chip_table = &hpt371; | 1020 | chip_table = &hpt371; |
1021 | /* Single channel device, master is not present | ||
1022 | but the BIOS (or us for non x86) must mark it | ||
1023 | absent */ | ||
1024 | pci_read_config_byte(dev, 0x50, &mcr1); | ||
1025 | mcr1 &= ~0x04; | ||
1026 | pci_write_config_byte(dev, 0x50, mcr1); | ||
1124 | break; | 1027 | break; |
1125 | case PCI_DEVICE_ID_TTI_HPT374: | 1028 | case PCI_DEVICE_ID_TTI_HPT374: |
1126 | chip_table = &hpt374; | 1029 | chip_table = &hpt374; |
@@ -1150,8 +1053,18 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1150 | */ | 1053 | */ |
1151 | 1054 | ||
1152 | pci_write_config_byte(dev, 0x5b, 0x23); | 1055 | pci_write_config_byte(dev, 0x5b, 0x23); |
1056 | |||
1057 | /* | ||
1058 | * HighPoint does this for HPT372A. | ||
1059 | * NOTE: This register is only writeable via I/O space. | ||
1060 | */ | ||
1061 | if (chip_table == &hpt372a) | ||
1062 | outb(0x0e, iobase + 0x9c); | ||
1153 | 1063 | ||
1154 | pci_read_config_dword(dev, 0x70, &freq); | 1064 | /* Some devices do not let this value be accessed via PCI space |
1065 | according to the old driver */ | ||
1066 | |||
1067 | freq = inl(iobase + 0x90); | ||
1155 | if ((freq >> 12) != 0xABCDE) { | 1068 | if ((freq >> 12) != 0xABCDE) { |
1156 | int i; | 1069 | int i; |
1157 | u8 sr; | 1070 | u8 sr; |
@@ -1162,7 +1075,7 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1162 | /* This is the process the HPT371 BIOS is reported to use */ | 1075 | /* This is the process the HPT371 BIOS is reported to use */ |
1163 | for(i = 0; i < 128; i++) { | 1076 | for(i = 0; i < 128; i++) { |
1164 | pci_read_config_byte(dev, 0x78, &sr); | 1077 | pci_read_config_byte(dev, 0x78, &sr); |
1165 | total += sr; | 1078 | total += sr & 0x1FF; |
1166 | udelay(15); | 1079 | udelay(15); |
1167 | } | 1080 | } |
1168 | freq = total / 128; | 1081 | freq = total / 128; |
@@ -1173,15 +1086,27 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1173 | * Turn the frequency check into a band and then find a timing | 1086 | * Turn the frequency check into a band and then find a timing |
1174 | * table to match it. | 1087 | * table to match it. |
1175 | */ | 1088 | */ |
1176 | 1089 | ||
1177 | clock_slot = hpt37x_clock_slot(freq, chip_table->base); | 1090 | clock_slot = hpt37x_clock_slot(freq, chip_table->base); |
1178 | if (chip_table->clocks[clock_slot] == NULL) { | 1091 | if (chip_table->clocks[clock_slot] == NULL || prefer_dpll) { |
1179 | /* | 1092 | /* |
1180 | * We need to try PLL mode instead | 1093 | * We need to try PLL mode instead |
1094 | * | ||
1095 | * For non UDMA133 capable devices we should | ||
1096 | * use a 50MHz DPLL by choice | ||
1181 | */ | 1097 | */ |
1182 | unsigned int f_low = (MHz[clock_slot] * chip_table->base) / 192; | 1098 | unsigned int f_low, f_high; |
1183 | unsigned int f_high = f_low + 2; | ||
1184 | int adjust; | 1099 | int adjust; |
1100 | |||
1101 | clock_slot = 2; | ||
1102 | if (port->udma_mask & 0xE0) | ||
1103 | clock_slot = 3; | ||
1104 | |||
1105 | f_low = (MHz[clock_slot] * chip_table->base) / 192; | ||
1106 | f_high = f_low + 2; | ||
1107 | |||
1108 | /* Select the DPLL clock. */ | ||
1109 | pci_write_config_byte(dev, 0x5b, 0x21); | ||
1185 | 1110 | ||
1186 | for(adjust = 0; adjust < 8; adjust++) { | 1111 | for(adjust = 0; adjust < 8; adjust++) { |
1187 | if (hpt37x_calibrate_dpll(dev)) | 1112 | if (hpt37x_calibrate_dpll(dev)) |
@@ -1197,25 +1122,27 @@ static int hpt37x_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
1197 | printk(KERN_WARNING "hpt37x: DPLL did not stabilize.\n"); | 1122 | printk(KERN_WARNING "hpt37x: DPLL did not stabilize.\n"); |
1198 | return -ENODEV; | 1123 | return -ENODEV; |
1199 | } | 1124 | } |
1200 | /* Check if this works for all cases */ | 1125 | if (clock_slot == 3) |
1201 | port->private_data = (void *)hpt370_timings_66; | 1126 | port->private_data = (void *)hpt37x_timings_66; |
1127 | else | ||
1128 | port->private_data = (void *)hpt37x_timings_50; | ||
1202 | 1129 | ||
1203 | printk(KERN_INFO "hpt37x: Bus clock %dMHz, using DPLL.\n", MHz[clock_slot]); | 1130 | printk(KERN_INFO "hpt37x: Bus clock %dMHz, using DPLL.\n", MHz[clock_slot]); |
1204 | } else { | 1131 | } else { |
1205 | port->private_data = (void *)chip_table->clocks[clock_slot]; | 1132 | port->private_data = (void *)chip_table->clocks[clock_slot]; |
1206 | /* | 1133 | /* |
1207 | * Perform a final fixup. The 371 and 372 clock determines | 1134 | * Perform a final fixup. Note that we will have used the |
1208 | * if UDMA133 is available. | 1135 | * DPLL on the HPT372 which means we don't have to worry |
1209 | */ | 1136 | * about lack of UDMA133 support on lower clocks |
1210 | 1137 | */ | |
1211 | if (clock_slot == 2 && chip_table == &hpt372) { /* 50Mhz */ | 1138 | |
1212 | printk(KERN_WARNING "pata_hpt37x: No UDMA133 support available with 50MHz bus clock.\n"); | 1139 | if (clock_slot < 2 && port == &info_hpt370) |
1213 | if (port == &info_hpt372) | 1140 | port = &info_hpt370_33; |
1214 | port = &info_hpt372_50; | 1141 | if (clock_slot < 2 && port == &info_hpt370a) |
1215 | else BUG(); | 1142 | port = &info_hpt370a_33; |
1216 | } | ||
1217 | printk(KERN_INFO "hpt37x: %s: Bus clock %dMHz.\n", chip_table->name, MHz[clock_slot]); | 1143 | printk(KERN_INFO "hpt37x: %s: Bus clock %dMHz.\n", chip_table->name, MHz[clock_slot]); |
1218 | } | 1144 | } |
1145 | |||
1219 | port_info[0] = port_info[1] = port; | 1146 | port_info[0] = port_info[1] = port; |
1220 | /* Now kick off ATA set up */ | 1147 | /* Now kick off ATA set up */ |
1221 | return ata_pci_init_one(dev, port_info, 2); | 1148 | return ata_pci_init_one(dev, port_info, 2); |
diff --git a/drivers/ata/pata_hpt3x2n.c b/drivers/ata/pata_hpt3x2n.c index 65f2e180e7f..6a34521b9e0 100644 --- a/drivers/ata/pata_hpt3x2n.c +++ b/drivers/ata/pata_hpt3x2n.c | |||
@@ -8,10 +8,10 @@ | |||
8 | * Copyright (C) 1999-2003 Andre Hedrick <andre@linux-ide.org> | 8 | * Copyright (C) 1999-2003 Andre Hedrick <andre@linux-ide.org> |
9 | * Portions Copyright (C) 2001 Sun Microsystems, Inc. | 9 | * Portions Copyright (C) 2001 Sun Microsystems, Inc. |
10 | * Portions Copyright (C) 2003 Red Hat Inc | 10 | * Portions Copyright (C) 2003 Red Hat Inc |
11 | * Portions Copyright (C) 2005-2006 MontaVista Software, Inc. | ||
11 | * | 12 | * |
12 | * | 13 | * |
13 | * TODO | 14 | * TODO |
14 | * 371N | ||
15 | * Work out best PLL policy | 15 | * Work out best PLL policy |
16 | */ | 16 | */ |
17 | 17 | ||
@@ -25,7 +25,7 @@ | |||
25 | #include <linux/libata.h> | 25 | #include <linux/libata.h> |
26 | 26 | ||
27 | #define DRV_NAME "pata_hpt3x2n" | 27 | #define DRV_NAME "pata_hpt3x2n" |
28 | #define DRV_VERSION "0.3.2" | 28 | #define DRV_VERSION "0.3.3" |
29 | 29 | ||
30 | enum { | 30 | enum { |
31 | HPT_PCI_FAST = (1 << 31), | 31 | HPT_PCI_FAST = (1 << 31), |
@@ -115,14 +115,13 @@ static u32 hpt3x2n_find_mode(struct ata_port *ap, int speed) | |||
115 | } | 115 | } |
116 | 116 | ||
117 | /** | 117 | /** |
118 | * hpt3x2n_pre_reset - reset the hpt3x2n bus | 118 | * hpt3x2n_cable_detect - Detect the cable type |
119 | * @ap: ATA port to reset | 119 | * @ap: ATA port to detect on |
120 | * | 120 | * |
121 | * Perform the initial reset handling for the 3x2n series controllers. | 121 | * Return the cable type attached to this port |
122 | * Reset the hardware and state machine, obtain the cable type. | ||
123 | */ | 122 | */ |
124 | 123 | ||
125 | static int hpt3xn_pre_reset(struct ata_port *ap) | 124 | static int hpt3x2n_cable_detect(struct ata_port *ap) |
126 | { | 125 | { |
127 | u8 scr2, ata66; | 126 | u8 scr2, ata66; |
128 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 127 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
@@ -135,15 +134,26 @@ static int hpt3xn_pre_reset(struct ata_port *ap) | |||
135 | pci_write_config_byte(pdev, 0x5B, scr2); | 134 | pci_write_config_byte(pdev, 0x5B, scr2); |
136 | 135 | ||
137 | if (ata66 & (1 << ap->port_no)) | 136 | if (ata66 & (1 << ap->port_no)) |
138 | ap->cbl = ATA_CBL_PATA40; | 137 | return ATA_CBL_PATA40; |
139 | else | 138 | else |
140 | ap->cbl = ATA_CBL_PATA80; | 139 | return ATA_CBL_PATA80; |
140 | } | ||
141 | |||
142 | /** | ||
143 | * hpt3x2n_pre_reset - reset the hpt3x2n bus | ||
144 | * @ap: ATA port to reset | ||
145 | * @deadline: deadline jiffies for the operation | ||
146 | * | ||
147 | * Perform the initial reset handling for the 3x2n series controllers. | ||
148 | * Reset the hardware and state machine, | ||
149 | */ | ||
141 | 150 | ||
151 | static int hpt3xn_pre_reset(struct ata_port *ap) | ||
152 | { | ||
153 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
142 | /* Reset the state machine */ | 154 | /* Reset the state machine */ |
143 | pci_write_config_byte(pdev, 0x50, 0x37); | 155 | pci_write_config_byte(pdev, 0x50 + 4 * ap->port_no, 0x37); |
144 | pci_write_config_byte(pdev, 0x54, 0x37); | ||
145 | udelay(100); | 156 | udelay(100); |
146 | |||
147 | return ata_std_prereset(ap); | 157 | return ata_std_prereset(ap); |
148 | } | 158 | } |
149 | 159 | ||
@@ -364,6 +374,7 @@ static struct ata_port_operations hpt3x2n_port_ops = { | |||
364 | .thaw = ata_bmdma_thaw, | 374 | .thaw = ata_bmdma_thaw, |
365 | .error_handler = hpt3x2n_error_handler, | 375 | .error_handler = hpt3x2n_error_handler, |
366 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 376 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
377 | .cable_detect = hpt3x2n_cable_detect, | ||
367 | 378 | ||
368 | .bmdma_setup = ata_bmdma_setup, | 379 | .bmdma_setup = ata_bmdma_setup, |
369 | .bmdma_start = ata_bmdma_start, | 380 | .bmdma_start = ata_bmdma_start, |
@@ -422,8 +433,9 @@ static int hpt3x2n_pci_clock(struct pci_dev *pdev) | |||
422 | { | 433 | { |
423 | unsigned long freq; | 434 | unsigned long freq; |
424 | u32 fcnt; | 435 | u32 fcnt; |
436 | unsigned long iobase = pci_resource_start(pdev, 4); | ||
425 | 437 | ||
426 | pci_read_config_dword(pdev, 0x70/*CHECKME*/, &fcnt); | 438 | fcnt = inl(iobase + 0x90); /* Not PCI readable for some chips */ |
427 | if ((fcnt >> 12) != 0xABCDE) { | 439 | if ((fcnt >> 12) != 0xABCDE) { |
428 | printk(KERN_WARNING "hpt3xn: BIOS clock data not set.\n"); | 440 | printk(KERN_WARNING "hpt3xn: BIOS clock data not set.\n"); |
429 | return 33; /* Not BIOS set */ | 441 | return 33; /* Not BIOS set */ |
@@ -492,6 +504,7 @@ static int hpt3x2n_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
492 | unsigned int pci_mhz; | 504 | unsigned int pci_mhz; |
493 | unsigned int f_low, f_high; | 505 | unsigned int f_low, f_high; |
494 | int adjust; | 506 | int adjust; |
507 | unsigned long iobase = pci_resource_start(dev, 4); | ||
495 | 508 | ||
496 | pci_read_config_dword(dev, PCI_CLASS_REVISION, &class_rev); | 509 | pci_read_config_dword(dev, PCI_CLASS_REVISION, &class_rev); |
497 | class_rev &= 0xFF; | 510 | class_rev &= 0xFF; |
@@ -501,6 +514,11 @@ static int hpt3x2n_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
501 | if (class_rev < 6) | 514 | if (class_rev < 6) |
502 | return -ENODEV; | 515 | return -ENODEV; |
503 | break; | 516 | break; |
517 | case PCI_DEVICE_ID_TTI_HPT371: | ||
518 | if (class_rev < 2) | ||
519 | return -ENODEV; | ||
520 | /* 371N if rev > 1 */ | ||
521 | break; | ||
504 | case PCI_DEVICE_ID_TTI_HPT372: | 522 | case PCI_DEVICE_ID_TTI_HPT372: |
505 | /* 372N if rev >= 1*/ | 523 | /* 372N if rev >= 1*/ |
506 | if (class_rev == 0) | 524 | if (class_rev == 0) |
@@ -528,6 +546,19 @@ static int hpt3x2n_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
528 | irqmask &= ~0x10; | 546 | irqmask &= ~0x10; |
529 | pci_write_config_byte(dev, 0x5a, irqmask); | 547 | pci_write_config_byte(dev, 0x5a, irqmask); |
530 | 548 | ||
549 | /* | ||
550 | * HPT371 chips physically have only one channel, the secondary one, | ||
551 | * but the primary channel registers do exist! Go figure... | ||
552 | * So, we manually disable the non-existing channel here | ||
553 | * (if the BIOS hasn't done this already). | ||
554 | */ | ||
555 | if (dev->device == PCI_DEVICE_ID_TTI_HPT371) { | ||
556 | u8 mcr1; | ||
557 | pci_read_config_byte(dev, 0x50, &mcr1); | ||
558 | mcr1 &= ~0x04; | ||
559 | pci_write_config_byte(dev, 0x50, mcr1); | ||
560 | } | ||
561 | |||
531 | /* Tune the PLL. HPT recommend using 75 for SATA, 66 for UDMA133 or | 562 | /* Tune the PLL. HPT recommend using 75 for SATA, 66 for UDMA133 or |
532 | 50 for UDMA100. Right now we always use 66 */ | 563 | 50 for UDMA100. Right now we always use 66 */ |
533 | 564 | ||
@@ -546,14 +577,24 @@ static int hpt3x2n_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
546 | break; | 577 | break; |
547 | pci_write_config_dword(dev, 0x5C, (f_high << 16) | f_low); | 578 | pci_write_config_dword(dev, 0x5C, (f_high << 16) | f_low); |
548 | } | 579 | } |
549 | if (adjust == 8) | 580 | if (adjust == 8) { |
550 | printk(KERN_WARNING "hpt3xn: DPLL did not stabilize.\n"); | 581 | printk(KERN_WARNING "hpt3x2n: DPLL did not stabilize.\n"); |
582 | return -ENODEV; | ||
583 | } | ||
551 | 584 | ||
552 | /* Set our private data up. We only need a few flags so we use | 585 | /* Set our private data up. We only need a few flags so we use |
553 | it directly */ | 586 | it directly */ |
554 | port->private_data = NULL; | 587 | port->private_data = NULL; |
555 | if (pci_mhz > 60) | 588 | if (pci_mhz > 60) { |
556 | port->private_data = (void *)PCI66; | 589 | port->private_data = (void *)PCI66; |
590 | /* | ||
591 | * On HPT371N, if ATA clock is 66 MHz we must set bit 2 in | ||
592 | * the MISC. register to stretch the UltraDMA Tss timing. | ||
593 | * NOTE: This register is only writeable via I/O space. | ||
594 | */ | ||
595 | if (dev->device == PCI_DEVICE_ID_TTI_HPT371) | ||
596 | outb(inb(iobase + 0x9c) | 0x04, iobase + 0x9c); | ||
597 | } | ||
557 | 598 | ||
558 | /* Now kick off ATA set up */ | 599 | /* Now kick off ATA set up */ |
559 | port_info[0] = port_info[1] = port; | 600 | port_info[0] = port_info[1] = port; |
@@ -562,6 +603,7 @@ static int hpt3x2n_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
562 | 603 | ||
563 | static const struct pci_device_id hpt3x2n[] = { | 604 | static const struct pci_device_id hpt3x2n[] = { |
564 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT366), }, | 605 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT366), }, |
606 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT371), }, | ||
565 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT372), }, | 607 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT372), }, |
566 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT302), }, | 608 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT302), }, |
567 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT372N), }, | 609 | { PCI_VDEVICE(TTI, PCI_DEVICE_ID_TTI_HPT372N), }, |
diff --git a/drivers/ata/pata_hpt3x3.c b/drivers/ata/pata_hpt3x3.c index 813485c8526..ac28ec8c50a 100644 --- a/drivers/ata/pata_hpt3x3.c +++ b/drivers/ata/pata_hpt3x3.c | |||
@@ -25,25 +25,6 @@ | |||
25 | #define DRV_NAME "pata_hpt3x3" | 25 | #define DRV_NAME "pata_hpt3x3" |
26 | #define DRV_VERSION "0.4.2" | 26 | #define DRV_VERSION "0.4.2" |
27 | 27 | ||
28 | static int hpt3x3_probe_init(struct ata_port *ap) | ||
29 | { | ||
30 | ap->cbl = ATA_CBL_PATA40; | ||
31 | return ata_std_prereset(ap); | ||
32 | } | ||
33 | |||
34 | /** | ||
35 | * hpt3x3_probe_reset - reset the hpt3x3 bus | ||
36 | * @ap: ATA port to reset | ||
37 | * | ||
38 | * Perform the housekeeping when doing an ATA bus reeset. We just | ||
39 | * need to force the cable type. | ||
40 | */ | ||
41 | |||
42 | static void hpt3x3_error_handler(struct ata_port *ap) | ||
43 | { | ||
44 | return ata_bmdma_drive_eh(ap, hpt3x3_probe_init, ata_std_softreset, NULL, ata_std_postreset); | ||
45 | } | ||
46 | |||
47 | /** | 28 | /** |
48 | * hpt3x3_set_piomode - PIO setup | 29 | * hpt3x3_set_piomode - PIO setup |
49 | * @ap: ATA interface | 30 | * @ap: ATA interface |
@@ -139,8 +120,9 @@ static struct ata_port_operations hpt3x3_port_ops = { | |||
139 | 120 | ||
140 | .freeze = ata_bmdma_freeze, | 121 | .freeze = ata_bmdma_freeze, |
141 | .thaw = ata_bmdma_thaw, | 122 | .thaw = ata_bmdma_thaw, |
142 | .error_handler = hpt3x3_error_handler, | 123 | .error_handler = ata_bmdma_error_handler, |
143 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 124 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
125 | .cable_detect = ata_cable_40wire, | ||
144 | 126 | ||
145 | .bmdma_setup = ata_bmdma_setup, | 127 | .bmdma_setup = ata_bmdma_setup, |
146 | .bmdma_start = ata_bmdma_start, | 128 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_isapnp.c b/drivers/ata/pata_isapnp.c index 1a61cc89174..d042efdfbac 100644 --- a/drivers/ata/pata_isapnp.c +++ b/drivers/ata/pata_isapnp.c | |||
@@ -49,13 +49,13 @@ static struct ata_port_operations isapnp_port_ops = { | |||
49 | .thaw = ata_bmdma_thaw, | 49 | .thaw = ata_bmdma_thaw, |
50 | .error_handler = ata_bmdma_error_handler, | 50 | .error_handler = ata_bmdma_error_handler, |
51 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 51 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
52 | .cable_detect = ata_cable_40wire, | ||
52 | 53 | ||
53 | .qc_prep = ata_qc_prep, | 54 | .qc_prep = ata_qc_prep, |
54 | .qc_issue = ata_qc_issue_prot, | 55 | .qc_issue = ata_qc_issue_prot, |
55 | 56 | ||
56 | .data_xfer = ata_data_xfer, | 57 | .data_xfer = ata_data_xfer, |
57 | 58 | ||
58 | .irq_handler = ata_interrupt, | ||
59 | .irq_clear = ata_bmdma_irq_clear, | 59 | .irq_clear = ata_bmdma_irq_clear, |
60 | .irq_on = ata_irq_on, | 60 | .irq_on = ata_irq_on, |
61 | .irq_ack = ata_irq_ack, | 61 | .irq_ack = ata_irq_ack, |
@@ -74,8 +74,10 @@ static struct ata_port_operations isapnp_port_ops = { | |||
74 | 74 | ||
75 | static int isapnp_init_one(struct pnp_dev *idev, const struct pnp_device_id *dev_id) | 75 | static int isapnp_init_one(struct pnp_dev *idev, const struct pnp_device_id *dev_id) |
76 | { | 76 | { |
77 | struct ata_probe_ent ae; | 77 | struct ata_host *host; |
78 | struct ata_port *ap; | ||
78 | void __iomem *cmd_addr, *ctl_addr; | 79 | void __iomem *cmd_addr, *ctl_addr; |
80 | int rc; | ||
79 | 81 | ||
80 | if (pnp_port_valid(idev, 0) == 0) | 82 | if (pnp_port_valid(idev, 0) == 0) |
81 | return -ENODEV; | 83 | return -ENODEV; |
@@ -84,34 +86,36 @@ static int isapnp_init_one(struct pnp_dev *idev, const struct pnp_device_id *dev | |||
84 | if (pnp_irq_valid(idev, 0) == 0) | 86 | if (pnp_irq_valid(idev, 0) == 0) |
85 | return -ENODEV; | 87 | return -ENODEV; |
86 | 88 | ||
89 | /* allocate host */ | ||
90 | host = ata_host_alloc(&idev->dev, 1); | ||
91 | if (!host) | ||
92 | return -ENOMEM; | ||
93 | |||
94 | /* acquire resources and fill host */ | ||
87 | cmd_addr = devm_ioport_map(&idev->dev, pnp_port_start(idev, 0), 8); | 95 | cmd_addr = devm_ioport_map(&idev->dev, pnp_port_start(idev, 0), 8); |
88 | if (!cmd_addr) | 96 | if (!cmd_addr) |
89 | return -ENOMEM; | 97 | return -ENOMEM; |
90 | 98 | ||
91 | memset(&ae, 0, sizeof(struct ata_probe_ent)); | 99 | ap = host->ports[0]; |
92 | INIT_LIST_HEAD(&ae.node); | 100 | |
93 | ae.dev = &idev->dev; | 101 | ap->ops = &isapnp_port_ops; |
94 | ae.port_ops = &isapnp_port_ops; | 102 | ap->pio_mask = 1; |
95 | ae.sht = &isapnp_sht; | 103 | ap->flags |= ATA_FLAG_SLAVE_POSS; |
96 | ae.n_ports = 1; | 104 | |
97 | ae.pio_mask = 1; /* ISA so PIO 0 cycles */ | 105 | ap->ioaddr.cmd_addr = cmd_addr; |
98 | ae.irq = pnp_irq(idev, 0); | ||
99 | ae.irq_flags = 0; | ||
100 | ae.port_flags = ATA_FLAG_SLAVE_POSS; | ||
101 | ae.port[0].cmd_addr = cmd_addr; | ||
102 | 106 | ||
103 | if (pnp_port_valid(idev, 1) == 0) { | 107 | if (pnp_port_valid(idev, 1) == 0) { |
104 | ctl_addr = devm_ioport_map(&idev->dev, | 108 | ctl_addr = devm_ioport_map(&idev->dev, |
105 | pnp_port_start(idev, 1), 1); | 109 | pnp_port_start(idev, 1), 1); |
106 | ae.port[0].altstatus_addr = ctl_addr; | 110 | ap->ioaddr.altstatus_addr = ctl_addr; |
107 | ae.port[0].ctl_addr = ctl_addr; | 111 | ap->ioaddr.ctl_addr = ctl_addr; |
108 | ae.port_flags |= ATA_FLAG_SRST; | ||
109 | } | 112 | } |
110 | ata_std_ports(&ae.port[0]); | ||
111 | 113 | ||
112 | if (ata_device_add(&ae) == 0) | 114 | ata_std_ports(&ap->ioaddr); |
113 | return -ENODEV; | 115 | |
114 | return 0; | 116 | /* activate */ |
117 | return ata_host_activate(host, pnp_irq(idev, 0), ata_interrupt, 0, | ||
118 | &isapnp_sht); | ||
115 | } | 119 | } |
116 | 120 | ||
117 | /** | 121 | /** |
diff --git a/drivers/ata/pata_it8213.c b/drivers/ata/pata_it8213.c index ea734701555..011306ef833 100644 --- a/drivers/ata/pata_it8213.c +++ b/drivers/ata/pata_it8213.c | |||
@@ -25,8 +25,8 @@ | |||
25 | * it8213_pre_reset - check for 40/80 pin | 25 | * it8213_pre_reset - check for 40/80 pin |
26 | * @ap: Port | 26 | * @ap: Port |
27 | * | 27 | * |
28 | * Perform cable detection for the 8213 ATA interface. This is | 28 | * Filter out ports by the enable bits before doing the normal reset |
29 | * different to the PIIX arrangement | 29 | * and probe. |
30 | */ | 30 | */ |
31 | 31 | ||
32 | static int it8213_pre_reset(struct ata_port *ap) | 32 | static int it8213_pre_reset(struct ata_port *ap) |
@@ -34,23 +34,14 @@ static int it8213_pre_reset(struct ata_port *ap) | |||
34 | static const struct pci_bits it8213_enable_bits[] = { | 34 | static const struct pci_bits it8213_enable_bits[] = { |
35 | { 0x41U, 1U, 0x80UL, 0x80UL }, /* port 0 */ | 35 | { 0x41U, 1U, 0x80UL, 0x80UL }, /* port 0 */ |
36 | }; | 36 | }; |
37 | |||
38 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 37 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
39 | u8 tmp; | ||
40 | |||
41 | if (!pci_test_config_bits(pdev, &it8213_enable_bits[ap->port_no])) | 38 | if (!pci_test_config_bits(pdev, &it8213_enable_bits[ap->port_no])) |
42 | return -ENOENT; | 39 | return -ENOENT; |
43 | |||
44 | pci_read_config_byte(pdev, 0x42, &tmp); | ||
45 | if (tmp & 2) /* The initial docs are incorrect */ | ||
46 | ap->cbl = ATA_CBL_PATA40; | ||
47 | else | ||
48 | ap->cbl = ATA_CBL_PATA80; | ||
49 | return ata_std_prereset(ap); | 40 | return ata_std_prereset(ap); |
50 | } | 41 | } |
51 | 42 | ||
52 | /** | 43 | /** |
53 | * it8213_probe_reset - Probe specified port on PATA host controller | 44 | * it8213_error_handler - Probe specified port on PATA host controller |
54 | * @ap: Port to probe | 45 | * @ap: Port to probe |
55 | * | 46 | * |
56 | * LOCKING: | 47 | * LOCKING: |
@@ -63,9 +54,27 @@ static void it8213_error_handler(struct ata_port *ap) | |||
63 | } | 54 | } |
64 | 55 | ||
65 | /** | 56 | /** |
57 | * it8213_cable_detect - check for 40/80 pin | ||
58 | * @ap: Port | ||
59 | * | ||
60 | * Perform cable detection for the 8213 ATA interface. This is | ||
61 | * different to the PIIX arrangement | ||
62 | */ | ||
63 | |||
64 | static int it8213_cable_detect(struct ata_port *ap) | ||
65 | { | ||
66 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | ||
67 | u8 tmp; | ||
68 | pci_read_config_byte(pdev, 0x42, &tmp); | ||
69 | if (tmp & 2) /* The initial docs are incorrect */ | ||
70 | return ATA_CBL_PATA40; | ||
71 | return ATA_CBL_PATA80; | ||
72 | } | ||
73 | |||
74 | /** | ||
66 | * it8213_set_piomode - Initialize host controller PATA PIO timings | 75 | * it8213_set_piomode - Initialize host controller PATA PIO timings |
67 | * @ap: Port whose timings we are configuring | 76 | * @ap: Port whose timings we are configuring |
68 | * @adev: um | 77 | * @adev: Device whose timings we are configuring |
69 | * | 78 | * |
70 | * Set PIO mode for device, in host controller PCI config space. | 79 | * Set PIO mode for device, in host controller PCI config space. |
71 | * | 80 | * |
@@ -268,6 +277,7 @@ static const struct ata_port_operations it8213_ops = { | |||
268 | .thaw = ata_bmdma_thaw, | 277 | .thaw = ata_bmdma_thaw, |
269 | .error_handler = it8213_error_handler, | 278 | .error_handler = it8213_error_handler, |
270 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 279 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
280 | .cable_detect = it8213_cable_detect, | ||
271 | 281 | ||
272 | .bmdma_setup = ata_bmdma_setup, | 282 | .bmdma_setup = ata_bmdma_setup, |
273 | .bmdma_start = ata_bmdma_start, | 283 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_it821x.c b/drivers/ata/pata_it821x.c index 35ecb2ba067..f1f8cec8c22 100644 --- a/drivers/ata/pata_it821x.c +++ b/drivers/ata/pata_it821x.c | |||
@@ -80,7 +80,7 @@ | |||
80 | 80 | ||
81 | 81 | ||
82 | #define DRV_NAME "pata_it821x" | 82 | #define DRV_NAME "pata_it821x" |
83 | #define DRV_VERSION "0.3.4" | 83 | #define DRV_VERSION "0.3.6" |
84 | 84 | ||
85 | struct it821x_dev | 85 | struct it821x_dev |
86 | { | 86 | { |
@@ -113,31 +113,6 @@ struct it821x_dev | |||
113 | static int it8212_noraid; | 113 | static int it8212_noraid; |
114 | 114 | ||
115 | /** | 115 | /** |
116 | * it821x_pre_reset - probe | ||
117 | * @ap: ATA port | ||
118 | * | ||
119 | * Set the cable type | ||
120 | */ | ||
121 | |||
122 | static int it821x_pre_reset(struct ata_port *ap) | ||
123 | { | ||
124 | ap->cbl = ATA_CBL_PATA80; | ||
125 | return ata_std_prereset(ap); | ||
126 | } | ||
127 | |||
128 | /** | ||
129 | * it821x_error_handler - probe/reset | ||
130 | * @ap: ATA port | ||
131 | * | ||
132 | * Set the cable type and trigger a probe | ||
133 | */ | ||
134 | |||
135 | static void it821x_error_handler(struct ata_port *ap) | ||
136 | { | ||
137 | return ata_bmdma_drive_eh(ap, it821x_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
138 | } | ||
139 | |||
140 | /** | ||
141 | * it821x_program - program the PIO/MWDMA registers | 116 | * it821x_program - program the PIO/MWDMA registers |
142 | * @ap: ATA port | 117 | * @ap: ATA port |
143 | * @adev: Device to program | 118 | * @adev: Device to program |
@@ -520,7 +495,6 @@ static int it821x_smart_set_mode(struct ata_port *ap, struct ata_device **unused | |||
520 | 495 | ||
521 | /** | 496 | /** |
522 | * it821x_dev_config - Called each device identify | 497 | * it821x_dev_config - Called each device identify |
523 | * @ap: ATA port | ||
524 | * @adev: Device that has just been identified | 498 | * @adev: Device that has just been identified |
525 | * | 499 | * |
526 | * Perform the initial setup needed for each device that is chip | 500 | * Perform the initial setup needed for each device that is chip |
@@ -531,7 +505,7 @@ static int it821x_smart_set_mode(struct ata_port *ap, struct ata_device **unused | |||
531 | * basically we need to filter commands for this chip. | 505 | * basically we need to filter commands for this chip. |
532 | */ | 506 | */ |
533 | 507 | ||
534 | static void it821x_dev_config(struct ata_port *ap, struct ata_device *adev) | 508 | static void it821x_dev_config(struct ata_device *adev) |
535 | { | 509 | { |
536 | unsigned char model_num[ATA_ID_PROD_LEN + 1]; | 510 | unsigned char model_num[ATA_ID_PROD_LEN + 1]; |
537 | 511 | ||
@@ -667,8 +641,9 @@ static struct ata_port_operations it821x_smart_port_ops = { | |||
667 | 641 | ||
668 | .freeze = ata_bmdma_freeze, | 642 | .freeze = ata_bmdma_freeze, |
669 | .thaw = ata_bmdma_thaw, | 643 | .thaw = ata_bmdma_thaw, |
670 | .error_handler = it821x_error_handler, | 644 | .error_handler = ata_bmdma_error_handler, |
671 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 645 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
646 | .cable_detect = ata_cable_unknown, | ||
672 | 647 | ||
673 | .bmdma_setup = ata_bmdma_setup, | 648 | .bmdma_setup = ata_bmdma_setup, |
674 | .bmdma_start = ata_bmdma_start, | 649 | .bmdma_start = ata_bmdma_start, |
@@ -703,8 +678,9 @@ static struct ata_port_operations it821x_passthru_port_ops = { | |||
703 | 678 | ||
704 | .freeze = ata_bmdma_freeze, | 679 | .freeze = ata_bmdma_freeze, |
705 | .thaw = ata_bmdma_thaw, | 680 | .thaw = ata_bmdma_thaw, |
706 | .error_handler = it821x_error_handler, | 681 | .error_handler = ata_bmdma_error_handler, |
707 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 682 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
683 | .cable_detect = ata_cable_unknown, | ||
708 | 684 | ||
709 | .bmdma_setup = ata_bmdma_setup, | 685 | .bmdma_setup = ata_bmdma_setup, |
710 | .bmdma_start = it821x_passthru_bmdma_start, | 686 | .bmdma_start = it821x_passthru_bmdma_start, |
diff --git a/drivers/ata/pata_ixp4xx_cf.c b/drivers/ata/pata_ixp4xx_cf.c index c6f0e192755..420c343e571 100644 --- a/drivers/ata/pata_ixp4xx_cf.c +++ b/drivers/ata/pata_ixp4xx_cf.c | |||
@@ -129,8 +129,8 @@ static struct ata_port_operations ixp4xx_port_ops = { | |||
129 | .qc_issue = ata_qc_issue_prot, | 129 | .qc_issue = ata_qc_issue_prot, |
130 | .eng_timeout = ata_eng_timeout, | 130 | .eng_timeout = ata_eng_timeout, |
131 | .data_xfer = ixp4xx_mmio_data_xfer, | 131 | .data_xfer = ixp4xx_mmio_data_xfer, |
132 | .cable_detect = ata_cable_40wire, | ||
132 | 133 | ||
133 | .irq_handler = ata_interrupt, | ||
134 | .irq_clear = ixp4xx_irq_clear, | 134 | .irq_clear = ixp4xx_irq_clear, |
135 | .irq_on = ata_irq_on, | 135 | .irq_on = ata_irq_on, |
136 | .irq_ack = ata_irq_ack, | 136 | .irq_ack = ata_irq_ack, |
@@ -173,12 +173,12 @@ static void ixp4xx_setup_port(struct ata_ioports *ioaddr, | |||
173 | 173 | ||
174 | static __devinit int ixp4xx_pata_probe(struct platform_device *pdev) | 174 | static __devinit int ixp4xx_pata_probe(struct platform_device *pdev) |
175 | { | 175 | { |
176 | int ret; | ||
177 | unsigned int irq; | 176 | unsigned int irq; |
178 | struct resource *cs0, *cs1; | 177 | struct resource *cs0, *cs1; |
179 | struct ata_probe_ent ae; | 178 | struct ata_host *host; |
180 | 179 | struct ata_port *ap; | |
181 | struct ixp4xx_pata_data *data = pdev->dev.platform_data; | 180 | struct ixp4xx_pata_data *data = pdev->dev.platform_data; |
181 | int rc; | ||
182 | 182 | ||
183 | cs0 = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 183 | cs0 = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
184 | cs1 = platform_get_resource(pdev, IORESOURCE_MEM, 1); | 184 | cs1 = platform_get_resource(pdev, IORESOURCE_MEM, 1); |
@@ -186,6 +186,12 @@ static __devinit int ixp4xx_pata_probe(struct platform_device *pdev) | |||
186 | if (!cs0 || !cs1) | 186 | if (!cs0 || !cs1) |
187 | return -EINVAL; | 187 | return -EINVAL; |
188 | 188 | ||
189 | /* allocate host */ | ||
190 | host = ata_host_alloc(&pdev->dev, 1); | ||
191 | if (!host) | ||
192 | return -ENOMEM; | ||
193 | |||
194 | /* acquire resources and fill host */ | ||
189 | pdev->dev.coherent_dma_mask = DMA_32BIT_MASK; | 195 | pdev->dev.coherent_dma_mask = DMA_32BIT_MASK; |
190 | 196 | ||
191 | data->cs0 = devm_ioremap(&pdev->dev, cs0->start, 0x1000); | 197 | data->cs0 = devm_ioremap(&pdev->dev, cs0->start, 0x1000); |
@@ -199,32 +205,22 @@ static __devinit int ixp4xx_pata_probe(struct platform_device *pdev) | |||
199 | *data->cs0_cfg = data->cs0_bits; | 205 | *data->cs0_cfg = data->cs0_bits; |
200 | *data->cs1_cfg = data->cs1_bits; | 206 | *data->cs1_cfg = data->cs1_bits; |
201 | 207 | ||
202 | memset(&ae, 0, sizeof(struct ata_probe_ent)); | 208 | ap = host->ports[0]; |
203 | INIT_LIST_HEAD(&ae.node); | ||
204 | 209 | ||
205 | ae.dev = &pdev->dev; | 210 | ap->ops = &ixp4xx_port_ops; |
206 | ae.port_ops = &ixp4xx_port_ops; | 211 | ap->pio_mask = 0x1f; /* PIO4 */ |
207 | ae.sht = &ixp4xx_sht; | 212 | ap->flags |= ATA_FLAG_MMIO | ATA_FLAG_NO_LEGACY | ATA_FLAG_NO_ATAPI; |
208 | ae.n_ports = 1; | ||
209 | ae.pio_mask = 0x1f; /* PIO4 */ | ||
210 | ae.irq = irq; | ||
211 | ae.irq_flags = 0; | ||
212 | ae.port_flags = ATA_FLAG_MMIO | ATA_FLAG_NO_LEGACY | ||
213 | | ATA_FLAG_NO_ATAPI | ATA_FLAG_SRST; | ||
214 | 213 | ||
215 | /* run in polling mode if no irq has been assigned */ | 214 | /* run in polling mode if no irq has been assigned */ |
216 | if (!irq) | 215 | if (!irq) |
217 | ae.port_flags |= ATA_FLAG_PIO_POLLING; | 216 | ap->flags |= ATA_FLAG_PIO_POLLING; |
218 | 217 | ||
219 | ixp4xx_setup_port(&ae.port[0], data); | 218 | ixp4xx_setup_port(&ap->ioaddr, data); |
220 | 219 | ||
221 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); | 220 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); |
222 | 221 | ||
223 | ret = ata_device_add(&ae); | 222 | /* activate host */ |
224 | if (ret == 0) | 223 | return ata_host_activate(host, irq, ata_interrupt, 0, &ixp4xx_sht); |
225 | return -ENODEV; | ||
226 | |||
227 | return 0; | ||
228 | } | 224 | } |
229 | 225 | ||
230 | static __devexit int ixp4xx_pata_remove(struct platform_device *dev) | 226 | static __devexit int ixp4xx_pata_remove(struct platform_device *dev) |
diff --git a/drivers/ata/pata_legacy.c b/drivers/ata/pata_legacy.c index 86fbcd6a742..707099291e0 100644 --- a/drivers/ata/pata_legacy.c +++ b/drivers/ata/pata_legacy.c | |||
@@ -162,6 +162,7 @@ static struct ata_port_operations simple_port_ops = { | |||
162 | .thaw = ata_bmdma_thaw, | 162 | .thaw = ata_bmdma_thaw, |
163 | .error_handler = ata_bmdma_error_handler, | 163 | .error_handler = ata_bmdma_error_handler, |
164 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 164 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
165 | .cable_detect = ata_cable_40wire, | ||
165 | 166 | ||
166 | .qc_prep = ata_qc_prep, | 167 | .qc_prep = ata_qc_prep, |
167 | .qc_issue = ata_qc_issue_prot, | 168 | .qc_issue = ata_qc_issue_prot, |
@@ -185,6 +186,7 @@ static struct ata_port_operations legacy_port_ops = { | |||
185 | .check_status = ata_check_status, | 186 | .check_status = ata_check_status, |
186 | .exec_command = ata_exec_command, | 187 | .exec_command = ata_exec_command, |
187 | .dev_select = ata_std_dev_select, | 188 | .dev_select = ata_std_dev_select, |
189 | .cable_detect = ata_cable_40wire, | ||
188 | 190 | ||
189 | .freeze = ata_bmdma_freeze, | 191 | .freeze = ata_bmdma_freeze, |
190 | .thaw = ata_bmdma_thaw, | 192 | .thaw = ata_bmdma_thaw, |
@@ -305,6 +307,7 @@ static struct ata_port_operations pdc20230_port_ops = { | |||
305 | .thaw = ata_bmdma_thaw, | 307 | .thaw = ata_bmdma_thaw, |
306 | .error_handler = ata_bmdma_error_handler, | 308 | .error_handler = ata_bmdma_error_handler, |
307 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 309 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
310 | .cable_detect = ata_cable_40wire, | ||
308 | 311 | ||
309 | .qc_prep = ata_qc_prep, | 312 | .qc_prep = ata_qc_prep, |
310 | .qc_issue = ata_qc_issue_prot, | 313 | .qc_issue = ata_qc_issue_prot, |
@@ -360,6 +363,7 @@ static struct ata_port_operations ht6560a_port_ops = { | |||
360 | .thaw = ata_bmdma_thaw, | 363 | .thaw = ata_bmdma_thaw, |
361 | .error_handler = ata_bmdma_error_handler, | 364 | .error_handler = ata_bmdma_error_handler, |
362 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 365 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
366 | .cable_detect = ata_cable_40wire, | ||
363 | 367 | ||
364 | .qc_prep = ata_qc_prep, | 368 | .qc_prep = ata_qc_prep, |
365 | .qc_issue = ata_qc_issue_prot, | 369 | .qc_issue = ata_qc_issue_prot, |
@@ -426,6 +430,7 @@ static struct ata_port_operations ht6560b_port_ops = { | |||
426 | .thaw = ata_bmdma_thaw, | 430 | .thaw = ata_bmdma_thaw, |
427 | .error_handler = ata_bmdma_error_handler, | 431 | .error_handler = ata_bmdma_error_handler, |
428 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 432 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
433 | .cable_detect = ata_cable_40wire, | ||
429 | 434 | ||
430 | .qc_prep = ata_qc_prep, | 435 | .qc_prep = ata_qc_prep, |
431 | .qc_issue = ata_qc_issue_prot, | 436 | .qc_issue = ata_qc_issue_prot, |
@@ -547,6 +552,7 @@ static struct ata_port_operations opti82c611a_port_ops = { | |||
547 | .thaw = ata_bmdma_thaw, | 552 | .thaw = ata_bmdma_thaw, |
548 | .error_handler = ata_bmdma_error_handler, | 553 | .error_handler = ata_bmdma_error_handler, |
549 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 554 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
555 | .cable_detect = ata_cable_40wire, | ||
550 | 556 | ||
551 | .qc_prep = ata_qc_prep, | 557 | .qc_prep = ata_qc_prep, |
552 | .qc_issue = ata_qc_issue_prot, | 558 | .qc_issue = ata_qc_issue_prot, |
@@ -680,6 +686,7 @@ static struct ata_port_operations opti82c46x_port_ops = { | |||
680 | .thaw = ata_bmdma_thaw, | 686 | .thaw = ata_bmdma_thaw, |
681 | .error_handler = ata_bmdma_error_handler, | 687 | .error_handler = ata_bmdma_error_handler, |
682 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 688 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
689 | .cable_detect = ata_cable_40wire, | ||
683 | 690 | ||
684 | .qc_prep = ata_qc_prep, | 691 | .qc_prep = ata_qc_prep, |
685 | .qc_issue = opti82c46x_qc_issue_prot, | 692 | .qc_issue = opti82c46x_qc_issue_prot, |
@@ -709,7 +716,8 @@ static struct ata_port_operations opti82c46x_port_ops = { | |||
709 | static __init int legacy_init_one(int port, unsigned long io, unsigned long ctrl, int irq) | 716 | static __init int legacy_init_one(int port, unsigned long io, unsigned long ctrl, int irq) |
710 | { | 717 | { |
711 | struct legacy_data *ld = &legacy_data[nr_legacy_host]; | 718 | struct legacy_data *ld = &legacy_data[nr_legacy_host]; |
712 | struct ata_probe_ent ae; | 719 | struct ata_host *host; |
720 | struct ata_port *ap; | ||
713 | struct platform_device *pdev; | 721 | struct platform_device *pdev; |
714 | struct ata_port_operations *ops = &legacy_port_ops; | 722 | struct ata_port_operations *ops = &legacy_port_ops; |
715 | void __iomem *io_addr, *ctrl_addr; | 723 | void __iomem *io_addr, *ctrl_addr; |
@@ -791,24 +799,23 @@ static __init int legacy_init_one(int port, unsigned long io, unsigned long ctrl | |||
791 | if (ops == &legacy_port_ops && (autospeed & mask)) | 799 | if (ops == &legacy_port_ops && (autospeed & mask)) |
792 | ops = &simple_port_ops; | 800 | ops = &simple_port_ops; |
793 | 801 | ||
794 | memset(&ae, 0, sizeof(struct ata_probe_ent)); | 802 | ret = -ENOMEM; |
795 | INIT_LIST_HEAD(&ae.node); | 803 | host = ata_host_alloc(&pdev->dev, 1); |
796 | ae.dev = &pdev->dev; | 804 | if (!host) |
797 | ae.port_ops = ops; | 805 | goto fail; |
798 | ae.sht = &legacy_sht; | 806 | ap = host->ports[0]; |
799 | ae.n_ports = 1; | 807 | |
800 | ae.pio_mask = pio_modes; | 808 | ap->ops = ops; |
801 | ae.irq = irq; | 809 | ap->pio_mask = pio_modes; |
802 | ae.irq_flags = 0; | 810 | ap->flags |= ATA_FLAG_SLAVE_POSS | iordy; |
803 | ae.port_flags = ATA_FLAG_SLAVE_POSS|ATA_FLAG_SRST|iordy; | 811 | ap->ioaddr.cmd_addr = io_addr; |
804 | ae.port[0].cmd_addr = io_addr; | 812 | ap->ioaddr.altstatus_addr = ctrl_addr; |
805 | ae.port[0].altstatus_addr = ctrl_addr; | 813 | ap->ioaddr.ctl_addr = ctrl_addr; |
806 | ae.port[0].ctl_addr = ctrl_addr; | 814 | ata_std_ports(&ap->ioaddr); |
807 | ata_std_ports(&ae.port[0]); | 815 | ap->private_data = ld; |
808 | ae.private_data = ld; | 816 | |
809 | 817 | ret = ata_host_activate(host, irq, ata_interrupt, 0, &legacy_sht); | |
810 | ret = -ENODEV; | 818 | if (ret) |
811 | if (!ata_device_add(&ae)) | ||
812 | goto fail; | 819 | goto fail; |
813 | 820 | ||
814 | legacy_host[nr_legacy_host++] = dev_get_drvdata(&pdev->dev); | 821 | legacy_host[nr_legacy_host++] = dev_get_drvdata(&pdev->dev); |
diff --git a/drivers/ata/pata_marvell.c b/drivers/ata/pata_marvell.c index 6dd7c4ef3e6..d9b94a1b695 100644 --- a/drivers/ata/pata_marvell.c +++ b/drivers/ata/pata_marvell.c | |||
@@ -20,7 +20,7 @@ | |||
20 | #include <linux/ata.h> | 20 | #include <linux/ata.h> |
21 | 21 | ||
22 | #define DRV_NAME "pata_marvell" | 22 | #define DRV_NAME "pata_marvell" |
23 | #define DRV_VERSION "0.1.1" | 23 | #define DRV_VERSION "0.1.4" |
24 | 24 | ||
25 | /** | 25 | /** |
26 | * marvell_pre_reset - check for 40/80 pin | 26 | * marvell_pre_reset - check for 40/80 pin |
@@ -52,22 +52,23 @@ static int marvell_pre_reset(struct ata_port *ap) | |||
52 | if ((pdev->device == 0x6145) && (ap->port_no == 0) && | 52 | if ((pdev->device == 0x6145) && (ap->port_no == 0) && |
53 | (!(devices & 0x10))) /* PATA enable ? */ | 53 | (!(devices & 0x10))) /* PATA enable ? */ |
54 | return -ENOENT; | 54 | return -ENOENT; |
55 | return ata_std_prereset(ap); | ||
56 | } | ||
55 | 57 | ||
58 | static int marvell_cable_detect(struct ata_port *ap) | ||
59 | { | ||
56 | /* Cable type */ | 60 | /* Cable type */ |
57 | switch(ap->port_no) | 61 | switch(ap->port_no) |
58 | { | 62 | { |
59 | case 0: | 63 | case 0: |
60 | if (ioread8(ap->ioaddr.bmdma_addr + 1) & 1) | 64 | if (ioread8(ap->ioaddr.bmdma_addr + 1) & 1) |
61 | ap->cbl = ATA_CBL_PATA40; | 65 | return ATA_CBL_PATA40; |
62 | else | 66 | return ATA_CBL_PATA80; |
63 | ap->cbl = ATA_CBL_PATA80; | ||
64 | break; | ||
65 | |||
66 | case 1: /* Legacy SATA port */ | 67 | case 1: /* Legacy SATA port */ |
67 | ap->cbl = ATA_CBL_SATA; | 68 | return ATA_CBL_SATA; |
68 | break; | ||
69 | } | 69 | } |
70 | return ata_std_prereset(ap); | 70 | BUG(); |
71 | return 0; /* Our BUG macro needs the right markup */ | ||
71 | } | 72 | } |
72 | 73 | ||
73 | /** | 74 | /** |
@@ -123,6 +124,7 @@ static const struct ata_port_operations marvell_ops = { | |||
123 | .thaw = ata_bmdma_thaw, | 124 | .thaw = ata_bmdma_thaw, |
124 | .error_handler = marvell_error_handler, | 125 | .error_handler = marvell_error_handler, |
125 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 126 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
127 | .cable_detect = marvell_cable_detect, | ||
126 | 128 | ||
127 | /* BMDMA handling is PCI ATA format, use helpers */ | 129 | /* BMDMA handling is PCI ATA format, use helpers */ |
128 | .bmdma_setup = ata_bmdma_setup, | 130 | .bmdma_setup = ata_bmdma_setup, |
diff --git a/drivers/ata/pata_mpc52xx.c b/drivers/ata/pata_mpc52xx.c index 882c36eaf29..9587a89f968 100644 --- a/drivers/ata/pata_mpc52xx.c +++ b/drivers/ata/pata_mpc52xx.c | |||
@@ -24,7 +24,7 @@ | |||
24 | 24 | ||
25 | 25 | ||
26 | #define DRV_NAME "mpc52xx_ata" | 26 | #define DRV_NAME "mpc52xx_ata" |
27 | #define DRV_VERSION "0.1.0" | 27 | #define DRV_VERSION "0.1.0ac2" |
28 | 28 | ||
29 | 29 | ||
30 | /* Private structures used by the driver */ | 30 | /* Private structures used by the driver */ |
@@ -297,38 +297,37 @@ static struct ata_port_operations mpc52xx_ata_port_ops = { | |||
297 | .freeze = ata_bmdma_freeze, | 297 | .freeze = ata_bmdma_freeze, |
298 | .thaw = ata_bmdma_thaw, | 298 | .thaw = ata_bmdma_thaw, |
299 | .error_handler = mpc52xx_ata_error_handler, | 299 | .error_handler = mpc52xx_ata_error_handler, |
300 | .cable_detect = ata_cable_40wire, | ||
300 | .qc_prep = ata_qc_prep, | 301 | .qc_prep = ata_qc_prep, |
301 | .qc_issue = ata_qc_issue_prot, | 302 | .qc_issue = ata_qc_issue_prot, |
302 | .data_xfer = ata_data_xfer, | 303 | .data_xfer = ata_data_xfer, |
303 | .irq_handler = ata_interrupt, | ||
304 | .irq_clear = ata_bmdma_irq_clear, | 304 | .irq_clear = ata_bmdma_irq_clear, |
305 | .irq_on = ata_irq_on, | 305 | .irq_on = ata_irq_on, |
306 | .irq_ack = ata_irq_ack, | 306 | .irq_ack = ata_irq_ack, |
307 | .port_start = ata_port_start, | 307 | .port_start = ata_port_start, |
308 | }; | 308 | }; |
309 | 309 | ||
310 | static struct ata_probe_ent mpc52xx_ata_probe_ent = { | ||
311 | .port_ops = &mpc52xx_ata_port_ops, | ||
312 | .sht = &mpc52xx_ata_sht, | ||
313 | .n_ports = 1, | ||
314 | .pio_mask = 0x1f, /* Up to PIO4 */ | ||
315 | .mwdma_mask = 0x00, /* No MWDMA */ | ||
316 | .udma_mask = 0x00, /* No UDMA */ | ||
317 | .port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST, | ||
318 | .irq_flags = 0, | ||
319 | }; | ||
320 | |||
321 | static int __devinit | 310 | static int __devinit |
322 | mpc52xx_ata_init_one(struct device *dev, struct mpc52xx_ata_priv *priv) | 311 | mpc52xx_ata_init_one(struct device *dev, struct mpc52xx_ata_priv *priv) |
323 | { | 312 | { |
324 | struct ata_probe_ent *ae = &mpc52xx_ata_probe_ent; | 313 | struct ata_host *host; |
325 | struct ata_ioports *aio = &ae->port[0]; | 314 | struct ata_port *ap; |
326 | int rv; | 315 | struct ata_ioports *aio; |
327 | 316 | int rc; | |
328 | INIT_LIST_HEAD(&ae->node); | 317 | |
329 | ae->dev = dev; | 318 | host = ata_host_alloc(dev, 1); |
330 | ae->irq = priv->ata_irq; | 319 | if (!host) |
331 | 320 | return -ENOMEM; | |
321 | |||
322 | ap = host->ports[0]; | ||
323 | ap->flags |= ATA_FLAG_SLAVE_POSS; | ||
324 | ap->pio_mask = 0x1f; /* Up to PIO4 */ | ||
325 | ap->mwdma_mask = 0x00; /* No MWDMA */ | ||
326 | ap->udma_mask = 0x00; /* No UDMA */ | ||
327 | ap->ops = &mpc52xx_ata_port_ops; | ||
328 | host->private_data = priv; | ||
329 | |||
330 | aio = &ap->ioaddr; | ||
332 | aio->cmd_addr = NULL; /* Don't have a classic reg block */ | 331 | aio->cmd_addr = NULL; /* Don't have a classic reg block */ |
333 | aio->altstatus_addr = &priv->ata_regs->tf_control; | 332 | aio->altstatus_addr = &priv->ata_regs->tf_control; |
334 | aio->ctl_addr = &priv->ata_regs->tf_control; | 333 | aio->ctl_addr = &priv->ata_regs->tf_control; |
@@ -343,11 +342,9 @@ mpc52xx_ata_init_one(struct device *dev, struct mpc52xx_ata_priv *priv) | |||
343 | aio->status_addr = &priv->ata_regs->tf_command; | 342 | aio->status_addr = &priv->ata_regs->tf_command; |
344 | aio->command_addr = &priv->ata_regs->tf_command; | 343 | aio->command_addr = &priv->ata_regs->tf_command; |
345 | 344 | ||
346 | ae->private_data = priv; | 345 | /* activate host */ |
347 | 346 | return ata_host_activate(host, priv->ata_irq, ata_interrupt, 0, | |
348 | rv = ata_device_add(ae); | 347 | &mpc52xx_ata_sht); |
349 | |||
350 | return rv ? 0 : -EINVAL; | ||
351 | } | 348 | } |
352 | 349 | ||
353 | static struct mpc52xx_ata_priv * | 350 | static struct mpc52xx_ata_priv * |
diff --git a/drivers/ata/pata_mpiix.c b/drivers/ata/pata_mpiix.c index 4abe45ac19a..987c5fafab0 100644 --- a/drivers/ata/pata_mpiix.c +++ b/drivers/ata/pata_mpiix.c | |||
@@ -35,7 +35,7 @@ | |||
35 | #include <linux/libata.h> | 35 | #include <linux/libata.h> |
36 | 36 | ||
37 | #define DRV_NAME "pata_mpiix" | 37 | #define DRV_NAME "pata_mpiix" |
38 | #define DRV_VERSION "0.7.5" | 38 | #define DRV_VERSION "0.7.6" |
39 | 39 | ||
40 | enum { | 40 | enum { |
41 | IDETIM = 0x6C, /* IDE control register */ | 41 | IDETIM = 0x6C, /* IDE control register */ |
@@ -53,7 +53,6 @@ static int mpiix_pre_reset(struct ata_port *ap) | |||
53 | 53 | ||
54 | if (!pci_test_config_bits(pdev, &mpiix_enable_bits)) | 54 | if (!pci_test_config_bits(pdev, &mpiix_enable_bits)) |
55 | return -ENOENT; | 55 | return -ENOENT; |
56 | ap->cbl = ATA_CBL_PATA40; | ||
57 | return ata_std_prereset(ap); | 56 | return ata_std_prereset(ap); |
58 | } | 57 | } |
59 | 58 | ||
@@ -185,12 +184,12 @@ static struct ata_port_operations mpiix_port_ops = { | |||
185 | .thaw = ata_bmdma_thaw, | 184 | .thaw = ata_bmdma_thaw, |
186 | .error_handler = mpiix_error_handler, | 185 | .error_handler = mpiix_error_handler, |
187 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 186 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
187 | .cable_detect = ata_cable_40wire, | ||
188 | 188 | ||
189 | .qc_prep = ata_qc_prep, | 189 | .qc_prep = ata_qc_prep, |
190 | .qc_issue = mpiix_qc_issue_prot, | 190 | .qc_issue = mpiix_qc_issue_prot, |
191 | .data_xfer = ata_data_xfer, | 191 | .data_xfer = ata_data_xfer, |
192 | 192 | ||
193 | .irq_handler = ata_interrupt, | ||
194 | .irq_clear = ata_bmdma_irq_clear, | 193 | .irq_clear = ata_bmdma_irq_clear, |
195 | .irq_on = ata_irq_on, | 194 | .irq_on = ata_irq_on, |
196 | .irq_ack = ata_irq_ack, | 195 | .irq_ack = ata_irq_ack, |
@@ -201,8 +200,9 @@ static struct ata_port_operations mpiix_port_ops = { | |||
201 | static int mpiix_init_one(struct pci_dev *dev, const struct pci_device_id *id) | 200 | static int mpiix_init_one(struct pci_dev *dev, const struct pci_device_id *id) |
202 | { | 201 | { |
203 | /* Single threaded by the PCI probe logic */ | 202 | /* Single threaded by the PCI probe logic */ |
204 | static struct ata_probe_ent probe; | ||
205 | static int printed_version; | 203 | static int printed_version; |
204 | struct ata_host *host; | ||
205 | struct ata_port *ap; | ||
206 | void __iomem *cmd_addr, *ctl_addr; | 206 | void __iomem *cmd_addr, *ctl_addr; |
207 | u16 idetim; | 207 | u16 idetim; |
208 | int irq; | 208 | int irq; |
@@ -210,6 +210,10 @@ static int mpiix_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
210 | if (!printed_version++) | 210 | if (!printed_version++) |
211 | dev_printk(KERN_DEBUG, &dev->dev, "version " DRV_VERSION "\n"); | 211 | dev_printk(KERN_DEBUG, &dev->dev, "version " DRV_VERSION "\n"); |
212 | 212 | ||
213 | host = ata_host_alloc(&dev->dev, 1); | ||
214 | if (!host) | ||
215 | return -ENOMEM; | ||
216 | |||
213 | /* MPIIX has many functions which can be turned on or off according | 217 | /* MPIIX has many functions which can be turned on or off according |
214 | to other devices present. Make sure IDE is enabled before we try | 218 | to other devices present. Make sure IDE is enabled before we try |
215 | and use it */ | 219 | and use it */ |
@@ -238,27 +242,21 @@ static int mpiix_init_one(struct pci_dev *dev, const struct pci_device_id *id) | |||
238 | without BARs set fools the setup. #2 If you pci_disable_device | 242 | without BARs set fools the setup. #2 If you pci_disable_device |
239 | the MPIIX your box goes castors up */ | 243 | the MPIIX your box goes castors up */ |
240 | 244 | ||
241 | INIT_LIST_HEAD(&probe.node); | 245 | ap = host->ports[0]; |
242 | probe.dev = pci_dev_to_dev(dev); | 246 | ap->ops = &mpiix_port_ops; |
243 | probe.port_ops = &mpiix_port_ops; | 247 | ap->pio_mask = 0x1F; |
244 | probe.sht = &mpiix_sht; | 248 | ap->flags |= ATA_FLAG_SLAVE_POSS; |
245 | probe.pio_mask = 0x1F; | ||
246 | probe.irq_flags = IRQF_SHARED; | ||
247 | probe.port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST; | ||
248 | probe.n_ports = 1; | ||
249 | 249 | ||
250 | probe.irq = irq; | 250 | ap->ioaddr.cmd_addr = cmd_addr; |
251 | probe.port[0].cmd_addr = cmd_addr; | 251 | ap->ioaddr.ctl_addr = ctl_addr; |
252 | probe.port[0].ctl_addr = ctl_addr; | 252 | ap->ioaddr.altstatus_addr = ctl_addr; |
253 | probe.port[0].altstatus_addr = ctl_addr; | ||
254 | 253 | ||
255 | /* Let libata fill in the port details */ | 254 | /* Let libata fill in the port details */ |
256 | ata_std_ports(&probe.port[0]); | 255 | ata_std_ports(&ap->ioaddr); |
257 | 256 | ||
258 | /* Now add the port that is active */ | 257 | /* activate host */ |
259 | if (ata_device_add(&probe)) | 258 | return ata_host_activate(host, irq, ata_interrupt, IRQF_SHARED, |
260 | return 0; | 259 | &mpiix_sht); |
261 | return -ENODEV; | ||
262 | } | 260 | } |
263 | 261 | ||
264 | static const struct pci_device_id mpiix[] = { | 262 | static const struct pci_device_id mpiix[] = { |
diff --git a/drivers/ata/pata_netcell.c b/drivers/ata/pata_netcell.c index 38f99b38a5e..dbba5b77d79 100644 --- a/drivers/ata/pata_netcell.c +++ b/drivers/ata/pata_netcell.c | |||
@@ -16,33 +16,7 @@ | |||
16 | #include <linux/ata.h> | 16 | #include <linux/ata.h> |
17 | 17 | ||
18 | #define DRV_NAME "pata_netcell" | 18 | #define DRV_NAME "pata_netcell" |
19 | #define DRV_VERSION "0.1.6" | 19 | #define DRV_VERSION "0.1.7" |
20 | |||
21 | /** | ||
22 | * netcell_probe_init - check for 40/80 pin | ||
23 | * @ap: Port | ||
24 | * | ||
25 | * Cables are handled by the RAID controller. Report 80 pin. | ||
26 | */ | ||
27 | |||
28 | static int netcell_pre_reset(struct ata_port *ap) | ||
29 | { | ||
30 | ap->cbl = ATA_CBL_PATA80; | ||
31 | return ata_std_prereset(ap); | ||
32 | } | ||
33 | |||
34 | /** | ||
35 | * netcell_probe_reset - Probe specified port on PATA host controller | ||
36 | * @ap: Port to probe | ||
37 | * | ||
38 | * LOCKING: | ||
39 | * None (inherited from caller). | ||
40 | */ | ||
41 | |||
42 | static void netcell_error_handler(struct ata_port *ap) | ||
43 | { | ||
44 | return ata_bmdma_drive_eh(ap, netcell_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
45 | } | ||
46 | 20 | ||
47 | /* No PIO or DMA methods needed for this device */ | 21 | /* No PIO or DMA methods needed for this device */ |
48 | 22 | ||
@@ -81,8 +55,9 @@ static const struct ata_port_operations netcell_ops = { | |||
81 | 55 | ||
82 | .freeze = ata_bmdma_freeze, | 56 | .freeze = ata_bmdma_freeze, |
83 | .thaw = ata_bmdma_thaw, | 57 | .thaw = ata_bmdma_thaw, |
84 | .error_handler = netcell_error_handler, | 58 | .error_handler = ata_bmdma_error_handler, |
85 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 59 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
60 | .cable_detect = ata_cable_80wire, | ||
86 | 61 | ||
87 | /* BMDMA handling is PCI ATA format, use helpers */ | 62 | /* BMDMA handling is PCI ATA format, use helpers */ |
88 | .bmdma_setup = ata_bmdma_setup, | 63 | .bmdma_setup = ata_bmdma_setup, |
diff --git a/drivers/ata/pata_ns87410.c b/drivers/ata/pata_ns87410.c index 9944a28daa9..078aeda9cf8 100644 --- a/drivers/ata/pata_ns87410.c +++ b/drivers/ata/pata_ns87410.c | |||
@@ -28,13 +28,13 @@ | |||
28 | #include <linux/libata.h> | 28 | #include <linux/libata.h> |
29 | 29 | ||
30 | #define DRV_NAME "pata_ns87410" | 30 | #define DRV_NAME "pata_ns87410" |
31 | #define DRV_VERSION "0.4.3" | 31 | #define DRV_VERSION "0.4.6" |
32 | 32 | ||
33 | /** | 33 | /** |
34 | * ns87410_pre_reset - probe begin | 34 | * ns87410_pre_reset - probe begin |
35 | * @ap: ATA port | 35 | * @ap: ATA port |
36 | * | 36 | * |
37 | * Set up cable type and use generic probe init | 37 | * Check enabled ports |
38 | */ | 38 | */ |
39 | 39 | ||
40 | static int ns87410_pre_reset(struct ata_port *ap) | 40 | static int ns87410_pre_reset(struct ata_port *ap) |
@@ -47,7 +47,6 @@ static int ns87410_pre_reset(struct ata_port *ap) | |||
47 | 47 | ||
48 | if (!pci_test_config_bits(pdev, &ns87410_enable_bits[ap->port_no])) | 48 | if (!pci_test_config_bits(pdev, &ns87410_enable_bits[ap->port_no])) |
49 | return -ENOENT; | 49 | return -ENOENT; |
50 | ap->cbl = ATA_CBL_PATA40; | ||
51 | return ata_std_prereset(ap); | 50 | return ata_std_prereset(ap); |
52 | } | 51 | } |
53 | 52 | ||
@@ -177,6 +176,7 @@ static struct ata_port_operations ns87410_port_ops = { | |||
177 | .thaw = ata_bmdma_thaw, | 176 | .thaw = ata_bmdma_thaw, |
178 | .error_handler = ns87410_error_handler, | 177 | .error_handler = ns87410_error_handler, |
179 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 178 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
179 | .cable_detect = ata_cable_40wire, | ||
180 | 180 | ||
181 | .qc_prep = ata_qc_prep, | 181 | .qc_prep = ata_qc_prep, |
182 | .qc_issue = ns87410_qc_issue_prot, | 182 | .qc_issue = ns87410_qc_issue_prot, |
diff --git a/drivers/ata/pata_oldpiix.c b/drivers/ata/pata_oldpiix.c index da68cd19efd..dea4690340d 100644 --- a/drivers/ata/pata_oldpiix.c +++ b/drivers/ata/pata_oldpiix.c | |||
@@ -25,7 +25,7 @@ | |||
25 | #include <linux/ata.h> | 25 | #include <linux/ata.h> |
26 | 26 | ||
27 | #define DRV_NAME "pata_oldpiix" | 27 | #define DRV_NAME "pata_oldpiix" |
28 | #define DRV_VERSION "0.5.4" | 28 | #define DRV_VERSION "0.5.5" |
29 | 29 | ||
30 | /** | 30 | /** |
31 | * oldpiix_pre_reset - probe begin | 31 | * oldpiix_pre_reset - probe begin |
@@ -44,7 +44,6 @@ static int oldpiix_pre_reset(struct ata_port *ap) | |||
44 | 44 | ||
45 | if (!pci_test_config_bits(pdev, &oldpiix_enable_bits[ap->port_no])) | 45 | if (!pci_test_config_bits(pdev, &oldpiix_enable_bits[ap->port_no])) |
46 | return -ENOENT; | 46 | return -ENOENT; |
47 | ap->cbl = ATA_CBL_PATA40; | ||
48 | return ata_std_prereset(ap); | 47 | return ata_std_prereset(ap); |
49 | } | 48 | } |
50 | 49 | ||
@@ -65,7 +64,7 @@ static void oldpiix_pata_error_handler(struct ata_port *ap) | |||
65 | /** | 64 | /** |
66 | * oldpiix_set_piomode - Initialize host controller PATA PIO timings | 65 | * oldpiix_set_piomode - Initialize host controller PATA PIO timings |
67 | * @ap: Port whose timings we are configuring | 66 | * @ap: Port whose timings we are configuring |
68 | * @adev: um | 67 | * @adev: Device whose timings we are configuring |
69 | * | 68 | * |
70 | * Set PIO mode for device, in host controller PCI config space. | 69 | * Set PIO mode for device, in host controller PCI config space. |
71 | * | 70 | * |
@@ -255,6 +254,7 @@ static const struct ata_port_operations oldpiix_pata_ops = { | |||
255 | .thaw = ata_bmdma_thaw, | 254 | .thaw = ata_bmdma_thaw, |
256 | .error_handler = oldpiix_pata_error_handler, | 255 | .error_handler = oldpiix_pata_error_handler, |
257 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 256 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
257 | .cable_detect = ata_cable_40wire, | ||
258 | 258 | ||
259 | .bmdma_setup = ata_bmdma_setup, | 259 | .bmdma_setup = ata_bmdma_setup, |
260 | .bmdma_start = ata_bmdma_start, | 260 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_opti.c b/drivers/ata/pata_opti.c index 3fd3a35c224..13b63e21838 100644 --- a/drivers/ata/pata_opti.c +++ b/drivers/ata/pata_opti.c | |||
@@ -34,7 +34,7 @@ | |||
34 | #include <linux/libata.h> | 34 | #include <linux/libata.h> |
35 | 35 | ||
36 | #define DRV_NAME "pata_opti" | 36 | #define DRV_NAME "pata_opti" |
37 | #define DRV_VERSION "0.2.8" | 37 | #define DRV_VERSION "0.2.9" |
38 | 38 | ||
39 | enum { | 39 | enum { |
40 | READ_REG = 0, /* index of Read cycle timing register */ | 40 | READ_REG = 0, /* index of Read cycle timing register */ |
@@ -61,8 +61,6 @@ static int opti_pre_reset(struct ata_port *ap) | |||
61 | 61 | ||
62 | if (!pci_test_config_bits(pdev, &opti_enable_bits[ap->port_no])) | 62 | if (!pci_test_config_bits(pdev, &opti_enable_bits[ap->port_no])) |
63 | return -ENOENT; | 63 | return -ENOENT; |
64 | |||
65 | ap->cbl = ATA_CBL_PATA40; | ||
66 | return ata_std_prereset(ap); | 64 | return ata_std_prereset(ap); |
67 | } | 65 | } |
68 | 66 | ||
@@ -198,6 +196,7 @@ static struct ata_port_operations opti_port_ops = { | |||
198 | .thaw = ata_bmdma_thaw, | 196 | .thaw = ata_bmdma_thaw, |
199 | .error_handler = opti_error_handler, | 197 | .error_handler = opti_error_handler, |
200 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 198 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
199 | .cable_detect = ata_cable_40wire, | ||
201 | 200 | ||
202 | .bmdma_setup = ata_bmdma_setup, | 201 | .bmdma_setup = ata_bmdma_setup, |
203 | .bmdma_start = ata_bmdma_start, | 202 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_optidma.c b/drivers/ata/pata_optidma.c index 9764907e8a1..b70e04c144d 100644 --- a/drivers/ata/pata_optidma.c +++ b/drivers/ata/pata_optidma.c | |||
@@ -33,7 +33,7 @@ | |||
33 | #include <linux/libata.h> | 33 | #include <linux/libata.h> |
34 | 34 | ||
35 | #define DRV_NAME "pata_optidma" | 35 | #define DRV_NAME "pata_optidma" |
36 | #define DRV_VERSION "0.2.4" | 36 | #define DRV_VERSION "0.3.2" |
37 | 37 | ||
38 | enum { | 38 | enum { |
39 | READ_REG = 0, /* index of Read cycle timing register */ | 39 | READ_REG = 0, /* index of Read cycle timing register */ |
@@ -62,7 +62,6 @@ static int optidma_pre_reset(struct ata_port *ap) | |||
62 | if (ap->port_no && !pci_test_config_bits(pdev, &optidma_enable_bits)) | 62 | if (ap->port_no && !pci_test_config_bits(pdev, &optidma_enable_bits)) |
63 | return -ENOENT; | 63 | return -ENOENT; |
64 | 64 | ||
65 | ap->cbl = ATA_CBL_PATA40; | ||
66 | return ata_std_prereset(ap); | 65 | return ata_std_prereset(ap); |
67 | } | 66 | } |
68 | 67 | ||
@@ -115,7 +114,7 @@ static void optidma_lock(struct ata_port *ap) | |||
115 | } | 114 | } |
116 | 115 | ||
117 | /** | 116 | /** |
118 | * optidma_set_mode - set mode data | 117 | * optidma_mode_setup - set mode data |
119 | * @ap: ATA interface | 118 | * @ap: ATA interface |
120 | * @adev: ATA device | 119 | * @adev: ATA device |
121 | * @mode: Mode to set | 120 | * @mode: Mode to set |
@@ -128,7 +127,7 @@ static void optidma_lock(struct ata_port *ap) | |||
128 | * IRQ here we depend on the host set locking to avoid catastrophe. | 127 | * IRQ here we depend on the host set locking to avoid catastrophe. |
129 | */ | 128 | */ |
130 | 129 | ||
131 | static void optidma_set_mode(struct ata_port *ap, struct ata_device *adev, u8 mode) | 130 | static void optidma_mode_setup(struct ata_port *ap, struct ata_device *adev, u8 mode) |
132 | { | 131 | { |
133 | struct ata_device *pair = ata_dev_pair(adev); | 132 | struct ata_device *pair = ata_dev_pair(adev); |
134 | int pio = adev->pio_mode - XFER_PIO_0; | 133 | int pio = adev->pio_mode - XFER_PIO_0; |
@@ -202,7 +201,7 @@ static void optidma_set_mode(struct ata_port *ap, struct ata_device *adev, u8 mo | |||
202 | } | 201 | } |
203 | 202 | ||
204 | /** | 203 | /** |
205 | * optiplus_set_mode - DMA setup for Firestar Plus | 204 | * optiplus_mode_setup - DMA setup for Firestar Plus |
206 | * @ap: ATA port | 205 | * @ap: ATA port |
207 | * @adev: device | 206 | * @adev: device |
208 | * @mode: desired mode | 207 | * @mode: desired mode |
@@ -213,7 +212,7 @@ static void optidma_set_mode(struct ata_port *ap, struct ata_device *adev, u8 mo | |||
213 | * one | 212 | * one |
214 | */ | 213 | */ |
215 | 214 | ||
216 | static void optiplus_set_mode(struct ata_port *ap, struct ata_device *adev, u8 mode) | 215 | static void optiplus_mode_setup(struct ata_port *ap, struct ata_device *adev, u8 mode) |
217 | { | 216 | { |
218 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 217 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
219 | u8 udcfg; | 218 | u8 udcfg; |
@@ -225,7 +224,7 @@ static void optiplus_set_mode(struct ata_port *ap, struct ata_device *adev, u8 m | |||
225 | pci_read_config_byte(pdev, 0x44, &udcfg); | 224 | pci_read_config_byte(pdev, 0x44, &udcfg); |
226 | if (mode <= XFER_UDMA_0) { | 225 | if (mode <= XFER_UDMA_0) { |
227 | udcfg &= ~(1 << unit); | 226 | udcfg &= ~(1 << unit); |
228 | optidma_set_mode(ap, adev, adev->dma_mode); | 227 | optidma_mode_setup(ap, adev, adev->dma_mode); |
229 | } else { | 228 | } else { |
230 | udcfg |= (1 << unit); | 229 | udcfg |= (1 << unit); |
231 | if (ap->port_no) { | 230 | if (ap->port_no) { |
@@ -253,7 +252,7 @@ static void optiplus_set_mode(struct ata_port *ap, struct ata_device *adev, u8 m | |||
253 | 252 | ||
254 | static void optidma_set_pio_mode(struct ata_port *ap, struct ata_device *adev) | 253 | static void optidma_set_pio_mode(struct ata_port *ap, struct ata_device *adev) |
255 | { | 254 | { |
256 | optidma_set_mode(ap, adev, adev->pio_mode); | 255 | optidma_mode_setup(ap, adev, adev->pio_mode); |
257 | } | 256 | } |
258 | 257 | ||
259 | /** | 258 | /** |
@@ -268,7 +267,7 @@ static void optidma_set_pio_mode(struct ata_port *ap, struct ata_device *adev) | |||
268 | 267 | ||
269 | static void optidma_set_dma_mode(struct ata_port *ap, struct ata_device *adev) | 268 | static void optidma_set_dma_mode(struct ata_port *ap, struct ata_device *adev) |
270 | { | 269 | { |
271 | optidma_set_mode(ap, adev, adev->dma_mode); | 270 | optidma_mode_setup(ap, adev, adev->dma_mode); |
272 | } | 271 | } |
273 | 272 | ||
274 | /** | 273 | /** |
@@ -283,7 +282,7 @@ static void optidma_set_dma_mode(struct ata_port *ap, struct ata_device *adev) | |||
283 | 282 | ||
284 | static void optiplus_set_pio_mode(struct ata_port *ap, struct ata_device *adev) | 283 | static void optiplus_set_pio_mode(struct ata_port *ap, struct ata_device *adev) |
285 | { | 284 | { |
286 | optiplus_set_mode(ap, adev, adev->pio_mode); | 285 | optiplus_mode_setup(ap, adev, adev->pio_mode); |
287 | } | 286 | } |
288 | 287 | ||
289 | /** | 288 | /** |
@@ -298,7 +297,7 @@ static void optiplus_set_pio_mode(struct ata_port *ap, struct ata_device *adev) | |||
298 | 297 | ||
299 | static void optiplus_set_dma_mode(struct ata_port *ap, struct ata_device *adev) | 298 | static void optiplus_set_dma_mode(struct ata_port *ap, struct ata_device *adev) |
300 | { | 299 | { |
301 | optiplus_set_mode(ap, adev, adev->dma_mode); | 300 | optiplus_mode_setup(ap, adev, adev->dma_mode); |
302 | } | 301 | } |
303 | 302 | ||
304 | /** | 303 | /** |
@@ -322,26 +321,29 @@ static u8 optidma_make_bits43(struct ata_device *adev) | |||
322 | } | 321 | } |
323 | 322 | ||
324 | /** | 323 | /** |
325 | * optidma_post_set_mode - finalize PCI setup | 324 | * optidma_set_mode - mode setup |
326 | * @ap: port to set up | 325 | * @ap: port to set up |
327 | * | 326 | * |
328 | * Finalise the configuration by writing the nibble of extra bits | 327 | * Use the standard setup to tune the chipset and then finalise the |
329 | * of data into the chip. | 328 | * configuration by writing the nibble of extra bits of data into |
329 | * the chip. | ||
330 | */ | 330 | */ |
331 | 331 | ||
332 | static void optidma_post_set_mode(struct ata_port *ap) | 332 | static int optidma_set_mode(struct ata_port *ap, struct ata_device **r_failed) |
333 | { | 333 | { |
334 | u8 r; | 334 | u8 r; |
335 | int nybble = 4 * ap->port_no; | 335 | int nybble = 4 * ap->port_no; |
336 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 336 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
337 | 337 | int rc = ata_do_set_mode(ap, r_failed); | |
338 | pci_read_config_byte(pdev, 0x43, &r); | 338 | if (rc == 0) { |
339 | 339 | pci_read_config_byte(pdev, 0x43, &r); | |
340 | r &= (0x0F << nybble); | 340 | |
341 | r |= (optidma_make_bits43(&ap->device[0]) + | 341 | r &= (0x0F << nybble); |
342 | (optidma_make_bits43(&ap->device[0]) << 2)) << nybble; | 342 | r |= (optidma_make_bits43(&ap->device[0]) + |
343 | 343 | (optidma_make_bits43(&ap->device[0]) << 2)) << nybble; | |
344 | pci_write_config_byte(pdev, 0x43, r); | 344 | pci_write_config_byte(pdev, 0x43, r); |
345 | } | ||
346 | return rc; | ||
345 | } | 347 | } |
346 | 348 | ||
347 | static struct scsi_host_template optidma_sht = { | 349 | static struct scsi_host_template optidma_sht = { |
@@ -381,7 +383,8 @@ static struct ata_port_operations optidma_port_ops = { | |||
381 | .thaw = ata_bmdma_thaw, | 383 | .thaw = ata_bmdma_thaw, |
382 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 384 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
383 | .error_handler = optidma_error_handler, | 385 | .error_handler = optidma_error_handler, |
384 | .post_set_mode = optidma_post_set_mode, | 386 | .set_mode = optidma_set_mode, |
387 | .cable_detect = ata_cable_40wire, | ||
385 | 388 | ||
386 | .bmdma_setup = ata_bmdma_setup, | 389 | .bmdma_setup = ata_bmdma_setup, |
387 | .bmdma_start = ata_bmdma_start, | 390 | .bmdma_start = ata_bmdma_start, |
@@ -416,7 +419,8 @@ static struct ata_port_operations optiplus_port_ops = { | |||
416 | .thaw = ata_bmdma_thaw, | 419 | .thaw = ata_bmdma_thaw, |
417 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 420 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
418 | .error_handler = optidma_error_handler, | 421 | .error_handler = optidma_error_handler, |
419 | .post_set_mode = optidma_post_set_mode, | 422 | .set_mode = optidma_set_mode, |
423 | .cable_detect = ata_cable_40wire, | ||
420 | 424 | ||
421 | .bmdma_setup = ata_bmdma_setup, | 425 | .bmdma_setup = ata_bmdma_setup, |
422 | .bmdma_start = ata_bmdma_start, | 426 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_pcmcia.c b/drivers/ata/pata_pcmcia.c index 103720f873c..75dc84797ff 100644 --- a/drivers/ata/pata_pcmcia.c +++ b/drivers/ata/pata_pcmcia.c | |||
@@ -42,7 +42,7 @@ | |||
42 | 42 | ||
43 | 43 | ||
44 | #define DRV_NAME "pata_pcmcia" | 44 | #define DRV_NAME "pata_pcmcia" |
45 | #define DRV_VERSION "0.3.0" | 45 | #define DRV_VERSION "0.3.1" |
46 | 46 | ||
47 | /* | 47 | /* |
48 | * Private data structure to glue stuff together | 48 | * Private data structure to glue stuff together |
@@ -54,6 +54,39 @@ struct ata_pcmcia_info { | |||
54 | dev_node_t node; | 54 | dev_node_t node; |
55 | }; | 55 | }; |
56 | 56 | ||
57 | /** | ||
58 | * pcmcia_set_mode - PCMCIA specific mode setup | ||
59 | * @ap: Port | ||
60 | * @r_failed_dev: Return pointer for failed device | ||
61 | * | ||
62 | * Perform the tuning and setup of the devices and timings, which | ||
63 | * for PCMCIA is the same as any other controller. We wrap it however | ||
64 | * as we need to spot hardware with incorrect or missing master/slave | ||
65 | * decode, which alas is embarrassingly common in the PC world | ||
66 | */ | ||
67 | |||
68 | static int pcmcia_set_mode(struct ata_port *ap, struct ata_device **r_failed_dev) | ||
69 | { | ||
70 | struct ata_device *master = &ap->device[0]; | ||
71 | struct ata_device *slave = &ap->device[1]; | ||
72 | |||
73 | if (!ata_dev_enabled(master) || !ata_dev_enabled(slave)) | ||
74 | return ata_do_set_mode(ap, r_failed_dev); | ||
75 | |||
76 | if (memcmp(master->id + ATA_ID_FW_REV, slave->id + ATA_ID_FW_REV, | ||
77 | ATA_ID_FW_REV_LEN + ATA_ID_PROD_LEN) == 0) | ||
78 | { | ||
79 | /* Suspicious match, but could be two cards from | ||
80 | the same vendor - check serial */ | ||
81 | if (memcmp(master->id + ATA_ID_SERNO, slave->id + ATA_ID_SERNO, | ||
82 | ATA_ID_SERNO_LEN) == 0 && master->id[ATA_ID_SERNO] >> 8) { | ||
83 | ata_dev_printk(slave, KERN_WARNING, "is a ghost device, ignoring.\n"); | ||
84 | ata_dev_disable(slave); | ||
85 | } | ||
86 | } | ||
87 | return ata_do_set_mode(ap, r_failed_dev); | ||
88 | } | ||
89 | |||
57 | static struct scsi_host_template pcmcia_sht = { | 90 | static struct scsi_host_template pcmcia_sht = { |
58 | .module = THIS_MODULE, | 91 | .module = THIS_MODULE, |
59 | .name = DRV_NAME, | 92 | .name = DRV_NAME, |
@@ -73,6 +106,7 @@ static struct scsi_host_template pcmcia_sht = { | |||
73 | }; | 106 | }; |
74 | 107 | ||
75 | static struct ata_port_operations pcmcia_port_ops = { | 108 | static struct ata_port_operations pcmcia_port_ops = { |
109 | .set_mode = pcmcia_set_mode, | ||
76 | .port_disable = ata_port_disable, | 110 | .port_disable = ata_port_disable, |
77 | .tf_load = ata_tf_load, | 111 | .tf_load = ata_tf_load, |
78 | .tf_read = ata_tf_read, | 112 | .tf_read = ata_tf_read, |
@@ -84,13 +118,13 @@ static struct ata_port_operations pcmcia_port_ops = { | |||
84 | .thaw = ata_bmdma_thaw, | 118 | .thaw = ata_bmdma_thaw, |
85 | .error_handler = ata_bmdma_error_handler, | 119 | .error_handler = ata_bmdma_error_handler, |
86 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 120 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
121 | .cable_detect = ata_cable_40wire, | ||
87 | 122 | ||
88 | .qc_prep = ata_qc_prep, | 123 | .qc_prep = ata_qc_prep, |
89 | .qc_issue = ata_qc_issue_prot, | 124 | .qc_issue = ata_qc_issue_prot, |
90 | 125 | ||
91 | .data_xfer = ata_data_xfer_noirq, | 126 | .data_xfer = ata_data_xfer_noirq, |
92 | 127 | ||
93 | .irq_handler = ata_interrupt, | ||
94 | .irq_clear = ata_bmdma_irq_clear, | 128 | .irq_clear = ata_bmdma_irq_clear, |
95 | .irq_on = ata_irq_on, | 129 | .irq_on = ata_irq_on, |
96 | .irq_ack = ata_irq_ack, | 130 | .irq_ack = ata_irq_ack, |
@@ -111,7 +145,8 @@ do { last_fn = (fn); if ((last_ret = (ret)) != 0) goto cs_failed; } while (0) | |||
111 | 145 | ||
112 | static int pcmcia_init_one(struct pcmcia_device *pdev) | 146 | static int pcmcia_init_one(struct pcmcia_device *pdev) |
113 | { | 147 | { |
114 | struct ata_probe_ent ae; | 148 | struct ata_host *host; |
149 | struct ata_port *ap; | ||
115 | struct ata_pcmcia_info *info; | 150 | struct ata_pcmcia_info *info; |
116 | tuple_t tuple; | 151 | tuple_t tuple; |
117 | struct { | 152 | struct { |
@@ -255,24 +290,24 @@ next_entry: | |||
255 | * Having done the PCMCIA plumbing the ATA side is relatively | 290 | * Having done the PCMCIA plumbing the ATA side is relatively |
256 | * sane. | 291 | * sane. |
257 | */ | 292 | */ |
258 | 293 | ret = -ENOMEM; | |
259 | memset(&ae, 0, sizeof(struct ata_probe_ent)); | 294 | host = ata_host_alloc(&pdev->dev, 1); |
260 | INIT_LIST_HEAD(&ae.node); | 295 | if (!host) |
261 | ae.dev = &pdev->dev; | 296 | goto failed; |
262 | ae.port_ops = &pcmcia_port_ops; | 297 | ap = host->ports[0]; |
263 | ae.sht = &pcmcia_sht; | 298 | |
264 | ae.n_ports = 1; | 299 | ap->ops = &pcmcia_port_ops; |
265 | ae.pio_mask = 1; /* ISA so PIO 0 cycles */ | 300 | ap->pio_mask = 1; /* ISA so PIO 0 cycles */ |
266 | ae.irq = pdev->irq.AssignedIRQ; | 301 | ap->flags |= ATA_FLAG_SLAVE_POSS; |
267 | ae.irq_flags = IRQF_SHARED; | 302 | ap->ioaddr.cmd_addr = io_addr; |
268 | ae.port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST; | 303 | ap->ioaddr.altstatus_addr = ctl_addr; |
269 | ae.port[0].cmd_addr = io_addr; | 304 | ap->ioaddr.ctl_addr = ctl_addr; |
270 | ae.port[0].altstatus_addr = ctl_addr; | 305 | ata_std_ports(&ap->ioaddr); |
271 | ae.port[0].ctl_addr = ctl_addr; | 306 | |
272 | ata_std_ports(&ae.port[0]); | 307 | /* activate */ |
273 | 308 | ret = ata_host_activate(host, pdev->irq.AssignedIRQ, ata_interrupt, | |
274 | ret = -ENODEV; | 309 | IRQF_SHARED, &pcmcia_sht); |
275 | if (ata_device_add(&ae) == 0) | 310 | if (ret) |
276 | goto failed; | 311 | goto failed; |
277 | 312 | ||
278 | info->ndev = 1; | 313 | info->ndev = 1; |
diff --git a/drivers/ata/pata_pdc2027x.c b/drivers/ata/pata_pdc2027x.c index 93bcdadb7be..a61cbc11068 100644 --- a/drivers/ata/pata_pdc2027x.c +++ b/drivers/ata/pata_pdc2027x.c | |||
@@ -35,7 +35,7 @@ | |||
35 | #include <linux/libata.h> | 35 | #include <linux/libata.h> |
36 | 36 | ||
37 | #define DRV_NAME "pata_pdc2027x" | 37 | #define DRV_NAME "pata_pdc2027x" |
38 | #define DRV_VERSION "0.8" | 38 | #define DRV_VERSION "0.9" |
39 | #undef PDC_DEBUG | 39 | #undef PDC_DEBUG |
40 | 40 | ||
41 | #ifdef PDC_DEBUG | 41 | #ifdef PDC_DEBUG |
@@ -66,8 +66,10 @@ static int pdc2027x_init_one(struct pci_dev *pdev, const struct pci_device_id *e | |||
66 | static void pdc2027x_error_handler(struct ata_port *ap); | 66 | static void pdc2027x_error_handler(struct ata_port *ap); |
67 | static void pdc2027x_set_piomode(struct ata_port *ap, struct ata_device *adev); | 67 | static void pdc2027x_set_piomode(struct ata_port *ap, struct ata_device *adev); |
68 | static void pdc2027x_set_dmamode(struct ata_port *ap, struct ata_device *adev); | 68 | static void pdc2027x_set_dmamode(struct ata_port *ap, struct ata_device *adev); |
69 | static void pdc2027x_post_set_mode(struct ata_port *ap); | ||
70 | static int pdc2027x_check_atapi_dma(struct ata_queued_cmd *qc); | 69 | static int pdc2027x_check_atapi_dma(struct ata_queued_cmd *qc); |
70 | static unsigned long pdc2027x_mode_filter(struct ata_device *adev, unsigned long mask); | ||
71 | static int pdc2027x_cable_detect(struct ata_port *ap); | ||
72 | static int pdc2027x_set_mode(struct ata_port *ap, struct ata_device **r_failed); | ||
71 | 73 | ||
72 | /* | 74 | /* |
73 | * ATA Timing Tables based on 133MHz controller clock. | 75 | * ATA Timing Tables based on 133MHz controller clock. |
@@ -146,6 +148,7 @@ static struct scsi_host_template pdc2027x_sht = { | |||
146 | 148 | ||
147 | static struct ata_port_operations pdc2027x_pata100_ops = { | 149 | static struct ata_port_operations pdc2027x_pata100_ops = { |
148 | .port_disable = ata_port_disable, | 150 | .port_disable = ata_port_disable, |
151 | .mode_filter = ata_pci_default_filter, | ||
149 | 152 | ||
150 | .tf_load = ata_tf_load, | 153 | .tf_load = ata_tf_load, |
151 | .tf_read = ata_tf_read, | 154 | .tf_read = ata_tf_read, |
@@ -166,8 +169,8 @@ static struct ata_port_operations pdc2027x_pata100_ops = { | |||
166 | .thaw = ata_bmdma_thaw, | 169 | .thaw = ata_bmdma_thaw, |
167 | .error_handler = pdc2027x_error_handler, | 170 | .error_handler = pdc2027x_error_handler, |
168 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 171 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
172 | .cable_detect = pdc2027x_cable_detect, | ||
169 | 173 | ||
170 | .irq_handler = ata_interrupt, | ||
171 | .irq_clear = ata_bmdma_irq_clear, | 174 | .irq_clear = ata_bmdma_irq_clear, |
172 | .irq_on = ata_irq_on, | 175 | .irq_on = ata_irq_on, |
173 | .irq_ack = ata_irq_ack, | 176 | .irq_ack = ata_irq_ack, |
@@ -179,7 +182,8 @@ static struct ata_port_operations pdc2027x_pata133_ops = { | |||
179 | .port_disable = ata_port_disable, | 182 | .port_disable = ata_port_disable, |
180 | .set_piomode = pdc2027x_set_piomode, | 183 | .set_piomode = pdc2027x_set_piomode, |
181 | .set_dmamode = pdc2027x_set_dmamode, | 184 | .set_dmamode = pdc2027x_set_dmamode, |
182 | .post_set_mode = pdc2027x_post_set_mode, | 185 | .set_mode = pdc2027x_set_mode, |
186 | .mode_filter = pdc2027x_mode_filter, | ||
183 | 187 | ||
184 | .tf_load = ata_tf_load, | 188 | .tf_load = ata_tf_load, |
185 | .tf_read = ata_tf_read, | 189 | .tf_read = ata_tf_read, |
@@ -200,8 +204,8 @@ static struct ata_port_operations pdc2027x_pata133_ops = { | |||
200 | .thaw = ata_bmdma_thaw, | 204 | .thaw = ata_bmdma_thaw, |
201 | .error_handler = pdc2027x_error_handler, | 205 | .error_handler = pdc2027x_error_handler, |
202 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 206 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
207 | .cable_detect = pdc2027x_cable_detect, | ||
203 | 208 | ||
204 | .irq_handler = ata_interrupt, | ||
205 | .irq_clear = ata_bmdma_irq_clear, | 209 | .irq_clear = ata_bmdma_irq_clear, |
206 | .irq_on = ata_irq_on, | 210 | .irq_on = ata_irq_on, |
207 | .irq_ack = ata_irq_ack, | 211 | .irq_ack = ata_irq_ack, |
@@ -212,7 +216,6 @@ static struct ata_port_operations pdc2027x_pata133_ops = { | |||
212 | static struct ata_port_info pdc2027x_port_info[] = { | 216 | static struct ata_port_info pdc2027x_port_info[] = { |
213 | /* PDC_UDMA_100 */ | 217 | /* PDC_UDMA_100 */ |
214 | { | 218 | { |
215 | .sht = &pdc2027x_sht, | ||
216 | .flags = ATA_FLAG_NO_LEGACY | ATA_FLAG_SLAVE_POSS | | 219 | .flags = ATA_FLAG_NO_LEGACY | ATA_FLAG_SLAVE_POSS | |
217 | ATA_FLAG_MMIO, | 220 | ATA_FLAG_MMIO, |
218 | .pio_mask = 0x1f, /* pio0-4 */ | 221 | .pio_mask = 0x1f, /* pio0-4 */ |
@@ -222,7 +225,6 @@ static struct ata_port_info pdc2027x_port_info[] = { | |||
222 | }, | 225 | }, |
223 | /* PDC_UDMA_133 */ | 226 | /* PDC_UDMA_133 */ |
224 | { | 227 | { |
225 | .sht = &pdc2027x_sht, | ||
226 | .flags = ATA_FLAG_NO_LEGACY | ATA_FLAG_SLAVE_POSS | | 228 | .flags = ATA_FLAG_NO_LEGACY | ATA_FLAG_SLAVE_POSS | |
227 | ATA_FLAG_MMIO, | 229 | ATA_FLAG_MMIO, |
228 | .pio_mask = 0x1f, /* pio0-4 */ | 230 | .pio_mask = 0x1f, /* pio0-4 */ |
@@ -261,7 +263,7 @@ static inline void __iomem *dev_mmio(struct ata_port *ap, struct ata_device *ade | |||
261 | } | 263 | } |
262 | 264 | ||
263 | /** | 265 | /** |
264 | * pdc2027x_pata_cbl_detect - Probe host controller cable detect info | 266 | * pdc2027x_pata_cable_detect - Probe host controller cable detect info |
265 | * @ap: Port for which cable detect info is desired | 267 | * @ap: Port for which cable detect info is desired |
266 | * | 268 | * |
267 | * Read 80c cable indicator from Promise extended register. | 269 | * Read 80c cable indicator from Promise extended register. |
@@ -270,7 +272,7 @@ static inline void __iomem *dev_mmio(struct ata_port *ap, struct ata_device *ade | |||
270 | * LOCKING: | 272 | * LOCKING: |
271 | * None (inherited from caller). | 273 | * None (inherited from caller). |
272 | */ | 274 | */ |
273 | static void pdc2027x_cbl_detect(struct ata_port *ap) | 275 | static int pdc2027x_cable_detect(struct ata_port *ap) |
274 | { | 276 | { |
275 | u32 cgcr; | 277 | u32 cgcr; |
276 | 278 | ||
@@ -281,13 +283,10 @@ static void pdc2027x_cbl_detect(struct ata_port *ap) | |||
281 | 283 | ||
282 | PDPRINTK("No cable or 80-conductor cable on port %d\n", ap->port_no); | 284 | PDPRINTK("No cable or 80-conductor cable on port %d\n", ap->port_no); |
283 | 285 | ||
284 | ap->cbl = ATA_CBL_PATA80; | 286 | return ATA_CBL_PATA80; |
285 | return; | ||
286 | |||
287 | cbl40: | 287 | cbl40: |
288 | printk(KERN_INFO DRV_NAME ": 40-conductor cable detected on port %d\n", ap->port_no); | 288 | printk(KERN_INFO DRV_NAME ": 40-conductor cable detected on port %d\n", ap->port_no); |
289 | ap->cbl = ATA_CBL_PATA40; | 289 | return ATA_CBL_PATA40; |
290 | ap->udma_mask &= ATA_UDMA_MASK_40C; | ||
291 | } | 290 | } |
292 | 291 | ||
293 | /** | 292 | /** |
@@ -314,7 +313,6 @@ static int pdc2027x_prereset(struct ata_port *ap) | |||
314 | /* Check whether port enabled */ | 313 | /* Check whether port enabled */ |
315 | if (!pdc2027x_port_enabled(ap)) | 314 | if (!pdc2027x_port_enabled(ap)) |
316 | return -ENOENT; | 315 | return -ENOENT; |
317 | pdc2027x_cbl_detect(ap); | ||
318 | return ata_std_prereset(ap); | 316 | return ata_std_prereset(ap); |
319 | } | 317 | } |
320 | 318 | ||
@@ -334,6 +332,32 @@ static void pdc2027x_error_handler(struct ata_port *ap) | |||
334 | } | 332 | } |
335 | 333 | ||
336 | /** | 334 | /** |
335 | * pdc2720x_mode_filter - mode selection filter | ||
336 | * @adev: ATA device | ||
337 | * @mask: list of modes proposed | ||
338 | * | ||
339 | * Block UDMA on devices that cause trouble with this controller. | ||
340 | */ | ||
341 | |||
342 | static unsigned long pdc2027x_mode_filter(struct ata_device *adev, unsigned long mask) | ||
343 | { | ||
344 | unsigned char model_num[ATA_ID_PROD_LEN + 1]; | ||
345 | struct ata_device *pair = ata_dev_pair(adev); | ||
346 | |||
347 | if (adev->class != ATA_DEV_ATA || adev->devno == 0 || pair == NULL) | ||
348 | return ata_pci_default_filter(adev, mask); | ||
349 | |||
350 | /* Check for slave of a Maxtor at UDMA6 */ | ||
351 | ata_id_c_string(pair->id, model_num, ATA_ID_PROD, | ||
352 | ATA_ID_PROD_LEN + 1); | ||
353 | /* If the master is a maxtor in UDMA6 then the slave should not use UDMA 6 */ | ||
354 | if(strstr(model_num, "Maxtor") == 0 && pair->dma_mode == XFER_UDMA_6) | ||
355 | mask &= ~ (1 << (6 + ATA_SHIFT_UDMA)); | ||
356 | |||
357 | return ata_pci_default_filter(adev, mask); | ||
358 | } | ||
359 | |||
360 | /** | ||
337 | * pdc2027x_set_piomode - Initialize host controller PATA PIO timings | 361 | * pdc2027x_set_piomode - Initialize host controller PATA PIO timings |
338 | * @ap: Port to configure | 362 | * @ap: Port to configure |
339 | * @adev: um | 363 | * @adev: um |
@@ -444,17 +468,22 @@ static void pdc2027x_set_dmamode(struct ata_port *ap, struct ata_device *adev) | |||
444 | } | 468 | } |
445 | 469 | ||
446 | /** | 470 | /** |
447 | * pdc2027x_post_set_mode - Set the timing registers back to correct values. | 471 | * pdc2027x_set_mode - Set the timing registers back to correct values. |
448 | * @ap: Port to configure | 472 | * @ap: Port to configure |
473 | * @r_failed: Returned device for failure | ||
449 | * | 474 | * |
450 | * The pdc2027x hardware will look at "SET FEATURES" and change the timing registers | 475 | * The pdc2027x hardware will look at "SET FEATURES" and change the timing registers |
451 | * automatically. The values set by the hardware might be incorrect, under 133Mhz PLL. | 476 | * automatically. The values set by the hardware might be incorrect, under 133Mhz PLL. |
452 | * This function overwrites the possibly incorrect values set by the hardware to be correct. | 477 | * This function overwrites the possibly incorrect values set by the hardware to be correct. |
453 | */ | 478 | */ |
454 | static void pdc2027x_post_set_mode(struct ata_port *ap) | 479 | static int pdc2027x_set_mode(struct ata_port *ap, struct ata_device **r_failed) |
455 | { | 480 | { |
456 | int i; | 481 | int i; |
457 | 482 | ||
483 | i = ata_do_set_mode(ap, r_failed); | ||
484 | if (i < 0) | ||
485 | return i; | ||
486 | |||
458 | for (i = 0; i < ATA_MAX_DEVICES; i++) { | 487 | for (i = 0; i < ATA_MAX_DEVICES; i++) { |
459 | struct ata_device *dev = &ap->device[i]; | 488 | struct ata_device *dev = &ap->device[i]; |
460 | 489 | ||
@@ -476,6 +505,7 @@ static void pdc2027x_post_set_mode(struct ata_port *ap) | |||
476 | } | 505 | } |
477 | } | 506 | } |
478 | } | 507 | } |
508 | return 0; | ||
479 | } | 509 | } |
480 | 510 | ||
481 | /** | 511 | /** |
@@ -521,12 +551,12 @@ static int pdc2027x_check_atapi_dma(struct ata_queued_cmd *qc) | |||
521 | 551 | ||
522 | /** | 552 | /** |
523 | * pdc_read_counter - Read the ctr counter | 553 | * pdc_read_counter - Read the ctr counter |
524 | * @probe_ent: for the port address | 554 | * @host: target ATA host |
525 | */ | 555 | */ |
526 | 556 | ||
527 | static long pdc_read_counter(struct ata_probe_ent *probe_ent) | 557 | static long pdc_read_counter(struct ata_host *host) |
528 | { | 558 | { |
529 | void __iomem *mmio_base = probe_ent->iomap[PDC_MMIO_BAR]; | 559 | void __iomem *mmio_base = host->iomap[PDC_MMIO_BAR]; |
530 | long counter; | 560 | long counter; |
531 | int retry = 1; | 561 | int retry = 1; |
532 | u32 bccrl, bccrh, bccrlv, bccrhv; | 562 | u32 bccrl, bccrh, bccrlv, bccrhv; |
@@ -564,12 +594,12 @@ retry: | |||
564 | * adjust_pll - Adjust the PLL input clock in Hz. | 594 | * adjust_pll - Adjust the PLL input clock in Hz. |
565 | * | 595 | * |
566 | * @pdc_controller: controller specific information | 596 | * @pdc_controller: controller specific information |
567 | * @probe_ent: For the port address | 597 | * @host: target ATA host |
568 | * @pll_clock: The input of PLL in HZ | 598 | * @pll_clock: The input of PLL in HZ |
569 | */ | 599 | */ |
570 | static void pdc_adjust_pll(struct ata_probe_ent *probe_ent, long pll_clock, unsigned int board_idx) | 600 | static void pdc_adjust_pll(struct ata_host *host, long pll_clock, unsigned int board_idx) |
571 | { | 601 | { |
572 | void __iomem *mmio_base = probe_ent->iomap[PDC_MMIO_BAR]; | 602 | void __iomem *mmio_base = host->iomap[PDC_MMIO_BAR]; |
573 | u16 pll_ctl; | 603 | u16 pll_ctl; |
574 | long pll_clock_khz = pll_clock / 1000; | 604 | long pll_clock_khz = pll_clock / 1000; |
575 | long pout_required = board_idx? PDC_133_MHZ:PDC_100_MHZ; | 605 | long pout_required = board_idx? PDC_133_MHZ:PDC_100_MHZ; |
@@ -649,19 +679,19 @@ static void pdc_adjust_pll(struct ata_probe_ent *probe_ent, long pll_clock, unsi | |||
649 | 679 | ||
650 | /** | 680 | /** |
651 | * detect_pll_input_clock - Detect the PLL input clock in Hz. | 681 | * detect_pll_input_clock - Detect the PLL input clock in Hz. |
652 | * @probe_ent: for the port address | 682 | * @host: target ATA host |
653 | * Ex. 16949000 on 33MHz PCI bus for pdc20275. | 683 | * Ex. 16949000 on 33MHz PCI bus for pdc20275. |
654 | * Half of the PCI clock. | 684 | * Half of the PCI clock. |
655 | */ | 685 | */ |
656 | static long pdc_detect_pll_input_clock(struct ata_probe_ent *probe_ent) | 686 | static long pdc_detect_pll_input_clock(struct ata_host *host) |
657 | { | 687 | { |
658 | void __iomem *mmio_base = probe_ent->iomap[PDC_MMIO_BAR]; | 688 | void __iomem *mmio_base = host->iomap[PDC_MMIO_BAR]; |
659 | u32 scr; | 689 | u32 scr; |
660 | long start_count, end_count; | 690 | long start_count, end_count; |
661 | long pll_clock; | 691 | long pll_clock; |
662 | 692 | ||
663 | /* Read current counter value */ | 693 | /* Read current counter value */ |
664 | start_count = pdc_read_counter(probe_ent); | 694 | start_count = pdc_read_counter(host); |
665 | 695 | ||
666 | /* Start the test mode */ | 696 | /* Start the test mode */ |
667 | scr = readl(mmio_base + PDC_SYS_CTL); | 697 | scr = readl(mmio_base + PDC_SYS_CTL); |
@@ -673,7 +703,7 @@ static long pdc_detect_pll_input_clock(struct ata_probe_ent *probe_ent) | |||
673 | mdelay(100); | 703 | mdelay(100); |
674 | 704 | ||
675 | /* Read the counter values again */ | 705 | /* Read the counter values again */ |
676 | end_count = pdc_read_counter(probe_ent); | 706 | end_count = pdc_read_counter(host); |
677 | 707 | ||
678 | /* Stop the test mode */ | 708 | /* Stop the test mode */ |
679 | scr = readl(mmio_base + PDC_SYS_CTL); | 709 | scr = readl(mmio_base + PDC_SYS_CTL); |
@@ -692,11 +722,10 @@ static long pdc_detect_pll_input_clock(struct ata_probe_ent *probe_ent) | |||
692 | 722 | ||
693 | /** | 723 | /** |
694 | * pdc_hardware_init - Initialize the hardware. | 724 | * pdc_hardware_init - Initialize the hardware. |
695 | * @pdev: instance of pci_dev found | 725 | * @host: target ATA host |
696 | * @pdc_controller: controller specific information | 726 | * @board_idx: board identifier |
697 | * @pe: for the port address | ||
698 | */ | 727 | */ |
699 | static int pdc_hardware_init(struct pci_dev *pdev, struct ata_probe_ent *pe, unsigned int board_idx) | 728 | static int pdc_hardware_init(struct ata_host *host, unsigned int board_idx) |
700 | { | 729 | { |
701 | long pll_clock; | 730 | long pll_clock; |
702 | 731 | ||
@@ -706,15 +735,15 @@ static int pdc_hardware_init(struct pci_dev *pdev, struct ata_probe_ent *pe, uns | |||
706 | * Ex. 25MHz or 40MHz, we have to adjust the cycle_time. | 735 | * Ex. 25MHz or 40MHz, we have to adjust the cycle_time. |
707 | * The pdc20275 controller employs PLL circuit to help correct timing registers setting. | 736 | * The pdc20275 controller employs PLL circuit to help correct timing registers setting. |
708 | */ | 737 | */ |
709 | pll_clock = pdc_detect_pll_input_clock(pe); | 738 | pll_clock = pdc_detect_pll_input_clock(host); |
710 | 739 | ||
711 | if (pll_clock < 0) /* counter overflow? Try again. */ | 740 | if (pll_clock < 0) /* counter overflow? Try again. */ |
712 | pll_clock = pdc_detect_pll_input_clock(pe); | 741 | pll_clock = pdc_detect_pll_input_clock(host); |
713 | 742 | ||
714 | dev_printk(KERN_INFO, &pdev->dev, "PLL input clock %ld kHz\n", pll_clock/1000); | 743 | dev_printk(KERN_INFO, host->dev, "PLL input clock %ld kHz\n", pll_clock/1000); |
715 | 744 | ||
716 | /* Adjust PLL control register */ | 745 | /* Adjust PLL control register */ |
717 | pdc_adjust_pll(pe, pll_clock, board_idx); | 746 | pdc_adjust_pll(host, pll_clock, board_idx); |
718 | 747 | ||
719 | return 0; | 748 | return 0; |
720 | } | 749 | } |
@@ -746,8 +775,7 @@ static void pdc_ata_setup_port(struct ata_ioports *port, void __iomem *base) | |||
746 | * Called when an instance of PCI adapter is inserted. | 775 | * Called when an instance of PCI adapter is inserted. |
747 | * This function checks whether the hardware is supported, | 776 | * This function checks whether the hardware is supported, |
748 | * initialize hardware and register an instance of ata_host to | 777 | * initialize hardware and register an instance of ata_host to |
749 | * libata by providing struct ata_probe_ent and ata_device_add(). | 778 | * libata. (implements struct pci_driver.probe() ) |
750 | * (implements struct pci_driver.probe() ) | ||
751 | * | 779 | * |
752 | * @pdev: instance of pci_dev found | 780 | * @pdev: instance of pci_dev found |
753 | * @ent: matching entry in the id_tbl[] | 781 | * @ent: matching entry in the id_tbl[] |
@@ -756,14 +784,21 @@ static int __devinit pdc2027x_init_one(struct pci_dev *pdev, const struct pci_de | |||
756 | { | 784 | { |
757 | static int printed_version; | 785 | static int printed_version; |
758 | unsigned int board_idx = (unsigned int) ent->driver_data; | 786 | unsigned int board_idx = (unsigned int) ent->driver_data; |
759 | 787 | const struct ata_port_info *ppi[] = | |
760 | struct ata_probe_ent *probe_ent; | 788 | { &pdc2027x_port_info[board_idx], NULL }; |
789 | struct ata_host *host; | ||
761 | void __iomem *mmio_base; | 790 | void __iomem *mmio_base; |
762 | int rc; | 791 | int rc; |
763 | 792 | ||
764 | if (!printed_version++) | 793 | if (!printed_version++) |
765 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 794 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
766 | 795 | ||
796 | /* alloc host */ | ||
797 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, 2); | ||
798 | if (!host) | ||
799 | return -ENOMEM; | ||
800 | |||
801 | /* acquire resources and fill host */ | ||
767 | rc = pcim_enable_device(pdev); | 802 | rc = pcim_enable_device(pdev); |
768 | if (rc) | 803 | if (rc) |
769 | return rc; | 804 | return rc; |
@@ -771,6 +806,7 @@ static int __devinit pdc2027x_init_one(struct pci_dev *pdev, const struct pci_de | |||
771 | rc = pcim_iomap_regions(pdev, 1 << PDC_MMIO_BAR, DRV_NAME); | 806 | rc = pcim_iomap_regions(pdev, 1 << PDC_MMIO_BAR, DRV_NAME); |
772 | if (rc) | 807 | if (rc) |
773 | return rc; | 808 | return rc; |
809 | host->iomap = pcim_iomap_table(pdev); | ||
774 | 810 | ||
775 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | 811 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); |
776 | if (rc) | 812 | if (rc) |
@@ -780,46 +816,22 @@ static int __devinit pdc2027x_init_one(struct pci_dev *pdev, const struct pci_de | |||
780 | if (rc) | 816 | if (rc) |
781 | return rc; | 817 | return rc; |
782 | 818 | ||
783 | /* Prepare the probe entry */ | 819 | mmio_base = host->iomap[PDC_MMIO_BAR]; |
784 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | ||
785 | if (probe_ent == NULL) | ||
786 | return -ENOMEM; | ||
787 | |||
788 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
789 | INIT_LIST_HEAD(&probe_ent->node); | ||
790 | |||
791 | probe_ent->sht = pdc2027x_port_info[board_idx].sht; | ||
792 | probe_ent->port_flags = pdc2027x_port_info[board_idx].flags; | ||
793 | probe_ent->pio_mask = pdc2027x_port_info[board_idx].pio_mask; | ||
794 | probe_ent->mwdma_mask = pdc2027x_port_info[board_idx].mwdma_mask; | ||
795 | probe_ent->udma_mask = pdc2027x_port_info[board_idx].udma_mask; | ||
796 | probe_ent->port_ops = pdc2027x_port_info[board_idx].port_ops; | ||
797 | 820 | ||
798 | probe_ent->irq = pdev->irq; | 821 | pdc_ata_setup_port(&host->ports[0]->ioaddr, mmio_base + 0x17c0); |
799 | probe_ent->irq_flags = IRQF_SHARED; | 822 | host->ports[0]->ioaddr.bmdma_addr = mmio_base + 0x1000; |
800 | probe_ent->iomap = pcim_iomap_table(pdev); | 823 | pdc_ata_setup_port(&host->ports[1]->ioaddr, mmio_base + 0x15c0); |
824 | host->ports[1]->ioaddr.bmdma_addr = mmio_base + 0x1008; | ||
801 | 825 | ||
802 | mmio_base = probe_ent->iomap[PDC_MMIO_BAR]; | ||
803 | |||
804 | pdc_ata_setup_port(&probe_ent->port[0], mmio_base + 0x17c0); | ||
805 | probe_ent->port[0].bmdma_addr = mmio_base + 0x1000; | ||
806 | pdc_ata_setup_port(&probe_ent->port[1], mmio_base + 0x15c0); | ||
807 | probe_ent->port[1].bmdma_addr = mmio_base + 0x1008; | ||
808 | |||
809 | probe_ent->n_ports = 2; | ||
810 | |||
811 | pci_set_master(pdev); | ||
812 | //pci_enable_intx(pdev); | 826 | //pci_enable_intx(pdev); |
813 | 827 | ||
814 | /* initialize adapter */ | 828 | /* initialize adapter */ |
815 | if (pdc_hardware_init(pdev, probe_ent, board_idx) != 0) | 829 | if (pdc_hardware_init(host, board_idx) != 0) |
816 | return -EIO; | 830 | return -EIO; |
817 | 831 | ||
818 | if (!ata_device_add(probe_ent)) | 832 | pci_set_master(pdev); |
819 | return -ENODEV; | 833 | return ata_host_activate(host, pdev->irq, ata_interrupt, IRQF_SHARED, |
820 | 834 | &pdc2027x_sht); | |
821 | devm_kfree(&pdev->dev, probe_ent); | ||
822 | return 0; | ||
823 | } | 835 | } |
824 | 836 | ||
825 | /** | 837 | /** |
diff --git a/drivers/ata/pata_pdc202xx_old.c b/drivers/ata/pata_pdc202xx_old.c index 0a149339891..ee636beb05e 100644 --- a/drivers/ata/pata_pdc202xx_old.c +++ b/drivers/ata/pata_pdc202xx_old.c | |||
@@ -22,45 +22,17 @@ | |||
22 | #include <linux/libata.h> | 22 | #include <linux/libata.h> |
23 | 23 | ||
24 | #define DRV_NAME "pata_pdc202xx_old" | 24 | #define DRV_NAME "pata_pdc202xx_old" |
25 | #define DRV_VERSION "0.4.0" | 25 | #define DRV_VERSION "0.4.2" |
26 | 26 | ||
27 | /** | 27 | static int pdc2026x_cable_detect(struct ata_port *ap) |
28 | * pdc2024x_pre_reset - probe begin | ||
29 | * @ap: ATA port | ||
30 | * | ||
31 | * Set up cable type and use generic probe init | ||
32 | */ | ||
33 | |||
34 | static int pdc2024x_pre_reset(struct ata_port *ap) | ||
35 | { | ||
36 | ap->cbl = ATA_CBL_PATA40; | ||
37 | return ata_std_prereset(ap); | ||
38 | } | ||
39 | |||
40 | |||
41 | static void pdc2024x_error_handler(struct ata_port *ap) | ||
42 | { | ||
43 | ata_bmdma_drive_eh(ap, pdc2024x_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
44 | } | ||
45 | |||
46 | |||
47 | static int pdc2026x_pre_reset(struct ata_port *ap) | ||
48 | { | 28 | { |
49 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 29 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
50 | u16 cis; | 30 | u16 cis; |
51 | 31 | ||
52 | pci_read_config_word(pdev, 0x50, &cis); | 32 | pci_read_config_word(pdev, 0x50, &cis); |
53 | if (cis & (1 << (10 + ap->port_no))) | 33 | if (cis & (1 << (10 + ap->port_no))) |
54 | ap->cbl = ATA_CBL_PATA80; | 34 | return ATA_CBL_PATA80; |
55 | else | 35 | return ATA_CBL_PATA40; |
56 | ap->cbl = ATA_CBL_PATA40; | ||
57 | |||
58 | return ata_std_prereset(ap); | ||
59 | } | ||
60 | |||
61 | static void pdc2026x_error_handler(struct ata_port *ap) | ||
62 | { | ||
63 | ata_bmdma_drive_eh(ap, pdc2026x_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
64 | } | 36 | } |
65 | 37 | ||
66 | /** | 38 | /** |
@@ -244,7 +216,6 @@ static void pdc2026x_bmdma_stop(struct ata_queued_cmd *qc) | |||
244 | 216 | ||
245 | /** | 217 | /** |
246 | * pdc2026x_dev_config - device setup hook | 218 | * pdc2026x_dev_config - device setup hook |
247 | * @ap: ATA port | ||
248 | * @adev: newly found device | 219 | * @adev: newly found device |
249 | * | 220 | * |
250 | * Perform chip specific early setup. We need to lock the transfer | 221 | * Perform chip specific early setup. We need to lock the transfer |
@@ -252,7 +223,7 @@ static void pdc2026x_bmdma_stop(struct ata_queued_cmd *qc) | |||
252 | * barf. | 223 | * barf. |
253 | */ | 224 | */ |
254 | 225 | ||
255 | static void pdc2026x_dev_config(struct ata_port *ap, struct ata_device *adev) | 226 | static void pdc2026x_dev_config(struct ata_device *adev) |
256 | { | 227 | { |
257 | adev->max_sectors = 256; | 228 | adev->max_sectors = 256; |
258 | } | 229 | } |
@@ -292,8 +263,9 @@ static struct ata_port_operations pdc2024x_port_ops = { | |||
292 | 263 | ||
293 | .freeze = ata_bmdma_freeze, | 264 | .freeze = ata_bmdma_freeze, |
294 | .thaw = ata_bmdma_thaw, | 265 | .thaw = ata_bmdma_thaw, |
295 | .error_handler = pdc2024x_error_handler, | 266 | .error_handler = ata_bmdma_error_handler, |
296 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 267 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
268 | .cable_detect = ata_cable_40wire, | ||
297 | 269 | ||
298 | .bmdma_setup = ata_bmdma_setup, | 270 | .bmdma_setup = ata_bmdma_setup, |
299 | .bmdma_start = ata_bmdma_start, | 271 | .bmdma_start = ata_bmdma_start, |
@@ -326,8 +298,9 @@ static struct ata_port_operations pdc2026x_port_ops = { | |||
326 | 298 | ||
327 | .freeze = ata_bmdma_freeze, | 299 | .freeze = ata_bmdma_freeze, |
328 | .thaw = ata_bmdma_thaw, | 300 | .thaw = ata_bmdma_thaw, |
329 | .error_handler = pdc2026x_error_handler, | 301 | .error_handler = ata_bmdma_error_handler, |
330 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 302 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
303 | .cable_detect = pdc2026x_cable_detect, | ||
331 | 304 | ||
332 | .bmdma_setup = ata_bmdma_setup, | 305 | .bmdma_setup = ata_bmdma_setup, |
333 | .bmdma_start = pdc2026x_bmdma_start, | 306 | .bmdma_start = pdc2026x_bmdma_start, |
diff --git a/drivers/ata/pata_platform.c b/drivers/ata/pata_platform.c index 4b82a5435a4..a0a650c7f27 100644 --- a/drivers/ata/pata_platform.c +++ b/drivers/ata/pata_platform.c | |||
@@ -80,13 +80,13 @@ static struct ata_port_operations pata_platform_port_ops = { | |||
80 | .thaw = ata_bmdma_thaw, | 80 | .thaw = ata_bmdma_thaw, |
81 | .error_handler = ata_bmdma_error_handler, | 81 | .error_handler = ata_bmdma_error_handler, |
82 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 82 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
83 | .cable_detect = ata_cable_unknown, | ||
83 | 84 | ||
84 | .qc_prep = ata_qc_prep, | 85 | .qc_prep = ata_qc_prep, |
85 | .qc_issue = ata_qc_issue_prot, | 86 | .qc_issue = ata_qc_issue_prot, |
86 | 87 | ||
87 | .data_xfer = ata_data_xfer_noirq, | 88 | .data_xfer = ata_data_xfer_noirq, |
88 | 89 | ||
89 | .irq_handler = ata_interrupt, | ||
90 | .irq_clear = ata_bmdma_irq_clear, | 90 | .irq_clear = ata_bmdma_irq_clear, |
91 | .irq_on = ata_irq_on, | 91 | .irq_on = ata_irq_on, |
92 | .irq_ack = ata_irq_ack, | 92 | .irq_ack = ata_irq_ack, |
@@ -135,7 +135,8 @@ static void pata_platform_setup_port(struct ata_ioports *ioaddr, | |||
135 | static int __devinit pata_platform_probe(struct platform_device *pdev) | 135 | static int __devinit pata_platform_probe(struct platform_device *pdev) |
136 | { | 136 | { |
137 | struct resource *io_res, *ctl_res; | 137 | struct resource *io_res, *ctl_res; |
138 | struct ata_probe_ent ae; | 138 | struct ata_host *host; |
139 | struct ata_port *ap; | ||
139 | unsigned int mmio; | 140 | unsigned int mmio; |
140 | 141 | ||
141 | /* | 142 | /* |
@@ -175,44 +176,41 @@ static int __devinit pata_platform_probe(struct platform_device *pdev) | |||
175 | /* | 176 | /* |
176 | * Now that that's out of the way, wire up the port.. | 177 | * Now that that's out of the way, wire up the port.. |
177 | */ | 178 | */ |
178 | memset(&ae, 0, sizeof(struct ata_probe_ent)); | 179 | host = ata_host_alloc(&pdev->dev, 1); |
179 | INIT_LIST_HEAD(&ae.node); | 180 | if (!host) |
180 | ae.dev = &pdev->dev; | 181 | return -ENOMEM; |
181 | ae.port_ops = &pata_platform_port_ops; | 182 | ap = host->ports[0]; |
182 | ae.sht = &pata_platform_sht; | 183 | |
183 | ae.n_ports = 1; | 184 | ap->ops = &pata_platform_port_ops; |
184 | ae.pio_mask = pio_mask; | 185 | ap->pio_mask = pio_mask; |
185 | ae.irq = platform_get_irq(pdev, 0); | 186 | ap->flags |= ATA_FLAG_SLAVE_POSS; |
186 | ae.irq_flags = 0; | ||
187 | ae.port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST; | ||
188 | 187 | ||
189 | /* | 188 | /* |
190 | * Handle the MMIO case | 189 | * Handle the MMIO case |
191 | */ | 190 | */ |
192 | if (mmio) { | 191 | if (mmio) { |
193 | ae.port[0].cmd_addr = devm_ioremap(&pdev->dev, io_res->start, | 192 | ap->ioaddr.cmd_addr = devm_ioremap(&pdev->dev, io_res->start, |
194 | io_res->end - io_res->start + 1); | 193 | io_res->end - io_res->start + 1); |
195 | ae.port[0].ctl_addr = devm_ioremap(&pdev->dev, ctl_res->start, | 194 | ap->ioaddr.ctl_addr = devm_ioremap(&pdev->dev, ctl_res->start, |
196 | ctl_res->end - ctl_res->start + 1); | 195 | ctl_res->end - ctl_res->start + 1); |
197 | } else { | 196 | } else { |
198 | ae.port[0].cmd_addr = devm_ioport_map(&pdev->dev, io_res->start, | 197 | ap->ioaddr.cmd_addr = devm_ioport_map(&pdev->dev, io_res->start, |
199 | io_res->end - io_res->start + 1); | 198 | io_res->end - io_res->start + 1); |
200 | ae.port[0].ctl_addr = devm_ioport_map(&pdev->dev, ctl_res->start, | 199 | ap->ioaddr.ctl_addr = devm_ioport_map(&pdev->dev, ctl_res->start, |
201 | ctl_res->end - ctl_res->start + 1); | 200 | ctl_res->end - ctl_res->start + 1); |
202 | } | 201 | } |
203 | if (!ae.port[0].cmd_addr || !ae.port[0].ctl_addr) { | 202 | if (!ap->ioaddr.cmd_addr || !ap->ioaddr.ctl_addr) { |
204 | dev_err(&pdev->dev, "failed to map IO/CTL base\n"); | 203 | dev_err(&pdev->dev, "failed to map IO/CTL base\n"); |
205 | return -ENOMEM; | 204 | return -ENOMEM; |
206 | } | 205 | } |
207 | 206 | ||
208 | ae.port[0].altstatus_addr = ae.port[0].ctl_addr; | 207 | ap->ioaddr.altstatus_addr = ap->ioaddr.ctl_addr; |
209 | 208 | ||
210 | pata_platform_setup_port(&ae.port[0], pdev->dev.platform_data); | 209 | pata_platform_setup_port(&ap->ioaddr, pdev->dev.platform_data); |
211 | 210 | ||
212 | if (unlikely(ata_device_add(&ae) == 0)) | 211 | /* activate */ |
213 | return -ENODEV; | 212 | return ata_host_activate(host, platform_get_irq(pdev, 0), ata_interrupt, |
214 | 213 | 0, &pata_platform_sht); | |
215 | return 0; | ||
216 | } | 214 | } |
217 | 215 | ||
218 | /** | 216 | /** |
diff --git a/drivers/ata/pata_qdi.c b/drivers/ata/pata_qdi.c index c3810012f3f..27685ce63ce 100644 --- a/drivers/ata/pata_qdi.c +++ b/drivers/ata/pata_qdi.c | |||
@@ -183,13 +183,13 @@ static struct ata_port_operations qdi6500_port_ops = { | |||
183 | .thaw = ata_bmdma_thaw, | 183 | .thaw = ata_bmdma_thaw, |
184 | .error_handler = ata_bmdma_error_handler, | 184 | .error_handler = ata_bmdma_error_handler, |
185 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 185 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
186 | .cable_detect = ata_cable_40wire, | ||
186 | 187 | ||
187 | .qc_prep = ata_qc_prep, | 188 | .qc_prep = ata_qc_prep, |
188 | .qc_issue = qdi_qc_issue_prot, | 189 | .qc_issue = qdi_qc_issue_prot, |
189 | 190 | ||
190 | .data_xfer = qdi_data_xfer, | 191 | .data_xfer = qdi_data_xfer, |
191 | 192 | ||
192 | .irq_handler = ata_interrupt, | ||
193 | .irq_clear = ata_bmdma_irq_clear, | 193 | .irq_clear = ata_bmdma_irq_clear, |
194 | .irq_on = ata_irq_on, | 194 | .irq_on = ata_irq_on, |
195 | .irq_ack = ata_irq_ack, | 195 | .irq_ack = ata_irq_ack, |
@@ -211,13 +211,13 @@ static struct ata_port_operations qdi6580_port_ops = { | |||
211 | .thaw = ata_bmdma_thaw, | 211 | .thaw = ata_bmdma_thaw, |
212 | .error_handler = ata_bmdma_error_handler, | 212 | .error_handler = ata_bmdma_error_handler, |
213 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 213 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
214 | .cable_detect = ata_cable_40wire, | ||
214 | 215 | ||
215 | .qc_prep = ata_qc_prep, | 216 | .qc_prep = ata_qc_prep, |
216 | .qc_issue = qdi_qc_issue_prot, | 217 | .qc_issue = qdi_qc_issue_prot, |
217 | 218 | ||
218 | .data_xfer = qdi_data_xfer, | 219 | .data_xfer = qdi_data_xfer, |
219 | 220 | ||
220 | .irq_handler = ata_interrupt, | ||
221 | .irq_clear = ata_bmdma_irq_clear, | 221 | .irq_clear = ata_bmdma_irq_clear, |
222 | .irq_on = ata_irq_on, | 222 | .irq_on = ata_irq_on, |
223 | .irq_ack = ata_irq_ack, | 223 | .irq_ack = ata_irq_ack, |
@@ -238,8 +238,9 @@ static struct ata_port_operations qdi6580_port_ops = { | |||
238 | 238 | ||
239 | static __init int qdi_init_one(unsigned long port, int type, unsigned long io, int irq, int fast) | 239 | static __init int qdi_init_one(unsigned long port, int type, unsigned long io, int irq, int fast) |
240 | { | 240 | { |
241 | struct ata_probe_ent ae; | ||
242 | struct platform_device *pdev; | 241 | struct platform_device *pdev; |
242 | struct ata_host *host; | ||
243 | struct ata_port *ap; | ||
243 | void __iomem *io_addr, *ctl_addr; | 244 | void __iomem *io_addr, *ctl_addr; |
244 | int ret; | 245 | int ret; |
245 | 246 | ||
@@ -257,34 +258,31 @@ static __init int qdi_init_one(unsigned long port, int type, unsigned long io, i | |||
257 | if (!io_addr || !ctl_addr) | 258 | if (!io_addr || !ctl_addr) |
258 | goto fail; | 259 | goto fail; |
259 | 260 | ||
260 | memset(&ae, 0, sizeof(struct ata_probe_ent)); | 261 | ret = -ENOMEM; |
261 | INIT_LIST_HEAD(&ae.node); | 262 | host = ata_host_alloc(&pdev->dev, 1); |
262 | ae.dev = &pdev->dev; | 263 | if (!host) |
264 | goto fail; | ||
265 | ap = host->ports[0]; | ||
263 | 266 | ||
264 | if (type == 6580) { | 267 | if (type == 6580) { |
265 | ae.port_ops = &qdi6580_port_ops; | 268 | ap->ops = &qdi6580_port_ops; |
266 | ae.pio_mask = 0x1F; | 269 | ap->pio_mask = 0x1F; |
267 | ae.port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST; | 270 | ap->flags |= ATA_FLAG_SLAVE_POSS; |
268 | } else { | 271 | } else { |
269 | ae.port_ops = &qdi6500_port_ops; | 272 | ap->ops = &qdi6500_port_ops; |
270 | ae.pio_mask = 0x07; /* Actually PIO3 !IORDY is possible */ | 273 | ap->pio_mask = 0x07; /* Actually PIO3 !IORDY is possible */ |
271 | ae.port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST | | 274 | ap->flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_NO_IORDY; |
272 | ATA_FLAG_NO_IORDY; | ||
273 | } | 275 | } |
274 | 276 | ||
275 | ae.sht = &qdi_sht; | 277 | ap->ioaddr.cmd_addr = io_addr; |
276 | ae.n_ports = 1; | 278 | ap->ioaddr.altstatus_addr = ctl_addr; |
277 | ae.irq = irq; | 279 | ap->ioaddr.ctl_addr = ctl_addr; |
278 | ae.irq_flags = 0; | 280 | ata_std_ports(&ap->ioaddr); |
279 | ae.port[0].cmd_addr = io_addr; | ||
280 | ae.port[0].altstatus_addr = ctl_addr; | ||
281 | ae.port[0].ctl_addr = ctl_addr; | ||
282 | ata_std_ports(&ae.port[0]); | ||
283 | 281 | ||
284 | /* | 282 | /* |
285 | * Hook in a private data structure per channel | 283 | * Hook in a private data structure per channel |
286 | */ | 284 | */ |
287 | ae.private_data = &qdi_data[nr_qdi_host]; | 285 | ap->private_data = &qdi_data[nr_qdi_host]; |
288 | 286 | ||
289 | qdi_data[nr_qdi_host].timing = port; | 287 | qdi_data[nr_qdi_host].timing = port; |
290 | qdi_data[nr_qdi_host].fast = fast; | 288 | qdi_data[nr_qdi_host].fast = fast; |
@@ -292,8 +290,9 @@ static __init int qdi_init_one(unsigned long port, int type, unsigned long io, i | |||
292 | 290 | ||
293 | printk(KERN_INFO DRV_NAME": qd%d at 0x%lx.\n", type, io); | 291 | printk(KERN_INFO DRV_NAME": qd%d at 0x%lx.\n", type, io); |
294 | 292 | ||
295 | ret = -ENODEV; | 293 | /* activate */ |
296 | if (!ata_device_add(&ae)) | 294 | ret = ata_host_activate(host, irq, ata_interrupt, 0, &qdi_sht); |
295 | if (ret) | ||
297 | goto fail; | 296 | goto fail; |
298 | 297 | ||
299 | qdi_host[nr_qdi_host++] = dev_get_drvdata(&pdev->dev); | 298 | qdi_host[nr_qdi_host++] = dev_get_drvdata(&pdev->dev); |
diff --git a/drivers/ata/pata_radisys.c b/drivers/ata/pata_radisys.c index 9a9132c9e33..1c54673e008 100644 --- a/drivers/ata/pata_radisys.c +++ b/drivers/ata/pata_radisys.c | |||
@@ -24,40 +24,12 @@ | |||
24 | #include <linux/ata.h> | 24 | #include <linux/ata.h> |
25 | 25 | ||
26 | #define DRV_NAME "pata_radisys" | 26 | #define DRV_NAME "pata_radisys" |
27 | #define DRV_VERSION "0.4.1" | 27 | #define DRV_VERSION "0.4.4" |
28 | |||
29 | /** | ||
30 | * radisys_probe_init - probe begin | ||
31 | * @ap: ATA port | ||
32 | * | ||
33 | * Set up cable type and use generic probe init | ||
34 | */ | ||
35 | |||
36 | static int radisys_pre_reset(struct ata_port *ap) | ||
37 | { | ||
38 | ap->cbl = ATA_CBL_PATA80; | ||
39 | return ata_std_prereset(ap); | ||
40 | } | ||
41 | |||
42 | |||
43 | /** | ||
44 | * radisys_pata_error_handler - Probe specified port on PATA host controller | ||
45 | * @ap: Port to probe | ||
46 | * @classes: | ||
47 | * | ||
48 | * LOCKING: | ||
49 | * None (inherited from caller). | ||
50 | */ | ||
51 | |||
52 | static void radisys_pata_error_handler(struct ata_port *ap) | ||
53 | { | ||
54 | ata_bmdma_drive_eh(ap, radisys_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
55 | } | ||
56 | 28 | ||
57 | /** | 29 | /** |
58 | * radisys_set_piomode - Initialize host controller PATA PIO timings | 30 | * radisys_set_piomode - Initialize host controller PATA PIO timings |
59 | * @ap: Port whose timings we are configuring | 31 | * @ap: ATA port |
60 | * @adev: um | 32 | * @adev: Device whose timings we are configuring |
61 | * | 33 | * |
62 | * Set PIO mode for device, in host controller PCI config space. | 34 | * Set PIO mode for device, in host controller PCI config space. |
63 | * | 35 | * |
@@ -248,8 +220,9 @@ static const struct ata_port_operations radisys_pata_ops = { | |||
248 | 220 | ||
249 | .freeze = ata_bmdma_freeze, | 221 | .freeze = ata_bmdma_freeze, |
250 | .thaw = ata_bmdma_thaw, | 222 | .thaw = ata_bmdma_thaw, |
251 | .error_handler = radisys_pata_error_handler, | 223 | .error_handler = ata_bmdma_error_handler, |
252 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 224 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
225 | .cable_detect = ata_cable_unknown, | ||
253 | 226 | ||
254 | .bmdma_setup = ata_bmdma_setup, | 227 | .bmdma_setup = ata_bmdma_setup, |
255 | .bmdma_start = ata_bmdma_start, | 228 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_rz1000.c b/drivers/ata/pata_rz1000.c index f522daa2a6a..85c45290eee 100644 --- a/drivers/ata/pata_rz1000.c +++ b/drivers/ata/pata_rz1000.c | |||
@@ -25,31 +25,6 @@ | |||
25 | 25 | ||
26 | 26 | ||
27 | /** | 27 | /** |
28 | * rz1000_prereset - probe begin | ||
29 | * @ap: ATA port | ||
30 | * | ||
31 | * Set up cable type and use generics | ||
32 | */ | ||
33 | |||
34 | static int rz1000_prereset(struct ata_port *ap) | ||
35 | { | ||
36 | ap->cbl = ATA_CBL_PATA40; | ||
37 | return ata_std_prereset(ap); | ||
38 | } | ||
39 | |||
40 | /** | ||
41 | * rz1000_error_handler - probe reset | ||
42 | * @ap: ATA port | ||
43 | * | ||
44 | * Perform the ATA standard reset sequence | ||
45 | */ | ||
46 | |||
47 | static void rz1000_error_handler(struct ata_port *ap) | ||
48 | { | ||
49 | ata_bmdma_drive_eh(ap, rz1000_prereset, ata_std_softreset, NULL, ata_std_postreset); | ||
50 | } | ||
51 | |||
52 | /** | ||
53 | * rz1000_set_mode - mode setting function | 28 | * rz1000_set_mode - mode setting function |
54 | * @ap: ATA interface | 29 | * @ap: ATA interface |
55 | * @unused: returned device on set_mode failure | 30 | * @unused: returned device on set_mode failure |
@@ -122,8 +97,9 @@ static struct ata_port_operations rz1000_port_ops = { | |||
122 | 97 | ||
123 | .freeze = ata_bmdma_freeze, | 98 | .freeze = ata_bmdma_freeze, |
124 | .thaw = ata_bmdma_thaw, | 99 | .thaw = ata_bmdma_thaw, |
125 | .error_handler = rz1000_error_handler, | 100 | .error_handler = ata_bmdma_error_handler, |
126 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 101 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
102 | .cable_detect = ata_cable_40wire, | ||
127 | 103 | ||
128 | .irq_handler = ata_interrupt, | 104 | .irq_handler = ata_interrupt, |
129 | .irq_clear = ata_bmdma_irq_clear, | 105 | .irq_clear = ata_bmdma_irq_clear, |
diff --git a/drivers/ata/pata_sc1200.c b/drivers/ata/pata_sc1200.c index 93b3ed0f9e8..66e8ff467c8 100644 --- a/drivers/ata/pata_sc1200.c +++ b/drivers/ata/pata_sc1200.c | |||
@@ -216,6 +216,7 @@ static struct ata_port_operations sc1200_port_ops = { | |||
216 | .thaw = ata_bmdma_thaw, | 216 | .thaw = ata_bmdma_thaw, |
217 | .error_handler = ata_bmdma_error_handler, | 217 | .error_handler = ata_bmdma_error_handler, |
218 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 218 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
219 | .cable_detect = ata_cable_40wire, | ||
219 | 220 | ||
220 | .bmdma_setup = ata_bmdma_setup, | 221 | .bmdma_setup = ata_bmdma_setup, |
221 | .bmdma_start = ata_bmdma_start, | 222 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_scc.c b/drivers/ata/pata_scc.c index f3ed141fdc0..5df354d573e 100644 --- a/drivers/ata/pata_scc.c +++ b/drivers/ata/pata_scc.c | |||
@@ -1016,7 +1016,6 @@ static const struct ata_port_operations scc_pata_ops = { | |||
1016 | .error_handler = scc_error_handler, | 1016 | .error_handler = scc_error_handler, |
1017 | .post_internal_cmd = scc_bmdma_stop, | 1017 | .post_internal_cmd = scc_bmdma_stop, |
1018 | 1018 | ||
1019 | .irq_handler = ata_interrupt, | ||
1020 | .irq_clear = scc_bmdma_irq_clear, | 1019 | .irq_clear = scc_bmdma_irq_clear, |
1021 | .irq_on = scc_irq_on, | 1020 | .irq_on = scc_irq_on, |
1022 | .irq_ack = scc_irq_ack, | 1021 | .irq_ack = scc_irq_ack, |
@@ -1027,7 +1026,6 @@ static const struct ata_port_operations scc_pata_ops = { | |||
1027 | 1026 | ||
1028 | static struct ata_port_info scc_port_info[] = { | 1027 | static struct ata_port_info scc_port_info[] = { |
1029 | { | 1028 | { |
1030 | .sht = &scc_sht, | ||
1031 | .flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_MMIO | ATA_FLAG_NO_LEGACY, | 1029 | .flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_MMIO | ATA_FLAG_NO_LEGACY, |
1032 | .pio_mask = 0x1f, /* pio0-4 */ | 1030 | .pio_mask = 0x1f, /* pio0-4 */ |
1033 | .mwdma_mask = 0x00, | 1031 | .mwdma_mask = 0x00, |
@@ -1040,10 +1038,10 @@ static struct ata_port_info scc_port_info[] = { | |||
1040 | * scc_reset_controller - initialize SCC PATA controller. | 1038 | * scc_reset_controller - initialize SCC PATA controller. |
1041 | */ | 1039 | */ |
1042 | 1040 | ||
1043 | static int scc_reset_controller(struct ata_probe_ent *probe_ent) | 1041 | static int scc_reset_controller(struct ata_host *host) |
1044 | { | 1042 | { |
1045 | void __iomem *ctrl_base = probe_ent->iomap[SCC_CTRL_BAR]; | 1043 | void __iomem *ctrl_base = host->iomap[SCC_CTRL_BAR]; |
1046 | void __iomem *bmid_base = probe_ent->iomap[SCC_BMID_BAR]; | 1044 | void __iomem *bmid_base = host->iomap[SCC_BMID_BAR]; |
1047 | void __iomem *cckctrl_port = ctrl_base + SCC_CTL_CCKCTRL; | 1045 | void __iomem *cckctrl_port = ctrl_base + SCC_CTL_CCKCTRL; |
1048 | void __iomem *mode_port = ctrl_base + SCC_CTL_MODEREG; | 1046 | void __iomem *mode_port = ctrl_base + SCC_CTL_MODEREG; |
1049 | void __iomem *ecmode_port = ctrl_base + SCC_CTL_ECMODE; | 1047 | void __iomem *ecmode_port = ctrl_base + SCC_CTL_ECMODE; |
@@ -1104,17 +1102,15 @@ static void scc_setup_ports (struct ata_ioports *ioaddr, void __iomem *base) | |||
1104 | ioaddr->command_addr = ioaddr->cmd_addr + SCC_REG_CMD; | 1102 | ioaddr->command_addr = ioaddr->cmd_addr + SCC_REG_CMD; |
1105 | } | 1103 | } |
1106 | 1104 | ||
1107 | static int scc_host_init(struct ata_probe_ent *probe_ent) | 1105 | static int scc_host_init(struct ata_host *host) |
1108 | { | 1106 | { |
1109 | struct pci_dev *pdev = to_pci_dev(probe_ent->dev); | 1107 | struct pci_dev *pdev = to_pci_dev(host->dev); |
1110 | int rc; | 1108 | int rc; |
1111 | 1109 | ||
1112 | rc = scc_reset_controller(probe_ent); | 1110 | rc = scc_reset_controller(host); |
1113 | if (rc) | 1111 | if (rc) |
1114 | return rc; | 1112 | return rc; |
1115 | 1113 | ||
1116 | probe_ent->n_ports = 1; | ||
1117 | |||
1118 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | 1114 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); |
1119 | if (rc) | 1115 | if (rc) |
1120 | return rc; | 1116 | return rc; |
@@ -1122,7 +1118,7 @@ static int scc_host_init(struct ata_probe_ent *probe_ent) | |||
1122 | if (rc) | 1118 | if (rc) |
1123 | return rc; | 1119 | return rc; |
1124 | 1120 | ||
1125 | scc_setup_ports(&probe_ent->port[0], probe_ent->iomap[SCC_BMID_BAR]); | 1121 | scc_setup_ports(&host->ports[0]->ioaddr, host->iomap[SCC_BMID_BAR]); |
1126 | 1122 | ||
1127 | pci_set_master(pdev); | 1123 | pci_set_master(pdev); |
1128 | 1124 | ||
@@ -1145,14 +1141,18 @@ static int scc_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1145 | { | 1141 | { |
1146 | static int printed_version; | 1142 | static int printed_version; |
1147 | unsigned int board_idx = (unsigned int) ent->driver_data; | 1143 | unsigned int board_idx = (unsigned int) ent->driver_data; |
1144 | const struct ata_port_info *ppi[] = { &scc_port_info[board_idx], NULL }; | ||
1148 | struct device *dev = &pdev->dev; | 1145 | struct device *dev = &pdev->dev; |
1149 | struct ata_probe_ent *probe_ent; | ||
1150 | int rc; | 1146 | int rc; |
1151 | 1147 | ||
1152 | if (!printed_version++) | 1148 | if (!printed_version++) |
1153 | dev_printk(KERN_DEBUG, &pdev->dev, | 1149 | dev_printk(KERN_DEBUG, &pdev->dev, |
1154 | "version " DRV_VERSION "\n"); | 1150 | "version " DRV_VERSION "\n"); |
1155 | 1151 | ||
1152 | host = ata_port_alloc_pinfo(&pdev->dev, ppi, 1); | ||
1153 | if (!host) | ||
1154 | return -ENOMEM; | ||
1155 | |||
1156 | rc = pcim_enable_device(pdev); | 1156 | rc = pcim_enable_device(pdev); |
1157 | if (rc) | 1157 | if (rc) |
1158 | return rc; | 1158 | return rc; |
@@ -1162,33 +1162,14 @@ static int scc_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1162 | pcim_pin_device(pdev); | 1162 | pcim_pin_device(pdev); |
1163 | if (rc) | 1163 | if (rc) |
1164 | return rc; | 1164 | return rc; |
1165 | host->iomap = pcim_iomap_table(pdev); | ||
1165 | 1166 | ||
1166 | probe_ent = devm_kzalloc(dev, sizeof(*probe_ent), GFP_KERNEL); | 1167 | rc = scc_host_init(host); |
1167 | if (!probe_ent) | ||
1168 | return -ENOMEM; | ||
1169 | |||
1170 | probe_ent->dev = dev; | ||
1171 | INIT_LIST_HEAD(&probe_ent->node); | ||
1172 | |||
1173 | probe_ent->sht = scc_port_info[board_idx].sht; | ||
1174 | probe_ent->port_flags = scc_port_info[board_idx].flags; | ||
1175 | probe_ent->pio_mask = scc_port_info[board_idx].pio_mask; | ||
1176 | probe_ent->udma_mask = scc_port_info[board_idx].udma_mask; | ||
1177 | probe_ent->port_ops = scc_port_info[board_idx].port_ops; | ||
1178 | |||
1179 | probe_ent->irq = pdev->irq; | ||
1180 | probe_ent->irq_flags = IRQF_SHARED; | ||
1181 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
1182 | |||
1183 | rc = scc_host_init(probe_ent); | ||
1184 | if (rc) | 1168 | if (rc) |
1185 | return rc; | 1169 | return rc; |
1186 | 1170 | ||
1187 | if (!ata_device_add(probe_ent)) | 1171 | return ata_host_activate(host, pdev->irq, ata_interrupt, IRQF_SHARED, |
1188 | return -ENODEV; | 1172 | &scc_sht); |
1189 | |||
1190 | devm_kfree(dev, probe_ent); | ||
1191 | return 0; | ||
1192 | } | 1173 | } |
1193 | 1174 | ||
1194 | static struct pci_driver scc_pci_driver = { | 1175 | static struct pci_driver scc_pci_driver = { |
diff --git a/drivers/ata/pata_serverworks.c b/drivers/ata/pata_serverworks.c index 598eef810a7..3956ef26936 100644 --- a/drivers/ata/pata_serverworks.c +++ b/drivers/ata/pata_serverworks.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * ata-serverworks.c - Serverworks PATA for new ATA layer | 2 | * pata_serverworks.c - Serverworks PATA for new ATA layer |
3 | * (C) 2005 Red Hat Inc | 3 | * (C) 2005 Red Hat Inc |
4 | * Alan Cox <alan@redhat.com> | 4 | * Alan Cox <alan@redhat.com> |
5 | * | 5 | * |
@@ -137,14 +137,14 @@ static struct sv_cable_table cable_detect[] = { | |||
137 | }; | 137 | }; |
138 | 138 | ||
139 | /** | 139 | /** |
140 | * serverworks_pre_reset - cable detection | 140 | * serverworks_cable_detect - cable detection |
141 | * @ap: ATA port | 141 | * @ap: ATA port |
142 | * | 142 | * |
143 | * Perform cable detection according to the device and subvendor | 143 | * Perform cable detection according to the device and subvendor |
144 | * identifications | 144 | * identifications |
145 | */ | 145 | */ |
146 | 146 | ||
147 | static int serverworks_pre_reset(struct ata_port *ap) { | 147 | static int serverworks_cable_detect(struct ata_port *ap) { |
148 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 148 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
149 | struct sv_cable_table *cb = cable_detect; | 149 | struct sv_cable_table *cb = cable_detect; |
150 | 150 | ||
@@ -152,8 +152,7 @@ static int serverworks_pre_reset(struct ata_port *ap) { | |||
152 | if (cb->device == pdev->device && | 152 | if (cb->device == pdev->device && |
153 | (cb->subvendor == pdev->subsystem_vendor || | 153 | (cb->subvendor == pdev->subsystem_vendor || |
154 | cb->subvendor == PCI_ANY_ID)) { | 154 | cb->subvendor == PCI_ANY_ID)) { |
155 | ap->cbl = cb->cable_detect(ap); | 155 | return cb->cable_detect(ap); |
156 | return ata_std_prereset(ap); | ||
157 | } | 156 | } |
158 | cb++; | 157 | cb++; |
159 | } | 158 | } |
@@ -162,11 +161,6 @@ static int serverworks_pre_reset(struct ata_port *ap) { | |||
162 | return -1; /* kill compiler warning */ | 161 | return -1; /* kill compiler warning */ |
163 | } | 162 | } |
164 | 163 | ||
165 | static void serverworks_error_handler(struct ata_port *ap) | ||
166 | { | ||
167 | return ata_bmdma_drive_eh(ap, serverworks_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
168 | } | ||
169 | |||
170 | /** | 164 | /** |
171 | * serverworks_is_csb - Check for CSB or OSB | 165 | * serverworks_is_csb - Check for CSB or OSB |
172 | * @pdev: PCI device to check | 166 | * @pdev: PCI device to check |
@@ -191,31 +185,31 @@ static u8 serverworks_is_csb(struct pci_dev *pdev) | |||
191 | 185 | ||
192 | /** | 186 | /** |
193 | * serverworks_osb4_filter - mode selection filter | 187 | * serverworks_osb4_filter - mode selection filter |
194 | * @ap: ATA interface | ||
195 | * @adev: ATA device | 188 | * @adev: ATA device |
189 | * @mask: Mask of proposed modes | ||
196 | * | 190 | * |
197 | * Filter the offered modes for the device to apply controller | 191 | * Filter the offered modes for the device to apply controller |
198 | * specific rules. OSB4 requires no UDMA for disks due to a FIFO | 192 | * specific rules. OSB4 requires no UDMA for disks due to a FIFO |
199 | * bug we hit. | 193 | * bug we hit. |
200 | */ | 194 | */ |
201 | 195 | ||
202 | static unsigned long serverworks_osb4_filter(const struct ata_port *ap, struct ata_device *adev, unsigned long mask) | 196 | static unsigned long serverworks_osb4_filter(struct ata_device *adev, unsigned long mask) |
203 | { | 197 | { |
204 | if (adev->class == ATA_DEV_ATA) | 198 | if (adev->class == ATA_DEV_ATA) |
205 | mask &= ~ATA_MASK_UDMA; | 199 | mask &= ~ATA_MASK_UDMA; |
206 | return ata_pci_default_filter(ap, adev, mask); | 200 | return ata_pci_default_filter(adev, mask); |
207 | } | 201 | } |
208 | 202 | ||
209 | 203 | ||
210 | /** | 204 | /** |
211 | * serverworks_csb_filter - mode selection filter | 205 | * serverworks_csb_filter - mode selection filter |
212 | * @ap: ATA interface | ||
213 | * @adev: ATA device | 206 | * @adev: ATA device |
207 | * @mask: Mask of proposed modes | ||
214 | * | 208 | * |
215 | * Check the blacklist and disable UDMA5 if matched | 209 | * Check the blacklist and disable UDMA5 if matched |
216 | */ | 210 | */ |
217 | 211 | ||
218 | static unsigned long serverworks_csb_filter(const struct ata_port *ap, struct ata_device *adev, unsigned long mask) | 212 | static unsigned long serverworks_csb_filter(struct ata_device *adev, unsigned long mask) |
219 | { | 213 | { |
220 | const char *p; | 214 | const char *p; |
221 | char model_num[ATA_ID_PROD_LEN + 1]; | 215 | char model_num[ATA_ID_PROD_LEN + 1]; |
@@ -223,7 +217,7 @@ static unsigned long serverworks_csb_filter(const struct ata_port *ap, struct at | |||
223 | 217 | ||
224 | /* Disk, UDMA */ | 218 | /* Disk, UDMA */ |
225 | if (adev->class != ATA_DEV_ATA) | 219 | if (adev->class != ATA_DEV_ATA) |
226 | return ata_pci_default_filter(ap, adev, mask); | 220 | return ata_pci_default_filter(adev, mask); |
227 | 221 | ||
228 | /* Actually do need to check */ | 222 | /* Actually do need to check */ |
229 | ata_id_c_string(adev->id, model_num, ATA_ID_PROD, sizeof(model_num)); | 223 | ata_id_c_string(adev->id, model_num, ATA_ID_PROD, sizeof(model_num)); |
@@ -232,7 +226,7 @@ static unsigned long serverworks_csb_filter(const struct ata_port *ap, struct at | |||
232 | if (!strcmp(p, model_num)) | 226 | if (!strcmp(p, model_num)) |
233 | mask &= ~(0x1F << ATA_SHIFT_UDMA); | 227 | mask &= ~(0x1F << ATA_SHIFT_UDMA); |
234 | } | 228 | } |
235 | return ata_pci_default_filter(ap, adev, mask); | 229 | return ata_pci_default_filter(adev, mask); |
236 | } | 230 | } |
237 | 231 | ||
238 | 232 | ||
@@ -339,8 +333,9 @@ static struct ata_port_operations serverworks_osb4_port_ops = { | |||
339 | 333 | ||
340 | .freeze = ata_bmdma_freeze, | 334 | .freeze = ata_bmdma_freeze, |
341 | .thaw = ata_bmdma_thaw, | 335 | .thaw = ata_bmdma_thaw, |
342 | .error_handler = serverworks_error_handler, | 336 | .error_handler = ata_bmdma_error_handler, |
343 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 337 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
338 | .cable_detect = serverworks_cable_detect, | ||
344 | 339 | ||
345 | .bmdma_setup = ata_bmdma_setup, | 340 | .bmdma_setup = ata_bmdma_setup, |
346 | .bmdma_start = ata_bmdma_start, | 341 | .bmdma_start = ata_bmdma_start, |
@@ -374,8 +369,9 @@ static struct ata_port_operations serverworks_csb_port_ops = { | |||
374 | 369 | ||
375 | .freeze = ata_bmdma_freeze, | 370 | .freeze = ata_bmdma_freeze, |
376 | .thaw = ata_bmdma_thaw, | 371 | .thaw = ata_bmdma_thaw, |
377 | .error_handler = serverworks_error_handler, | 372 | .error_handler = ata_bmdma_error_handler, |
378 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 373 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
374 | .cable_detect = serverworks_cable_detect, | ||
379 | 375 | ||
380 | .bmdma_setup = ata_bmdma_setup, | 376 | .bmdma_setup = ata_bmdma_setup, |
381 | .bmdma_start = ata_bmdma_start, | 377 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_sil680.c b/drivers/ata/pata_sil680.c index dab2889a556..6770820cfca 100644 --- a/drivers/ata/pata_sil680.c +++ b/drivers/ata/pata_sil680.c | |||
@@ -33,7 +33,7 @@ | |||
33 | #include <linux/libata.h> | 33 | #include <linux/libata.h> |
34 | 34 | ||
35 | #define DRV_NAME "pata_sil680" | 35 | #define DRV_NAME "pata_sil680" |
36 | #define DRV_VERSION "0.4.5" | 36 | #define DRV_VERSION "0.4.6" |
37 | 37 | ||
38 | /** | 38 | /** |
39 | * sil680_selreg - return register base | 39 | * sil680_selreg - return register base |
@@ -91,12 +91,6 @@ static int sil680_cable_detect(struct ata_port *ap) { | |||
91 | return ATA_CBL_PATA40; | 91 | return ATA_CBL_PATA40; |
92 | } | 92 | } |
93 | 93 | ||
94 | static int sil680_pre_reset(struct ata_port *ap) | ||
95 | { | ||
96 | ap->cbl = sil680_cable_detect(ap); | ||
97 | return ata_std_prereset(ap); | ||
98 | } | ||
99 | |||
100 | /** | 94 | /** |
101 | * sil680_bus_reset - reset the SIL680 bus | 95 | * sil680_bus_reset - reset the SIL680 bus |
102 | * @ap: ATA port to reset | 96 | * @ap: ATA port to reset |
@@ -119,7 +113,7 @@ static int sil680_bus_reset(struct ata_port *ap,unsigned int *classes) | |||
119 | 113 | ||
120 | static void sil680_error_handler(struct ata_port *ap) | 114 | static void sil680_error_handler(struct ata_port *ap) |
121 | { | 115 | { |
122 | ata_bmdma_drive_eh(ap, sil680_pre_reset, sil680_bus_reset, NULL, ata_std_postreset); | 116 | ata_bmdma_drive_eh(ap, ata_std_prereset, sil680_bus_reset, NULL, ata_std_postreset); |
123 | } | 117 | } |
124 | 118 | ||
125 | /** | 119 | /** |
@@ -257,6 +251,7 @@ static struct ata_port_operations sil680_port_ops = { | |||
257 | .thaw = ata_bmdma_thaw, | 251 | .thaw = ata_bmdma_thaw, |
258 | .error_handler = sil680_error_handler, | 252 | .error_handler = sil680_error_handler, |
259 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 253 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
254 | .cable_detect = sil680_cable_detect, | ||
260 | 255 | ||
261 | .bmdma_setup = ata_bmdma_setup, | 256 | .bmdma_setup = ata_bmdma_setup, |
262 | .bmdma_start = ata_bmdma_start, | 257 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_sis.c b/drivers/ata/pata_sis.c index 8dc3bc4f586..a3fbcee6fb3 100644 --- a/drivers/ata/pata_sis.c +++ b/drivers/ata/pata_sis.c | |||
@@ -35,7 +35,7 @@ | |||
35 | #include "sis.h" | 35 | #include "sis.h" |
36 | 36 | ||
37 | #define DRV_NAME "pata_sis" | 37 | #define DRV_NAME "pata_sis" |
38 | #define DRV_VERSION "0.5.0" | 38 | #define DRV_VERSION "0.5.1" |
39 | 39 | ||
40 | struct sis_chipset { | 40 | struct sis_chipset { |
41 | u16 device; /* PCI host ID */ | 41 | u16 device; /* PCI host ID */ |
@@ -86,106 +86,55 @@ static int sis_port_base(struct ata_device *adev) | |||
86 | } | 86 | } |
87 | 87 | ||
88 | /** | 88 | /** |
89 | * sis_133_pre_reset - check for 40/80 pin | 89 | * sis_133_cable_detect - check for 40/80 pin |
90 | * @ap: Port | 90 | * @ap: Port |
91 | * | 91 | * |
92 | * Perform cable detection for the later UDMA133 capable | 92 | * Perform cable detection for the later UDMA133 capable |
93 | * SiS chipset. | 93 | * SiS chipset. |
94 | */ | 94 | */ |
95 | 95 | ||
96 | static int sis_133_pre_reset(struct ata_port *ap) | 96 | static int sis_133_cable_detect(struct ata_port *ap) |
97 | { | 97 | { |
98 | static const struct pci_bits sis_enable_bits[] = { | ||
99 | { 0x4aU, 1U, 0x02UL, 0x02UL }, /* port 0 */ | ||
100 | { 0x4aU, 1U, 0x04UL, 0x04UL }, /* port 1 */ | ||
101 | }; | ||
102 | |||
103 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 98 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
104 | u16 tmp; | 99 | u16 tmp; |
105 | 100 | ||
106 | if (!pci_test_config_bits(pdev, &sis_enable_bits[ap->port_no])) | ||
107 | return -ENOENT; | ||
108 | |||
109 | /* The top bit of this register is the cable detect bit */ | 101 | /* The top bit of this register is the cable detect bit */ |
110 | pci_read_config_word(pdev, 0x50 + 2 * ap->port_no, &tmp); | 102 | pci_read_config_word(pdev, 0x50 + 2 * ap->port_no, &tmp); |
111 | if ((tmp & 0x8000) && !sis_short_ata40(pdev)) | 103 | if ((tmp & 0x8000) && !sis_short_ata40(pdev)) |
112 | ap->cbl = ATA_CBL_PATA40; | 104 | return ATA_CBL_PATA40; |
113 | else | 105 | return ATA_CBL_PATA80; |
114 | ap->cbl = ATA_CBL_PATA80; | ||
115 | |||
116 | return ata_std_prereset(ap); | ||
117 | } | 106 | } |
118 | 107 | ||
119 | /** | 108 | /** |
120 | * sis_error_handler - Probe specified port on PATA host controller | 109 | * sis_66_cable_detect - check for 40/80 pin |
121 | * @ap: Port to probe | ||
122 | * | ||
123 | * LOCKING: | ||
124 | * None (inherited from caller). | ||
125 | */ | ||
126 | |||
127 | static void sis_133_error_handler(struct ata_port *ap) | ||
128 | { | ||
129 | ata_bmdma_drive_eh(ap, sis_133_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
130 | } | ||
131 | |||
132 | |||
133 | /** | ||
134 | * sis_66_pre_reset - check for 40/80 pin | ||
135 | * @ap: Port | 110 | * @ap: Port |
136 | * | 111 | * |
137 | * Perform cable detection on the UDMA66, UDMA100 and early UDMA133 | 112 | * Perform cable detection on the UDMA66, UDMA100 and early UDMA133 |
138 | * SiS IDE controllers. | 113 | * SiS IDE controllers. |
139 | */ | 114 | */ |
140 | 115 | ||
141 | static int sis_66_pre_reset(struct ata_port *ap) | 116 | static int sis_66_cable_detect(struct ata_port *ap) |
142 | { | 117 | { |
143 | static const struct pci_bits sis_enable_bits[] = { | ||
144 | { 0x4aU, 1U, 0x02UL, 0x02UL }, /* port 0 */ | ||
145 | { 0x4aU, 1U, 0x04UL, 0x04UL }, /* port 1 */ | ||
146 | }; | ||
147 | |||
148 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 118 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
149 | u8 tmp; | 119 | u8 tmp; |
150 | 120 | ||
151 | if (!pci_test_config_bits(pdev, &sis_enable_bits[ap->port_no])) { | ||
152 | ata_port_disable(ap); | ||
153 | ata_port_printk(ap, KERN_INFO, "port disabled. ignoring.\n"); | ||
154 | return 0; | ||
155 | } | ||
156 | /* Older chips keep cable detect in bits 4/5 of reg 0x48 */ | 121 | /* Older chips keep cable detect in bits 4/5 of reg 0x48 */ |
157 | pci_read_config_byte(pdev, 0x48, &tmp); | 122 | pci_read_config_byte(pdev, 0x48, &tmp); |
158 | tmp >>= ap->port_no; | 123 | tmp >>= ap->port_no; |
159 | if ((tmp & 0x10) && !sis_short_ata40(pdev)) | 124 | if ((tmp & 0x10) && !sis_short_ata40(pdev)) |
160 | ap->cbl = ATA_CBL_PATA40; | 125 | return ATA_CBL_PATA40; |
161 | else | 126 | return ATA_CBL_PATA80; |
162 | ap->cbl = ATA_CBL_PATA80; | ||
163 | |||
164 | return ata_std_prereset(ap); | ||
165 | } | 127 | } |
166 | 128 | ||
167 | /** | ||
168 | * sis_66_error_handler - Probe specified port on PATA host controller | ||
169 | * @ap: Port to probe | ||
170 | * @classes: | ||
171 | * | ||
172 | * LOCKING: | ||
173 | * None (inherited from caller). | ||
174 | */ | ||
175 | |||
176 | static void sis_66_error_handler(struct ata_port *ap) | ||
177 | { | ||
178 | ata_bmdma_drive_eh(ap, sis_66_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | ||
179 | } | ||
180 | 129 | ||
181 | /** | 130 | /** |
182 | * sis_old_pre_reset - probe begin | 131 | * sis_pre_reset - probe begin |
183 | * @ap: ATA port | 132 | * @ap: ATA port |
184 | * | 133 | * |
185 | * Set up cable type and use generic probe init | 134 | * Set up cable type and use generic probe init |
186 | */ | 135 | */ |
187 | 136 | ||
188 | static int sis_old_pre_reset(struct ata_port *ap) | 137 | static int sis_pre_reset(struct ata_port *ap) |
189 | { | 138 | { |
190 | static const struct pci_bits sis_enable_bits[] = { | 139 | static const struct pci_bits sis_enable_bits[] = { |
191 | { 0x4aU, 1U, 0x02UL, 0x02UL }, /* port 0 */ | 140 | { 0x4aU, 1U, 0x02UL, 0x02UL }, /* port 0 */ |
@@ -194,27 +143,23 @@ static int sis_old_pre_reset(struct ata_port *ap) | |||
194 | 143 | ||
195 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 144 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
196 | 145 | ||
197 | if (!pci_test_config_bits(pdev, &sis_enable_bits[ap->port_no])) { | 146 | if (!pci_test_config_bits(pdev, &sis_enable_bits[ap->port_no])) |
198 | ata_port_disable(ap); | 147 | return -ENOENT; |
199 | ata_port_printk(ap, KERN_INFO, "port disabled. ignoring.\n"); | ||
200 | return 0; | ||
201 | } | ||
202 | ap->cbl = ATA_CBL_PATA40; | ||
203 | return ata_std_prereset(ap); | 148 | return ata_std_prereset(ap); |
204 | } | 149 | } |
205 | 150 | ||
206 | 151 | ||
207 | /** | 152 | /** |
208 | * sis_old_error_handler - Probe specified port on PATA host controller | 153 | * sis_error_handler - Probe specified port on PATA host controller |
209 | * @ap: Port to probe | 154 | * @ap: Port to probe |
210 | * | 155 | * |
211 | * LOCKING: | 156 | * LOCKING: |
212 | * None (inherited from caller). | 157 | * None (inherited from caller). |
213 | */ | 158 | */ |
214 | 159 | ||
215 | static void sis_old_error_handler(struct ata_port *ap) | 160 | static void sis_error_handler(struct ata_port *ap) |
216 | { | 161 | { |
217 | ata_bmdma_drive_eh(ap, sis_old_pre_reset, ata_std_softreset, NULL, ata_std_postreset); | 162 | ata_bmdma_drive_eh(ap, sis_pre_reset, ata_std_softreset, NULL, ata_std_postreset); |
218 | } | 163 | } |
219 | 164 | ||
220 | /** | 165 | /** |
@@ -494,7 +439,7 @@ static void sis_133_early_set_dmamode (struct ata_port *ap, struct ata_device *a | |||
494 | int drive_pci = sis_port_base(adev); | 439 | int drive_pci = sis_port_base(adev); |
495 | u16 timing; | 440 | u16 timing; |
496 | 441 | ||
497 | const u16 udma_bits[] = { 0x8F00, 0x8A00, 0x8700, 0x8500, 0x8300, 0x8200, 0x8100}; | 442 | static const u16 udma_bits[] = { 0x8F00, 0x8A00, 0x8700, 0x8500, 0x8300, 0x8200, 0x8100}; |
498 | 443 | ||
499 | pci_read_config_word(pdev, drive_pci, &timing); | 444 | pci_read_config_word(pdev, drive_pci, &timing); |
500 | 445 | ||
@@ -531,8 +476,8 @@ static void sis_133_set_dmamode (struct ata_port *ap, struct ata_device *adev) | |||
531 | u32 reg54; | 476 | u32 reg54; |
532 | 477 | ||
533 | /* bits 4- cycle time 8 - cvs time */ | 478 | /* bits 4- cycle time 8 - cvs time */ |
534 | const u32 timing_u100[] = { 0x6B0, 0x470, 0x350, 0x140, 0x120, 0x110, 0x000 }; | 479 | static const u32 timing_u100[] = { 0x6B0, 0x470, 0x350, 0x140, 0x120, 0x110, 0x000 }; |
535 | const u32 timing_u133[] = { 0x9F0, 0x6A0, 0x470, 0x250, 0x230, 0x220, 0x210 }; | 480 | static const u32 timing_u133[] = { 0x9F0, 0x6A0, 0x470, 0x250, 0x230, 0x220, 0x210 }; |
536 | 481 | ||
537 | /* If bit 14 is set then the registers are mapped at 0x70 not 0x40 */ | 482 | /* If bit 14 is set then the registers are mapped at 0x70 not 0x40 */ |
538 | pci_read_config_dword(pdev, 0x54, ®54); | 483 | pci_read_config_dword(pdev, 0x54, ®54); |
@@ -595,8 +540,9 @@ static const struct ata_port_operations sis_133_ops = { | |||
595 | 540 | ||
596 | .freeze = ata_bmdma_freeze, | 541 | .freeze = ata_bmdma_freeze, |
597 | .thaw = ata_bmdma_thaw, | 542 | .thaw = ata_bmdma_thaw, |
598 | .error_handler = sis_133_error_handler, | 543 | .error_handler = sis_error_handler, |
599 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 544 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
545 | .cable_detect = sis_133_cable_detect, | ||
600 | 546 | ||
601 | .bmdma_setup = ata_bmdma_setup, | 547 | .bmdma_setup = ata_bmdma_setup, |
602 | .bmdma_start = ata_bmdma_start, | 548 | .bmdma_start = ata_bmdma_start, |
@@ -628,8 +574,9 @@ static const struct ata_port_operations sis_133_early_ops = { | |||
628 | 574 | ||
629 | .freeze = ata_bmdma_freeze, | 575 | .freeze = ata_bmdma_freeze, |
630 | .thaw = ata_bmdma_thaw, | 576 | .thaw = ata_bmdma_thaw, |
631 | .error_handler = sis_66_error_handler, | 577 | .error_handler = sis_error_handler, |
632 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 578 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
579 | .cable_detect = sis_66_cable_detect, | ||
633 | 580 | ||
634 | .bmdma_setup = ata_bmdma_setup, | 581 | .bmdma_setup = ata_bmdma_setup, |
635 | .bmdma_start = ata_bmdma_start, | 582 | .bmdma_start = ata_bmdma_start, |
@@ -661,9 +608,9 @@ static const struct ata_port_operations sis_100_ops = { | |||
661 | 608 | ||
662 | .freeze = ata_bmdma_freeze, | 609 | .freeze = ata_bmdma_freeze, |
663 | .thaw = ata_bmdma_thaw, | 610 | .thaw = ata_bmdma_thaw, |
664 | .error_handler = sis_66_error_handler, | 611 | .error_handler = sis_error_handler, |
665 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 612 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
666 | 613 | .cable_detect = sis_66_cable_detect, | |
667 | 614 | ||
668 | .bmdma_setup = ata_bmdma_setup, | 615 | .bmdma_setup = ata_bmdma_setup, |
669 | .bmdma_start = ata_bmdma_start, | 616 | .bmdma_start = ata_bmdma_start, |
@@ -692,10 +639,11 @@ static const struct ata_port_operations sis_66_ops = { | |||
692 | .check_status = ata_check_status, | 639 | .check_status = ata_check_status, |
693 | .exec_command = ata_exec_command, | 640 | .exec_command = ata_exec_command, |
694 | .dev_select = ata_std_dev_select, | 641 | .dev_select = ata_std_dev_select, |
642 | .cable_detect = sis_66_cable_detect, | ||
695 | 643 | ||
696 | .freeze = ata_bmdma_freeze, | 644 | .freeze = ata_bmdma_freeze, |
697 | .thaw = ata_bmdma_thaw, | 645 | .thaw = ata_bmdma_thaw, |
698 | .error_handler = sis_66_error_handler, | 646 | .error_handler = sis_error_handler, |
699 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 647 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
700 | 648 | ||
701 | .bmdma_setup = ata_bmdma_setup, | 649 | .bmdma_setup = ata_bmdma_setup, |
@@ -728,8 +676,9 @@ static const struct ata_port_operations sis_old_ops = { | |||
728 | 676 | ||
729 | .freeze = ata_bmdma_freeze, | 677 | .freeze = ata_bmdma_freeze, |
730 | .thaw = ata_bmdma_thaw, | 678 | .thaw = ata_bmdma_thaw, |
731 | .error_handler = sis_old_error_handler, | 679 | .error_handler = sis_error_handler, |
732 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 680 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
681 | .cable_detect = ata_cable_40wire, | ||
733 | 682 | ||
734 | .bmdma_setup = ata_bmdma_setup, | 683 | .bmdma_setup = ata_bmdma_setup, |
735 | .bmdma_start = ata_bmdma_start, | 684 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_sl82c105.c b/drivers/ata/pata_sl82c105.c index b681441cfcb..da9e22b2575 100644 --- a/drivers/ata/pata_sl82c105.c +++ b/drivers/ata/pata_sl82c105.c | |||
@@ -58,7 +58,6 @@ static int sl82c105_pre_reset(struct ata_port *ap) | |||
58 | 58 | ||
59 | if (ap->port_no && !pci_test_config_bits(pdev, &sl82c105_enable_bits[ap->port_no])) | 59 | if (ap->port_no && !pci_test_config_bits(pdev, &sl82c105_enable_bits[ap->port_no])) |
60 | return -ENOENT; | 60 | return -ENOENT; |
61 | ap->cbl = ATA_CBL_PATA40; | ||
62 | return ata_std_prereset(ap); | 61 | return ata_std_prereset(ap); |
63 | } | 62 | } |
64 | 63 | ||
@@ -238,6 +237,7 @@ static struct ata_port_operations sl82c105_port_ops = { | |||
238 | .thaw = ata_bmdma_thaw, | 237 | .thaw = ata_bmdma_thaw, |
239 | .error_handler = sl82c105_error_handler, | 238 | .error_handler = sl82c105_error_handler, |
240 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 239 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
240 | .cable_detect = ata_cable_40wire, | ||
241 | 241 | ||
242 | .bmdma_setup = ata_bmdma_setup, | 242 | .bmdma_setup = ata_bmdma_setup, |
243 | .bmdma_start = sl82c105_bmdma_start, | 243 | .bmdma_start = sl82c105_bmdma_start, |
diff --git a/drivers/ata/pata_triflex.c b/drivers/ata/pata_triflex.c index 71418f2a0cd..e618ffd6e94 100644 --- a/drivers/ata/pata_triflex.c +++ b/drivers/ata/pata_triflex.c | |||
@@ -43,7 +43,7 @@ | |||
43 | #include <linux/libata.h> | 43 | #include <linux/libata.h> |
44 | 44 | ||
45 | #define DRV_NAME "pata_triflex" | 45 | #define DRV_NAME "pata_triflex" |
46 | #define DRV_VERSION "0.2.7" | 46 | #define DRV_VERSION "0.2.8" |
47 | 47 | ||
48 | /** | 48 | /** |
49 | * triflex_prereset - probe begin | 49 | * triflex_prereset - probe begin |
@@ -63,7 +63,6 @@ static int triflex_prereset(struct ata_port *ap) | |||
63 | 63 | ||
64 | if (!pci_test_config_bits(pdev, &triflex_enable_bits[ap->port_no])) | 64 | if (!pci_test_config_bits(pdev, &triflex_enable_bits[ap->port_no])) |
65 | return -ENOENT; | 65 | return -ENOENT; |
66 | ap->cbl = ATA_CBL_PATA40; | ||
67 | return ata_std_prereset(ap); | 66 | return ata_std_prereset(ap); |
68 | } | 67 | } |
69 | 68 | ||
@@ -214,6 +213,7 @@ static struct ata_port_operations triflex_port_ops = { | |||
214 | .thaw = ata_bmdma_thaw, | 213 | .thaw = ata_bmdma_thaw, |
215 | .error_handler = triflex_error_handler, | 214 | .error_handler = triflex_error_handler, |
216 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 215 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
216 | .cable_detect = ata_cable_40wire, | ||
217 | 217 | ||
218 | .bmdma_setup = ata_bmdma_setup, | 218 | .bmdma_setup = ata_bmdma_setup, |
219 | .bmdma_start = triflex_bmdma_start, | 219 | .bmdma_start = triflex_bmdma_start, |
diff --git a/drivers/ata/pata_via.c b/drivers/ata/pata_via.c index 946ade0e1f1..96b71791d2f 100644 --- a/drivers/ata/pata_via.c +++ b/drivers/ata/pata_via.c | |||
@@ -62,7 +62,7 @@ | |||
62 | #include <linux/libata.h> | 62 | #include <linux/libata.h> |
63 | 63 | ||
64 | #define DRV_NAME "pata_via" | 64 | #define DRV_NAME "pata_via" |
65 | #define DRV_VERSION "0.2.1" | 65 | #define DRV_VERSION "0.3.1" |
66 | 66 | ||
67 | /* | 67 | /* |
68 | * The following comes directly from Vojtech Pavlik's ide/pci/via82cxxx | 68 | * The following comes directly from Vojtech Pavlik's ide/pci/via82cxxx |
@@ -135,16 +135,23 @@ static const struct via_isa_bridge { | |||
135 | */ | 135 | */ |
136 | 136 | ||
137 | static int via_cable_detect(struct ata_port *ap) { | 137 | static int via_cable_detect(struct ata_port *ap) { |
138 | const struct via_isa_bridge *config = ap->host->private_data; | ||
138 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 139 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
139 | u32 ata66; | 140 | u32 ata66; |
140 | 141 | ||
142 | /* Early chips are 40 wire */ | ||
143 | if ((config->flags & VIA_UDMA) < VIA_UDMA_66) | ||
144 | return ATA_CBL_PATA40; | ||
145 | /* UDMA 66 chips have only drive side logic */ | ||
146 | else if((config->flags & VIA_UDMA) < VIA_UDMA_100) | ||
147 | return ATA_CBL_PATA_UNK; | ||
148 | /* UDMA 100 or later */ | ||
141 | pci_read_config_dword(pdev, 0x50, &ata66); | 149 | pci_read_config_dword(pdev, 0x50, &ata66); |
142 | /* Check both the drive cable reporting bits, we might not have | 150 | /* Check both the drive cable reporting bits, we might not have |
143 | two drives */ | 151 | two drives */ |
144 | if (ata66 & (0x10100000 >> (16 * ap->port_no))) | 152 | if (ata66 & (0x10100000 >> (16 * ap->port_no))) |
145 | return ATA_CBL_PATA80; | 153 | return ATA_CBL_PATA80; |
146 | else | 154 | return ATA_CBL_PATA40; |
147 | return ATA_CBL_PATA40; | ||
148 | } | 155 | } |
149 | 156 | ||
150 | static int via_pre_reset(struct ata_port *ap) | 157 | static int via_pre_reset(struct ata_port *ap) |
@@ -156,22 +163,10 @@ static int via_pre_reset(struct ata_port *ap) | |||
156 | { 0x40, 1, 0x02, 0x02 }, | 163 | { 0x40, 1, 0x02, 0x02 }, |
157 | { 0x40, 1, 0x01, 0x01 } | 164 | { 0x40, 1, 0x01, 0x01 } |
158 | }; | 165 | }; |
159 | |||
160 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 166 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
161 | |||
162 | if (!pci_test_config_bits(pdev, &via_enable_bits[ap->port_no])) | 167 | if (!pci_test_config_bits(pdev, &via_enable_bits[ap->port_no])) |
163 | return -ENOENT; | 168 | return -ENOENT; |
164 | } | 169 | } |
165 | |||
166 | if ((config->flags & VIA_UDMA) >= VIA_UDMA_100) | ||
167 | ap->cbl = via_cable_detect(ap); | ||
168 | /* The UDMA66 series has no cable detect so do drive side detect */ | ||
169 | else if ((config->flags & VIA_UDMA) < VIA_UDMA_66) | ||
170 | ap->cbl = ATA_CBL_PATA40; | ||
171 | else | ||
172 | ap->cbl = ATA_CBL_PATA_UNK; | ||
173 | |||
174 | |||
175 | return ata_std_prereset(ap); | 170 | return ata_std_prereset(ap); |
176 | } | 171 | } |
177 | 172 | ||
@@ -327,6 +322,7 @@ static struct ata_port_operations via_port_ops = { | |||
327 | .thaw = ata_bmdma_thaw, | 322 | .thaw = ata_bmdma_thaw, |
328 | .error_handler = via_error_handler, | 323 | .error_handler = via_error_handler, |
329 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 324 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
325 | .cable_detect = via_cable_detect, | ||
330 | 326 | ||
331 | .bmdma_setup = ata_bmdma_setup, | 327 | .bmdma_setup = ata_bmdma_setup, |
332 | .bmdma_start = ata_bmdma_start, | 328 | .bmdma_start = ata_bmdma_start, |
@@ -362,6 +358,7 @@ static struct ata_port_operations via_port_ops_noirq = { | |||
362 | .thaw = ata_bmdma_thaw, | 358 | .thaw = ata_bmdma_thaw, |
363 | .error_handler = via_error_handler, | 359 | .error_handler = via_error_handler, |
364 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 360 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
361 | .cable_detect = via_cable_detect, | ||
365 | 362 | ||
366 | .bmdma_setup = ata_bmdma_setup, | 363 | .bmdma_setup = ata_bmdma_setup, |
367 | .bmdma_start = ata_bmdma_start, | 364 | .bmdma_start = ata_bmdma_start, |
diff --git a/drivers/ata/pata_winbond.c b/drivers/ata/pata_winbond.c index 6c111035fc8..cc4ad271afb 100644 --- a/drivers/ata/pata_winbond.c +++ b/drivers/ata/pata_winbond.c | |||
@@ -8,7 +8,6 @@ | |||
8 | 8 | ||
9 | #include <linux/kernel.h> | 9 | #include <linux/kernel.h> |
10 | #include <linux/module.h> | 10 | #include <linux/module.h> |
11 | #include <linux/pci.h> | ||
12 | #include <linux/init.h> | 11 | #include <linux/init.h> |
13 | #include <linux/blkdev.h> | 12 | #include <linux/blkdev.h> |
14 | #include <linux/delay.h> | 13 | #include <linux/delay.h> |
@@ -36,7 +35,7 @@ static int probe_winbond = 1; | |||
36 | static int probe_winbond; | 35 | static int probe_winbond; |
37 | #endif | 36 | #endif |
38 | 37 | ||
39 | static spinlock_t winbond_lock = SPIN_LOCK_UNLOCKED; | 38 | static DEFINE_SPINLOCK(winbond_lock); |
40 | 39 | ||
41 | static void winbond_writecfg(unsigned long port, u8 reg, u8 val) | 40 | static void winbond_writecfg(unsigned long port, u8 reg, u8 val) |
42 | { | 41 | { |
@@ -152,13 +151,13 @@ static struct ata_port_operations winbond_port_ops = { | |||
152 | .thaw = ata_bmdma_thaw, | 151 | .thaw = ata_bmdma_thaw, |
153 | .error_handler = ata_bmdma_error_handler, | 152 | .error_handler = ata_bmdma_error_handler, |
154 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 153 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
154 | .cable_detect = ata_cable_40wire, | ||
155 | 155 | ||
156 | .qc_prep = ata_qc_prep, | 156 | .qc_prep = ata_qc_prep, |
157 | .qc_issue = ata_qc_issue_prot, | 157 | .qc_issue = ata_qc_issue_prot, |
158 | 158 | ||
159 | .data_xfer = winbond_data_xfer, | 159 | .data_xfer = winbond_data_xfer, |
160 | 160 | ||
161 | .irq_handler = ata_interrupt, | ||
162 | .irq_clear = ata_bmdma_irq_clear, | 161 | .irq_clear = ata_bmdma_irq_clear, |
163 | .irq_on = ata_irq_on, | 162 | .irq_on = ata_irq_on, |
164 | .irq_ack = ata_irq_ack, | 163 | .irq_ack = ata_irq_ack, |
@@ -179,11 +178,9 @@ static struct ata_port_operations winbond_port_ops = { | |||
179 | 178 | ||
180 | static __init int winbond_init_one(unsigned long port) | 179 | static __init int winbond_init_one(unsigned long port) |
181 | { | 180 | { |
182 | struct ata_probe_ent ae; | ||
183 | struct platform_device *pdev; | 181 | struct platform_device *pdev; |
184 | int ret; | ||
185 | u8 reg; | 182 | u8 reg; |
186 | int i; | 183 | int i, rc; |
187 | 184 | ||
188 | reg = winbond_readcfg(port, 0x81); | 185 | reg = winbond_readcfg(port, 0x81); |
189 | reg |= 0x80; /* jumpered mode off */ | 186 | reg |= 0x80; /* jumpered mode off */ |
@@ -202,58 +199,56 @@ static __init int winbond_init_one(unsigned long port) | |||
202 | 199 | ||
203 | for (i = 0; i < 2 ; i ++) { | 200 | for (i = 0; i < 2 ; i ++) { |
204 | unsigned long cmd_port = 0x1F0 - (0x80 * i); | 201 | unsigned long cmd_port = 0x1F0 - (0x80 * i); |
202 | struct ata_host *host; | ||
203 | struct ata_port *ap; | ||
205 | void __iomem *cmd_addr, *ctl_addr; | 204 | void __iomem *cmd_addr, *ctl_addr; |
206 | 205 | ||
207 | if (reg & (1 << i)) { | 206 | if (!(reg & (1 << i))) |
208 | /* | 207 | continue; |
209 | * Fill in a probe structure first of all | 208 | |
210 | */ | 209 | pdev = platform_device_register_simple(DRV_NAME, nr_winbond_host, NULL, 0); |
211 | 210 | if (IS_ERR(pdev)) | |
212 | pdev = platform_device_register_simple(DRV_NAME, nr_winbond_host, NULL, 0); | 211 | return PTR_ERR(pdev); |
213 | if (IS_ERR(pdev)) | 212 | |
214 | return PTR_ERR(pdev); | 213 | rc = -ENOMEM; |
215 | 214 | host = ata_host_alloc(&pdev->dev, 1); | |
216 | cmd_addr = devm_ioport_map(&pdev->dev, cmd_port, 8); | 215 | if (!host) |
217 | ctl_addr = devm_ioport_map(&pdev->dev, cmd_port + 0x0206, 1); | 216 | goto err_unregister; |
218 | if (!cmd_addr || !ctl_addr) { | 217 | |
219 | platform_device_unregister(pdev); | 218 | rc = -ENOMEM; |
220 | return -ENOMEM; | 219 | cmd_addr = devm_ioport_map(&pdev->dev, cmd_port, 8); |
221 | } | 220 | ctl_addr = devm_ioport_map(&pdev->dev, cmd_port + 0x0206, 1); |
222 | 221 | if (!cmd_addr || !ctl_addr) | |
223 | memset(&ae, 0, sizeof(struct ata_probe_ent)); | 222 | goto err_unregister; |
224 | INIT_LIST_HEAD(&ae.node); | 223 | |
225 | ae.dev = &pdev->dev; | 224 | ap = host->ports[0]; |
226 | 225 | ap->ops = &winbond_port_ops; | |
227 | ae.port_ops = &winbond_port_ops; | 226 | ap->pio_mask = 0x1F; |
228 | ae.pio_mask = 0x1F; | 227 | ap->flags |= ATA_FLAG_SLAVE_POSS; |
229 | 228 | ap->ioaddr.cmd_addr = cmd_addr; | |
230 | ae.sht = &winbond_sht; | 229 | ap->ioaddr.altstatus_addr = ctl_addr; |
231 | 230 | ap->ioaddr.ctl_addr = ctl_addr; | |
232 | ae.n_ports = 1; | 231 | ata_std_ports(&ap->ioaddr); |
233 | ae.irq = 14 + i; | 232 | |
234 | ae.irq_flags = 0; | 233 | /* hook in a private data structure per channel */ |
235 | ae.port_flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST; | 234 | host->private_data = &winbond_data[nr_winbond_host]; |
236 | ae.port[0].cmd_addr = cmd_addr; | 235 | winbond_data[nr_winbond_host].config = port; |
237 | ae.port[0].altstatus_addr = ctl_addr; | 236 | winbond_data[nr_winbond_host].platform_dev = pdev; |
238 | ae.port[0].ctl_addr = ctl_addr; | 237 | |
239 | ata_std_ports(&ae.port[0]); | 238 | /* activate */ |
240 | /* | 239 | rc = ata_host_activate(host, 14 + i, ata_interrupt, 0, |
241 | * Hook in a private data structure per channel | 240 | &winbond_sht); |
242 | */ | 241 | if (rc) |
243 | ae.private_data = &winbond_data[nr_winbond_host]; | 242 | goto err_unregister; |
244 | winbond_data[nr_winbond_host].config = port; | 243 | |
245 | winbond_data[nr_winbond_host].platform_dev = pdev; | 244 | winbond_host[nr_winbond_host++] = dev_get_drvdata(&pdev->dev); |
246 | |||
247 | ret = ata_device_add(&ae); | ||
248 | if (ret == 0) { | ||
249 | platform_device_unregister(pdev); | ||
250 | return -ENODEV; | ||
251 | } | ||
252 | winbond_host[nr_winbond_host++] = dev_get_drvdata(&pdev->dev); | ||
253 | } | ||
254 | } | 245 | } |
255 | 246 | ||
256 | return 0; | 247 | return 0; |
248 | |||
249 | err_unregister: | ||
250 | platform_device_unregister(pdev); | ||
251 | return rc; | ||
257 | } | 252 | } |
258 | 253 | ||
259 | /** | 254 | /** |
diff --git a/drivers/ata/pdc_adma.c b/drivers/ata/pdc_adma.c index 5dd3ca8b5f2..52b69530ab2 100644 --- a/drivers/ata/pdc_adma.c +++ b/drivers/ata/pdc_adma.c | |||
@@ -52,9 +52,9 @@ | |||
52 | /* macro to calculate base address for ADMA regs */ | 52 | /* macro to calculate base address for ADMA regs */ |
53 | #define ADMA_REGS(base,port_no) ((base) + 0x80 + ((port_no) * 0x20)) | 53 | #define ADMA_REGS(base,port_no) ((base) + 0x80 + ((port_no) * 0x20)) |
54 | 54 | ||
55 | /* macro to obtain addresses from ata_host */ | 55 | /* macro to obtain addresses from ata_port */ |
56 | #define ADMA_HOST_REGS(host,port_no) \ | 56 | #define ADMA_PORT_REGS(ap) \ |
57 | ADMA_REGS((host)->iomap[ADMA_MMIO_BAR], port_no) | 57 | ADMA_REGS((ap)->host->iomap[ADMA_MMIO_BAR], ap->port_no) |
58 | 58 | ||
59 | enum { | 59 | enum { |
60 | ADMA_MMIO_BAR = 4, | 60 | ADMA_MMIO_BAR = 4, |
@@ -128,7 +128,6 @@ struct adma_port_priv { | |||
128 | 128 | ||
129 | static int adma_ata_init_one (struct pci_dev *pdev, | 129 | static int adma_ata_init_one (struct pci_dev *pdev, |
130 | const struct pci_device_id *ent); | 130 | const struct pci_device_id *ent); |
131 | static irqreturn_t adma_intr (int irq, void *dev_instance); | ||
132 | static int adma_port_start(struct ata_port *ap); | 131 | static int adma_port_start(struct ata_port *ap); |
133 | static void adma_host_stop(struct ata_host *host); | 132 | static void adma_host_stop(struct ata_host *host); |
134 | static void adma_port_stop(struct ata_port *ap); | 133 | static void adma_port_stop(struct ata_port *ap); |
@@ -172,7 +171,6 @@ static const struct ata_port_operations adma_ata_ops = { | |||
172 | .qc_issue = adma_qc_issue, | 171 | .qc_issue = adma_qc_issue, |
173 | .eng_timeout = adma_eng_timeout, | 172 | .eng_timeout = adma_eng_timeout, |
174 | .data_xfer = ata_data_xfer, | 173 | .data_xfer = ata_data_xfer, |
175 | .irq_handler = adma_intr, | ||
176 | .irq_clear = adma_irq_clear, | 174 | .irq_clear = adma_irq_clear, |
177 | .irq_on = ata_irq_on, | 175 | .irq_on = ata_irq_on, |
178 | .irq_ack = ata_irq_ack, | 176 | .irq_ack = ata_irq_ack, |
@@ -186,7 +184,6 @@ static const struct ata_port_operations adma_ata_ops = { | |||
186 | static struct ata_port_info adma_port_info[] = { | 184 | static struct ata_port_info adma_port_info[] = { |
187 | /* board_1841_idx */ | 185 | /* board_1841_idx */ |
188 | { | 186 | { |
189 | .sht = &adma_ata_sht, | ||
190 | .flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST | | 187 | .flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_SRST | |
191 | ATA_FLAG_NO_LEGACY | ATA_FLAG_MMIO | | 188 | ATA_FLAG_NO_LEGACY | ATA_FLAG_MMIO | |
192 | ATA_FLAG_PIO_POLLING, | 189 | ATA_FLAG_PIO_POLLING, |
@@ -229,8 +226,10 @@ static void adma_irq_clear(struct ata_port *ap) | |||
229 | /* nothing */ | 226 | /* nothing */ |
230 | } | 227 | } |
231 | 228 | ||
232 | static void adma_reset_engine(void __iomem *chan) | 229 | static void adma_reset_engine(struct ata_port *ap) |
233 | { | 230 | { |
231 | void __iomem *chan = ADMA_PORT_REGS(ap); | ||
232 | |||
234 | /* reset ADMA to idle state */ | 233 | /* reset ADMA to idle state */ |
235 | writew(aPIOMD4 | aNIEN | aRSTADM, chan + ADMA_CONTROL); | 234 | writew(aPIOMD4 | aNIEN | aRSTADM, chan + ADMA_CONTROL); |
236 | udelay(2); | 235 | udelay(2); |
@@ -241,14 +240,14 @@ static void adma_reset_engine(void __iomem *chan) | |||
241 | static void adma_reinit_engine(struct ata_port *ap) | 240 | static void adma_reinit_engine(struct ata_port *ap) |
242 | { | 241 | { |
243 | struct adma_port_priv *pp = ap->private_data; | 242 | struct adma_port_priv *pp = ap->private_data; |
244 | void __iomem *chan = ADMA_HOST_REGS(ap->host, ap->port_no); | 243 | void __iomem *chan = ADMA_PORT_REGS(ap); |
245 | 244 | ||
246 | /* mask/clear ATA interrupts */ | 245 | /* mask/clear ATA interrupts */ |
247 | writeb(ATA_NIEN, ap->ioaddr.ctl_addr); | 246 | writeb(ATA_NIEN, ap->ioaddr.ctl_addr); |
248 | ata_check_status(ap); | 247 | ata_check_status(ap); |
249 | 248 | ||
250 | /* reset the ADMA engine */ | 249 | /* reset the ADMA engine */ |
251 | adma_reset_engine(chan); | 250 | adma_reset_engine(ap); |
252 | 251 | ||
253 | /* set in-FIFO threshold to 0x100 */ | 252 | /* set in-FIFO threshold to 0x100 */ |
254 | writew(0x100, chan + ADMA_FIFO_IN); | 253 | writew(0x100, chan + ADMA_FIFO_IN); |
@@ -268,7 +267,7 @@ static void adma_reinit_engine(struct ata_port *ap) | |||
268 | 267 | ||
269 | static inline void adma_enter_reg_mode(struct ata_port *ap) | 268 | static inline void adma_enter_reg_mode(struct ata_port *ap) |
270 | { | 269 | { |
271 | void __iomem *chan = ADMA_HOST_REGS(ap->host, ap->port_no); | 270 | void __iomem *chan = ADMA_PORT_REGS(ap); |
272 | 271 | ||
273 | writew(aPIOMD4, chan + ADMA_CONTROL); | 272 | writew(aPIOMD4, chan + ADMA_CONTROL); |
274 | readb(chan + ADMA_STATUS); /* flush */ | 273 | readb(chan + ADMA_STATUS); /* flush */ |
@@ -415,7 +414,7 @@ static void adma_qc_prep(struct ata_queued_cmd *qc) | |||
415 | static inline void adma_packet_start(struct ata_queued_cmd *qc) | 414 | static inline void adma_packet_start(struct ata_queued_cmd *qc) |
416 | { | 415 | { |
417 | struct ata_port *ap = qc->ap; | 416 | struct ata_port *ap = qc->ap; |
418 | void __iomem *chan = ADMA_HOST_REGS(ap->host, ap->port_no); | 417 | void __iomem *chan = ADMA_PORT_REGS(ap); |
419 | 418 | ||
420 | VPRINTK("ENTER, ap %p\n", ap); | 419 | VPRINTK("ENTER, ap %p\n", ap); |
421 | 420 | ||
@@ -453,7 +452,7 @@ static inline unsigned int adma_intr_pkt(struct ata_host *host) | |||
453 | struct ata_port *ap = host->ports[port_no]; | 452 | struct ata_port *ap = host->ports[port_no]; |
454 | struct adma_port_priv *pp; | 453 | struct adma_port_priv *pp; |
455 | struct ata_queued_cmd *qc; | 454 | struct ata_queued_cmd *qc; |
456 | void __iomem *chan = ADMA_HOST_REGS(host, port_no); | 455 | void __iomem *chan = ADMA_PORT_REGS(ap); |
457 | u8 status = readb(chan + ADMA_STATUS); | 456 | u8 status = readb(chan + ADMA_STATUS); |
458 | 457 | ||
459 | if (status == 0) | 458 | if (status == 0) |
@@ -575,7 +574,7 @@ static int adma_port_start(struct ata_port *ap) | |||
575 | 574 | ||
576 | static void adma_port_stop(struct ata_port *ap) | 575 | static void adma_port_stop(struct ata_port *ap) |
577 | { | 576 | { |
578 | adma_reset_engine(ADMA_HOST_REGS(ap->host, ap->port_no)); | 577 | adma_reset_engine(ap); |
579 | } | 578 | } |
580 | 579 | ||
581 | static void adma_host_stop(struct ata_host *host) | 580 | static void adma_host_stop(struct ata_host *host) |
@@ -583,21 +582,19 @@ static void adma_host_stop(struct ata_host *host) | |||
583 | unsigned int port_no; | 582 | unsigned int port_no; |
584 | 583 | ||
585 | for (port_no = 0; port_no < ADMA_PORTS; ++port_no) | 584 | for (port_no = 0; port_no < ADMA_PORTS; ++port_no) |
586 | adma_reset_engine(ADMA_HOST_REGS(host, port_no)); | 585 | adma_reset_engine(host->ports[port_no]); |
587 | } | 586 | } |
588 | 587 | ||
589 | static void adma_host_init(unsigned int chip_id, | 588 | static void adma_host_init(struct ata_host *host, unsigned int chip_id) |
590 | struct ata_probe_ent *probe_ent) | ||
591 | { | 589 | { |
592 | unsigned int port_no; | 590 | unsigned int port_no; |
593 | void __iomem *mmio_base = probe_ent->iomap[ADMA_MMIO_BAR]; | ||
594 | 591 | ||
595 | /* enable/lock aGO operation */ | 592 | /* enable/lock aGO operation */ |
596 | writeb(7, mmio_base + ADMA_MODE_LOCK); | 593 | writeb(7, host->iomap[ADMA_MMIO_BAR] + ADMA_MODE_LOCK); |
597 | 594 | ||
598 | /* reset the ADMA logic */ | 595 | /* reset the ADMA logic */ |
599 | for (port_no = 0; port_no < ADMA_PORTS; ++port_no) | 596 | for (port_no = 0; port_no < ADMA_PORTS; ++port_no) |
600 | adma_reset_engine(ADMA_REGS(mmio_base, port_no)); | 597 | adma_reset_engine(host->ports[port_no]); |
601 | } | 598 | } |
602 | 599 | ||
603 | static int adma_set_dma_masks(struct pci_dev *pdev, void __iomem *mmio_base) | 600 | static int adma_set_dma_masks(struct pci_dev *pdev, void __iomem *mmio_base) |
@@ -623,14 +620,21 @@ static int adma_ata_init_one(struct pci_dev *pdev, | |||
623 | const struct pci_device_id *ent) | 620 | const struct pci_device_id *ent) |
624 | { | 621 | { |
625 | static int printed_version; | 622 | static int printed_version; |
626 | struct ata_probe_ent *probe_ent = NULL; | ||
627 | void __iomem *mmio_base; | ||
628 | unsigned int board_idx = (unsigned int) ent->driver_data; | 623 | unsigned int board_idx = (unsigned int) ent->driver_data; |
624 | const struct ata_port_info *ppi[] = { &adma_port_info[board_idx], NULL }; | ||
625 | struct ata_host *host; | ||
626 | void __iomem *mmio_base; | ||
629 | int rc, port_no; | 627 | int rc, port_no; |
630 | 628 | ||
631 | if (!printed_version++) | 629 | if (!printed_version++) |
632 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 630 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
633 | 631 | ||
632 | /* alloc host */ | ||
633 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, ADMA_PORTS); | ||
634 | if (!host) | ||
635 | return -ENOMEM; | ||
636 | |||
637 | /* acquire resources and fill host */ | ||
634 | rc = pcim_enable_device(pdev); | 638 | rc = pcim_enable_device(pdev); |
635 | if (rc) | 639 | if (rc) |
636 | return rc; | 640 | return rc; |
@@ -641,46 +645,23 @@ static int adma_ata_init_one(struct pci_dev *pdev, | |||
641 | rc = pcim_iomap_regions(pdev, 1 << ADMA_MMIO_BAR, DRV_NAME); | 645 | rc = pcim_iomap_regions(pdev, 1 << ADMA_MMIO_BAR, DRV_NAME); |
642 | if (rc) | 646 | if (rc) |
643 | return rc; | 647 | return rc; |
644 | mmio_base = pcim_iomap_table(pdev)[ADMA_MMIO_BAR]; | 648 | host->iomap = pcim_iomap_table(pdev); |
649 | mmio_base = host->iomap[ADMA_MMIO_BAR]; | ||
645 | 650 | ||
646 | rc = adma_set_dma_masks(pdev, mmio_base); | 651 | rc = adma_set_dma_masks(pdev, mmio_base); |
647 | if (rc) | 652 | if (rc) |
648 | return rc; | 653 | return rc; |
649 | 654 | ||
650 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | 655 | for (port_no = 0; port_no < ADMA_PORTS; ++port_no) |
651 | if (probe_ent == NULL) | 656 | adma_ata_setup_port(&host->ports[port_no]->ioaddr, |
652 | return -ENOMEM; | ||
653 | |||
654 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
655 | INIT_LIST_HEAD(&probe_ent->node); | ||
656 | |||
657 | probe_ent->sht = adma_port_info[board_idx].sht; | ||
658 | probe_ent->port_flags = adma_port_info[board_idx].flags; | ||
659 | probe_ent->pio_mask = adma_port_info[board_idx].pio_mask; | ||
660 | probe_ent->mwdma_mask = adma_port_info[board_idx].mwdma_mask; | ||
661 | probe_ent->udma_mask = adma_port_info[board_idx].udma_mask; | ||
662 | probe_ent->port_ops = adma_port_info[board_idx].port_ops; | ||
663 | |||
664 | probe_ent->irq = pdev->irq; | ||
665 | probe_ent->irq_flags = IRQF_SHARED; | ||
666 | probe_ent->n_ports = ADMA_PORTS; | ||
667 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
668 | |||
669 | for (port_no = 0; port_no < probe_ent->n_ports; ++port_no) { | ||
670 | adma_ata_setup_port(&probe_ent->port[port_no], | ||
671 | ADMA_ATA_REGS(mmio_base, port_no)); | 657 | ADMA_ATA_REGS(mmio_base, port_no)); |
672 | } | ||
673 | |||
674 | pci_set_master(pdev); | ||
675 | 658 | ||
676 | /* initialize adapter */ | 659 | /* initialize adapter */ |
677 | adma_host_init(board_idx, probe_ent); | 660 | adma_host_init(host, board_idx); |
678 | 661 | ||
679 | if (!ata_device_add(probe_ent)) | 662 | pci_set_master(pdev); |
680 | return -ENODEV; | 663 | return ata_host_activate(host, pdev->irq, adma_intr, IRQF_SHARED, |
681 | 664 | &adma_ata_sht); | |
682 | devm_kfree(&pdev->dev, probe_ent); | ||
683 | return 0; | ||
684 | } | 665 | } |
685 | 666 | ||
686 | static int __init adma_ata_init(void) | 667 | static int __init adma_ata_init(void) |
diff --git a/drivers/ata/sata_inic162x.c b/drivers/ata/sata_inic162x.c index 1e21688bfcf..f099a1d83a0 100644 --- a/drivers/ata/sata_inic162x.c +++ b/drivers/ata/sata_inic162x.c | |||
@@ -488,11 +488,11 @@ static void inic_error_handler(struct ata_port *ap) | |||
488 | static void inic_post_internal_cmd(struct ata_queued_cmd *qc) | 488 | static void inic_post_internal_cmd(struct ata_queued_cmd *qc) |
489 | { | 489 | { |
490 | /* make DMA engine forget about the failed command */ | 490 | /* make DMA engine forget about the failed command */ |
491 | if (qc->err_mask) | 491 | if (qc->flags & ATA_QCFLAG_FAILED) |
492 | inic_reset_port(inic_port_base(qc->ap)); | 492 | inic_reset_port(inic_port_base(qc->ap)); |
493 | } | 493 | } |
494 | 494 | ||
495 | static void inic_dev_config(struct ata_port *ap, struct ata_device *dev) | 495 | static void inic_dev_config(struct ata_device *dev) |
496 | { | 496 | { |
497 | /* inic can only handle upto LBA28 max sectors */ | 497 | /* inic can only handle upto LBA28 max sectors */ |
498 | if (dev->max_sectors > ATA_MAX_SECTORS) | 498 | if (dev->max_sectors > ATA_MAX_SECTORS) |
@@ -559,7 +559,6 @@ static struct ata_port_operations inic_port_ops = { | |||
559 | .bmdma_stop = inic_bmdma_stop, | 559 | .bmdma_stop = inic_bmdma_stop, |
560 | .bmdma_status = inic_bmdma_status, | 560 | .bmdma_status = inic_bmdma_status, |
561 | 561 | ||
562 | .irq_handler = inic_interrupt, | ||
563 | .irq_clear = inic_irq_clear, | 562 | .irq_clear = inic_irq_clear, |
564 | .irq_on = ata_irq_on, | 563 | .irq_on = ata_irq_on, |
565 | .irq_ack = ata_irq_ack, | 564 | .irq_ack = ata_irq_ack, |
@@ -580,7 +579,6 @@ static struct ata_port_operations inic_port_ops = { | |||
580 | }; | 579 | }; |
581 | 580 | ||
582 | static struct ata_port_info inic_port_info = { | 581 | static struct ata_port_info inic_port_info = { |
583 | .sht = &inic_sht, | ||
584 | /* For some reason, ATA_PROT_ATAPI is broken on this | 582 | /* For some reason, ATA_PROT_ATAPI is broken on this |
585 | * controller, and no, PIO_POLLING does't fix it. It somehow | 583 | * controller, and no, PIO_POLLING does't fix it. It somehow |
586 | * manages to report the wrong ireason and ignoring ireason | 584 | * manages to report the wrong ireason and ignoring ireason |
@@ -642,7 +640,9 @@ static int inic_pci_device_resume(struct pci_dev *pdev) | |||
642 | void __iomem *mmio_base = host->iomap[MMIO_BAR]; | 640 | void __iomem *mmio_base = host->iomap[MMIO_BAR]; |
643 | int rc; | 641 | int rc; |
644 | 642 | ||
645 | ata_pci_device_do_resume(pdev); | 643 | rc = ata_pci_device_do_resume(pdev); |
644 | if (rc) | ||
645 | return rc; | ||
646 | 646 | ||
647 | if (pdev->dev.power.power_state.event == PM_EVENT_SUSPEND) { | 647 | if (pdev->dev.power.power_state.event == PM_EVENT_SUSPEND) { |
648 | rc = init_controller(mmio_base, hpriv->cached_hctl); | 648 | rc = init_controller(mmio_base, hpriv->cached_hctl); |
@@ -659,8 +659,8 @@ static int inic_pci_device_resume(struct pci_dev *pdev) | |||
659 | static int inic_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | 659 | static int inic_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
660 | { | 660 | { |
661 | static int printed_version; | 661 | static int printed_version; |
662 | struct ata_port_info *pinfo = &inic_port_info; | 662 | const struct ata_port_info *ppi[] = { &inic_port_info, NULL }; |
663 | struct ata_probe_ent *probe_ent; | 663 | struct ata_host *host; |
664 | struct inic_host_priv *hpriv; | 664 | struct inic_host_priv *hpriv; |
665 | void __iomem * const *iomap; | 665 | void __iomem * const *iomap; |
666 | int i, rc; | 666 | int i, rc; |
@@ -668,6 +668,15 @@ static int inic_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
668 | if (!printed_version++) | 668 | if (!printed_version++) |
669 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 669 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
670 | 670 | ||
671 | /* alloc host */ | ||
672 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, NR_PORTS); | ||
673 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); | ||
674 | if (!host || !hpriv) | ||
675 | return -ENOMEM; | ||
676 | |||
677 | host->private_data = hpriv; | ||
678 | |||
679 | /* acquire resources and fill host */ | ||
671 | rc = pcim_enable_device(pdev); | 680 | rc = pcim_enable_device(pdev); |
672 | if (rc) | 681 | if (rc) |
673 | return rc; | 682 | return rc; |
@@ -675,7 +684,22 @@ static int inic_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
675 | rc = pcim_iomap_regions(pdev, 0x3f, DRV_NAME); | 684 | rc = pcim_iomap_regions(pdev, 0x3f, DRV_NAME); |
676 | if (rc) | 685 | if (rc) |
677 | return rc; | 686 | return rc; |
678 | iomap = pcim_iomap_table(pdev); | 687 | host->iomap = iomap = pcim_iomap_table(pdev); |
688 | |||
689 | for (i = 0; i < NR_PORTS; i++) { | ||
690 | struct ata_ioports *port = &host->ports[i]->ioaddr; | ||
691 | void __iomem *port_base = iomap[MMIO_BAR] + i * PORT_SIZE; | ||
692 | |||
693 | port->cmd_addr = iomap[2 * i]; | ||
694 | port->altstatus_addr = | ||
695 | port->ctl_addr = (void __iomem *) | ||
696 | ((unsigned long)iomap[2 * i + 1] | ATA_PCI_CTL_OFS); | ||
697 | port->scr_addr = port_base + PORT_SCR; | ||
698 | |||
699 | ata_std_ports(port); | ||
700 | } | ||
701 | |||
702 | hpriv->cached_hctl = readw(iomap[MMIO_BAR] + HOST_CTL); | ||
679 | 703 | ||
680 | /* Set dma_mask. This devices doesn't support 64bit addressing. */ | 704 | /* Set dma_mask. This devices doesn't support 64bit addressing. */ |
681 | rc = pci_set_dma_mask(pdev, DMA_32BIT_MASK); | 705 | rc = pci_set_dma_mask(pdev, DMA_32BIT_MASK); |
@@ -692,43 +716,6 @@ static int inic_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
692 | return rc; | 716 | return rc; |
693 | } | 717 | } |
694 | 718 | ||
695 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | ||
696 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); | ||
697 | if (!probe_ent || !hpriv) | ||
698 | return -ENOMEM; | ||
699 | |||
700 | probe_ent->dev = &pdev->dev; | ||
701 | INIT_LIST_HEAD(&probe_ent->node); | ||
702 | |||
703 | probe_ent->sht = pinfo->sht; | ||
704 | probe_ent->port_flags = pinfo->flags; | ||
705 | probe_ent->pio_mask = pinfo->pio_mask; | ||
706 | probe_ent->mwdma_mask = pinfo->mwdma_mask; | ||
707 | probe_ent->udma_mask = pinfo->udma_mask; | ||
708 | probe_ent->port_ops = pinfo->port_ops; | ||
709 | probe_ent->n_ports = NR_PORTS; | ||
710 | |||
711 | probe_ent->irq = pdev->irq; | ||
712 | probe_ent->irq_flags = IRQF_SHARED; | ||
713 | |||
714 | probe_ent->iomap = iomap; | ||
715 | |||
716 | for (i = 0; i < NR_PORTS; i++) { | ||
717 | struct ata_ioports *port = &probe_ent->port[i]; | ||
718 | void __iomem *port_base = iomap[MMIO_BAR] + i * PORT_SIZE; | ||
719 | |||
720 | port->cmd_addr = iomap[2 * i]; | ||
721 | port->altstatus_addr = | ||
722 | port->ctl_addr = (void __iomem *) | ||
723 | ((unsigned long)iomap[2 * i + 1] | ATA_PCI_CTL_OFS); | ||
724 | port->scr_addr = port_base + PORT_SCR; | ||
725 | |||
726 | ata_std_ports(port); | ||
727 | } | ||
728 | |||
729 | probe_ent->private_data = hpriv; | ||
730 | hpriv->cached_hctl = readw(iomap[MMIO_BAR] + HOST_CTL); | ||
731 | |||
732 | rc = init_controller(iomap[MMIO_BAR], hpriv->cached_hctl); | 719 | rc = init_controller(iomap[MMIO_BAR], hpriv->cached_hctl); |
733 | if (rc) { | 720 | if (rc) { |
734 | dev_printk(KERN_ERR, &pdev->dev, | 721 | dev_printk(KERN_ERR, &pdev->dev, |
@@ -737,13 +724,8 @@ static int inic_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
737 | } | 724 | } |
738 | 725 | ||
739 | pci_set_master(pdev); | 726 | pci_set_master(pdev); |
740 | 727 | return ata_host_activate(host, pdev->irq, inic_interrupt, IRQF_SHARED, | |
741 | if (!ata_device_add(probe_ent)) | 728 | &inic_sht); |
742 | return -ENODEV; | ||
743 | |||
744 | devm_kfree(&pdev->dev, probe_ent); | ||
745 | |||
746 | return 0; | ||
747 | } | 729 | } |
748 | 730 | ||
749 | static const struct pci_device_id inic_pci_tbl[] = { | 731 | static const struct pci_device_id inic_pci_tbl[] = { |
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c index a65ba636aaa..cb9b9ac12b4 100644 --- a/drivers/ata/sata_mv.c +++ b/drivers/ata/sata_mv.c | |||
@@ -253,10 +253,7 @@ enum { | |||
253 | #define IS_GEN_IIE(hpriv) ((hpriv)->hp_flags & MV_HP_GEN_IIE) | 253 | #define IS_GEN_IIE(hpriv) ((hpriv)->hp_flags & MV_HP_GEN_IIE) |
254 | 254 | ||
255 | enum { | 255 | enum { |
256 | /* Our DMA boundary is determined by an ePRD being unable to handle | 256 | MV_DMA_BOUNDARY = 0xffffffffU, |
257 | * anything larger than 64KB | ||
258 | */ | ||
259 | MV_DMA_BOUNDARY = 0xffffU, | ||
260 | 257 | ||
261 | EDMA_REQ_Q_BASE_LO_MASK = 0xfffffc00U, | 258 | EDMA_REQ_Q_BASE_LO_MASK = 0xfffffc00U, |
262 | 259 | ||
@@ -350,7 +347,6 @@ static void mv_port_stop(struct ata_port *ap); | |||
350 | static void mv_qc_prep(struct ata_queued_cmd *qc); | 347 | static void mv_qc_prep(struct ata_queued_cmd *qc); |
351 | static void mv_qc_prep_iie(struct ata_queued_cmd *qc); | 348 | static void mv_qc_prep_iie(struct ata_queued_cmd *qc); |
352 | static unsigned int mv_qc_issue(struct ata_queued_cmd *qc); | 349 | static unsigned int mv_qc_issue(struct ata_queued_cmd *qc); |
353 | static irqreturn_t mv_interrupt(int irq, void *dev_instance); | ||
354 | static void mv_eng_timeout(struct ata_port *ap); | 350 | static void mv_eng_timeout(struct ata_port *ap); |
355 | static int mv_init_one(struct pci_dev *pdev, const struct pci_device_id *ent); | 351 | static int mv_init_one(struct pci_dev *pdev, const struct pci_device_id *ent); |
356 | 352 | ||
@@ -384,10 +380,10 @@ static struct scsi_host_template mv_sht = { | |||
384 | .queuecommand = ata_scsi_queuecmd, | 380 | .queuecommand = ata_scsi_queuecmd, |
385 | .can_queue = MV_USE_Q_DEPTH, | 381 | .can_queue = MV_USE_Q_DEPTH, |
386 | .this_id = ATA_SHT_THIS_ID, | 382 | .this_id = ATA_SHT_THIS_ID, |
387 | .sg_tablesize = MV_MAX_SG_CT / 2, | 383 | .sg_tablesize = MV_MAX_SG_CT, |
388 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, | 384 | .cmd_per_lun = ATA_SHT_CMD_PER_LUN, |
389 | .emulated = ATA_SHT_EMULATED, | 385 | .emulated = ATA_SHT_EMULATED, |
390 | .use_clustering = ATA_SHT_USE_CLUSTERING, | 386 | .use_clustering = 1, |
391 | .proc_name = DRV_NAME, | 387 | .proc_name = DRV_NAME, |
392 | .dma_boundary = MV_DMA_BOUNDARY, | 388 | .dma_boundary = MV_DMA_BOUNDARY, |
393 | .slave_configure = ata_scsi_slave_config, | 389 | .slave_configure = ata_scsi_slave_config, |
@@ -405,6 +401,7 @@ static const struct ata_port_operations mv5_ops = { | |||
405 | .dev_select = ata_std_dev_select, | 401 | .dev_select = ata_std_dev_select, |
406 | 402 | ||
407 | .phy_reset = mv_phy_reset, | 403 | .phy_reset = mv_phy_reset, |
404 | .cable_detect = ata_cable_sata, | ||
408 | 405 | ||
409 | .qc_prep = mv_qc_prep, | 406 | .qc_prep = mv_qc_prep, |
410 | .qc_issue = mv_qc_issue, | 407 | .qc_issue = mv_qc_issue, |
@@ -412,7 +409,6 @@ static const struct ata_port_operations mv5_ops = { | |||
412 | 409 | ||
413 | .eng_timeout = mv_eng_timeout, | 410 | .eng_timeout = mv_eng_timeout, |
414 | 411 | ||
415 | .irq_handler = mv_interrupt, | ||
416 | .irq_clear = mv_irq_clear, | 412 | .irq_clear = mv_irq_clear, |
417 | .irq_on = ata_irq_on, | 413 | .irq_on = ata_irq_on, |
418 | .irq_ack = ata_irq_ack, | 414 | .irq_ack = ata_irq_ack, |
@@ -434,6 +430,7 @@ static const struct ata_port_operations mv6_ops = { | |||
434 | .dev_select = ata_std_dev_select, | 430 | .dev_select = ata_std_dev_select, |
435 | 431 | ||
436 | .phy_reset = mv_phy_reset, | 432 | .phy_reset = mv_phy_reset, |
433 | .cable_detect = ata_cable_sata, | ||
437 | 434 | ||
438 | .qc_prep = mv_qc_prep, | 435 | .qc_prep = mv_qc_prep, |
439 | .qc_issue = mv_qc_issue, | 436 | .qc_issue = mv_qc_issue, |
@@ -441,7 +438,6 @@ static const struct ata_port_operations mv6_ops = { | |||
441 | 438 | ||
442 | .eng_timeout = mv_eng_timeout, | 439 | .eng_timeout = mv_eng_timeout, |
443 | 440 | ||
444 | .irq_handler = mv_interrupt, | ||
445 | .irq_clear = mv_irq_clear, | 441 | .irq_clear = mv_irq_clear, |
446 | .irq_on = ata_irq_on, | 442 | .irq_on = ata_irq_on, |
447 | .irq_ack = ata_irq_ack, | 443 | .irq_ack = ata_irq_ack, |
@@ -463,6 +459,7 @@ static const struct ata_port_operations mv_iie_ops = { | |||
463 | .dev_select = ata_std_dev_select, | 459 | .dev_select = ata_std_dev_select, |
464 | 460 | ||
465 | .phy_reset = mv_phy_reset, | 461 | .phy_reset = mv_phy_reset, |
462 | .cable_detect = ata_cable_sata, | ||
466 | 463 | ||
467 | .qc_prep = mv_qc_prep_iie, | 464 | .qc_prep = mv_qc_prep_iie, |
468 | .qc_issue = mv_qc_issue, | 465 | .qc_issue = mv_qc_issue, |
@@ -470,7 +467,6 @@ static const struct ata_port_operations mv_iie_ops = { | |||
470 | 467 | ||
471 | .eng_timeout = mv_eng_timeout, | 468 | .eng_timeout = mv_eng_timeout, |
472 | 469 | ||
473 | .irq_handler = mv_interrupt, | ||
474 | .irq_clear = mv_irq_clear, | 470 | .irq_clear = mv_irq_clear, |
475 | .irq_on = ata_irq_on, | 471 | .irq_on = ata_irq_on, |
476 | .irq_ack = ata_irq_ack, | 472 | .irq_ack = ata_irq_ack, |
@@ -484,35 +480,30 @@ static const struct ata_port_operations mv_iie_ops = { | |||
484 | 480 | ||
485 | static const struct ata_port_info mv_port_info[] = { | 481 | static const struct ata_port_info mv_port_info[] = { |
486 | { /* chip_504x */ | 482 | { /* chip_504x */ |
487 | .sht = &mv_sht, | ||
488 | .flags = MV_COMMON_FLAGS, | 483 | .flags = MV_COMMON_FLAGS, |
489 | .pio_mask = 0x1f, /* pio0-4 */ | 484 | .pio_mask = 0x1f, /* pio0-4 */ |
490 | .udma_mask = 0x7f, /* udma0-6 */ | 485 | .udma_mask = 0x7f, /* udma0-6 */ |
491 | .port_ops = &mv5_ops, | 486 | .port_ops = &mv5_ops, |
492 | }, | 487 | }, |
493 | { /* chip_508x */ | 488 | { /* chip_508x */ |
494 | .sht = &mv_sht, | ||
495 | .flags = (MV_COMMON_FLAGS | MV_FLAG_DUAL_HC), | 489 | .flags = (MV_COMMON_FLAGS | MV_FLAG_DUAL_HC), |
496 | .pio_mask = 0x1f, /* pio0-4 */ | 490 | .pio_mask = 0x1f, /* pio0-4 */ |
497 | .udma_mask = 0x7f, /* udma0-6 */ | 491 | .udma_mask = 0x7f, /* udma0-6 */ |
498 | .port_ops = &mv5_ops, | 492 | .port_ops = &mv5_ops, |
499 | }, | 493 | }, |
500 | { /* chip_5080 */ | 494 | { /* chip_5080 */ |
501 | .sht = &mv_sht, | ||
502 | .flags = (MV_COMMON_FLAGS | MV_FLAG_DUAL_HC), | 495 | .flags = (MV_COMMON_FLAGS | MV_FLAG_DUAL_HC), |
503 | .pio_mask = 0x1f, /* pio0-4 */ | 496 | .pio_mask = 0x1f, /* pio0-4 */ |
504 | .udma_mask = 0x7f, /* udma0-6 */ | 497 | .udma_mask = 0x7f, /* udma0-6 */ |
505 | .port_ops = &mv5_ops, | 498 | .port_ops = &mv5_ops, |
506 | }, | 499 | }, |
507 | { /* chip_604x */ | 500 | { /* chip_604x */ |
508 | .sht = &mv_sht, | ||
509 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS), | 501 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS), |
510 | .pio_mask = 0x1f, /* pio0-4 */ | 502 | .pio_mask = 0x1f, /* pio0-4 */ |
511 | .udma_mask = 0x7f, /* udma0-6 */ | 503 | .udma_mask = 0x7f, /* udma0-6 */ |
512 | .port_ops = &mv6_ops, | 504 | .port_ops = &mv6_ops, |
513 | }, | 505 | }, |
514 | { /* chip_608x */ | 506 | { /* chip_608x */ |
515 | .sht = &mv_sht, | ||
516 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS | | 507 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS | |
517 | MV_FLAG_DUAL_HC), | 508 | MV_FLAG_DUAL_HC), |
518 | .pio_mask = 0x1f, /* pio0-4 */ | 509 | .pio_mask = 0x1f, /* pio0-4 */ |
@@ -520,14 +511,12 @@ static const struct ata_port_info mv_port_info[] = { | |||
520 | .port_ops = &mv6_ops, | 511 | .port_ops = &mv6_ops, |
521 | }, | 512 | }, |
522 | { /* chip_6042 */ | 513 | { /* chip_6042 */ |
523 | .sht = &mv_sht, | ||
524 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS), | 514 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS), |
525 | .pio_mask = 0x1f, /* pio0-4 */ | 515 | .pio_mask = 0x1f, /* pio0-4 */ |
526 | .udma_mask = 0x7f, /* udma0-6 */ | 516 | .udma_mask = 0x7f, /* udma0-6 */ |
527 | .port_ops = &mv_iie_ops, | 517 | .port_ops = &mv_iie_ops, |
528 | }, | 518 | }, |
529 | { /* chip_7042 */ | 519 | { /* chip_7042 */ |
530 | .sht = &mv_sht, | ||
531 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS), | 520 | .flags = (MV_COMMON_FLAGS | MV_6XXX_FLAGS), |
532 | .pio_mask = 0x1f, /* pio0-4 */ | 521 | .pio_mask = 0x1f, /* pio0-4 */ |
533 | .udma_mask = 0x7f, /* udma0-6 */ | 522 | .udma_mask = 0x7f, /* udma0-6 */ |
@@ -551,6 +540,9 @@ static const struct pci_device_id mv_pci_tbl[] = { | |||
551 | 540 | ||
552 | { PCI_VDEVICE(TTI, 0x2310), chip_7042 }, | 541 | { PCI_VDEVICE(TTI, 0x2310), chip_7042 }, |
553 | 542 | ||
543 | /* add Marvell 7042 support */ | ||
544 | { PCI_VDEVICE(MARVELL, 0x7042), chip_7042 }, | ||
545 | |||
554 | { } /* terminate list */ | 546 | { } /* terminate list */ |
555 | }; | 547 | }; |
556 | 548 | ||
@@ -585,6 +577,39 @@ static const struct mv_hw_ops mv6xxx_ops = { | |||
585 | static int msi; /* Use PCI msi; either zero (off, default) or non-zero */ | 577 | static int msi; /* Use PCI msi; either zero (off, default) or non-zero */ |
586 | 578 | ||
587 | 579 | ||
580 | /* move to PCI layer or libata core? */ | ||
581 | static int pci_go_64(struct pci_dev *pdev) | ||
582 | { | ||
583 | int rc; | ||
584 | |||
585 | if (!pci_set_dma_mask(pdev, DMA_64BIT_MASK)) { | ||
586 | rc = pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK); | ||
587 | if (rc) { | ||
588 | rc = pci_set_consistent_dma_mask(pdev, DMA_32BIT_MASK); | ||
589 | if (rc) { | ||
590 | dev_printk(KERN_ERR, &pdev->dev, | ||
591 | "64-bit DMA enable failed\n"); | ||
592 | return rc; | ||
593 | } | ||
594 | } | ||
595 | } else { | ||
596 | rc = pci_set_dma_mask(pdev, DMA_32BIT_MASK); | ||
597 | if (rc) { | ||
598 | dev_printk(KERN_ERR, &pdev->dev, | ||
599 | "32-bit DMA enable failed\n"); | ||
600 | return rc; | ||
601 | } | ||
602 | rc = pci_set_consistent_dma_mask(pdev, DMA_32BIT_MASK); | ||
603 | if (rc) { | ||
604 | dev_printk(KERN_ERR, &pdev->dev, | ||
605 | "32-bit consistent DMA enable failed\n"); | ||
606 | return rc; | ||
607 | } | ||
608 | } | ||
609 | |||
610 | return rc; | ||
611 | } | ||
612 | |||
588 | /* | 613 | /* |
589 | * Functions | 614 | * Functions |
590 | */ | 615 | */ |
@@ -798,20 +823,18 @@ static u32 mv_scr_read(struct ata_port *ap, unsigned int sc_reg_in) | |||
798 | { | 823 | { |
799 | unsigned int ofs = mv_scr_offset(sc_reg_in); | 824 | unsigned int ofs = mv_scr_offset(sc_reg_in); |
800 | 825 | ||
801 | if (0xffffffffU != ofs) { | 826 | if (0xffffffffU != ofs) |
802 | return readl(mv_ap_base(ap) + ofs); | 827 | return readl(mv_ap_base(ap) + ofs); |
803 | } else { | 828 | else |
804 | return (u32) ofs; | 829 | return (u32) ofs; |
805 | } | ||
806 | } | 830 | } |
807 | 831 | ||
808 | static void mv_scr_write(struct ata_port *ap, unsigned int sc_reg_in, u32 val) | 832 | static void mv_scr_write(struct ata_port *ap, unsigned int sc_reg_in, u32 val) |
809 | { | 833 | { |
810 | unsigned int ofs = mv_scr_offset(sc_reg_in); | 834 | unsigned int ofs = mv_scr_offset(sc_reg_in); |
811 | 835 | ||
812 | if (0xffffffffU != ofs) { | 836 | if (0xffffffffU != ofs) |
813 | writelfl(val, mv_ap_base(ap) + ofs); | 837 | writelfl(val, mv_ap_base(ap) + ofs); |
814 | } | ||
815 | } | 838 | } |
816 | 839 | ||
817 | static void mv_edma_cfg(struct mv_host_priv *hpriv, void __iomem *port_mmio) | 840 | static void mv_edma_cfg(struct mv_host_priv *hpriv, void __iomem *port_mmio) |
@@ -959,38 +982,30 @@ static void mv_port_stop(struct ata_port *ap) | |||
959 | * LOCKING: | 982 | * LOCKING: |
960 | * Inherited from caller. | 983 | * Inherited from caller. |
961 | */ | 984 | */ |
962 | static void mv_fill_sg(struct ata_queued_cmd *qc) | 985 | static unsigned int mv_fill_sg(struct ata_queued_cmd *qc) |
963 | { | 986 | { |
964 | struct mv_port_priv *pp = qc->ap->private_data; | 987 | struct mv_port_priv *pp = qc->ap->private_data; |
965 | unsigned int i = 0; | 988 | unsigned int n_sg = 0; |
966 | struct scatterlist *sg; | 989 | struct scatterlist *sg; |
990 | struct mv_sg *mv_sg; | ||
967 | 991 | ||
992 | mv_sg = pp->sg_tbl; | ||
968 | ata_for_each_sg(sg, qc) { | 993 | ata_for_each_sg(sg, qc) { |
969 | dma_addr_t addr; | 994 | dma_addr_t addr = sg_dma_address(sg); |
970 | u32 sg_len, len, offset; | 995 | u32 sg_len = sg_dma_len(sg); |
971 | |||
972 | addr = sg_dma_address(sg); | ||
973 | sg_len = sg_dma_len(sg); | ||
974 | |||
975 | while (sg_len) { | ||
976 | offset = addr & MV_DMA_BOUNDARY; | ||
977 | len = sg_len; | ||
978 | if ((offset + sg_len) > 0x10000) | ||
979 | len = 0x10000 - offset; | ||
980 | 996 | ||
981 | pp->sg_tbl[i].addr = cpu_to_le32(addr & 0xffffffff); | 997 | mv_sg->addr = cpu_to_le32(addr & 0xffffffff); |
982 | pp->sg_tbl[i].addr_hi = cpu_to_le32((addr >> 16) >> 16); | 998 | mv_sg->addr_hi = cpu_to_le32((addr >> 16) >> 16); |
983 | pp->sg_tbl[i].flags_size = cpu_to_le32(len & 0xffff); | 999 | mv_sg->flags_size = cpu_to_le32(sg_len & 0xffff); |
984 | 1000 | ||
985 | sg_len -= len; | 1001 | if (ata_sg_is_last(sg, qc)) |
986 | addr += len; | 1002 | mv_sg->flags_size |= cpu_to_le32(EPRD_FLAG_END_OF_TBL); |
987 | 1003 | ||
988 | if (!sg_len && ata_sg_is_last(sg, qc)) | 1004 | mv_sg++; |
989 | pp->sg_tbl[i].flags_size |= cpu_to_le32(EPRD_FLAG_END_OF_TBL); | 1005 | n_sg++; |
990 | |||
991 | i++; | ||
992 | } | ||
993 | } | 1006 | } |
1007 | |||
1008 | return n_sg; | ||
994 | } | 1009 | } |
995 | 1010 | ||
996 | static inline unsigned mv_inc_q_index(unsigned index) | 1011 | static inline unsigned mv_inc_q_index(unsigned index) |
@@ -1320,17 +1335,15 @@ static void mv_host_intr(struct ata_host *host, u32 relevant, unsigned int hc) | |||
1320 | int shift, port, port0, hard_port, handled; | 1335 | int shift, port, port0, hard_port, handled; |
1321 | unsigned int err_mask; | 1336 | unsigned int err_mask; |
1322 | 1337 | ||
1323 | if (hc == 0) { | 1338 | if (hc == 0) |
1324 | port0 = 0; | 1339 | port0 = 0; |
1325 | } else { | 1340 | else |
1326 | port0 = MV_PORTS_PER_HC; | 1341 | port0 = MV_PORTS_PER_HC; |
1327 | } | ||
1328 | 1342 | ||
1329 | /* we'll need the HC success int register in most cases */ | 1343 | /* we'll need the HC success int register in most cases */ |
1330 | hc_irq_cause = readl(hc_mmio + HC_IRQ_CAUSE_OFS); | 1344 | hc_irq_cause = readl(hc_mmio + HC_IRQ_CAUSE_OFS); |
1331 | if (hc_irq_cause) { | 1345 | if (hc_irq_cause) |
1332 | writelfl(~hc_irq_cause, hc_mmio + HC_IRQ_CAUSE_OFS); | 1346 | writelfl(~hc_irq_cause, hc_mmio + HC_IRQ_CAUSE_OFS); |
1333 | } | ||
1334 | 1347 | ||
1335 | VPRINTK("ENTER, hc%u relevant=0x%08x HC IRQ cause=0x%08x\n", | 1348 | VPRINTK("ENTER, hc%u relevant=0x%08x HC IRQ cause=0x%08x\n", |
1336 | hc,relevant,hc_irq_cause); | 1349 | hc,relevant,hc_irq_cause); |
@@ -1425,9 +1438,8 @@ static irqreturn_t mv_interrupt(int irq, void *dev_instance) | |||
1425 | /* check the cases where we either have nothing pending or have read | 1438 | /* check the cases where we either have nothing pending or have read |
1426 | * a bogus register value which can indicate HW removal or PCI fault | 1439 | * a bogus register value which can indicate HW removal or PCI fault |
1427 | */ | 1440 | */ |
1428 | if (!irq_stat || (0xffffffffU == irq_stat)) { | 1441 | if (!irq_stat || (0xffffffffU == irq_stat)) |
1429 | return IRQ_NONE; | 1442 | return IRQ_NONE; |
1430 | } | ||
1431 | 1443 | ||
1432 | n_hcs = mv_get_hc_count(host->ports[0]->flags); | 1444 | n_hcs = mv_get_hc_count(host->ports[0]->flags); |
1433 | spin_lock(&host->lock); | 1445 | spin_lock(&host->lock); |
@@ -1952,7 +1964,6 @@ comreset_retry: | |||
1952 | ata_port_disable(ap); | 1964 | ata_port_disable(ap); |
1953 | return; | 1965 | return; |
1954 | } | 1966 | } |
1955 | ap->cbl = ATA_CBL_SATA; | ||
1956 | 1967 | ||
1957 | /* even after SStatus reflects that device is ready, | 1968 | /* even after SStatus reflects that device is ready, |
1958 | * it seems to take a while for link to be fully | 1969 | * it seems to take a while for link to be fully |
@@ -2077,9 +2088,10 @@ static void mv_port_init(struct ata_ioports *port, void __iomem *port_mmio) | |||
2077 | readl(port_mmio + EDMA_ERR_IRQ_MASK_OFS)); | 2088 | readl(port_mmio + EDMA_ERR_IRQ_MASK_OFS)); |
2078 | } | 2089 | } |
2079 | 2090 | ||
2080 | static int mv_chip_id(struct pci_dev *pdev, struct mv_host_priv *hpriv, | 2091 | static int mv_chip_id(struct ata_host *host, unsigned int board_idx) |
2081 | unsigned int board_idx) | ||
2082 | { | 2092 | { |
2093 | struct pci_dev *pdev = to_pci_dev(host->dev); | ||
2094 | struct mv_host_priv *hpriv = host->private_data; | ||
2083 | u8 rev_id; | 2095 | u8 rev_id; |
2084 | u32 hp_flags = hpriv->hp_flags; | 2096 | u32 hp_flags = hpriv->hp_flags; |
2085 | 2097 | ||
@@ -2177,8 +2189,8 @@ static int mv_chip_id(struct pci_dev *pdev, struct mv_host_priv *hpriv, | |||
2177 | 2189 | ||
2178 | /** | 2190 | /** |
2179 | * mv_init_host - Perform some early initialization of the host. | 2191 | * mv_init_host - Perform some early initialization of the host. |
2180 | * @pdev: host PCI device | 2192 | * @host: ATA host to initialize |
2181 | * @probe_ent: early data struct representing the host | 2193 | * @board_idx: controller index |
2182 | * | 2194 | * |
2183 | * If possible, do an early global reset of the host. Then do | 2195 | * If possible, do an early global reset of the host. Then do |
2184 | * our port init and clear/unmask all/relevant host interrupts. | 2196 | * our port init and clear/unmask all/relevant host interrupts. |
@@ -2186,24 +2198,23 @@ static int mv_chip_id(struct pci_dev *pdev, struct mv_host_priv *hpriv, | |||
2186 | * LOCKING: | 2198 | * LOCKING: |
2187 | * Inherited from caller. | 2199 | * Inherited from caller. |
2188 | */ | 2200 | */ |
2189 | static int mv_init_host(struct pci_dev *pdev, struct ata_probe_ent *probe_ent, | 2201 | static int mv_init_host(struct ata_host *host, unsigned int board_idx) |
2190 | unsigned int board_idx) | ||
2191 | { | 2202 | { |
2192 | int rc = 0, n_hc, port, hc; | 2203 | int rc = 0, n_hc, port, hc; |
2193 | void __iomem *mmio = probe_ent->iomap[MV_PRIMARY_BAR]; | 2204 | struct pci_dev *pdev = to_pci_dev(host->dev); |
2194 | struct mv_host_priv *hpriv = probe_ent->private_data; | 2205 | void __iomem *mmio = host->iomap[MV_PRIMARY_BAR]; |
2206 | struct mv_host_priv *hpriv = host->private_data; | ||
2195 | 2207 | ||
2196 | /* global interrupt mask */ | 2208 | /* global interrupt mask */ |
2197 | writel(0, mmio + HC_MAIN_IRQ_MASK_OFS); | 2209 | writel(0, mmio + HC_MAIN_IRQ_MASK_OFS); |
2198 | 2210 | ||
2199 | rc = mv_chip_id(pdev, hpriv, board_idx); | 2211 | rc = mv_chip_id(host, board_idx); |
2200 | if (rc) | 2212 | if (rc) |
2201 | goto done; | 2213 | goto done; |
2202 | 2214 | ||
2203 | n_hc = mv_get_hc_count(probe_ent->port_flags); | 2215 | n_hc = mv_get_hc_count(host->ports[0]->flags); |
2204 | probe_ent->n_ports = MV_PORTS_PER_HC * n_hc; | ||
2205 | 2216 | ||
2206 | for (port = 0; port < probe_ent->n_ports; port++) | 2217 | for (port = 0; port < host->n_ports; port++) |
2207 | hpriv->ops->read_preamp(hpriv, port, mmio); | 2218 | hpriv->ops->read_preamp(hpriv, port, mmio); |
2208 | 2219 | ||
2209 | rc = hpriv->ops->reset_hc(hpriv, mmio, n_hc); | 2220 | rc = hpriv->ops->reset_hc(hpriv, mmio, n_hc); |
@@ -2214,7 +2225,7 @@ static int mv_init_host(struct pci_dev *pdev, struct ata_probe_ent *probe_ent, | |||
2214 | hpriv->ops->reset_bus(pdev, mmio); | 2225 | hpriv->ops->reset_bus(pdev, mmio); |
2215 | hpriv->ops->enable_leds(hpriv, mmio); | 2226 | hpriv->ops->enable_leds(hpriv, mmio); |
2216 | 2227 | ||
2217 | for (port = 0; port < probe_ent->n_ports; port++) { | 2228 | for (port = 0; port < host->n_ports; port++) { |
2218 | if (IS_60XX(hpriv)) { | 2229 | if (IS_60XX(hpriv)) { |
2219 | void __iomem *port_mmio = mv_port_base(mmio, port); | 2230 | void __iomem *port_mmio = mv_port_base(mmio, port); |
2220 | 2231 | ||
@@ -2227,9 +2238,9 @@ static int mv_init_host(struct pci_dev *pdev, struct ata_probe_ent *probe_ent, | |||
2227 | hpriv->ops->phy_errata(hpriv, mmio, port); | 2238 | hpriv->ops->phy_errata(hpriv, mmio, port); |
2228 | } | 2239 | } |
2229 | 2240 | ||
2230 | for (port = 0; port < probe_ent->n_ports; port++) { | 2241 | for (port = 0; port < host->n_ports; port++) { |
2231 | void __iomem *port_mmio = mv_port_base(mmio, port); | 2242 | void __iomem *port_mmio = mv_port_base(mmio, port); |
2232 | mv_port_init(&probe_ent->port[port], port_mmio); | 2243 | mv_port_init(&host->ports[port]->ioaddr, port_mmio); |
2233 | } | 2244 | } |
2234 | 2245 | ||
2235 | for (hc = 0; hc < n_hc; hc++) { | 2246 | for (hc = 0; hc < n_hc; hc++) { |
@@ -2268,17 +2279,17 @@ done: | |||
2268 | 2279 | ||
2269 | /** | 2280 | /** |
2270 | * mv_print_info - Dump key info to kernel log for perusal. | 2281 | * mv_print_info - Dump key info to kernel log for perusal. |
2271 | * @probe_ent: early data struct representing the host | 2282 | * @host: ATA host to print info about |
2272 | * | 2283 | * |
2273 | * FIXME: complete this. | 2284 | * FIXME: complete this. |
2274 | * | 2285 | * |
2275 | * LOCKING: | 2286 | * LOCKING: |
2276 | * Inherited from caller. | 2287 | * Inherited from caller. |
2277 | */ | 2288 | */ |
2278 | static void mv_print_info(struct ata_probe_ent *probe_ent) | 2289 | static void mv_print_info(struct ata_host *host) |
2279 | { | 2290 | { |
2280 | struct pci_dev *pdev = to_pci_dev(probe_ent->dev); | 2291 | struct pci_dev *pdev = to_pci_dev(host->dev); |
2281 | struct mv_host_priv *hpriv = probe_ent->private_data; | 2292 | struct mv_host_priv *hpriv = host->private_data; |
2282 | u8 rev_id, scc; | 2293 | u8 rev_id, scc; |
2283 | const char *scc_s; | 2294 | const char *scc_s; |
2284 | 2295 | ||
@@ -2297,7 +2308,7 @@ static void mv_print_info(struct ata_probe_ent *probe_ent) | |||
2297 | 2308 | ||
2298 | dev_printk(KERN_INFO, &pdev->dev, | 2309 | dev_printk(KERN_INFO, &pdev->dev, |
2299 | "%u slots %u ports %s mode IRQ via %s\n", | 2310 | "%u slots %u ports %s mode IRQ via %s\n", |
2300 | (unsigned)MV_MAX_Q_DEPTH, probe_ent->n_ports, | 2311 | (unsigned)MV_MAX_Q_DEPTH, host->n_ports, |
2301 | scc_s, (MV_HP_FLAG_MSI & hpriv->hp_flags) ? "MSI" : "INTx"); | 2312 | scc_s, (MV_HP_FLAG_MSI & hpriv->hp_flags) ? "MSI" : "INTx"); |
2302 | } | 2313 | } |
2303 | 2314 | ||
@@ -2312,50 +2323,42 @@ static void mv_print_info(struct ata_probe_ent *probe_ent) | |||
2312 | static int mv_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | 2323 | static int mv_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
2313 | { | 2324 | { |
2314 | static int printed_version = 0; | 2325 | static int printed_version = 0; |
2315 | struct device *dev = &pdev->dev; | ||
2316 | struct ata_probe_ent *probe_ent; | ||
2317 | struct mv_host_priv *hpriv; | ||
2318 | unsigned int board_idx = (unsigned int)ent->driver_data; | 2326 | unsigned int board_idx = (unsigned int)ent->driver_data; |
2319 | int rc; | 2327 | const struct ata_port_info *ppi[] = { &mv_port_info[board_idx], NULL }; |
2328 | struct ata_host *host; | ||
2329 | struct mv_host_priv *hpriv; | ||
2330 | int n_ports, rc; | ||
2320 | 2331 | ||
2321 | if (!printed_version++) | 2332 | if (!printed_version++) |
2322 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); | 2333 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); |
2323 | 2334 | ||
2335 | /* allocate host */ | ||
2336 | n_ports = mv_get_hc_count(ppi[0]->flags) * MV_PORTS_PER_HC; | ||
2337 | |||
2338 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, n_ports); | ||
2339 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); | ||
2340 | if (!host || !hpriv) | ||
2341 | return -ENOMEM; | ||
2342 | host->private_data = hpriv; | ||
2343 | |||
2344 | /* acquire resources */ | ||
2324 | rc = pcim_enable_device(pdev); | 2345 | rc = pcim_enable_device(pdev); |
2325 | if (rc) | 2346 | if (rc) |
2326 | return rc; | 2347 | return rc; |
2327 | pci_set_master(pdev); | ||
2328 | 2348 | ||
2329 | rc = pcim_iomap_regions(pdev, 1 << MV_PRIMARY_BAR, DRV_NAME); | 2349 | rc = pcim_iomap_regions(pdev, 1 << MV_PRIMARY_BAR, DRV_NAME); |
2330 | if (rc == -EBUSY) | 2350 | if (rc == -EBUSY) |
2331 | pcim_pin_device(pdev); | 2351 | pcim_pin_device(pdev); |
2332 | if (rc) | 2352 | if (rc) |
2333 | return rc; | 2353 | return rc; |
2354 | host->iomap = pcim_iomap_table(pdev); | ||
2334 | 2355 | ||
2335 | probe_ent = devm_kzalloc(dev, sizeof(*probe_ent), GFP_KERNEL); | 2356 | rc = pci_go_64(pdev); |
2336 | if (probe_ent == NULL) | 2357 | if (rc) |
2337 | return -ENOMEM; | 2358 | return rc; |
2338 | |||
2339 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
2340 | INIT_LIST_HEAD(&probe_ent->node); | ||
2341 | |||
2342 | hpriv = devm_kzalloc(dev, sizeof(*hpriv), GFP_KERNEL); | ||
2343 | if (!hpriv) | ||
2344 | return -ENOMEM; | ||
2345 | |||
2346 | probe_ent->sht = mv_port_info[board_idx].sht; | ||
2347 | probe_ent->port_flags = mv_port_info[board_idx].flags; | ||
2348 | probe_ent->pio_mask = mv_port_info[board_idx].pio_mask; | ||
2349 | probe_ent->udma_mask = mv_port_info[board_idx].udma_mask; | ||
2350 | probe_ent->port_ops = mv_port_info[board_idx].port_ops; | ||
2351 | |||
2352 | probe_ent->irq = pdev->irq; | ||
2353 | probe_ent->irq_flags = IRQF_SHARED; | ||
2354 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
2355 | probe_ent->private_data = hpriv; | ||
2356 | 2359 | ||
2357 | /* initialize adapter */ | 2360 | /* initialize adapter */ |
2358 | rc = mv_init_host(pdev, probe_ent, board_idx); | 2361 | rc = mv_init_host(host, board_idx); |
2359 | if (rc) | 2362 | if (rc) |
2360 | return rc; | 2363 | return rc; |
2361 | 2364 | ||
@@ -2364,13 +2367,11 @@ static int mv_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
2364 | pci_intx(pdev, 1); | 2367 | pci_intx(pdev, 1); |
2365 | 2368 | ||
2366 | mv_dump_pci_cfg(pdev, 0x68); | 2369 | mv_dump_pci_cfg(pdev, 0x68); |
2367 | mv_print_info(probe_ent); | 2370 | mv_print_info(host); |
2368 | 2371 | ||
2369 | if (ata_device_add(probe_ent) == 0) | 2372 | pci_set_master(pdev); |
2370 | return -ENODEV; | 2373 | return ata_host_activate(host, pdev->irq, mv_interrupt, IRQF_SHARED, |
2371 | 2374 | &mv_sht); | |
2372 | devm_kfree(dev, probe_ent); | ||
2373 | return 0; | ||
2374 | } | 2375 | } |
2375 | 2376 | ||
2376 | static int __init mv_init(void) | 2377 | static int __init mv_init(void) |
diff --git a/drivers/ata/sata_nv.c b/drivers/ata/sata_nv.c index 9d9670a9b11..02169740ed2 100644 --- a/drivers/ata/sata_nv.c +++ b/drivers/ata/sata_nv.c | |||
@@ -260,6 +260,7 @@ static int nv_adma_port_resume(struct ata_port *ap); | |||
260 | static void nv_adma_error_handler(struct ata_port *ap); | 260 | static void nv_adma_error_handler(struct ata_port *ap); |
261 | static void nv_adma_host_stop(struct ata_host *host); | 261 | static void nv_adma_host_stop(struct ata_host *host); |
262 | static void nv_adma_post_internal_cmd(struct ata_queued_cmd *qc); | 262 | static void nv_adma_post_internal_cmd(struct ata_queued_cmd *qc); |
263 | static void nv_adma_tf_read(struct ata_port *ap, struct ata_taskfile *tf); | ||
263 | 264 | ||
264 | enum nv_host_type | 265 | enum nv_host_type |
265 | { | 266 | { |
@@ -368,7 +369,6 @@ static const struct ata_port_operations nv_generic_ops = { | |||
368 | .error_handler = nv_error_handler, | 369 | .error_handler = nv_error_handler, |
369 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 370 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
370 | .data_xfer = ata_data_xfer, | 371 | .data_xfer = ata_data_xfer, |
371 | .irq_handler = nv_generic_interrupt, | ||
372 | .irq_clear = ata_bmdma_irq_clear, | 372 | .irq_clear = ata_bmdma_irq_clear, |
373 | .irq_on = ata_irq_on, | 373 | .irq_on = ata_irq_on, |
374 | .irq_ack = ata_irq_ack, | 374 | .irq_ack = ata_irq_ack, |
@@ -395,7 +395,6 @@ static const struct ata_port_operations nv_nf2_ops = { | |||
395 | .error_handler = nv_error_handler, | 395 | .error_handler = nv_error_handler, |
396 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 396 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
397 | .data_xfer = ata_data_xfer, | 397 | .data_xfer = ata_data_xfer, |
398 | .irq_handler = nv_nf2_interrupt, | ||
399 | .irq_clear = ata_bmdma_irq_clear, | 398 | .irq_clear = ata_bmdma_irq_clear, |
400 | .irq_on = ata_irq_on, | 399 | .irq_on = ata_irq_on, |
401 | .irq_ack = ata_irq_ack, | 400 | .irq_ack = ata_irq_ack, |
@@ -422,7 +421,6 @@ static const struct ata_port_operations nv_ck804_ops = { | |||
422 | .error_handler = nv_error_handler, | 421 | .error_handler = nv_error_handler, |
423 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 422 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
424 | .data_xfer = ata_data_xfer, | 423 | .data_xfer = ata_data_xfer, |
425 | .irq_handler = nv_ck804_interrupt, | ||
426 | .irq_clear = ata_bmdma_irq_clear, | 424 | .irq_clear = ata_bmdma_irq_clear, |
427 | .irq_on = ata_irq_on, | 425 | .irq_on = ata_irq_on, |
428 | .irq_ack = ata_irq_ack, | 426 | .irq_ack = ata_irq_ack, |
@@ -435,7 +433,7 @@ static const struct ata_port_operations nv_ck804_ops = { | |||
435 | static const struct ata_port_operations nv_adma_ops = { | 433 | static const struct ata_port_operations nv_adma_ops = { |
436 | .port_disable = ata_port_disable, | 434 | .port_disable = ata_port_disable, |
437 | .tf_load = ata_tf_load, | 435 | .tf_load = ata_tf_load, |
438 | .tf_read = ata_tf_read, | 436 | .tf_read = nv_adma_tf_read, |
439 | .check_atapi_dma = nv_adma_check_atapi_dma, | 437 | .check_atapi_dma = nv_adma_check_atapi_dma, |
440 | .exec_command = ata_exec_command, | 438 | .exec_command = ata_exec_command, |
441 | .check_status = ata_check_status, | 439 | .check_status = ata_check_status, |
@@ -451,7 +449,6 @@ static const struct ata_port_operations nv_adma_ops = { | |||
451 | .error_handler = nv_adma_error_handler, | 449 | .error_handler = nv_adma_error_handler, |
452 | .post_internal_cmd = nv_adma_post_internal_cmd, | 450 | .post_internal_cmd = nv_adma_post_internal_cmd, |
453 | .data_xfer = ata_data_xfer, | 451 | .data_xfer = ata_data_xfer, |
454 | .irq_handler = nv_adma_interrupt, | ||
455 | .irq_clear = nv_adma_irq_clear, | 452 | .irq_clear = nv_adma_irq_clear, |
456 | .irq_on = ata_irq_on, | 453 | .irq_on = ata_irq_on, |
457 | .irq_ack = ata_irq_ack, | 454 | .irq_ack = ata_irq_ack, |
@@ -476,6 +473,7 @@ static struct ata_port_info nv_port_info[] = { | |||
476 | .mwdma_mask = NV_MWDMA_MASK, | 473 | .mwdma_mask = NV_MWDMA_MASK, |
477 | .udma_mask = NV_UDMA_MASK, | 474 | .udma_mask = NV_UDMA_MASK, |
478 | .port_ops = &nv_generic_ops, | 475 | .port_ops = &nv_generic_ops, |
476 | .irq_handler = nv_generic_interrupt, | ||
479 | }, | 477 | }, |
480 | /* nforce2/3 */ | 478 | /* nforce2/3 */ |
481 | { | 479 | { |
@@ -486,6 +484,7 @@ static struct ata_port_info nv_port_info[] = { | |||
486 | .mwdma_mask = NV_MWDMA_MASK, | 484 | .mwdma_mask = NV_MWDMA_MASK, |
487 | .udma_mask = NV_UDMA_MASK, | 485 | .udma_mask = NV_UDMA_MASK, |
488 | .port_ops = &nv_nf2_ops, | 486 | .port_ops = &nv_nf2_ops, |
487 | .irq_handler = nv_nf2_interrupt, | ||
489 | }, | 488 | }, |
490 | /* ck804 */ | 489 | /* ck804 */ |
491 | { | 490 | { |
@@ -496,6 +495,7 @@ static struct ata_port_info nv_port_info[] = { | |||
496 | .mwdma_mask = NV_MWDMA_MASK, | 495 | .mwdma_mask = NV_MWDMA_MASK, |
497 | .udma_mask = NV_UDMA_MASK, | 496 | .udma_mask = NV_UDMA_MASK, |
498 | .port_ops = &nv_ck804_ops, | 497 | .port_ops = &nv_ck804_ops, |
498 | .irq_handler = nv_ck804_interrupt, | ||
499 | }, | 499 | }, |
500 | /* ADMA */ | 500 | /* ADMA */ |
501 | { | 501 | { |
@@ -507,6 +507,7 @@ static struct ata_port_info nv_port_info[] = { | |||
507 | .mwdma_mask = NV_MWDMA_MASK, | 507 | .mwdma_mask = NV_MWDMA_MASK, |
508 | .udma_mask = NV_UDMA_MASK, | 508 | .udma_mask = NV_UDMA_MASK, |
509 | .port_ops = &nv_adma_ops, | 509 | .port_ops = &nv_adma_ops, |
510 | .irq_handler = nv_adma_interrupt, | ||
510 | }, | 511 | }, |
511 | }; | 512 | }; |
512 | 513 | ||
@@ -667,6 +668,18 @@ static int nv_adma_check_atapi_dma(struct ata_queued_cmd *qc) | |||
667 | return !(pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE); | 668 | return !(pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE); |
668 | } | 669 | } |
669 | 670 | ||
671 | static void nv_adma_tf_read(struct ata_port *ap, struct ata_taskfile *tf) | ||
672 | { | ||
673 | /* Since commands where a result TF is requested are not | ||
674 | executed in ADMA mode, the only time this function will be called | ||
675 | in ADMA mode will be if a command fails. In this case we | ||
676 | don't care about going into register mode with ADMA commands | ||
677 | pending, as the commands will all shortly be aborted anyway. */ | ||
678 | nv_adma_register_mode(ap); | ||
679 | |||
680 | ata_tf_read(ap, tf); | ||
681 | } | ||
682 | |||
670 | static unsigned int nv_adma_tf_to_cpb(struct ata_taskfile *tf, __le16 *cpb) | 683 | static unsigned int nv_adma_tf_to_cpb(struct ata_taskfile *tf, __le16 *cpb) |
671 | { | 684 | { |
672 | unsigned int idx = 0; | 685 | unsigned int idx = 0; |
@@ -738,19 +751,11 @@ static int nv_adma_check_cpb(struct ata_port *ap, int cpb_num, int force_err) | |||
738 | return 1; | 751 | return 1; |
739 | } | 752 | } |
740 | 753 | ||
741 | if (flags & NV_CPB_RESP_DONE) { | 754 | if (likely(flags & NV_CPB_RESP_DONE)) { |
742 | struct ata_queued_cmd *qc = ata_qc_from_tag(ap, cpb_num); | 755 | struct ata_queued_cmd *qc = ata_qc_from_tag(ap, cpb_num); |
743 | VPRINTK("CPB flags done, flags=0x%x\n", flags); | 756 | VPRINTK("CPB flags done, flags=0x%x\n", flags); |
744 | if (likely(qc)) { | 757 | if (likely(qc)) { |
745 | /* Grab the ATA port status for non-NCQ commands. | 758 | DPRINTK("Completing qc from tag %d\n",cpb_num); |
746 | For NCQ commands the current status may have nothing to do with | ||
747 | the command just completed. */ | ||
748 | if (qc->tf.protocol != ATA_PROT_NCQ) { | ||
749 | u8 ata_status = readb(pp->ctl_block + (ATA_REG_STATUS * 4)); | ||
750 | qc->err_mask |= ac_err_mask(ata_status); | ||
751 | } | ||
752 | DPRINTK("Completing qc from tag %d with err_mask %u\n",cpb_num, | ||
753 | qc->err_mask); | ||
754 | ata_qc_complete(qc); | 759 | ata_qc_complete(qc); |
755 | } else { | 760 | } else { |
756 | struct ata_eh_info *ehi = &ap->eh_info; | 761 | struct ata_eh_info *ehi = &ap->eh_info; |
@@ -1074,14 +1079,14 @@ static int nv_adma_port_resume(struct ata_port *ap) | |||
1074 | } | 1079 | } |
1075 | #endif | 1080 | #endif |
1076 | 1081 | ||
1077 | static void nv_adma_setup_port(struct ata_probe_ent *probe_ent, unsigned int port) | 1082 | static void nv_adma_setup_port(struct ata_port *ap) |
1078 | { | 1083 | { |
1079 | void __iomem *mmio = probe_ent->iomap[NV_MMIO_BAR]; | 1084 | void __iomem *mmio = ap->host->iomap[NV_MMIO_BAR]; |
1080 | struct ata_ioports *ioport = &probe_ent->port[port]; | 1085 | struct ata_ioports *ioport = &ap->ioaddr; |
1081 | 1086 | ||
1082 | VPRINTK("ENTER\n"); | 1087 | VPRINTK("ENTER\n"); |
1083 | 1088 | ||
1084 | mmio += NV_ADMA_PORT + port * NV_ADMA_PORT_SIZE; | 1089 | mmio += NV_ADMA_PORT + ap->port_no * NV_ADMA_PORT_SIZE; |
1085 | 1090 | ||
1086 | ioport->cmd_addr = mmio; | 1091 | ioport->cmd_addr = mmio; |
1087 | ioport->data_addr = mmio + (ATA_REG_DATA * 4); | 1092 | ioport->data_addr = mmio + (ATA_REG_DATA * 4); |
@@ -1098,9 +1103,9 @@ static void nv_adma_setup_port(struct ata_probe_ent *probe_ent, unsigned int por | |||
1098 | ioport->ctl_addr = mmio + 0x20; | 1103 | ioport->ctl_addr = mmio + 0x20; |
1099 | } | 1104 | } |
1100 | 1105 | ||
1101 | static int nv_adma_host_init(struct ata_probe_ent *probe_ent) | 1106 | static int nv_adma_host_init(struct ata_host *host) |
1102 | { | 1107 | { |
1103 | struct pci_dev *pdev = to_pci_dev(probe_ent->dev); | 1108 | struct pci_dev *pdev = to_pci_dev(host->dev); |
1104 | unsigned int i; | 1109 | unsigned int i; |
1105 | u32 tmp32; | 1110 | u32 tmp32; |
1106 | 1111 | ||
@@ -1115,8 +1120,8 @@ static int nv_adma_host_init(struct ata_probe_ent *probe_ent) | |||
1115 | 1120 | ||
1116 | pci_write_config_dword(pdev, NV_MCP_SATA_CFG_20, tmp32); | 1121 | pci_write_config_dword(pdev, NV_MCP_SATA_CFG_20, tmp32); |
1117 | 1122 | ||
1118 | for (i = 0; i < probe_ent->n_ports; i++) | 1123 | for (i = 0; i < host->n_ports; i++) |
1119 | nv_adma_setup_port(probe_ent, i); | 1124 | nv_adma_setup_port(host->ports[i]); |
1120 | 1125 | ||
1121 | return 0; | 1126 | return 0; |
1122 | } | 1127 | } |
@@ -1167,9 +1172,11 @@ static int nv_adma_use_reg_mode(struct ata_queued_cmd *qc) | |||
1167 | struct nv_adma_port_priv *pp = qc->ap->private_data; | 1172 | struct nv_adma_port_priv *pp = qc->ap->private_data; |
1168 | 1173 | ||
1169 | /* ADMA engine can only be used for non-ATAPI DMA commands, | 1174 | /* ADMA engine can only be used for non-ATAPI DMA commands, |
1170 | or interrupt-driven no-data commands. */ | 1175 | or interrupt-driven no-data commands, where a result taskfile |
1176 | is not required. */ | ||
1171 | if((pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE) || | 1177 | if((pp->flags & NV_ADMA_ATAPI_SETUP_COMPLETE) || |
1172 | (qc->tf.flags & ATA_TFLAG_POLLING)) | 1178 | (qc->tf.flags & ATA_TFLAG_POLLING) || |
1179 | (qc->flags & ATA_QCFLAG_RESULT_TF)) | ||
1173 | return 1; | 1180 | return 1; |
1174 | 1181 | ||
1175 | if((qc->flags & ATA_QCFLAG_DMAMAP) || | 1182 | if((qc->flags & ATA_QCFLAG_DMAMAP) || |
@@ -1473,14 +1480,13 @@ static void nv_adma_error_handler(struct ata_port *ap) | |||
1473 | static int nv_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 1480 | static int nv_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
1474 | { | 1481 | { |
1475 | static int printed_version = 0; | 1482 | static int printed_version = 0; |
1476 | struct ata_port_info *ppi[2]; | 1483 | const struct ata_port_info *ppi[2]; |
1477 | struct ata_probe_ent *probe_ent; | 1484 | struct ata_host *host; |
1478 | struct nv_host_priv *hpriv; | 1485 | struct nv_host_priv *hpriv; |
1479 | int rc; | 1486 | int rc; |
1480 | u32 bar; | 1487 | u32 bar; |
1481 | void __iomem *base; | 1488 | void __iomem *base; |
1482 | unsigned long type = ent->driver_data; | 1489 | unsigned long type = ent->driver_data; |
1483 | int mask_set = 0; | ||
1484 | 1490 | ||
1485 | // Make sure this is a SATA controller by counting the number of bars | 1491 | // Make sure this is a SATA controller by counting the number of bars |
1486 | // (NVIDIA SATA controllers will always have six bars). Otherwise, | 1492 | // (NVIDIA SATA controllers will always have six bars). Otherwise, |
@@ -1496,50 +1502,38 @@ static int nv_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1496 | if (rc) | 1502 | if (rc) |
1497 | return rc; | 1503 | return rc; |
1498 | 1504 | ||
1499 | rc = pci_request_regions(pdev, DRV_NAME); | 1505 | /* determine type and allocate host */ |
1500 | if (rc) { | 1506 | if (type >= CK804 && adma_enabled) { |
1501 | pcim_pin_device(pdev); | ||
1502 | return rc; | ||
1503 | } | ||
1504 | |||
1505 | if(type >= CK804 && adma_enabled) { | ||
1506 | dev_printk(KERN_NOTICE, &pdev->dev, "Using ADMA mode\n"); | 1507 | dev_printk(KERN_NOTICE, &pdev->dev, "Using ADMA mode\n"); |
1507 | type = ADMA; | 1508 | type = ADMA; |
1508 | if(!pci_set_dma_mask(pdev, DMA_64BIT_MASK) && | ||
1509 | !pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK)) | ||
1510 | mask_set = 1; | ||
1511 | } | ||
1512 | |||
1513 | if(!mask_set) { | ||
1514 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | ||
1515 | if (rc) | ||
1516 | return rc; | ||
1517 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | ||
1518 | if (rc) | ||
1519 | return rc; | ||
1520 | } | 1509 | } |
1521 | 1510 | ||
1522 | rc = -ENOMEM; | 1511 | ppi[0] = ppi[1] = &nv_port_info[type]; |
1512 | rc = ata_pci_prepare_native_host(pdev, ppi, 2, &host); | ||
1513 | if (rc) | ||
1514 | return rc; | ||
1523 | 1515 | ||
1524 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); | 1516 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); |
1525 | if (!hpriv) | 1517 | if (!hpriv) |
1526 | return -ENOMEM; | 1518 | return -ENOMEM; |
1519 | hpriv->type = type; | ||
1520 | host->private_data = hpriv; | ||
1527 | 1521 | ||
1528 | ppi[0] = ppi[1] = &nv_port_info[type]; | 1522 | /* set 64bit dma masks, may fail */ |
1529 | probe_ent = ata_pci_init_native_mode(pdev, ppi, ATA_PORT_PRIMARY | ATA_PORT_SECONDARY); | 1523 | if (type == ADMA) { |
1530 | if (!probe_ent) | 1524 | if (pci_set_dma_mask(pdev, DMA_64BIT_MASK) == 0) |
1531 | return -ENOMEM; | 1525 | pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK); |
1532 | 1526 | } | |
1533 | if (!pcim_iomap(pdev, NV_MMIO_BAR, 0)) | ||
1534 | return -EIO; | ||
1535 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
1536 | 1527 | ||
1537 | probe_ent->private_data = hpriv; | 1528 | /* request and iomap NV_MMIO_BAR */ |
1538 | hpriv->type = type; | 1529 | rc = pcim_iomap_regions(pdev, 1 << NV_MMIO_BAR, DRV_NAME); |
1530 | if (rc) | ||
1531 | return rc; | ||
1539 | 1532 | ||
1540 | base = probe_ent->iomap[NV_MMIO_BAR]; | 1533 | /* configure SCR access */ |
1541 | probe_ent->port[0].scr_addr = base + NV_PORT0_SCR_REG_OFFSET; | 1534 | base = host->iomap[NV_MMIO_BAR]; |
1542 | probe_ent->port[1].scr_addr = base + NV_PORT1_SCR_REG_OFFSET; | 1535 | host->ports[0]->ioaddr.scr_addr = base + NV_PORT0_SCR_REG_OFFSET; |
1536 | host->ports[1]->ioaddr.scr_addr = base + NV_PORT1_SCR_REG_OFFSET; | ||
1543 | 1537 | ||
1544 | /* enable SATA space for CK804 */ | 1538 | /* enable SATA space for CK804 */ |
1545 | if (type >= CK804) { | 1539 | if (type >= CK804) { |
@@ -1550,20 +1544,16 @@ static int nv_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1550 | pci_write_config_byte(pdev, NV_MCP_SATA_CFG_20, regval); | 1544 | pci_write_config_byte(pdev, NV_MCP_SATA_CFG_20, regval); |
1551 | } | 1545 | } |
1552 | 1546 | ||
1553 | pci_set_master(pdev); | 1547 | /* init ADMA */ |
1554 | |||
1555 | if (type == ADMA) { | 1548 | if (type == ADMA) { |
1556 | rc = nv_adma_host_init(probe_ent); | 1549 | rc = nv_adma_host_init(host); |
1557 | if (rc) | 1550 | if (rc) |
1558 | return rc; | 1551 | return rc; |
1559 | } | 1552 | } |
1560 | 1553 | ||
1561 | rc = ata_device_add(probe_ent); | 1554 | pci_set_master(pdev); |
1562 | if (rc != NV_PORTS) | 1555 | return ata_host_activate(host, pdev->irq, ppi[0]->irq_handler, |
1563 | return -ENODEV; | 1556 | IRQF_SHARED, ppi[0]->sht); |
1564 | |||
1565 | devm_kfree(&pdev->dev, probe_ent); | ||
1566 | return 0; | ||
1567 | } | 1557 | } |
1568 | 1558 | ||
1569 | static void nv_remove_one (struct pci_dev *pdev) | 1559 | static void nv_remove_one (struct pci_dev *pdev) |
diff --git a/drivers/ata/sata_promise.c b/drivers/ata/sata_promise.c index 2339813ce9f..f56549b90aa 100644 --- a/drivers/ata/sata_promise.c +++ b/drivers/ata/sata_promise.c | |||
@@ -45,10 +45,11 @@ | |||
45 | #include "sata_promise.h" | 45 | #include "sata_promise.h" |
46 | 46 | ||
47 | #define DRV_NAME "sata_promise" | 47 | #define DRV_NAME "sata_promise" |
48 | #define DRV_VERSION "2.00" | 48 | #define DRV_VERSION "2.05" |
49 | 49 | ||
50 | 50 | ||
51 | enum { | 51 | enum { |
52 | PDC_MAX_PORTS = 4, | ||
52 | PDC_MMIO_BAR = 3, | 53 | PDC_MMIO_BAR = 3, |
53 | 54 | ||
54 | /* register offsets */ | 55 | /* register offsets */ |
@@ -70,14 +71,31 @@ enum { | |||
70 | PDC_TBG_MODE = 0x41C, /* TBG mode (not SATAII) */ | 71 | PDC_TBG_MODE = 0x41C, /* TBG mode (not SATAII) */ |
71 | PDC_SLEW_CTL = 0x470, /* slew rate control reg (not SATAII) */ | 72 | PDC_SLEW_CTL = 0x470, /* slew rate control reg (not SATAII) */ |
72 | 73 | ||
73 | PDC_ERR_MASK = (1<<19) | (1<<20) | (1<<21) | (1<<22) | | 74 | /* PDC_GLOBAL_CTL bit definitions */ |
74 | (1<<8) | (1<<9) | (1<<10), | 75 | PDC_PH_ERR = (1 << 8), /* PCI error while loading packet */ |
76 | PDC_SH_ERR = (1 << 9), /* PCI error while loading S/G table */ | ||
77 | PDC_DH_ERR = (1 << 10), /* PCI error while loading data */ | ||
78 | PDC2_HTO_ERR = (1 << 12), /* host bus timeout */ | ||
79 | PDC2_ATA_HBA_ERR = (1 << 13), /* error during SATA DATA FIS transmission */ | ||
80 | PDC2_ATA_DMA_CNT_ERR = (1 << 14), /* DMA DATA FIS size differs from S/G count */ | ||
81 | PDC_OVERRUN_ERR = (1 << 19), /* S/G byte count larger than HD requires */ | ||
82 | PDC_UNDERRUN_ERR = (1 << 20), /* S/G byte count less than HD requires */ | ||
83 | PDC_DRIVE_ERR = (1 << 21), /* drive error */ | ||
84 | PDC_PCI_SYS_ERR = (1 << 22), /* PCI system error */ | ||
85 | PDC1_PCI_PARITY_ERR = (1 << 23), /* PCI parity error (from SATA150 driver) */ | ||
86 | PDC1_ERR_MASK = PDC1_PCI_PARITY_ERR, | ||
87 | PDC2_ERR_MASK = PDC2_HTO_ERR | PDC2_ATA_HBA_ERR | PDC2_ATA_DMA_CNT_ERR, | ||
88 | PDC_ERR_MASK = (PDC_PH_ERR | PDC_SH_ERR | PDC_DH_ERR | PDC_OVERRUN_ERR | ||
89 | | PDC_UNDERRUN_ERR | PDC_DRIVE_ERR | PDC_PCI_SYS_ERR | ||
90 | | PDC1_ERR_MASK | PDC2_ERR_MASK), | ||
75 | 91 | ||
76 | board_2037x = 0, /* FastTrak S150 TX2plus */ | 92 | board_2037x = 0, /* FastTrak S150 TX2plus */ |
77 | board_20319 = 1, /* FastTrak S150 TX4 */ | 93 | board_2037x_pata = 1, /* FastTrak S150 TX2plus PATA port */ |
78 | board_20619 = 2, /* FastTrak TX4000 */ | 94 | board_20319 = 2, /* FastTrak S150 TX4 */ |
79 | board_2057x = 3, /* SATAII150 Tx2plus */ | 95 | board_20619 = 3, /* FastTrak TX4000 */ |
80 | board_40518 = 4, /* SATAII150 Tx4 */ | 96 | board_2057x = 4, /* SATAII150 Tx2plus */ |
97 | board_2057x_pata = 5, /* SATAII150 Tx2plus */ | ||
98 | board_40518 = 6, /* SATAII150 Tx4 */ | ||
81 | 99 | ||
82 | PDC_HAS_PATA = (1 << 1), /* PDC20375/20575 has PATA */ | 100 | PDC_HAS_PATA = (1 << 1), /* PDC20375/20575 has PATA */ |
83 | 101 | ||
@@ -100,8 +118,10 @@ enum { | |||
100 | ATA_FLAG_MMIO | | 118 | ATA_FLAG_MMIO | |
101 | ATA_FLAG_PIO_POLLING, | 119 | ATA_FLAG_PIO_POLLING, |
102 | 120 | ||
103 | /* hp->flags bits */ | 121 | /* ap->flags bits */ |
104 | PDC_FLAG_GEN_II = (1 << 0), | 122 | PDC_FLAG_GEN_II = (1 << 24), |
123 | PDC_FLAG_SATA_PATA = (1 << 25), /* supports SATA + PATA */ | ||
124 | PDC_FLAG_4_PORTS = (1 << 26), /* 4 ports */ | ||
105 | }; | 125 | }; |
106 | 126 | ||
107 | 127 | ||
@@ -110,28 +130,25 @@ struct pdc_port_priv { | |||
110 | dma_addr_t pkt_dma; | 130 | dma_addr_t pkt_dma; |
111 | }; | 131 | }; |
112 | 132 | ||
113 | struct pdc_host_priv { | ||
114 | unsigned long flags; | ||
115 | unsigned long port_flags[ATA_MAX_PORTS]; | ||
116 | }; | ||
117 | |||
118 | static u32 pdc_sata_scr_read (struct ata_port *ap, unsigned int sc_reg); | 133 | static u32 pdc_sata_scr_read (struct ata_port *ap, unsigned int sc_reg); |
119 | static void pdc_sata_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); | 134 | static void pdc_sata_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); |
120 | static int pdc_ata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); | 135 | static int pdc_ata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); |
121 | static irqreturn_t pdc_interrupt (int irq, void *dev_instance); | 136 | static int pdc_common_port_start(struct ata_port *ap); |
122 | static int pdc_port_start(struct ata_port *ap); | 137 | static int pdc_sata_port_start(struct ata_port *ap); |
123 | static void pdc_qc_prep(struct ata_queued_cmd *qc); | 138 | static void pdc_qc_prep(struct ata_queued_cmd *qc); |
124 | static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf); | 139 | static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf); |
125 | static void pdc_exec_command_mmio(struct ata_port *ap, const struct ata_taskfile *tf); | 140 | static void pdc_exec_command_mmio(struct ata_port *ap, const struct ata_taskfile *tf); |
126 | static int pdc_check_atapi_dma(struct ata_queued_cmd *qc); | 141 | static int pdc_check_atapi_dma(struct ata_queued_cmd *qc); |
127 | static int pdc_old_check_atapi_dma(struct ata_queued_cmd *qc); | 142 | static int pdc_old_sata_check_atapi_dma(struct ata_queued_cmd *qc); |
128 | static void pdc_irq_clear(struct ata_port *ap); | 143 | static void pdc_irq_clear(struct ata_port *ap); |
129 | static unsigned int pdc_qc_issue_prot(struct ata_queued_cmd *qc); | 144 | static unsigned int pdc_qc_issue_prot(struct ata_queued_cmd *qc); |
130 | static void pdc_freeze(struct ata_port *ap); | 145 | static void pdc_freeze(struct ata_port *ap); |
131 | static void pdc_thaw(struct ata_port *ap); | 146 | static void pdc_thaw(struct ata_port *ap); |
132 | static void pdc_error_handler(struct ata_port *ap); | 147 | static void pdc_pata_error_handler(struct ata_port *ap); |
148 | static void pdc_sata_error_handler(struct ata_port *ap); | ||
133 | static void pdc_post_internal_cmd(struct ata_queued_cmd *qc); | 149 | static void pdc_post_internal_cmd(struct ata_queued_cmd *qc); |
134 | 150 | static int pdc_pata_cable_detect(struct ata_port *ap); | |
151 | static int pdc_sata_cable_detect(struct ata_port *ap); | ||
135 | 152 | ||
136 | static struct scsi_host_template pdc_ata_sht = { | 153 | static struct scsi_host_template pdc_ata_sht = { |
137 | .module = THIS_MODULE, | 154 | .module = THIS_MODULE, |
@@ -164,17 +181,17 @@ static const struct ata_port_operations pdc_sata_ops = { | |||
164 | .qc_issue = pdc_qc_issue_prot, | 181 | .qc_issue = pdc_qc_issue_prot, |
165 | .freeze = pdc_freeze, | 182 | .freeze = pdc_freeze, |
166 | .thaw = pdc_thaw, | 183 | .thaw = pdc_thaw, |
167 | .error_handler = pdc_error_handler, | 184 | .error_handler = pdc_sata_error_handler, |
168 | .post_internal_cmd = pdc_post_internal_cmd, | 185 | .post_internal_cmd = pdc_post_internal_cmd, |
186 | .cable_detect = pdc_sata_cable_detect, | ||
169 | .data_xfer = ata_data_xfer, | 187 | .data_xfer = ata_data_xfer, |
170 | .irq_handler = pdc_interrupt, | ||
171 | .irq_clear = pdc_irq_clear, | 188 | .irq_clear = pdc_irq_clear, |
172 | .irq_on = ata_irq_on, | 189 | .irq_on = ata_irq_on, |
173 | .irq_ack = ata_irq_ack, | 190 | .irq_ack = ata_irq_ack, |
174 | 191 | ||
175 | .scr_read = pdc_sata_scr_read, | 192 | .scr_read = pdc_sata_scr_read, |
176 | .scr_write = pdc_sata_scr_write, | 193 | .scr_write = pdc_sata_scr_write, |
177 | .port_start = pdc_port_start, | 194 | .port_start = pdc_sata_port_start, |
178 | }; | 195 | }; |
179 | 196 | ||
180 | /* First-generation chips need a more restrictive ->check_atapi_dma op */ | 197 | /* First-generation chips need a more restrictive ->check_atapi_dma op */ |
@@ -185,23 +202,23 @@ static const struct ata_port_operations pdc_old_sata_ops = { | |||
185 | .check_status = ata_check_status, | 202 | .check_status = ata_check_status, |
186 | .exec_command = pdc_exec_command_mmio, | 203 | .exec_command = pdc_exec_command_mmio, |
187 | .dev_select = ata_std_dev_select, | 204 | .dev_select = ata_std_dev_select, |
188 | .check_atapi_dma = pdc_old_check_atapi_dma, | 205 | .check_atapi_dma = pdc_old_sata_check_atapi_dma, |
189 | 206 | ||
190 | .qc_prep = pdc_qc_prep, | 207 | .qc_prep = pdc_qc_prep, |
191 | .qc_issue = pdc_qc_issue_prot, | 208 | .qc_issue = pdc_qc_issue_prot, |
192 | .freeze = pdc_freeze, | 209 | .freeze = pdc_freeze, |
193 | .thaw = pdc_thaw, | 210 | .thaw = pdc_thaw, |
194 | .error_handler = pdc_error_handler, | 211 | .error_handler = pdc_sata_error_handler, |
195 | .post_internal_cmd = pdc_post_internal_cmd, | 212 | .post_internal_cmd = pdc_post_internal_cmd, |
213 | .cable_detect = pdc_sata_cable_detect, | ||
196 | .data_xfer = ata_data_xfer, | 214 | .data_xfer = ata_data_xfer, |
197 | .irq_handler = pdc_interrupt, | ||
198 | .irq_clear = pdc_irq_clear, | 215 | .irq_clear = pdc_irq_clear, |
199 | .irq_on = ata_irq_on, | 216 | .irq_on = ata_irq_on, |
200 | .irq_ack = ata_irq_ack, | 217 | .irq_ack = ata_irq_ack, |
201 | 218 | ||
202 | .scr_read = pdc_sata_scr_read, | 219 | .scr_read = pdc_sata_scr_read, |
203 | .scr_write = pdc_sata_scr_write, | 220 | .scr_write = pdc_sata_scr_write, |
204 | .port_start = pdc_port_start, | 221 | .port_start = pdc_sata_port_start, |
205 | }; | 222 | }; |
206 | 223 | ||
207 | static const struct ata_port_operations pdc_pata_ops = { | 224 | static const struct ata_port_operations pdc_pata_ops = { |
@@ -217,32 +234,41 @@ static const struct ata_port_operations pdc_pata_ops = { | |||
217 | .qc_issue = pdc_qc_issue_prot, | 234 | .qc_issue = pdc_qc_issue_prot, |
218 | .freeze = pdc_freeze, | 235 | .freeze = pdc_freeze, |
219 | .thaw = pdc_thaw, | 236 | .thaw = pdc_thaw, |
220 | .error_handler = pdc_error_handler, | 237 | .error_handler = pdc_pata_error_handler, |
221 | .post_internal_cmd = pdc_post_internal_cmd, | 238 | .post_internal_cmd = pdc_post_internal_cmd, |
239 | .cable_detect = pdc_pata_cable_detect, | ||
222 | .data_xfer = ata_data_xfer, | 240 | .data_xfer = ata_data_xfer, |
223 | .irq_handler = pdc_interrupt, | ||
224 | .irq_clear = pdc_irq_clear, | 241 | .irq_clear = pdc_irq_clear, |
225 | .irq_on = ata_irq_on, | 242 | .irq_on = ata_irq_on, |
226 | .irq_ack = ata_irq_ack, | 243 | .irq_ack = ata_irq_ack, |
227 | 244 | ||
228 | .port_start = pdc_port_start, | 245 | .port_start = pdc_common_port_start, |
229 | }; | 246 | }; |
230 | 247 | ||
231 | static const struct ata_port_info pdc_port_info[] = { | 248 | static const struct ata_port_info pdc_port_info[] = { |
232 | /* board_2037x */ | 249 | /* board_2037x */ |
233 | { | 250 | { |
234 | .sht = &pdc_ata_sht, | 251 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SATA | |
235 | .flags = PDC_COMMON_FLAGS, | 252 | PDC_FLAG_SATA_PATA, |
236 | .pio_mask = 0x1f, /* pio0-4 */ | 253 | .pio_mask = 0x1f, /* pio0-4 */ |
237 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 254 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
238 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 255 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
239 | .port_ops = &pdc_old_sata_ops, | 256 | .port_ops = &pdc_old_sata_ops, |
240 | }, | 257 | }, |
241 | 258 | ||
259 | /* board_2037x_pata */ | ||
260 | { | ||
261 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SLAVE_POSS, | ||
262 | .pio_mask = 0x1f, /* pio0-4 */ | ||
263 | .mwdma_mask = 0x07, /* mwdma0-2 */ | ||
264 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | ||
265 | .port_ops = &pdc_pata_ops, | ||
266 | }, | ||
267 | |||
242 | /* board_20319 */ | 268 | /* board_20319 */ |
243 | { | 269 | { |
244 | .sht = &pdc_ata_sht, | 270 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SATA | |
245 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SATA, | 271 | PDC_FLAG_4_PORTS, |
246 | .pio_mask = 0x1f, /* pio0-4 */ | 272 | .pio_mask = 0x1f, /* pio0-4 */ |
247 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 273 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
248 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 274 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
@@ -251,8 +277,8 @@ static const struct ata_port_info pdc_port_info[] = { | |||
251 | 277 | ||
252 | /* board_20619 */ | 278 | /* board_20619 */ |
253 | { | 279 | { |
254 | .sht = &pdc_ata_sht, | 280 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SLAVE_POSS | |
255 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SLAVE_POSS, | 281 | PDC_FLAG_4_PORTS, |
256 | .pio_mask = 0x1f, /* pio0-4 */ | 282 | .pio_mask = 0x1f, /* pio0-4 */ |
257 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 283 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
258 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 284 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
@@ -261,18 +287,28 @@ static const struct ata_port_info pdc_port_info[] = { | |||
261 | 287 | ||
262 | /* board_2057x */ | 288 | /* board_2057x */ |
263 | { | 289 | { |
264 | .sht = &pdc_ata_sht, | 290 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SATA | |
265 | .flags = PDC_COMMON_FLAGS, | 291 | PDC_FLAG_GEN_II | PDC_FLAG_SATA_PATA, |
266 | .pio_mask = 0x1f, /* pio0-4 */ | 292 | .pio_mask = 0x1f, /* pio0-4 */ |
267 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 293 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
268 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 294 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
269 | .port_ops = &pdc_sata_ops, | 295 | .port_ops = &pdc_sata_ops, |
270 | }, | 296 | }, |
271 | 297 | ||
298 | /* board_2057x_pata */ | ||
299 | { | ||
300 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SLAVE_POSS, | ||
301 | PDC_FLAG_GEN_II, | ||
302 | .pio_mask = 0x1f, /* pio0-4 */ | ||
303 | .mwdma_mask = 0x07, /* mwdma0-2 */ | ||
304 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | ||
305 | .port_ops = &pdc_pata_ops, | ||
306 | }, | ||
307 | |||
272 | /* board_40518 */ | 308 | /* board_40518 */ |
273 | { | 309 | { |
274 | .sht = &pdc_ata_sht, | 310 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SATA | |
275 | .flags = PDC_COMMON_FLAGS | ATA_FLAG_SATA, | 311 | PDC_FLAG_GEN_II | PDC_FLAG_4_PORTS, |
276 | .pio_mask = 0x1f, /* pio0-4 */ | 312 | .pio_mask = 0x1f, /* pio0-4 */ |
277 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 313 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
278 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ | 314 | .udma_mask = 0x7f, /* udma0-6 ; FIXME */ |
@@ -313,18 +349,12 @@ static struct pci_driver pdc_ata_pci_driver = { | |||
313 | }; | 349 | }; |
314 | 350 | ||
315 | 351 | ||
316 | static int pdc_port_start(struct ata_port *ap) | 352 | static int pdc_common_port_start(struct ata_port *ap) |
317 | { | 353 | { |
318 | struct device *dev = ap->host->dev; | 354 | struct device *dev = ap->host->dev; |
319 | struct pdc_host_priv *hp = ap->host->private_data; | ||
320 | struct pdc_port_priv *pp; | 355 | struct pdc_port_priv *pp; |
321 | int rc; | 356 | int rc; |
322 | 357 | ||
323 | /* fix up port flags and cable type for SATA+PATA chips */ | ||
324 | ap->flags |= hp->port_flags[ap->port_no]; | ||
325 | if (ap->flags & ATA_FLAG_SATA) | ||
326 | ap->cbl = ATA_CBL_SATA; | ||
327 | |||
328 | rc = ata_port_start(ap); | 358 | rc = ata_port_start(ap); |
329 | if (rc) | 359 | if (rc) |
330 | return rc; | 360 | return rc; |
@@ -339,8 +369,19 @@ static int pdc_port_start(struct ata_port *ap) | |||
339 | 369 | ||
340 | ap->private_data = pp; | 370 | ap->private_data = pp; |
341 | 371 | ||
372 | return 0; | ||
373 | } | ||
374 | |||
375 | static int pdc_sata_port_start(struct ata_port *ap) | ||
376 | { | ||
377 | int rc; | ||
378 | |||
379 | rc = pdc_common_port_start(ap); | ||
380 | if (rc) | ||
381 | return rc; | ||
382 | |||
342 | /* fix up PHYMODE4 align timing */ | 383 | /* fix up PHYMODE4 align timing */ |
343 | if ((hp->flags & PDC_FLAG_GEN_II) && sata_scr_valid(ap)) { | 384 | if (ap->flags & PDC_FLAG_GEN_II) { |
344 | void __iomem *mmio = (void __iomem *) ap->ioaddr.scr_addr; | 385 | void __iomem *mmio = (void __iomem *) ap->ioaddr.scr_addr; |
345 | unsigned int tmp; | 386 | unsigned int tmp; |
346 | 387 | ||
@@ -374,23 +415,25 @@ static void pdc_reset_port(struct ata_port *ap) | |||
374 | readl(mmio); /* flush */ | 415 | readl(mmio); /* flush */ |
375 | } | 416 | } |
376 | 417 | ||
377 | static void pdc_pata_cbl_detect(struct ata_port *ap) | 418 | static int pdc_pata_cable_detect(struct ata_port *ap) |
378 | { | 419 | { |
379 | u8 tmp; | 420 | u8 tmp; |
380 | void __iomem *mmio = (void __iomem *) ap->ioaddr.cmd_addr + PDC_CTLSTAT + 0x03; | 421 | void __iomem *mmio = (void __iomem *) ap->ioaddr.cmd_addr + PDC_CTLSTAT + 0x03; |
381 | 422 | ||
382 | tmp = readb(mmio); | 423 | tmp = readb(mmio); |
424 | if (tmp & 0x01) | ||
425 | return ATA_CBL_PATA40; | ||
426 | return ATA_CBL_PATA80; | ||
427 | } | ||
383 | 428 | ||
384 | if (tmp & 0x01) { | 429 | static int pdc_sata_cable_detect(struct ata_port *ap) |
385 | ap->cbl = ATA_CBL_PATA40; | 430 | { |
386 | ap->udma_mask &= ATA_UDMA_MASK_40C; | 431 | return ATA_CBL_SATA; |
387 | } else | ||
388 | ap->cbl = ATA_CBL_PATA80; | ||
389 | } | 432 | } |
390 | 433 | ||
391 | static u32 pdc_sata_scr_read (struct ata_port *ap, unsigned int sc_reg) | 434 | static u32 pdc_sata_scr_read (struct ata_port *ap, unsigned int sc_reg) |
392 | { | 435 | { |
393 | if (sc_reg > SCR_CONTROL || ap->cbl != ATA_CBL_SATA) | 436 | if (sc_reg > SCR_CONTROL) |
394 | return 0xffffffffU; | 437 | return 0xffffffffU; |
395 | return readl(ap->ioaddr.scr_addr + (sc_reg * 4)); | 438 | return readl(ap->ioaddr.scr_addr + (sc_reg * 4)); |
396 | } | 439 | } |
@@ -399,7 +442,7 @@ static u32 pdc_sata_scr_read (struct ata_port *ap, unsigned int sc_reg) | |||
399 | static void pdc_sata_scr_write (struct ata_port *ap, unsigned int sc_reg, | 442 | static void pdc_sata_scr_write (struct ata_port *ap, unsigned int sc_reg, |
400 | u32 val) | 443 | u32 val) |
401 | { | 444 | { |
402 | if (sc_reg > SCR_CONTROL || ap->cbl != ATA_CBL_SATA) | 445 | if (sc_reg > SCR_CONTROL) |
403 | return; | 446 | return; |
404 | writel(val, ap->ioaddr.scr_addr + (sc_reg * 4)); | 447 | writel(val, ap->ioaddr.scr_addr + (sc_reg * 4)); |
405 | } | 448 | } |
@@ -555,52 +598,79 @@ static void pdc_thaw(struct ata_port *ap) | |||
555 | readl(mmio + PDC_CTLSTAT); /* flush */ | 598 | readl(mmio + PDC_CTLSTAT); /* flush */ |
556 | } | 599 | } |
557 | 600 | ||
558 | static int pdc_pre_reset(struct ata_port *ap) | 601 | static void pdc_common_error_handler(struct ata_port *ap, ata_reset_fn_t hardreset) |
559 | { | ||
560 | if (!sata_scr_valid(ap)) | ||
561 | pdc_pata_cbl_detect(ap); | ||
562 | return ata_std_prereset(ap); | ||
563 | } | ||
564 | |||
565 | static void pdc_error_handler(struct ata_port *ap) | ||
566 | { | 602 | { |
567 | ata_reset_fn_t hardreset; | ||
568 | |||
569 | if (!(ap->pflags & ATA_PFLAG_FROZEN)) | 603 | if (!(ap->pflags & ATA_PFLAG_FROZEN)) |
570 | pdc_reset_port(ap); | 604 | pdc_reset_port(ap); |
571 | 605 | ||
572 | hardreset = NULL; | ||
573 | if (sata_scr_valid(ap)) | ||
574 | hardreset = sata_std_hardreset; | ||
575 | |||
576 | /* perform recovery */ | 606 | /* perform recovery */ |
577 | ata_do_eh(ap, pdc_pre_reset, ata_std_softreset, hardreset, | 607 | ata_do_eh(ap, ata_std_prereset, ata_std_softreset, hardreset, |
578 | ata_std_postreset); | 608 | ata_std_postreset); |
579 | } | 609 | } |
580 | 610 | ||
611 | static void pdc_pata_error_handler(struct ata_port *ap) | ||
612 | { | ||
613 | pdc_common_error_handler(ap, NULL); | ||
614 | } | ||
615 | |||
616 | static void pdc_sata_error_handler(struct ata_port *ap) | ||
617 | { | ||
618 | pdc_common_error_handler(ap, sata_std_hardreset); | ||
619 | } | ||
620 | |||
581 | static void pdc_post_internal_cmd(struct ata_queued_cmd *qc) | 621 | static void pdc_post_internal_cmd(struct ata_queued_cmd *qc) |
582 | { | 622 | { |
583 | struct ata_port *ap = qc->ap; | 623 | struct ata_port *ap = qc->ap; |
584 | 624 | ||
585 | if (qc->flags & ATA_QCFLAG_FAILED) | ||
586 | qc->err_mask |= AC_ERR_OTHER; | ||
587 | |||
588 | /* make DMA engine forget about the failed command */ | 625 | /* make DMA engine forget about the failed command */ |
589 | if (qc->err_mask) | 626 | if (qc->flags & ATA_QCFLAG_FAILED) |
590 | pdc_reset_port(ap); | 627 | pdc_reset_port(ap); |
591 | } | 628 | } |
592 | 629 | ||
630 | static void pdc_error_intr(struct ata_port *ap, struct ata_queued_cmd *qc, | ||
631 | u32 port_status, u32 err_mask) | ||
632 | { | ||
633 | struct ata_eh_info *ehi = &ap->eh_info; | ||
634 | unsigned int ac_err_mask = 0; | ||
635 | |||
636 | ata_ehi_clear_desc(ehi); | ||
637 | ata_ehi_push_desc(ehi, "port_status 0x%08x", port_status); | ||
638 | port_status &= err_mask; | ||
639 | |||
640 | if (port_status & PDC_DRIVE_ERR) | ||
641 | ac_err_mask |= AC_ERR_DEV; | ||
642 | if (port_status & (PDC_OVERRUN_ERR | PDC_UNDERRUN_ERR)) | ||
643 | ac_err_mask |= AC_ERR_HSM; | ||
644 | if (port_status & (PDC2_ATA_HBA_ERR | PDC2_ATA_DMA_CNT_ERR)) | ||
645 | ac_err_mask |= AC_ERR_ATA_BUS; | ||
646 | if (port_status & (PDC_PH_ERR | PDC_SH_ERR | PDC_DH_ERR | PDC2_HTO_ERR | ||
647 | | PDC_PCI_SYS_ERR | PDC1_PCI_PARITY_ERR)) | ||
648 | ac_err_mask |= AC_ERR_HOST_BUS; | ||
649 | |||
650 | if (sata_scr_valid(ap)) | ||
651 | ehi->serror |= pdc_sata_scr_read(ap, SCR_ERROR); | ||
652 | |||
653 | qc->err_mask |= ac_err_mask; | ||
654 | |||
655 | pdc_reset_port(ap); | ||
656 | } | ||
657 | |||
593 | static inline unsigned int pdc_host_intr( struct ata_port *ap, | 658 | static inline unsigned int pdc_host_intr( struct ata_port *ap, |
594 | struct ata_queued_cmd *qc) | 659 | struct ata_queued_cmd *qc) |
595 | { | 660 | { |
596 | unsigned int handled = 0; | 661 | unsigned int handled = 0; |
597 | u32 tmp; | 662 | void __iomem *port_mmio = ap->ioaddr.cmd_addr; |
598 | void __iomem *mmio = ap->ioaddr.cmd_addr + PDC_GLOBAL_CTL; | 663 | u32 port_status, err_mask; |
599 | 664 | ||
600 | tmp = readl(mmio); | 665 | err_mask = PDC_ERR_MASK; |
601 | if (tmp & PDC_ERR_MASK) { | 666 | if (ap->flags & PDC_FLAG_GEN_II) |
602 | qc->err_mask |= AC_ERR_DEV; | 667 | err_mask &= ~PDC1_ERR_MASK; |
603 | pdc_reset_port(ap); | 668 | else |
669 | err_mask &= ~PDC2_ERR_MASK; | ||
670 | port_status = readl(port_mmio + PDC_GLOBAL_CTL); | ||
671 | if (unlikely(port_status & err_mask)) { | ||
672 | pdc_error_intr(ap, qc, port_status, err_mask); | ||
673 | return 1; | ||
604 | } | 674 | } |
605 | 675 | ||
606 | switch (qc->tf.protocol) { | 676 | switch (qc->tf.protocol) { |
@@ -767,44 +837,40 @@ static int pdc_check_atapi_dma(struct ata_queued_cmd *qc) | |||
767 | return pio; | 837 | return pio; |
768 | } | 838 | } |
769 | 839 | ||
770 | static int pdc_old_check_atapi_dma(struct ata_queued_cmd *qc) | 840 | static int pdc_old_sata_check_atapi_dma(struct ata_queued_cmd *qc) |
771 | { | 841 | { |
772 | struct ata_port *ap = qc->ap; | ||
773 | |||
774 | /* First generation chips cannot use ATAPI DMA on SATA ports */ | 842 | /* First generation chips cannot use ATAPI DMA on SATA ports */ |
775 | if (sata_scr_valid(ap)) | 843 | return 1; |
776 | return 1; | ||
777 | return pdc_check_atapi_dma(qc); | ||
778 | } | 844 | } |
779 | 845 | ||
780 | static void pdc_ata_setup_port(struct ata_ioports *port, void __iomem *base, | 846 | static void pdc_ata_setup_port(struct ata_port *ap, |
781 | void __iomem *scr_addr) | 847 | void __iomem *base, void __iomem *scr_addr) |
782 | { | 848 | { |
783 | port->cmd_addr = base; | 849 | ap->ioaddr.cmd_addr = base; |
784 | port->data_addr = base; | 850 | ap->ioaddr.data_addr = base; |
785 | port->feature_addr = | 851 | ap->ioaddr.feature_addr = |
786 | port->error_addr = base + 0x4; | 852 | ap->ioaddr.error_addr = base + 0x4; |
787 | port->nsect_addr = base + 0x8; | 853 | ap->ioaddr.nsect_addr = base + 0x8; |
788 | port->lbal_addr = base + 0xc; | 854 | ap->ioaddr.lbal_addr = base + 0xc; |
789 | port->lbam_addr = base + 0x10; | 855 | ap->ioaddr.lbam_addr = base + 0x10; |
790 | port->lbah_addr = base + 0x14; | 856 | ap->ioaddr.lbah_addr = base + 0x14; |
791 | port->device_addr = base + 0x18; | 857 | ap->ioaddr.device_addr = base + 0x18; |
792 | port->command_addr = | 858 | ap->ioaddr.command_addr = |
793 | port->status_addr = base + 0x1c; | 859 | ap->ioaddr.status_addr = base + 0x1c; |
794 | port->altstatus_addr = | 860 | ap->ioaddr.altstatus_addr = |
795 | port->ctl_addr = base + 0x38; | 861 | ap->ioaddr.ctl_addr = base + 0x38; |
796 | port->scr_addr = scr_addr; | 862 | ap->ioaddr.scr_addr = scr_addr; |
797 | } | 863 | } |
798 | 864 | ||
799 | 865 | ||
800 | static void pdc_host_init(unsigned int chip_id, struct ata_probe_ent *pe) | 866 | static void pdc_host_init(struct ata_host *host) |
801 | { | 867 | { |
802 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 868 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
803 | struct pdc_host_priv *hp = pe->private_data; | 869 | int is_gen2 = host->ports[0]->flags & PDC_FLAG_GEN_II; |
804 | int hotplug_offset; | 870 | int hotplug_offset; |
805 | u32 tmp; | 871 | u32 tmp; |
806 | 872 | ||
807 | if (hp->flags & PDC_FLAG_GEN_II) | 873 | if (is_gen2) |
808 | hotplug_offset = PDC2_SATA_PLUG_CSR; | 874 | hotplug_offset = PDC2_SATA_PLUG_CSR; |
809 | else | 875 | else |
810 | hotplug_offset = PDC_SATA_PLUG_CSR; | 876 | hotplug_offset = PDC_SATA_PLUG_CSR; |
@@ -818,7 +884,7 @@ static void pdc_host_init(unsigned int chip_id, struct ata_probe_ent *pe) | |||
818 | /* enable BMR_BURST, maybe change FIFO_SHD to 8 dwords */ | 884 | /* enable BMR_BURST, maybe change FIFO_SHD to 8 dwords */ |
819 | tmp = readl(mmio + PDC_FLASH_CTL); | 885 | tmp = readl(mmio + PDC_FLASH_CTL); |
820 | tmp |= 0x02000; /* bit 13 (enable bmr burst) */ | 886 | tmp |= 0x02000; /* bit 13 (enable bmr burst) */ |
821 | if (!(hp->flags & PDC_FLAG_GEN_II)) | 887 | if (!is_gen2) |
822 | tmp |= 0x10000; /* bit 16 (fifo threshold at 8 dw) */ | 888 | tmp |= 0x10000; /* bit 16 (fifo threshold at 8 dw) */ |
823 | writel(tmp, mmio + PDC_FLASH_CTL); | 889 | writel(tmp, mmio + PDC_FLASH_CTL); |
824 | 890 | ||
@@ -831,7 +897,7 @@ static void pdc_host_init(unsigned int chip_id, struct ata_probe_ent *pe) | |||
831 | writel(tmp | 0xff0000, mmio + hotplug_offset); | 897 | writel(tmp | 0xff0000, mmio + hotplug_offset); |
832 | 898 | ||
833 | /* don't initialise TBG or SLEW on 2nd generation chips */ | 899 | /* don't initialise TBG or SLEW on 2nd generation chips */ |
834 | if (hp->flags & PDC_FLAG_GEN_II) | 900 | if (is_gen2) |
835 | return; | 901 | return; |
836 | 902 | ||
837 | /* reduce TBG clock to 133 Mhz. */ | 903 | /* reduce TBG clock to 133 Mhz. */ |
@@ -853,16 +919,16 @@ static void pdc_host_init(unsigned int chip_id, struct ata_probe_ent *pe) | |||
853 | static int pdc_ata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 919 | static int pdc_ata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
854 | { | 920 | { |
855 | static int printed_version; | 921 | static int printed_version; |
856 | struct ata_probe_ent *probe_ent; | 922 | const struct ata_port_info *pi = &pdc_port_info[ent->driver_data]; |
857 | struct pdc_host_priv *hp; | 923 | const struct ata_port_info *ppi[PDC_MAX_PORTS]; |
924 | struct ata_host *host; | ||
858 | void __iomem *base; | 925 | void __iomem *base; |
859 | unsigned int board_idx = (unsigned int) ent->driver_data; | 926 | int n_ports, i, rc; |
860 | int rc; | ||
861 | u8 tmp; | ||
862 | 927 | ||
863 | if (!printed_version++) | 928 | if (!printed_version++) |
864 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 929 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
865 | 930 | ||
931 | /* enable and acquire resources */ | ||
866 | rc = pcim_enable_device(pdev); | 932 | rc = pcim_enable_device(pdev); |
867 | if (rc) | 933 | if (rc) |
868 | return rc; | 934 | return rc; |
@@ -872,89 +938,49 @@ static int pdc_ata_init_one (struct pci_dev *pdev, const struct pci_device_id *e | |||
872 | pcim_pin_device(pdev); | 938 | pcim_pin_device(pdev); |
873 | if (rc) | 939 | if (rc) |
874 | return rc; | 940 | return rc; |
941 | base = pcim_iomap_table(pdev)[PDC_MMIO_BAR]; | ||
875 | 942 | ||
876 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | 943 | /* determine port configuration and setup host */ |
877 | if (rc) | 944 | n_ports = 2; |
878 | return rc; | 945 | if (pi->flags & PDC_FLAG_4_PORTS) |
879 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | 946 | n_ports = 4; |
880 | if (rc) | 947 | for (i = 0; i < n_ports; i++) |
881 | return rc; | 948 | ppi[i] = pi; |
882 | |||
883 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | ||
884 | if (probe_ent == NULL) | ||
885 | return -ENOMEM; | ||
886 | 949 | ||
887 | probe_ent->dev = pci_dev_to_dev(pdev); | 950 | if (pi->flags & PDC_FLAG_SATA_PATA) { |
888 | INIT_LIST_HEAD(&probe_ent->node); | 951 | u8 tmp = readb(base + PDC_FLASH_CTL+1); |
952 | if (!(tmp & 0x80)) { | ||
953 | ppi[n_ports++] = pi + 1; | ||
954 | dev_printk(KERN_INFO, &pdev->dev, "PATA port found\n"); | ||
955 | } | ||
956 | } | ||
889 | 957 | ||
890 | hp = devm_kzalloc(&pdev->dev, sizeof(*hp), GFP_KERNEL); | 958 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, n_ports); |
891 | if (hp == NULL) | 959 | if (!host) { |
960 | dev_printk(KERN_ERR, &pdev->dev, "failed to allocate host\n"); | ||
892 | return -ENOMEM; | 961 | return -ENOMEM; |
893 | |||
894 | probe_ent->private_data = hp; | ||
895 | |||
896 | probe_ent->sht = pdc_port_info[board_idx].sht; | ||
897 | probe_ent->port_flags = pdc_port_info[board_idx].flags; | ||
898 | probe_ent->pio_mask = pdc_port_info[board_idx].pio_mask; | ||
899 | probe_ent->mwdma_mask = pdc_port_info[board_idx].mwdma_mask; | ||
900 | probe_ent->udma_mask = pdc_port_info[board_idx].udma_mask; | ||
901 | probe_ent->port_ops = pdc_port_info[board_idx].port_ops; | ||
902 | |||
903 | probe_ent->irq = pdev->irq; | ||
904 | probe_ent->irq_flags = IRQF_SHARED; | ||
905 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
906 | |||
907 | base = probe_ent->iomap[PDC_MMIO_BAR]; | ||
908 | |||
909 | pdc_ata_setup_port(&probe_ent->port[0], base + 0x200, base + 0x400); | ||
910 | pdc_ata_setup_port(&probe_ent->port[1], base + 0x280, base + 0x500); | ||
911 | |||
912 | /* notice 4-port boards */ | ||
913 | switch (board_idx) { | ||
914 | case board_40518: | ||
915 | hp->flags |= PDC_FLAG_GEN_II; | ||
916 | /* Fall through */ | ||
917 | case board_20319: | ||
918 | probe_ent->n_ports = 4; | ||
919 | pdc_ata_setup_port(&probe_ent->port[2], base + 0x300, base + 0x600); | ||
920 | pdc_ata_setup_port(&probe_ent->port[3], base + 0x380, base + 0x700); | ||
921 | break; | ||
922 | case board_2057x: | ||
923 | hp->flags |= PDC_FLAG_GEN_II; | ||
924 | /* Fall through */ | ||
925 | case board_2037x: | ||
926 | /* TX2plus boards also have a PATA port */ | ||
927 | tmp = readb(base + PDC_FLASH_CTL+1); | ||
928 | if (!(tmp & 0x80)) { | ||
929 | probe_ent->n_ports = 3; | ||
930 | pdc_ata_setup_port(&probe_ent->port[2], base + 0x300, NULL); | ||
931 | hp->port_flags[2] = ATA_FLAG_SLAVE_POSS; | ||
932 | printk(KERN_INFO DRV_NAME " PATA port found\n"); | ||
933 | } else | ||
934 | probe_ent->n_ports = 2; | ||
935 | hp->port_flags[0] = ATA_FLAG_SATA; | ||
936 | hp->port_flags[1] = ATA_FLAG_SATA; | ||
937 | break; | ||
938 | case board_20619: | ||
939 | probe_ent->n_ports = 4; | ||
940 | pdc_ata_setup_port(&probe_ent->port[2], base + 0x300, NULL); | ||
941 | pdc_ata_setup_port(&probe_ent->port[3], base + 0x380, NULL); | ||
942 | break; | ||
943 | default: | ||
944 | BUG(); | ||
945 | break; | ||
946 | } | 962 | } |
963 | host->iomap = pcim_iomap_table(pdev); | ||
947 | 964 | ||
948 | pci_set_master(pdev); | 965 | for (i = 0; i < host->n_ports; i++) |
966 | pdc_ata_setup_port(host->ports[i], | ||
967 | base + 0x200 + i * 0x80, | ||
968 | base + 0x400 + i * 0x100); | ||
949 | 969 | ||
950 | /* initialize adapter */ | 970 | /* initialize adapter */ |
951 | pdc_host_init(board_idx, probe_ent); | 971 | pdc_host_init(host); |
952 | 972 | ||
953 | if (!ata_device_add(probe_ent)) | 973 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); |
954 | return -ENODEV; | 974 | if (rc) |
975 | return rc; | ||
976 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | ||
977 | if (rc) | ||
978 | return rc; | ||
955 | 979 | ||
956 | devm_kfree(&pdev->dev, probe_ent); | 980 | /* start host, request IRQ and attach */ |
957 | return 0; | 981 | pci_set_master(pdev); |
982 | return ata_host_activate(host, pdev->irq, pdc_interrupt, IRQF_SHARED, | ||
983 | &pdc_ata_sht); | ||
958 | } | 984 | } |
959 | 985 | ||
960 | 986 | ||
diff --git a/drivers/ata/sata_qstor.c b/drivers/ata/sata_qstor.c index 8786b45f291..f5a05de0093 100644 --- a/drivers/ata/sata_qstor.c +++ b/drivers/ata/sata_qstor.c | |||
@@ -114,7 +114,6 @@ struct qs_port_priv { | |||
114 | static u32 qs_scr_read (struct ata_port *ap, unsigned int sc_reg); | 114 | static u32 qs_scr_read (struct ata_port *ap, unsigned int sc_reg); |
115 | static void qs_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); | 115 | static void qs_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); |
116 | static int qs_ata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); | 116 | static int qs_ata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); |
117 | static irqreturn_t qs_intr (int irq, void *dev_instance); | ||
118 | static int qs_port_start(struct ata_port *ap); | 117 | static int qs_port_start(struct ata_port *ap); |
119 | static void qs_host_stop(struct ata_host *host); | 118 | static void qs_host_stop(struct ata_host *host); |
120 | static void qs_phy_reset(struct ata_port *ap); | 119 | static void qs_phy_reset(struct ata_port *ap); |
@@ -158,7 +157,6 @@ static const struct ata_port_operations qs_ata_ops = { | |||
158 | .qc_issue = qs_qc_issue, | 157 | .qc_issue = qs_qc_issue, |
159 | .data_xfer = ata_data_xfer, | 158 | .data_xfer = ata_data_xfer, |
160 | .eng_timeout = qs_eng_timeout, | 159 | .eng_timeout = qs_eng_timeout, |
161 | .irq_handler = qs_intr, | ||
162 | .irq_clear = qs_irq_clear, | 160 | .irq_clear = qs_irq_clear, |
163 | .irq_on = ata_irq_on, | 161 | .irq_on = ata_irq_on, |
164 | .irq_ack = ata_irq_ack, | 162 | .irq_ack = ata_irq_ack, |
@@ -173,7 +171,6 @@ static const struct ata_port_operations qs_ata_ops = { | |||
173 | static const struct ata_port_info qs_port_info[] = { | 171 | static const struct ata_port_info qs_port_info[] = { |
174 | /* board_2068_idx */ | 172 | /* board_2068_idx */ |
175 | { | 173 | { |
176 | .sht = &qs_ata_sht, | ||
177 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | 174 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | |
178 | ATA_FLAG_SATA_RESET | | 175 | ATA_FLAG_SATA_RESET | |
179 | //FIXME ATA_FLAG_SRST | | 176 | //FIXME ATA_FLAG_SRST | |
@@ -530,16 +527,16 @@ static void qs_host_stop(struct ata_host *host) | |||
530 | writeb(QS_CNFG3_GSRST, mmio_base + QS_HCF_CNFG3); /* global reset */ | 527 | writeb(QS_CNFG3_GSRST, mmio_base + QS_HCF_CNFG3); /* global reset */ |
531 | } | 528 | } |
532 | 529 | ||
533 | static void qs_host_init(unsigned int chip_id, struct ata_probe_ent *pe) | 530 | static void qs_host_init(struct ata_host *host, unsigned int chip_id) |
534 | { | 531 | { |
535 | void __iomem *mmio_base = pe->iomap[QS_MMIO_BAR]; | 532 | void __iomem *mmio_base = host->iomap[QS_MMIO_BAR]; |
536 | unsigned int port_no; | 533 | unsigned int port_no; |
537 | 534 | ||
538 | writeb(0, mmio_base + QS_HCT_CTRL); /* disable host interrupts */ | 535 | writeb(0, mmio_base + QS_HCT_CTRL); /* disable host interrupts */ |
539 | writeb(QS_CNFG3_GSRST, mmio_base + QS_HCF_CNFG3); /* global reset */ | 536 | writeb(QS_CNFG3_GSRST, mmio_base + QS_HCF_CNFG3); /* global reset */ |
540 | 537 | ||
541 | /* reset each channel in turn */ | 538 | /* reset each channel in turn */ |
542 | for (port_no = 0; port_no < pe->n_ports; ++port_no) { | 539 | for (port_no = 0; port_no < host->n_ports; ++port_no) { |
543 | u8 __iomem *chan = mmio_base + (port_no * 0x4000); | 540 | u8 __iomem *chan = mmio_base + (port_no * 0x4000); |
544 | writeb(QS_CTR1_RDEV|QS_CTR1_RCHN, chan + QS_CCT_CTR1); | 541 | writeb(QS_CTR1_RDEV|QS_CTR1_RCHN, chan + QS_CCT_CTR1); |
545 | writeb(QS_CTR0_REG, chan + QS_CCT_CTR0); | 542 | writeb(QS_CTR0_REG, chan + QS_CCT_CTR0); |
@@ -547,7 +544,7 @@ static void qs_host_init(unsigned int chip_id, struct ata_probe_ent *pe) | |||
547 | } | 544 | } |
548 | writeb(QS_SERD3_PHY_ENA, mmio_base + QS_HVS_SERD3); /* enable phy */ | 545 | writeb(QS_SERD3_PHY_ENA, mmio_base + QS_HVS_SERD3); /* enable phy */ |
549 | 546 | ||
550 | for (port_no = 0; port_no < pe->n_ports; ++port_no) { | 547 | for (port_no = 0; port_no < host->n_ports; ++port_no) { |
551 | u8 __iomem *chan = mmio_base + (port_no * 0x4000); | 548 | u8 __iomem *chan = mmio_base + (port_no * 0x4000); |
552 | /* set FIFO depths to same settings as Windows driver */ | 549 | /* set FIFO depths to same settings as Windows driver */ |
553 | writew(32, chan + QS_CFC_HUFT); | 550 | writew(32, chan + QS_CFC_HUFT); |
@@ -607,14 +604,20 @@ static int qs_ata_init_one(struct pci_dev *pdev, | |||
607 | const struct pci_device_id *ent) | 604 | const struct pci_device_id *ent) |
608 | { | 605 | { |
609 | static int printed_version; | 606 | static int printed_version; |
610 | struct ata_probe_ent *probe_ent; | ||
611 | void __iomem * const *iomap; | ||
612 | unsigned int board_idx = (unsigned int) ent->driver_data; | 607 | unsigned int board_idx = (unsigned int) ent->driver_data; |
608 | const struct ata_port_info *ppi[] = { &qs_port_info[board_idx], NULL }; | ||
609 | struct ata_host *host; | ||
613 | int rc, port_no; | 610 | int rc, port_no; |
614 | 611 | ||
615 | if (!printed_version++) | 612 | if (!printed_version++) |
616 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 613 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
617 | 614 | ||
615 | /* alloc host */ | ||
616 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, QS_PORTS); | ||
617 | if (!host) | ||
618 | return -ENOMEM; | ||
619 | |||
620 | /* acquire resources and fill host */ | ||
618 | rc = pcim_enable_device(pdev); | 621 | rc = pcim_enable_device(pdev); |
619 | if (rc) | 622 | if (rc) |
620 | return rc; | 623 | return rc; |
@@ -625,47 +628,24 @@ static int qs_ata_init_one(struct pci_dev *pdev, | |||
625 | rc = pcim_iomap_regions(pdev, 1 << QS_MMIO_BAR, DRV_NAME); | 628 | rc = pcim_iomap_regions(pdev, 1 << QS_MMIO_BAR, DRV_NAME); |
626 | if (rc) | 629 | if (rc) |
627 | return rc; | 630 | return rc; |
628 | iomap = pcim_iomap_table(pdev); | 631 | host->iomap = pcim_iomap_table(pdev); |
629 | 632 | ||
630 | rc = qs_set_dma_masks(pdev, iomap[QS_MMIO_BAR]); | 633 | rc = qs_set_dma_masks(pdev, host->iomap[QS_MMIO_BAR]); |
631 | if (rc) | 634 | if (rc) |
632 | return rc; | 635 | return rc; |
633 | 636 | ||
634 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | 637 | for (port_no = 0; port_no < host->n_ports; ++port_no) { |
635 | if (probe_ent == NULL) | ||
636 | return -ENOMEM; | ||
637 | |||
638 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
639 | INIT_LIST_HEAD(&probe_ent->node); | ||
640 | |||
641 | probe_ent->sht = qs_port_info[board_idx].sht; | ||
642 | probe_ent->port_flags = qs_port_info[board_idx].flags; | ||
643 | probe_ent->pio_mask = qs_port_info[board_idx].pio_mask; | ||
644 | probe_ent->mwdma_mask = qs_port_info[board_idx].mwdma_mask; | ||
645 | probe_ent->udma_mask = qs_port_info[board_idx].udma_mask; | ||
646 | probe_ent->port_ops = qs_port_info[board_idx].port_ops; | ||
647 | |||
648 | probe_ent->irq = pdev->irq; | ||
649 | probe_ent->irq_flags = IRQF_SHARED; | ||
650 | probe_ent->iomap = iomap; | ||
651 | probe_ent->n_ports = QS_PORTS; | ||
652 | |||
653 | for (port_no = 0; port_no < probe_ent->n_ports; ++port_no) { | ||
654 | void __iomem *chan = | 638 | void __iomem *chan = |
655 | probe_ent->iomap[QS_MMIO_BAR] + (port_no * 0x4000); | 639 | host->iomap[QS_MMIO_BAR] + (port_no * 0x4000); |
656 | qs_ata_setup_port(&probe_ent->port[port_no], chan); | 640 | qs_ata_setup_port(&host->ports[port_no]->ioaddr, chan); |
657 | } | 641 | } |
658 | 642 | ||
659 | pci_set_master(pdev); | ||
660 | |||
661 | /* initialize adapter */ | 643 | /* initialize adapter */ |
662 | qs_host_init(board_idx, probe_ent); | 644 | qs_host_init(host, board_idx); |
663 | 645 | ||
664 | if (ata_device_add(probe_ent) != QS_PORTS) | 646 | pci_set_master(pdev); |
665 | return -EIO; | 647 | return ata_host_activate(host, pdev->irq, qs_intr, IRQF_SHARED, |
666 | 648 | &qs_ata_sht); | |
667 | devm_kfree(&pdev->dev, probe_ent); | ||
668 | return 0; | ||
669 | } | 649 | } |
670 | 650 | ||
671 | static int __init qs_ata_init(void) | 651 | static int __init qs_ata_init(void) |
diff --git a/drivers/ata/sata_sil.c b/drivers/ata/sata_sil.c index 917b7ea4ef7..0a1e417f309 100644 --- a/drivers/ata/sata_sil.c +++ b/drivers/ata/sata_sil.c | |||
@@ -46,7 +46,7 @@ | |||
46 | #include <linux/libata.h> | 46 | #include <linux/libata.h> |
47 | 47 | ||
48 | #define DRV_NAME "sata_sil" | 48 | #define DRV_NAME "sata_sil" |
49 | #define DRV_VERSION "2.1" | 49 | #define DRV_VERSION "2.2" |
50 | 50 | ||
51 | enum { | 51 | enum { |
52 | SIL_MMIO_BAR = 5, | 52 | SIL_MMIO_BAR = 5, |
@@ -114,11 +114,10 @@ static int sil_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); | |||
114 | #ifdef CONFIG_PM | 114 | #ifdef CONFIG_PM |
115 | static int sil_pci_device_resume(struct pci_dev *pdev); | 115 | static int sil_pci_device_resume(struct pci_dev *pdev); |
116 | #endif | 116 | #endif |
117 | static void sil_dev_config(struct ata_port *ap, struct ata_device *dev); | 117 | static void sil_dev_config(struct ata_device *dev); |
118 | static u32 sil_scr_read (struct ata_port *ap, unsigned int sc_reg); | 118 | static u32 sil_scr_read (struct ata_port *ap, unsigned int sc_reg); |
119 | static void sil_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); | 119 | static void sil_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); |
120 | static void sil_post_set_mode (struct ata_port *ap); | 120 | static int sil_set_mode (struct ata_port *ap, struct ata_device **r_failed); |
121 | static irqreturn_t sil_interrupt(int irq, void *dev_instance); | ||
122 | static void sil_freeze(struct ata_port *ap); | 121 | static void sil_freeze(struct ata_port *ap); |
123 | static void sil_thaw(struct ata_port *ap); | 122 | static void sil_thaw(struct ata_port *ap); |
124 | 123 | ||
@@ -197,7 +196,7 @@ static const struct ata_port_operations sil_ops = { | |||
197 | .check_status = ata_check_status, | 196 | .check_status = ata_check_status, |
198 | .exec_command = ata_exec_command, | 197 | .exec_command = ata_exec_command, |
199 | .dev_select = ata_std_dev_select, | 198 | .dev_select = ata_std_dev_select, |
200 | .post_set_mode = sil_post_set_mode, | 199 | .set_mode = sil_set_mode, |
201 | .bmdma_setup = ata_bmdma_setup, | 200 | .bmdma_setup = ata_bmdma_setup, |
202 | .bmdma_start = ata_bmdma_start, | 201 | .bmdma_start = ata_bmdma_start, |
203 | .bmdma_stop = ata_bmdma_stop, | 202 | .bmdma_stop = ata_bmdma_stop, |
@@ -209,7 +208,6 @@ static const struct ata_port_operations sil_ops = { | |||
209 | .thaw = sil_thaw, | 208 | .thaw = sil_thaw, |
210 | .error_handler = ata_bmdma_error_handler, | 209 | .error_handler = ata_bmdma_error_handler, |
211 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 210 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
212 | .irq_handler = sil_interrupt, | ||
213 | .irq_clear = ata_bmdma_irq_clear, | 211 | .irq_clear = ata_bmdma_irq_clear, |
214 | .irq_on = ata_irq_on, | 212 | .irq_on = ata_irq_on, |
215 | .irq_ack = ata_irq_ack, | 213 | .irq_ack = ata_irq_ack, |
@@ -221,7 +219,6 @@ static const struct ata_port_operations sil_ops = { | |||
221 | static const struct ata_port_info sil_port_info[] = { | 219 | static const struct ata_port_info sil_port_info[] = { |
222 | /* sil_3112 */ | 220 | /* sil_3112 */ |
223 | { | 221 | { |
224 | .sht = &sil_sht, | ||
225 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_MOD15WRITE, | 222 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_MOD15WRITE, |
226 | .pio_mask = 0x1f, /* pio0-4 */ | 223 | .pio_mask = 0x1f, /* pio0-4 */ |
227 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 224 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
@@ -230,7 +227,6 @@ static const struct ata_port_info sil_port_info[] = { | |||
230 | }, | 227 | }, |
231 | /* sil_3112_no_sata_irq */ | 228 | /* sil_3112_no_sata_irq */ |
232 | { | 229 | { |
233 | .sht = &sil_sht, | ||
234 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_MOD15WRITE | | 230 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_MOD15WRITE | |
235 | SIL_FLAG_NO_SATA_IRQ, | 231 | SIL_FLAG_NO_SATA_IRQ, |
236 | .pio_mask = 0x1f, /* pio0-4 */ | 232 | .pio_mask = 0x1f, /* pio0-4 */ |
@@ -240,7 +236,6 @@ static const struct ata_port_info sil_port_info[] = { | |||
240 | }, | 236 | }, |
241 | /* sil_3512 */ | 237 | /* sil_3512 */ |
242 | { | 238 | { |
243 | .sht = &sil_sht, | ||
244 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_RERR_ON_DMA_ACT, | 239 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_RERR_ON_DMA_ACT, |
245 | .pio_mask = 0x1f, /* pio0-4 */ | 240 | .pio_mask = 0x1f, /* pio0-4 */ |
246 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 241 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
@@ -249,7 +244,6 @@ static const struct ata_port_info sil_port_info[] = { | |||
249 | }, | 244 | }, |
250 | /* sil_3114 */ | 245 | /* sil_3114 */ |
251 | { | 246 | { |
252 | .sht = &sil_sht, | ||
253 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_RERR_ON_DMA_ACT, | 247 | .flags = SIL_DFL_PORT_FLAGS | SIL_FLAG_RERR_ON_DMA_ACT, |
254 | .pio_mask = 0x1f, /* pio0-4 */ | 248 | .pio_mask = 0x1f, /* pio0-4 */ |
255 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 249 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
@@ -297,7 +291,16 @@ static unsigned char sil_get_device_cache_line(struct pci_dev *pdev) | |||
297 | return cache_line; | 291 | return cache_line; |
298 | } | 292 | } |
299 | 293 | ||
300 | static void sil_post_set_mode (struct ata_port *ap) | 294 | /** |
295 | * sil_set_mode - wrap set_mode functions | ||
296 | * @ap: port to set up | ||
297 | * @r_failed: returned device when we fail | ||
298 | * | ||
299 | * Wrap the libata method for device setup as after the setup we need | ||
300 | * to inspect the results and do some configuration work | ||
301 | */ | ||
302 | |||
303 | static int sil_set_mode (struct ata_port *ap, struct ata_device **r_failed) | ||
301 | { | 304 | { |
302 | struct ata_host *host = ap->host; | 305 | struct ata_host *host = ap->host; |
303 | struct ata_device *dev; | 306 | struct ata_device *dev; |
@@ -305,6 +308,11 @@ static void sil_post_set_mode (struct ata_port *ap) | |||
305 | void __iomem *addr = mmio_base + sil_port[ap->port_no].xfer_mode; | 308 | void __iomem *addr = mmio_base + sil_port[ap->port_no].xfer_mode; |
306 | u32 tmp, dev_mode[2]; | 309 | u32 tmp, dev_mode[2]; |
307 | unsigned int i; | 310 | unsigned int i; |
311 | int rc; | ||
312 | |||
313 | rc = ata_do_set_mode(ap, r_failed); | ||
314 | if (rc) | ||
315 | return rc; | ||
308 | 316 | ||
309 | for (i = 0; i < 2; i++) { | 317 | for (i = 0; i < 2; i++) { |
310 | dev = &ap->device[i]; | 318 | dev = &ap->device[i]; |
@@ -323,6 +331,7 @@ static void sil_post_set_mode (struct ata_port *ap) | |||
323 | tmp |= (dev_mode[1] << 4); | 331 | tmp |= (dev_mode[1] << 4); |
324 | writel(tmp, addr); | 332 | writel(tmp, addr); |
325 | readl(addr); /* flush */ | 333 | readl(addr); /* flush */ |
334 | return 0; | ||
326 | } | 335 | } |
327 | 336 | ||
328 | static inline void __iomem *sil_scr_addr(struct ata_port *ap, unsigned int sc_reg) | 337 | static inline void __iomem *sil_scr_addr(struct ata_port *ap, unsigned int sc_reg) |
@@ -521,7 +530,6 @@ static void sil_thaw(struct ata_port *ap) | |||
521 | 530 | ||
522 | /** | 531 | /** |
523 | * sil_dev_config - Apply device/host-specific errata fixups | 532 | * sil_dev_config - Apply device/host-specific errata fixups |
524 | * @ap: Port containing device to be examined | ||
525 | * @dev: Device to be examined | 533 | * @dev: Device to be examined |
526 | * | 534 | * |
527 | * After the IDENTIFY [PACKET] DEVICE step is complete, and a | 535 | * After the IDENTIFY [PACKET] DEVICE step is complete, and a |
@@ -548,8 +556,9 @@ static void sil_thaw(struct ata_port *ap) | |||
548 | * appreciated. | 556 | * appreciated. |
549 | * - But then again UDMA5 is hardly anything to complain about | 557 | * - But then again UDMA5 is hardly anything to complain about |
550 | */ | 558 | */ |
551 | static void sil_dev_config(struct ata_port *ap, struct ata_device *dev) | 559 | static void sil_dev_config(struct ata_device *dev) |
552 | { | 560 | { |
561 | struct ata_port *ap = dev->ap; | ||
553 | int print_info = ap->eh_context.i.flags & ATA_EHI_PRINTINFO; | 562 | int print_info = ap->eh_context.i.flags & ATA_EHI_PRINTINFO; |
554 | unsigned int n, quirks = 0; | 563 | unsigned int n, quirks = 0; |
555 | unsigned char model_num[ATA_ID_PROD_LEN + 1]; | 564 | unsigned char model_num[ATA_ID_PROD_LEN + 1]; |
@@ -583,10 +592,10 @@ static void sil_dev_config(struct ata_port *ap, struct ata_device *dev) | |||
583 | } | 592 | } |
584 | } | 593 | } |
585 | 594 | ||
586 | static void sil_init_controller(struct pci_dev *pdev, | 595 | static void sil_init_controller(struct ata_host *host) |
587 | int n_ports, unsigned long port_flags, | ||
588 | void __iomem *mmio_base) | ||
589 | { | 596 | { |
597 | struct pci_dev *pdev = to_pci_dev(host->dev); | ||
598 | void __iomem *mmio_base = host->iomap[SIL_MMIO_BAR]; | ||
590 | u8 cls; | 599 | u8 cls; |
591 | u32 tmp; | 600 | u32 tmp; |
592 | int i; | 601 | int i; |
@@ -596,7 +605,7 @@ static void sil_init_controller(struct pci_dev *pdev, | |||
596 | if (cls) { | 605 | if (cls) { |
597 | cls >>= 3; | 606 | cls >>= 3; |
598 | cls++; /* cls = (line_size/8)+1 */ | 607 | cls++; /* cls = (line_size/8)+1 */ |
599 | for (i = 0; i < n_ports; i++) | 608 | for (i = 0; i < host->n_ports; i++) |
600 | writew(cls << 8 | cls, | 609 | writew(cls << 8 | cls, |
601 | mmio_base + sil_port[i].fifo_cfg); | 610 | mmio_base + sil_port[i].fifo_cfg); |
602 | } else | 611 | } else |
@@ -604,10 +613,10 @@ static void sil_init_controller(struct pci_dev *pdev, | |||
604 | "cache line size not set. Driver may not function\n"); | 613 | "cache line size not set. Driver may not function\n"); |
605 | 614 | ||
606 | /* Apply R_ERR on DMA activate FIS errata workaround */ | 615 | /* Apply R_ERR on DMA activate FIS errata workaround */ |
607 | if (port_flags & SIL_FLAG_RERR_ON_DMA_ACT) { | 616 | if (host->ports[0]->flags & SIL_FLAG_RERR_ON_DMA_ACT) { |
608 | int cnt; | 617 | int cnt; |
609 | 618 | ||
610 | for (i = 0, cnt = 0; i < n_ports; i++) { | 619 | for (i = 0, cnt = 0; i < host->n_ports; i++) { |
611 | tmp = readl(mmio_base + sil_port[i].sfis_cfg); | 620 | tmp = readl(mmio_base + sil_port[i].sfis_cfg); |
612 | if ((tmp & 0x3) != 0x01) | 621 | if ((tmp & 0x3) != 0x01) |
613 | continue; | 622 | continue; |
@@ -620,7 +629,7 @@ static void sil_init_controller(struct pci_dev *pdev, | |||
620 | } | 629 | } |
621 | } | 630 | } |
622 | 631 | ||
623 | if (n_ports == 4) { | 632 | if (host->n_ports == 4) { |
624 | /* flip the magic "make 4 ports work" bit */ | 633 | /* flip the magic "make 4 ports work" bit */ |
625 | tmp = readl(mmio_base + sil_port[2].bmdma); | 634 | tmp = readl(mmio_base + sil_port[2].bmdma); |
626 | if ((tmp & SIL_INTR_STEERING) == 0) | 635 | if ((tmp & SIL_INTR_STEERING) == 0) |
@@ -632,15 +641,26 @@ static void sil_init_controller(struct pci_dev *pdev, | |||
632 | static int sil_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 641 | static int sil_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
633 | { | 642 | { |
634 | static int printed_version; | 643 | static int printed_version; |
635 | struct device *dev = &pdev->dev; | 644 | int board_id = ent->driver_data; |
636 | struct ata_probe_ent *probe_ent; | 645 | const struct ata_port_info *ppi[] = { &sil_port_info[board_id], NULL }; |
646 | struct ata_host *host; | ||
637 | void __iomem *mmio_base; | 647 | void __iomem *mmio_base; |
638 | int rc; | 648 | int n_ports, rc; |
639 | unsigned int i; | 649 | unsigned int i; |
640 | 650 | ||
641 | if (!printed_version++) | 651 | if (!printed_version++) |
642 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 652 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
643 | 653 | ||
654 | /* allocate host */ | ||
655 | n_ports = 2; | ||
656 | if (board_id == sil_3114) | ||
657 | n_ports = 4; | ||
658 | |||
659 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, n_ports); | ||
660 | if (!host) | ||
661 | return -ENOMEM; | ||
662 | |||
663 | /* acquire resources and fill host */ | ||
644 | rc = pcim_enable_device(pdev); | 664 | rc = pcim_enable_device(pdev); |
645 | if (rc) | 665 | if (rc) |
646 | return rc; | 666 | return rc; |
@@ -650,6 +670,7 @@ static int sil_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
650 | pcim_pin_device(pdev); | 670 | pcim_pin_device(pdev); |
651 | if (rc) | 671 | if (rc) |
652 | return rc; | 672 | return rc; |
673 | host->iomap = pcim_iomap_table(pdev); | ||
653 | 674 | ||
654 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | 675 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); |
655 | if (rc) | 676 | if (rc) |
@@ -658,45 +679,25 @@ static int sil_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
658 | if (rc) | 679 | if (rc) |
659 | return rc; | 680 | return rc; |
660 | 681 | ||
661 | probe_ent = devm_kzalloc(dev, sizeof(*probe_ent), GFP_KERNEL); | 682 | mmio_base = host->iomap[SIL_MMIO_BAR]; |
662 | if (probe_ent == NULL) | ||
663 | return -ENOMEM; | ||
664 | 683 | ||
665 | INIT_LIST_HEAD(&probe_ent->node); | 684 | for (i = 0; i < host->n_ports; i++) { |
666 | probe_ent->dev = pci_dev_to_dev(pdev); | 685 | struct ata_ioports *ioaddr = &host->ports[i]->ioaddr; |
667 | probe_ent->port_ops = sil_port_info[ent->driver_data].port_ops; | 686 | |
668 | probe_ent->sht = sil_port_info[ent->driver_data].sht; | 687 | ioaddr->cmd_addr = mmio_base + sil_port[i].tf; |
669 | probe_ent->n_ports = (ent->driver_data == sil_3114) ? 4 : 2; | 688 | ioaddr->altstatus_addr = |
670 | probe_ent->pio_mask = sil_port_info[ent->driver_data].pio_mask; | 689 | ioaddr->ctl_addr = mmio_base + sil_port[i].ctl; |
671 | probe_ent->mwdma_mask = sil_port_info[ent->driver_data].mwdma_mask; | 690 | ioaddr->bmdma_addr = mmio_base + sil_port[i].bmdma; |
672 | probe_ent->udma_mask = sil_port_info[ent->driver_data].udma_mask; | 691 | ioaddr->scr_addr = mmio_base + sil_port[i].scr; |
673 | probe_ent->irq = pdev->irq; | 692 | ata_std_ports(ioaddr); |
674 | probe_ent->irq_flags = IRQF_SHARED; | ||
675 | probe_ent->port_flags = sil_port_info[ent->driver_data].flags; | ||
676 | |||
677 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
678 | |||
679 | mmio_base = probe_ent->iomap[SIL_MMIO_BAR]; | ||
680 | |||
681 | for (i = 0; i < probe_ent->n_ports; i++) { | ||
682 | probe_ent->port[i].cmd_addr = mmio_base + sil_port[i].tf; | ||
683 | probe_ent->port[i].altstatus_addr = | ||
684 | probe_ent->port[i].ctl_addr = mmio_base + sil_port[i].ctl; | ||
685 | probe_ent->port[i].bmdma_addr = mmio_base + sil_port[i].bmdma; | ||
686 | probe_ent->port[i].scr_addr = mmio_base + sil_port[i].scr; | ||
687 | ata_std_ports(&probe_ent->port[i]); | ||
688 | } | 693 | } |
689 | 694 | ||
690 | sil_init_controller(pdev, probe_ent->n_ports, probe_ent->port_flags, | 695 | /* initialize and activate */ |
691 | mmio_base); | 696 | sil_init_controller(host); |
692 | 697 | ||
693 | pci_set_master(pdev); | 698 | pci_set_master(pdev); |
694 | 699 | return ata_host_activate(host, pdev->irq, sil_interrupt, IRQF_SHARED, | |
695 | if (!ata_device_add(probe_ent)) | 700 | &sil_sht); |
696 | return -ENODEV; | ||
697 | |||
698 | devm_kfree(dev, probe_ent); | ||
699 | return 0; | ||
700 | } | 701 | } |
701 | 702 | ||
702 | #ifdef CONFIG_PM | 703 | #ifdef CONFIG_PM |
@@ -709,8 +710,7 @@ static int sil_pci_device_resume(struct pci_dev *pdev) | |||
709 | if (rc) | 710 | if (rc) |
710 | return rc; | 711 | return rc; |
711 | 712 | ||
712 | sil_init_controller(pdev, host->n_ports, host->ports[0]->flags, | 713 | sil_init_controller(host); |
713 | host->iomap[SIL_MMIO_BAR]); | ||
714 | ata_host_resume(host); | 714 | ata_host_resume(host); |
715 | 715 | ||
716 | return 0; | 716 | return 0; |
diff --git a/drivers/ata/sata_sil24.c b/drivers/ata/sata_sil24.c index 5614df8c1ce..e6223ba667d 100644 --- a/drivers/ata/sata_sil24.c +++ b/drivers/ata/sata_sil24.c | |||
@@ -323,7 +323,7 @@ struct sil24_port_priv { | |||
323 | struct ata_taskfile tf; /* Cached taskfile registers */ | 323 | struct ata_taskfile tf; /* Cached taskfile registers */ |
324 | }; | 324 | }; |
325 | 325 | ||
326 | static void sil24_dev_config(struct ata_port *ap, struct ata_device *dev); | 326 | static void sil24_dev_config(struct ata_device *dev); |
327 | static u8 sil24_check_status(struct ata_port *ap); | 327 | static u8 sil24_check_status(struct ata_port *ap); |
328 | static u32 sil24_scr_read(struct ata_port *ap, unsigned sc_reg); | 328 | static u32 sil24_scr_read(struct ata_port *ap, unsigned sc_reg); |
329 | static void sil24_scr_write(struct ata_port *ap, unsigned sc_reg, u32 val); | 329 | static void sil24_scr_write(struct ata_port *ap, unsigned sc_reg, u32 val); |
@@ -331,7 +331,6 @@ static void sil24_tf_read(struct ata_port *ap, struct ata_taskfile *tf); | |||
331 | static void sil24_qc_prep(struct ata_queued_cmd *qc); | 331 | static void sil24_qc_prep(struct ata_queued_cmd *qc); |
332 | static unsigned int sil24_qc_issue(struct ata_queued_cmd *qc); | 332 | static unsigned int sil24_qc_issue(struct ata_queued_cmd *qc); |
333 | static void sil24_irq_clear(struct ata_port *ap); | 333 | static void sil24_irq_clear(struct ata_port *ap); |
334 | static irqreturn_t sil24_interrupt(int irq, void *dev_instance); | ||
335 | static void sil24_freeze(struct ata_port *ap); | 334 | static void sil24_freeze(struct ata_port *ap); |
336 | static void sil24_thaw(struct ata_port *ap); | 335 | static void sil24_thaw(struct ata_port *ap); |
337 | static void sil24_error_handler(struct ata_port *ap); | 336 | static void sil24_error_handler(struct ata_port *ap); |
@@ -401,7 +400,6 @@ static const struct ata_port_operations sil24_ops = { | |||
401 | .qc_prep = sil24_qc_prep, | 400 | .qc_prep = sil24_qc_prep, |
402 | .qc_issue = sil24_qc_issue, | 401 | .qc_issue = sil24_qc_issue, |
403 | 402 | ||
404 | .irq_handler = sil24_interrupt, | ||
405 | .irq_clear = sil24_irq_clear, | 403 | .irq_clear = sil24_irq_clear, |
406 | .irq_on = ata_dummy_irq_on, | 404 | .irq_on = ata_dummy_irq_on, |
407 | .irq_ack = ata_dummy_irq_ack, | 405 | .irq_ack = ata_dummy_irq_ack, |
@@ -424,10 +422,9 @@ static const struct ata_port_operations sil24_ops = { | |||
424 | #define SIL24_NPORTS2FLAG(nports) ((((unsigned)(nports) - 1) & 0x3) << 30) | 422 | #define SIL24_NPORTS2FLAG(nports) ((((unsigned)(nports) - 1) & 0x3) << 30) |
425 | #define SIL24_FLAG2NPORTS(flag) ((((flag) >> 30) & 0x3) + 1) | 423 | #define SIL24_FLAG2NPORTS(flag) ((((flag) >> 30) & 0x3) + 1) |
426 | 424 | ||
427 | static struct ata_port_info sil24_port_info[] = { | 425 | static const struct ata_port_info sil24_port_info[] = { |
428 | /* sil_3124 */ | 426 | /* sil_3124 */ |
429 | { | 427 | { |
430 | .sht = &sil24_sht, | ||
431 | .flags = SIL24_COMMON_FLAGS | SIL24_NPORTS2FLAG(4) | | 428 | .flags = SIL24_COMMON_FLAGS | SIL24_NPORTS2FLAG(4) | |
432 | SIL24_FLAG_PCIX_IRQ_WOC, | 429 | SIL24_FLAG_PCIX_IRQ_WOC, |
433 | .pio_mask = 0x1f, /* pio0-4 */ | 430 | .pio_mask = 0x1f, /* pio0-4 */ |
@@ -437,7 +434,6 @@ static struct ata_port_info sil24_port_info[] = { | |||
437 | }, | 434 | }, |
438 | /* sil_3132 */ | 435 | /* sil_3132 */ |
439 | { | 436 | { |
440 | .sht = &sil24_sht, | ||
441 | .flags = SIL24_COMMON_FLAGS | SIL24_NPORTS2FLAG(2), | 437 | .flags = SIL24_COMMON_FLAGS | SIL24_NPORTS2FLAG(2), |
442 | .pio_mask = 0x1f, /* pio0-4 */ | 438 | .pio_mask = 0x1f, /* pio0-4 */ |
443 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 439 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
@@ -446,7 +442,6 @@ static struct ata_port_info sil24_port_info[] = { | |||
446 | }, | 442 | }, |
447 | /* sil_3131/sil_3531 */ | 443 | /* sil_3131/sil_3531 */ |
448 | { | 444 | { |
449 | .sht = &sil24_sht, | ||
450 | .flags = SIL24_COMMON_FLAGS | SIL24_NPORTS2FLAG(1), | 445 | .flags = SIL24_COMMON_FLAGS | SIL24_NPORTS2FLAG(1), |
451 | .pio_mask = 0x1f, /* pio0-4 */ | 446 | .pio_mask = 0x1f, /* pio0-4 */ |
452 | .mwdma_mask = 0x07, /* mwdma0-2 */ | 447 | .mwdma_mask = 0x07, /* mwdma0-2 */ |
@@ -462,9 +457,9 @@ static int sil24_tag(int tag) | |||
462 | return tag; | 457 | return tag; |
463 | } | 458 | } |
464 | 459 | ||
465 | static void sil24_dev_config(struct ata_port *ap, struct ata_device *dev) | 460 | static void sil24_dev_config(struct ata_device *dev) |
466 | { | 461 | { |
467 | void __iomem *port = ap->ioaddr.cmd_addr; | 462 | void __iomem *port = dev->ap->ioaddr.cmd_addr; |
468 | 463 | ||
469 | if (dev->cdb_len == 16) | 464 | if (dev->cdb_len == 16) |
470 | writel(PORT_CS_CDB16, port + PORT_CTRL_STAT); | 465 | writel(PORT_CS_CDB16, port + PORT_CTRL_STAT); |
@@ -924,11 +919,8 @@ static void sil24_post_internal_cmd(struct ata_queued_cmd *qc) | |||
924 | { | 919 | { |
925 | struct ata_port *ap = qc->ap; | 920 | struct ata_port *ap = qc->ap; |
926 | 921 | ||
927 | if (qc->flags & ATA_QCFLAG_FAILED) | ||
928 | qc->err_mask |= AC_ERR_OTHER; | ||
929 | |||
930 | /* make DMA engine forget about the failed command */ | 922 | /* make DMA engine forget about the failed command */ |
931 | if (qc->err_mask) | 923 | if (qc->flags & ATA_QCFLAG_FAILED) |
932 | sil24_init_port(ap); | 924 | sil24_init_port(ap); |
933 | } | 925 | } |
934 | 926 | ||
@@ -964,11 +956,10 @@ static int sil24_port_start(struct ata_port *ap) | |||
964 | return 0; | 956 | return 0; |
965 | } | 957 | } |
966 | 958 | ||
967 | static void sil24_init_controller(struct pci_dev *pdev, int n_ports, | 959 | static void sil24_init_controller(struct ata_host *host) |
968 | unsigned long port_flags, | ||
969 | void __iomem *host_base, | ||
970 | void __iomem *port_base) | ||
971 | { | 960 | { |
961 | void __iomem *host_base = host->iomap[SIL24_HOST_BAR]; | ||
962 | void __iomem *port_base = host->iomap[SIL24_PORT_BAR]; | ||
972 | u32 tmp; | 963 | u32 tmp; |
973 | int i; | 964 | int i; |
974 | 965 | ||
@@ -979,7 +970,7 @@ static void sil24_init_controller(struct pci_dev *pdev, int n_ports, | |||
979 | writel(0, host_base + HOST_CTRL); | 970 | writel(0, host_base + HOST_CTRL); |
980 | 971 | ||
981 | /* init ports */ | 972 | /* init ports */ |
982 | for (i = 0; i < n_ports; i++) { | 973 | for (i = 0; i < host->n_ports; i++) { |
983 | void __iomem *port = port_base + i * PORT_REGS_SIZE; | 974 | void __iomem *port = port_base + i * PORT_REGS_SIZE; |
984 | 975 | ||
985 | /* Initial PHY setting */ | 976 | /* Initial PHY setting */ |
@@ -993,12 +984,12 @@ static void sil24_init_controller(struct pci_dev *pdev, int n_ports, | |||
993 | PORT_CS_PORT_RST, | 984 | PORT_CS_PORT_RST, |
994 | PORT_CS_PORT_RST, 10, 100); | 985 | PORT_CS_PORT_RST, 10, 100); |
995 | if (tmp & PORT_CS_PORT_RST) | 986 | if (tmp & PORT_CS_PORT_RST) |
996 | dev_printk(KERN_ERR, &pdev->dev, | 987 | dev_printk(KERN_ERR, host->dev, |
997 | "failed to clear port RST\n"); | 988 | "failed to clear port RST\n"); |
998 | } | 989 | } |
999 | 990 | ||
1000 | /* Configure IRQ WoC */ | 991 | /* Configure IRQ WoC */ |
1001 | if (port_flags & SIL24_FLAG_PCIX_IRQ_WOC) | 992 | if (host->ports[0]->flags & SIL24_FLAG_PCIX_IRQ_WOC) |
1002 | writel(PORT_CS_IRQ_WOC, port + PORT_CTRL_STAT); | 993 | writel(PORT_CS_IRQ_WOC, port + PORT_CTRL_STAT); |
1003 | else | 994 | else |
1004 | writel(PORT_CS_IRQ_WOC, port + PORT_CTRL_CLR); | 995 | writel(PORT_CS_IRQ_WOC, port + PORT_CTRL_CLR); |
@@ -1026,18 +1017,17 @@ static void sil24_init_controller(struct pci_dev *pdev, int n_ports, | |||
1026 | static int sil24_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | 1017 | static int sil24_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
1027 | { | 1018 | { |
1028 | static int printed_version = 0; | 1019 | static int printed_version = 0; |
1029 | struct device *dev = &pdev->dev; | 1020 | struct ata_port_info pi = sil24_port_info[ent->driver_data]; |
1030 | unsigned int board_id = (unsigned int)ent->driver_data; | 1021 | const struct ata_port_info *ppi[] = { &pi, NULL }; |
1031 | struct ata_port_info *pinfo = &sil24_port_info[board_id]; | 1022 | void __iomem * const *iomap; |
1032 | struct ata_probe_ent *probe_ent; | 1023 | struct ata_host *host; |
1033 | void __iomem *host_base; | ||
1034 | void __iomem *port_base; | ||
1035 | int i, rc; | 1024 | int i, rc; |
1036 | u32 tmp; | 1025 | u32 tmp; |
1037 | 1026 | ||
1038 | if (!printed_version++) | 1027 | if (!printed_version++) |
1039 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 1028 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
1040 | 1029 | ||
1030 | /* acquire resources */ | ||
1041 | rc = pcim_enable_device(pdev); | 1031 | rc = pcim_enable_device(pdev); |
1042 | if (rc) | 1032 | if (rc) |
1043 | return rc; | 1033 | return rc; |
@@ -1047,33 +1037,36 @@ static int sil24_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1047 | DRV_NAME); | 1037 | DRV_NAME); |
1048 | if (rc) | 1038 | if (rc) |
1049 | return rc; | 1039 | return rc; |
1040 | iomap = pcim_iomap_table(pdev); | ||
1050 | 1041 | ||
1051 | /* allocate & init probe_ent */ | 1042 | /* apply workaround for completion IRQ loss on PCI-X errata */ |
1052 | probe_ent = devm_kzalloc(dev, sizeof(*probe_ent), GFP_KERNEL); | 1043 | if (pi.flags & SIL24_FLAG_PCIX_IRQ_WOC) { |
1053 | if (!probe_ent) | 1044 | tmp = readl(iomap[SIL24_HOST_BAR] + HOST_CTRL); |
1054 | return -ENOMEM; | 1045 | if (tmp & (HOST_CTRL_TRDY | HOST_CTRL_STOP | HOST_CTRL_DEVSEL)) |
1046 | dev_printk(KERN_INFO, &pdev->dev, | ||
1047 | "Applying completion IRQ loss on PCI-X " | ||
1048 | "errata fix\n"); | ||
1049 | else | ||
1050 | pi.flags &= ~SIL24_FLAG_PCIX_IRQ_WOC; | ||
1051 | } | ||
1055 | 1052 | ||
1056 | probe_ent->dev = pci_dev_to_dev(pdev); | 1053 | /* allocate and fill host */ |
1057 | INIT_LIST_HEAD(&probe_ent->node); | 1054 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, |
1055 | SIL24_FLAG2NPORTS(ppi[0]->flags)); | ||
1056 | if (!host) | ||
1057 | return -ENOMEM; | ||
1058 | host->iomap = iomap; | ||
1058 | 1059 | ||
1059 | probe_ent->sht = pinfo->sht; | 1060 | for (i = 0; i < host->n_ports; i++) { |
1060 | probe_ent->port_flags = pinfo->flags; | 1061 | void __iomem *port = iomap[SIL24_PORT_BAR] + i * PORT_REGS_SIZE; |
1061 | probe_ent->pio_mask = pinfo->pio_mask; | ||
1062 | probe_ent->mwdma_mask = pinfo->mwdma_mask; | ||
1063 | probe_ent->udma_mask = pinfo->udma_mask; | ||
1064 | probe_ent->port_ops = pinfo->port_ops; | ||
1065 | probe_ent->n_ports = SIL24_FLAG2NPORTS(pinfo->flags); | ||
1066 | 1062 | ||
1067 | probe_ent->irq = pdev->irq; | 1063 | host->ports[i]->ioaddr.cmd_addr = port; |
1068 | probe_ent->irq_flags = IRQF_SHARED; | 1064 | host->ports[i]->ioaddr.scr_addr = port + PORT_SCONTROL; |
1069 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
1070 | 1065 | ||
1071 | host_base = probe_ent->iomap[SIL24_HOST_BAR]; | 1066 | ata_std_ports(&host->ports[i]->ioaddr); |
1072 | port_base = probe_ent->iomap[SIL24_PORT_BAR]; | 1067 | } |
1073 | 1068 | ||
1074 | /* | 1069 | /* configure and activate the device */ |
1075 | * Configure the device | ||
1076 | */ | ||
1077 | if (!pci_set_dma_mask(pdev, DMA_64BIT_MASK)) { | 1070 | if (!pci_set_dma_mask(pdev, DMA_64BIT_MASK)) { |
1078 | rc = pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK); | 1071 | rc = pci_set_consistent_dma_mask(pdev, DMA_64BIT_MASK); |
1079 | if (rc) { | 1072 | if (rc) { |
@@ -1099,36 +1092,11 @@ static int sil24_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
1099 | } | 1092 | } |
1100 | } | 1093 | } |
1101 | 1094 | ||
1102 | /* Apply workaround for completion IRQ loss on PCI-X errata */ | 1095 | sil24_init_controller(host); |
1103 | if (probe_ent->port_flags & SIL24_FLAG_PCIX_IRQ_WOC) { | ||
1104 | tmp = readl(host_base + HOST_CTRL); | ||
1105 | if (tmp & (HOST_CTRL_TRDY | HOST_CTRL_STOP | HOST_CTRL_DEVSEL)) | ||
1106 | dev_printk(KERN_INFO, &pdev->dev, | ||
1107 | "Applying completion IRQ loss on PCI-X " | ||
1108 | "errata fix\n"); | ||
1109 | else | ||
1110 | probe_ent->port_flags &= ~SIL24_FLAG_PCIX_IRQ_WOC; | ||
1111 | } | ||
1112 | |||
1113 | for (i = 0; i < probe_ent->n_ports; i++) { | ||
1114 | void __iomem *port = port_base + i * PORT_REGS_SIZE; | ||
1115 | |||
1116 | probe_ent->port[i].cmd_addr = port; | ||
1117 | probe_ent->port[i].scr_addr = port + PORT_SCONTROL; | ||
1118 | |||
1119 | ata_std_ports(&probe_ent->port[i]); | ||
1120 | } | ||
1121 | |||
1122 | sil24_init_controller(pdev, probe_ent->n_ports, probe_ent->port_flags, | ||
1123 | host_base, port_base); | ||
1124 | 1096 | ||
1125 | pci_set_master(pdev); | 1097 | pci_set_master(pdev); |
1126 | 1098 | return ata_host_activate(host, pdev->irq, sil24_interrupt, IRQF_SHARED, | |
1127 | if (!ata_device_add(probe_ent)) | 1099 | &sil24_sht); |
1128 | return -ENODEV; | ||
1129 | |||
1130 | devm_kfree(dev, probe_ent); | ||
1131 | return 0; | ||
1132 | } | 1100 | } |
1133 | 1101 | ||
1134 | #ifdef CONFIG_PM | 1102 | #ifdef CONFIG_PM |
@@ -1136,7 +1104,6 @@ static int sil24_pci_device_resume(struct pci_dev *pdev) | |||
1136 | { | 1104 | { |
1137 | struct ata_host *host = dev_get_drvdata(&pdev->dev); | 1105 | struct ata_host *host = dev_get_drvdata(&pdev->dev); |
1138 | void __iomem *host_base = host->iomap[SIL24_HOST_BAR]; | 1106 | void __iomem *host_base = host->iomap[SIL24_HOST_BAR]; |
1139 | void __iomem *port_base = host->iomap[SIL24_PORT_BAR]; | ||
1140 | int rc; | 1107 | int rc; |
1141 | 1108 | ||
1142 | rc = ata_pci_device_do_resume(pdev); | 1109 | rc = ata_pci_device_do_resume(pdev); |
@@ -1146,8 +1113,7 @@ static int sil24_pci_device_resume(struct pci_dev *pdev) | |||
1146 | if (pdev->dev.power.power_state.event == PM_EVENT_SUSPEND) | 1113 | if (pdev->dev.power.power_state.event == PM_EVENT_SUSPEND) |
1147 | writel(HOST_CTRL_GLOBAL_RST, host_base + HOST_CTRL); | 1114 | writel(HOST_CTRL_GLOBAL_RST, host_base + HOST_CTRL); |
1148 | 1115 | ||
1149 | sil24_init_controller(pdev, host->n_ports, host->ports[0]->flags, | 1116 | sil24_init_controller(host); |
1150 | host_base, port_base); | ||
1151 | 1117 | ||
1152 | ata_host_resume(host); | 1118 | ata_host_resume(host); |
1153 | 1119 | ||
diff --git a/drivers/ata/sata_sis.c b/drivers/ata/sata_sis.c index a787f0d4a5b..d8ee062e82f 100644 --- a/drivers/ata/sata_sis.c +++ b/drivers/ata/sata_sis.c | |||
@@ -121,7 +121,6 @@ static const struct ata_port_operations sis_ops = { | |||
121 | .thaw = ata_bmdma_thaw, | 121 | .thaw = ata_bmdma_thaw, |
122 | .error_handler = ata_bmdma_error_handler, | 122 | .error_handler = ata_bmdma_error_handler, |
123 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 123 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
124 | .irq_handler = ata_interrupt, | ||
125 | .irq_clear = ata_bmdma_irq_clear, | 124 | .irq_clear = ata_bmdma_irq_clear, |
126 | .irq_on = ata_irq_on, | 125 | .irq_on = ata_irq_on, |
127 | .irq_ack = ata_irq_ack, | 126 | .irq_ack = ata_irq_ack, |
@@ -131,7 +130,6 @@ static const struct ata_port_operations sis_ops = { | |||
131 | }; | 130 | }; |
132 | 131 | ||
133 | static struct ata_port_info sis_port_info = { | 132 | static struct ata_port_info sis_port_info = { |
134 | .sht = &sis_sht, | ||
135 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY, | 133 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY, |
136 | .pio_mask = 0x1f, | 134 | .pio_mask = 0x1f, |
137 | .mwdma_mask = 0x7, | 135 | .mwdma_mask = 0x7, |
@@ -256,12 +254,13 @@ static void sis_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val) | |||
256 | static int sis_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 254 | static int sis_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
257 | { | 255 | { |
258 | static int printed_version; | 256 | static int printed_version; |
259 | struct ata_probe_ent *probe_ent = NULL; | 257 | struct ata_port_info pi = sis_port_info; |
260 | int rc; | 258 | const struct ata_port_info *ppi[2] = { &pi, &pi }; |
259 | struct ata_host *host; | ||
261 | u32 genctl, val; | 260 | u32 genctl, val; |
262 | struct ata_port_info pi = sis_port_info, *ppi[2] = { &pi, &pi }; | ||
263 | u8 pmr; | 261 | u8 pmr; |
264 | u8 port2_start = 0x20; | 262 | u8 port2_start = 0x20; |
263 | int rc; | ||
265 | 264 | ||
266 | if (!printed_version++) | 265 | if (!printed_version++) |
267 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); | 266 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); |
@@ -270,19 +269,6 @@ static int sis_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
270 | if (rc) | 269 | if (rc) |
271 | return rc; | 270 | return rc; |
272 | 271 | ||
273 | rc = pci_request_regions(pdev, DRV_NAME); | ||
274 | if (rc) { | ||
275 | pcim_pin_device(pdev); | ||
276 | return rc; | ||
277 | } | ||
278 | |||
279 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | ||
280 | if (rc) | ||
281 | return rc; | ||
282 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | ||
283 | if (rc) | ||
284 | return rc; | ||
285 | |||
286 | /* check and see if the SCRs are in IO space or PCI cfg space */ | 272 | /* check and see if the SCRs are in IO space or PCI cfg space */ |
287 | pci_read_config_dword(pdev, SIS_GENCTL, &genctl); | 273 | pci_read_config_dword(pdev, SIS_GENCTL, &genctl); |
288 | if ((genctl & GENCTL_IOMAPPED_SCR) == 0) | 274 | if ((genctl & GENCTL_IOMAPPED_SCR) == 0) |
@@ -349,30 +335,26 @@ static int sis_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
349 | break; | 335 | break; |
350 | } | 336 | } |
351 | 337 | ||
352 | probe_ent = ata_pci_init_native_mode(pdev, ppi, ATA_PORT_PRIMARY | ATA_PORT_SECONDARY); | 338 | rc = ata_pci_prepare_native_host(pdev, ppi, 2, &host); |
353 | if (!probe_ent) | 339 | if (rc) |
354 | return -ENOMEM; | 340 | return rc; |
355 | 341 | ||
356 | if (!(probe_ent->port_flags & SIS_FLAG_CFGSCR)) { | 342 | if (!(pi.flags & SIS_FLAG_CFGSCR)) { |
357 | void __iomem *mmio; | 343 | void __iomem *mmio; |
358 | 344 | ||
359 | mmio = pcim_iomap(pdev, SIS_SCR_PCI_BAR, 0); | 345 | rc = pcim_iomap_regions(pdev, 1 << SIS_SCR_PCI_BAR, DRV_NAME); |
360 | if (!mmio) | 346 | if (rc) |
361 | return -ENOMEM; | 347 | return rc; |
348 | mmio = host->iomap[SIS_SCR_PCI_BAR]; | ||
362 | 349 | ||
363 | probe_ent->port[0].scr_addr = mmio; | 350 | host->ports[0]->ioaddr.scr_addr = mmio; |
364 | probe_ent->port[1].scr_addr = mmio + port2_start; | 351 | host->ports[1]->ioaddr.scr_addr = mmio + port2_start; |
365 | } | 352 | } |
366 | 353 | ||
367 | pci_set_master(pdev); | 354 | pci_set_master(pdev); |
368 | pci_intx(pdev, 1); | 355 | pci_intx(pdev, 1); |
369 | 356 | return ata_host_activate(host, pdev->irq, ata_interrupt, IRQF_SHARED, | |
370 | if (!ata_device_add(probe_ent)) | 357 | &sis_sht); |
371 | return -EIO; | ||
372 | |||
373 | devm_kfree(&pdev->dev, probe_ent); | ||
374 | return 0; | ||
375 | |||
376 | } | 358 | } |
377 | 359 | ||
378 | static int __init sis_init(void) | 360 | static int __init sis_init(void) |
diff --git a/drivers/ata/sata_svw.c b/drivers/ata/sata_svw.c index b121195cc59..cc07aac10e8 100644 --- a/drivers/ata/sata_svw.c +++ b/drivers/ata/sata_svw.c | |||
@@ -56,7 +56,9 @@ | |||
56 | #define DRV_VERSION "2.1" | 56 | #define DRV_VERSION "2.1" |
57 | 57 | ||
58 | enum { | 58 | enum { |
59 | K2_FLAG_NO_ATAPI_DMA = (1 << 29), | 59 | /* ap->flags bits */ |
60 | K2_FLAG_SATA_8_PORTS = (1 << 24), | ||
61 | K2_FLAG_NO_ATAPI_DMA = (1 << 25), | ||
60 | 62 | ||
61 | /* Taskfile registers offsets */ | 63 | /* Taskfile registers offsets */ |
62 | K2_SATA_TF_CMD_OFFSET = 0x00, | 64 | K2_SATA_TF_CMD_OFFSET = 0x00, |
@@ -90,17 +92,6 @@ enum { | |||
90 | board_svw8 = 1, | 92 | board_svw8 = 1, |
91 | }; | 93 | }; |
92 | 94 | ||
93 | static const struct k2_board_info { | ||
94 | unsigned int n_ports; | ||
95 | unsigned long port_flags; | ||
96 | } k2_board_info[] = { | ||
97 | /* board_svw4 */ | ||
98 | { 4, K2_FLAG_NO_ATAPI_DMA }, | ||
99 | |||
100 | /* board_svw8 */ | ||
101 | { 8, K2_FLAG_NO_ATAPI_DMA }, | ||
102 | }; | ||
103 | |||
104 | static u8 k2_stat_check_status(struct ata_port *ap); | 95 | static u8 k2_stat_check_status(struct ata_port *ap); |
105 | 96 | ||
106 | 97 | ||
@@ -354,7 +345,6 @@ static const struct ata_port_operations k2_sata_ops = { | |||
354 | .thaw = ata_bmdma_thaw, | 345 | .thaw = ata_bmdma_thaw, |
355 | .error_handler = ata_bmdma_error_handler, | 346 | .error_handler = ata_bmdma_error_handler, |
356 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 347 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
357 | .irq_handler = ata_interrupt, | ||
358 | .irq_clear = ata_bmdma_irq_clear, | 348 | .irq_clear = ata_bmdma_irq_clear, |
359 | .irq_on = ata_irq_on, | 349 | .irq_on = ata_irq_on, |
360 | .irq_ack = ata_irq_ack, | 350 | .irq_ack = ata_irq_ack, |
@@ -363,6 +353,28 @@ static const struct ata_port_operations k2_sata_ops = { | |||
363 | .port_start = ata_port_start, | 353 | .port_start = ata_port_start, |
364 | }; | 354 | }; |
365 | 355 | ||
356 | static const struct ata_port_info k2_port_info[] = { | ||
357 | /* board_svw4 */ | ||
358 | { | ||
359 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
360 | ATA_FLAG_MMIO | K2_FLAG_NO_ATAPI_DMA, | ||
361 | .pio_mask = 0x1f, | ||
362 | .mwdma_mask = 0x07, | ||
363 | .udma_mask = 0x7f, | ||
364 | .port_ops = &k2_sata_ops, | ||
365 | }, | ||
366 | /* board_svw8 */ | ||
367 | { | ||
368 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
369 | ATA_FLAG_MMIO | K2_FLAG_NO_ATAPI_DMA | | ||
370 | K2_FLAG_SATA_8_PORTS, | ||
371 | .pio_mask = 0x1f, | ||
372 | .mwdma_mask = 0x07, | ||
373 | .udma_mask = 0x7f, | ||
374 | .port_ops = &k2_sata_ops, | ||
375 | }, | ||
376 | }; | ||
377 | |||
366 | static void k2_sata_setup_port(struct ata_ioports *port, void __iomem *base) | 378 | static void k2_sata_setup_port(struct ata_ioports *port, void __iomem *base) |
367 | { | 379 | { |
368 | port->cmd_addr = base + K2_SATA_TF_CMD_OFFSET; | 380 | port->cmd_addr = base + K2_SATA_TF_CMD_OFFSET; |
@@ -386,17 +398,24 @@ static void k2_sata_setup_port(struct ata_ioports *port, void __iomem *base) | |||
386 | static int k2_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 398 | static int k2_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
387 | { | 399 | { |
388 | static int printed_version; | 400 | static int printed_version; |
389 | struct device *dev = &pdev->dev; | 401 | const struct ata_port_info *ppi[] = |
390 | struct ata_probe_ent *probe_ent; | 402 | { &k2_port_info[ent->driver_data], NULL }; |
403 | struct ata_host *host; | ||
391 | void __iomem *mmio_base; | 404 | void __iomem *mmio_base; |
392 | const struct k2_board_info *board_info = | 405 | int n_ports, i, rc; |
393 | &k2_board_info[ent->driver_data]; | ||
394 | int rc; | ||
395 | int i; | ||
396 | 406 | ||
397 | if (!printed_version++) | 407 | if (!printed_version++) |
398 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 408 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
399 | 409 | ||
410 | /* allocate host */ | ||
411 | n_ports = 4; | ||
412 | if (ppi[0]->flags & K2_FLAG_SATA_8_PORTS) | ||
413 | n_ports = 8; | ||
414 | |||
415 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, n_ports); | ||
416 | if (!host) | ||
417 | return -ENOMEM; | ||
418 | |||
400 | /* | 419 | /* |
401 | * If this driver happens to only be useful on Apple's K2, then | 420 | * If this driver happens to only be useful on Apple's K2, then |
402 | * we should check that here as it has a normal Serverworks ID | 421 | * we should check that here as it has a normal Serverworks ID |
@@ -404,6 +423,7 @@ static int k2_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *e | |||
404 | rc = pcim_enable_device(pdev); | 423 | rc = pcim_enable_device(pdev); |
405 | if (rc) | 424 | if (rc) |
406 | return rc; | 425 | return rc; |
426 | |||
407 | /* | 427 | /* |
408 | * Check if we have resources mapped at all (second function may | 428 | * Check if we have resources mapped at all (second function may |
409 | * have been disabled by firmware) | 429 | * have been disabled by firmware) |
@@ -417,6 +437,15 @@ static int k2_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *e | |||
417 | pcim_pin_device(pdev); | 437 | pcim_pin_device(pdev); |
418 | if (rc) | 438 | if (rc) |
419 | return rc; | 439 | return rc; |
440 | host->iomap = pcim_iomap_table(pdev); | ||
441 | mmio_base = host->iomap[5]; | ||
442 | |||
443 | /* different controllers have different number of ports - currently 4 or 8 */ | ||
444 | /* All ports are on the same function. Multi-function device is no | ||
445 | * longer available. This should not be seen in any system. */ | ||
446 | for (i = 0; i < host->n_ports; i++) | ||
447 | k2_sata_setup_port(&host->ports[i]->ioaddr, | ||
448 | mmio_base + i * K2_SATA_PORT_OFFSET); | ||
420 | 449 | ||
421 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | 450 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); |
422 | if (rc) | 451 | if (rc) |
@@ -425,38 +454,6 @@ static int k2_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *e | |||
425 | if (rc) | 454 | if (rc) |
426 | return rc; | 455 | return rc; |
427 | 456 | ||
428 | probe_ent = devm_kzalloc(dev, sizeof(*probe_ent), GFP_KERNEL); | ||
429 | if (probe_ent == NULL) | ||
430 | return -ENOMEM; | ||
431 | |||
432 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
433 | INIT_LIST_HEAD(&probe_ent->node); | ||
434 | |||
435 | probe_ent->sht = &k2_sata_sht; | ||
436 | probe_ent->port_flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
437 | ATA_FLAG_MMIO | board_info->port_flags; | ||
438 | probe_ent->port_ops = &k2_sata_ops; | ||
439 | probe_ent->n_ports = 4; | ||
440 | probe_ent->irq = pdev->irq; | ||
441 | probe_ent->irq_flags = IRQF_SHARED; | ||
442 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
443 | |||
444 | /* We don't care much about the PIO/UDMA masks, but the core won't like us | ||
445 | * if we don't fill these | ||
446 | */ | ||
447 | probe_ent->pio_mask = 0x1f; | ||
448 | probe_ent->mwdma_mask = 0x7; | ||
449 | probe_ent->udma_mask = 0x7f; | ||
450 | |||
451 | mmio_base = probe_ent->iomap[5]; | ||
452 | |||
453 | /* different controllers have different number of ports - currently 4 or 8 */ | ||
454 | /* All ports are on the same function. Multi-function device is no | ||
455 | * longer available. This should not be seen in any system. */ | ||
456 | for (i = 0; i < board_info->n_ports; i++) | ||
457 | k2_sata_setup_port(&probe_ent->port[i], | ||
458 | mmio_base + i * K2_SATA_PORT_OFFSET); | ||
459 | |||
460 | /* Clear a magic bit in SCR1 according to Darwin, those help | 457 | /* Clear a magic bit in SCR1 according to Darwin, those help |
461 | * some funky seagate drives (though so far, those were already | 458 | * some funky seagate drives (though so far, those were already |
462 | * set by the firmware on the machines I had access to) | 459 | * set by the firmware on the machines I had access to) |
@@ -469,12 +466,8 @@ static int k2_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *e | |||
469 | writel(0x0, mmio_base + K2_SATA_SIM_OFFSET); | 466 | writel(0x0, mmio_base + K2_SATA_SIM_OFFSET); |
470 | 467 | ||
471 | pci_set_master(pdev); | 468 | pci_set_master(pdev); |
472 | 469 | return ata_host_activate(host, pdev->irq, ata_interrupt, IRQF_SHARED, | |
473 | if (!ata_device_add(probe_ent)) | 470 | &k2_sata_sht); |
474 | return -ENODEV; | ||
475 | |||
476 | devm_kfree(dev, probe_ent); | ||
477 | return 0; | ||
478 | } | 471 | } |
479 | 472 | ||
480 | /* 0x240 is device ID for Apple K2 device | 473 | /* 0x240 is device ID for Apple K2 device |
diff --git a/drivers/ata/sata_sx4.c b/drivers/ata/sata_sx4.c index 1a081c3a8c0..3a4f44559d0 100644 --- a/drivers/ata/sata_sx4.c +++ b/drivers/ata/sata_sx4.c | |||
@@ -151,24 +151,23 @@ struct pdc_host_priv { | |||
151 | 151 | ||
152 | 152 | ||
153 | static int pdc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); | 153 | static int pdc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent); |
154 | static irqreturn_t pdc20621_interrupt (int irq, void *dev_instance); | ||
155 | static void pdc_eng_timeout(struct ata_port *ap); | 154 | static void pdc_eng_timeout(struct ata_port *ap); |
156 | static void pdc_20621_phy_reset (struct ata_port *ap); | 155 | static void pdc_20621_phy_reset (struct ata_port *ap); |
157 | static int pdc_port_start(struct ata_port *ap); | 156 | static int pdc_port_start(struct ata_port *ap); |
158 | static void pdc20621_qc_prep(struct ata_queued_cmd *qc); | 157 | static void pdc20621_qc_prep(struct ata_queued_cmd *qc); |
159 | static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf); | 158 | static void pdc_tf_load_mmio(struct ata_port *ap, const struct ata_taskfile *tf); |
160 | static void pdc_exec_command_mmio(struct ata_port *ap, const struct ata_taskfile *tf); | 159 | static void pdc_exec_command_mmio(struct ata_port *ap, const struct ata_taskfile *tf); |
161 | static unsigned int pdc20621_dimm_init(struct ata_probe_ent *pe); | 160 | static unsigned int pdc20621_dimm_init(struct ata_host *host); |
162 | static int pdc20621_detect_dimm(struct ata_probe_ent *pe); | 161 | static int pdc20621_detect_dimm(struct ata_host *host); |
163 | static unsigned int pdc20621_i2c_read(struct ata_probe_ent *pe, | 162 | static unsigned int pdc20621_i2c_read(struct ata_host *host, |
164 | u32 device, u32 subaddr, u32 *pdata); | 163 | u32 device, u32 subaddr, u32 *pdata); |
165 | static int pdc20621_prog_dimm0(struct ata_probe_ent *pe); | 164 | static int pdc20621_prog_dimm0(struct ata_host *host); |
166 | static unsigned int pdc20621_prog_dimm_global(struct ata_probe_ent *pe); | 165 | static unsigned int pdc20621_prog_dimm_global(struct ata_host *host); |
167 | #ifdef ATA_VERBOSE_DEBUG | 166 | #ifdef ATA_VERBOSE_DEBUG |
168 | static void pdc20621_get_from_dimm(struct ata_probe_ent *pe, | 167 | static void pdc20621_get_from_dimm(struct ata_host *host, |
169 | void *psource, u32 offset, u32 size); | 168 | void *psource, u32 offset, u32 size); |
170 | #endif | 169 | #endif |
171 | static void pdc20621_put_to_dimm(struct ata_probe_ent *pe, | 170 | static void pdc20621_put_to_dimm(struct ata_host *host, |
172 | void *psource, u32 offset, u32 size); | 171 | void *psource, u32 offset, u32 size); |
173 | static void pdc20621_irq_clear(struct ata_port *ap); | 172 | static void pdc20621_irq_clear(struct ata_port *ap); |
174 | static unsigned int pdc20621_qc_issue_prot(struct ata_queued_cmd *qc); | 173 | static unsigned int pdc20621_qc_issue_prot(struct ata_queued_cmd *qc); |
@@ -204,7 +203,6 @@ static const struct ata_port_operations pdc_20621_ops = { | |||
204 | .qc_issue = pdc20621_qc_issue_prot, | 203 | .qc_issue = pdc20621_qc_issue_prot, |
205 | .data_xfer = ata_data_xfer, | 204 | .data_xfer = ata_data_xfer, |
206 | .eng_timeout = pdc_eng_timeout, | 205 | .eng_timeout = pdc_eng_timeout, |
207 | .irq_handler = pdc20621_interrupt, | ||
208 | .irq_clear = pdc20621_irq_clear, | 206 | .irq_clear = pdc20621_irq_clear, |
209 | .irq_on = ata_irq_on, | 207 | .irq_on = ata_irq_on, |
210 | .irq_ack = ata_irq_ack, | 208 | .irq_ack = ata_irq_ack, |
@@ -214,7 +212,6 @@ static const struct ata_port_operations pdc_20621_ops = { | |||
214 | static const struct ata_port_info pdc_port_info[] = { | 212 | static const struct ata_port_info pdc_port_info[] = { |
215 | /* board_20621 */ | 213 | /* board_20621 */ |
216 | { | 214 | { |
217 | .sht = &pdc_sata_sht, | ||
218 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | 215 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | |
219 | ATA_FLAG_SRST | ATA_FLAG_MMIO | | 216 | ATA_FLAG_SRST | ATA_FLAG_MMIO | |
220 | ATA_FLAG_NO_ATAPI | ATA_FLAG_PIO_POLLING, | 217 | ATA_FLAG_NO_ATAPI | ATA_FLAG_PIO_POLLING, |
@@ -882,15 +879,15 @@ static void pdc_sata_setup_port(struct ata_ioports *port, void __iomem *base) | |||
882 | 879 | ||
883 | 880 | ||
884 | #ifdef ATA_VERBOSE_DEBUG | 881 | #ifdef ATA_VERBOSE_DEBUG |
885 | static void pdc20621_get_from_dimm(struct ata_probe_ent *pe, void *psource, | 882 | static void pdc20621_get_from_dimm(struct ata_host *host, void *psource, |
886 | u32 offset, u32 size) | 883 | u32 offset, u32 size) |
887 | { | 884 | { |
888 | u32 window_size; | 885 | u32 window_size; |
889 | u16 idx; | 886 | u16 idx; |
890 | u8 page_mask; | 887 | u8 page_mask; |
891 | long dist; | 888 | long dist; |
892 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 889 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
893 | void __iomem *dimm_mmio = pe->iomap[PDC_DIMM_BAR]; | 890 | void __iomem *dimm_mmio = host->iomap[PDC_DIMM_BAR]; |
894 | 891 | ||
895 | /* hard-code chip #0 */ | 892 | /* hard-code chip #0 */ |
896 | mmio += PDC_CHIP0_OFS; | 893 | mmio += PDC_CHIP0_OFS; |
@@ -937,15 +934,15 @@ static void pdc20621_get_from_dimm(struct ata_probe_ent *pe, void *psource, | |||
937 | #endif | 934 | #endif |
938 | 935 | ||
939 | 936 | ||
940 | static void pdc20621_put_to_dimm(struct ata_probe_ent *pe, void *psource, | 937 | static void pdc20621_put_to_dimm(struct ata_host *host, void *psource, |
941 | u32 offset, u32 size) | 938 | u32 offset, u32 size) |
942 | { | 939 | { |
943 | u32 window_size; | 940 | u32 window_size; |
944 | u16 idx; | 941 | u16 idx; |
945 | u8 page_mask; | 942 | u8 page_mask; |
946 | long dist; | 943 | long dist; |
947 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 944 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
948 | void __iomem *dimm_mmio = pe->iomap[PDC_DIMM_BAR]; | 945 | void __iomem *dimm_mmio = host->iomap[PDC_DIMM_BAR]; |
949 | 946 | ||
950 | /* hard-code chip #0 */ | 947 | /* hard-code chip #0 */ |
951 | mmio += PDC_CHIP0_OFS; | 948 | mmio += PDC_CHIP0_OFS; |
@@ -987,10 +984,10 @@ static void pdc20621_put_to_dimm(struct ata_probe_ent *pe, void *psource, | |||
987 | } | 984 | } |
988 | 985 | ||
989 | 986 | ||
990 | static unsigned int pdc20621_i2c_read(struct ata_probe_ent *pe, u32 device, | 987 | static unsigned int pdc20621_i2c_read(struct ata_host *host, u32 device, |
991 | u32 subaddr, u32 *pdata) | 988 | u32 subaddr, u32 *pdata) |
992 | { | 989 | { |
993 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 990 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
994 | u32 i2creg = 0; | 991 | u32 i2creg = 0; |
995 | u32 status; | 992 | u32 status; |
996 | u32 count =0; | 993 | u32 count =0; |
@@ -1023,17 +1020,17 @@ static unsigned int pdc20621_i2c_read(struct ata_probe_ent *pe, u32 device, | |||
1023 | } | 1020 | } |
1024 | 1021 | ||
1025 | 1022 | ||
1026 | static int pdc20621_detect_dimm(struct ata_probe_ent *pe) | 1023 | static int pdc20621_detect_dimm(struct ata_host *host) |
1027 | { | 1024 | { |
1028 | u32 data=0 ; | 1025 | u32 data=0 ; |
1029 | if (pdc20621_i2c_read(pe, PDC_DIMM0_SPD_DEV_ADDRESS, | 1026 | if (pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS, |
1030 | PDC_DIMM_SPD_SYSTEM_FREQ, &data)) { | 1027 | PDC_DIMM_SPD_SYSTEM_FREQ, &data)) { |
1031 | if (data == 100) | 1028 | if (data == 100) |
1032 | return 100; | 1029 | return 100; |
1033 | } else | 1030 | } else |
1034 | return 0; | 1031 | return 0; |
1035 | 1032 | ||
1036 | if (pdc20621_i2c_read(pe, PDC_DIMM0_SPD_DEV_ADDRESS, 9, &data)) { | 1033 | if (pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS, 9, &data)) { |
1037 | if(data <= 0x75) | 1034 | if(data <= 0x75) |
1038 | return 133; | 1035 | return 133; |
1039 | } else | 1036 | } else |
@@ -1043,13 +1040,13 @@ static int pdc20621_detect_dimm(struct ata_probe_ent *pe) | |||
1043 | } | 1040 | } |
1044 | 1041 | ||
1045 | 1042 | ||
1046 | static int pdc20621_prog_dimm0(struct ata_probe_ent *pe) | 1043 | static int pdc20621_prog_dimm0(struct ata_host *host) |
1047 | { | 1044 | { |
1048 | u32 spd0[50]; | 1045 | u32 spd0[50]; |
1049 | u32 data = 0; | 1046 | u32 data = 0; |
1050 | int size, i; | 1047 | int size, i; |
1051 | u8 bdimmsize; | 1048 | u8 bdimmsize; |
1052 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 1049 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
1053 | static const struct { | 1050 | static const struct { |
1054 | unsigned int reg; | 1051 | unsigned int reg; |
1055 | unsigned int ofs; | 1052 | unsigned int ofs; |
@@ -1072,7 +1069,7 @@ static int pdc20621_prog_dimm0(struct ata_probe_ent *pe) | |||
1072 | mmio += PDC_CHIP0_OFS; | 1069 | mmio += PDC_CHIP0_OFS; |
1073 | 1070 | ||
1074 | for(i=0; i<ARRAY_SIZE(pdc_i2c_read_data); i++) | 1071 | for(i=0; i<ARRAY_SIZE(pdc_i2c_read_data); i++) |
1075 | pdc20621_i2c_read(pe, PDC_DIMM0_SPD_DEV_ADDRESS, | 1072 | pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS, |
1076 | pdc_i2c_read_data[i].reg, | 1073 | pdc_i2c_read_data[i].reg, |
1077 | &spd0[pdc_i2c_read_data[i].ofs]); | 1074 | &spd0[pdc_i2c_read_data[i].ofs]); |
1078 | 1075 | ||
@@ -1108,11 +1105,11 @@ static int pdc20621_prog_dimm0(struct ata_probe_ent *pe) | |||
1108 | } | 1105 | } |
1109 | 1106 | ||
1110 | 1107 | ||
1111 | static unsigned int pdc20621_prog_dimm_global(struct ata_probe_ent *pe) | 1108 | static unsigned int pdc20621_prog_dimm_global(struct ata_host *host) |
1112 | { | 1109 | { |
1113 | u32 data, spd0; | 1110 | u32 data, spd0; |
1114 | int error, i; | 1111 | int error, i; |
1115 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 1112 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
1116 | 1113 | ||
1117 | /* hard-code chip #0 */ | 1114 | /* hard-code chip #0 */ |
1118 | mmio += PDC_CHIP0_OFS; | 1115 | mmio += PDC_CHIP0_OFS; |
@@ -1129,7 +1126,7 @@ static unsigned int pdc20621_prog_dimm_global(struct ata_probe_ent *pe) | |||
1129 | readl(mmio + PDC_SDRAM_CONTROL_OFFSET); | 1126 | readl(mmio + PDC_SDRAM_CONTROL_OFFSET); |
1130 | 1127 | ||
1131 | /* Turn on for ECC */ | 1128 | /* Turn on for ECC */ |
1132 | pdc20621_i2c_read(pe, PDC_DIMM0_SPD_DEV_ADDRESS, | 1129 | pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS, |
1133 | PDC_DIMM_SPD_TYPE, &spd0); | 1130 | PDC_DIMM_SPD_TYPE, &spd0); |
1134 | if (spd0 == 0x02) { | 1131 | if (spd0 == 0x02) { |
1135 | data |= (0x01 << 16); | 1132 | data |= (0x01 << 16); |
@@ -1156,7 +1153,7 @@ static unsigned int pdc20621_prog_dimm_global(struct ata_probe_ent *pe) | |||
1156 | } | 1153 | } |
1157 | 1154 | ||
1158 | 1155 | ||
1159 | static unsigned int pdc20621_dimm_init(struct ata_probe_ent *pe) | 1156 | static unsigned int pdc20621_dimm_init(struct ata_host *host) |
1160 | { | 1157 | { |
1161 | int speed, size, length; | 1158 | int speed, size, length; |
1162 | u32 addr,spd0,pci_status; | 1159 | u32 addr,spd0,pci_status; |
@@ -1166,7 +1163,7 @@ static unsigned int pdc20621_dimm_init(struct ata_probe_ent *pe) | |||
1166 | u32 ticks=0; | 1163 | u32 ticks=0; |
1167 | u32 clock=0; | 1164 | u32 clock=0; |
1168 | u32 fparam=0; | 1165 | u32 fparam=0; |
1169 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 1166 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
1170 | 1167 | ||
1171 | /* hard-code chip #0 */ | 1168 | /* hard-code chip #0 */ |
1172 | mmio += PDC_CHIP0_OFS; | 1169 | mmio += PDC_CHIP0_OFS; |
@@ -1225,18 +1222,18 @@ static unsigned int pdc20621_dimm_init(struct ata_probe_ent *pe) | |||
1225 | Read SPD of DIMM by I2C interface, | 1222 | Read SPD of DIMM by I2C interface, |
1226 | and program the DIMM Module Controller. | 1223 | and program the DIMM Module Controller. |
1227 | */ | 1224 | */ |
1228 | if (!(speed = pdc20621_detect_dimm(pe))) { | 1225 | if (!(speed = pdc20621_detect_dimm(host))) { |
1229 | printk(KERN_ERR "Detect Local DIMM Fail\n"); | 1226 | printk(KERN_ERR "Detect Local DIMM Fail\n"); |
1230 | return 1; /* DIMM error */ | 1227 | return 1; /* DIMM error */ |
1231 | } | 1228 | } |
1232 | VPRINTK("Local DIMM Speed = %d\n", speed); | 1229 | VPRINTK("Local DIMM Speed = %d\n", speed); |
1233 | 1230 | ||
1234 | /* Programming DIMM0 Module Control Register (index_CID0:80h) */ | 1231 | /* Programming DIMM0 Module Control Register (index_CID0:80h) */ |
1235 | size = pdc20621_prog_dimm0(pe); | 1232 | size = pdc20621_prog_dimm0(host); |
1236 | VPRINTK("Local DIMM Size = %dMB\n",size); | 1233 | VPRINTK("Local DIMM Size = %dMB\n",size); |
1237 | 1234 | ||
1238 | /* Programming DIMM Module Global Control Register (index_CID0:88h) */ | 1235 | /* Programming DIMM Module Global Control Register (index_CID0:88h) */ |
1239 | if (pdc20621_prog_dimm_global(pe)) { | 1236 | if (pdc20621_prog_dimm_global(host)) { |
1240 | printk(KERN_ERR "Programming DIMM Module Global Control Register Fail\n"); | 1237 | printk(KERN_ERR "Programming DIMM Module Global Control Register Fail\n"); |
1241 | return 1; | 1238 | return 1; |
1242 | } | 1239 | } |
@@ -1249,20 +1246,20 @@ static unsigned int pdc20621_dimm_init(struct ata_probe_ent *pe) | |||
1249 | '9','8','0','3','1','6','1','2',0,0}; | 1246 | '9','8','0','3','1','6','1','2',0,0}; |
1250 | u8 test_parttern2[40] = {0}; | 1247 | u8 test_parttern2[40] = {0}; |
1251 | 1248 | ||
1252 | pdc20621_put_to_dimm(pe, (void *) test_parttern2, 0x10040, 40); | 1249 | pdc20621_put_to_dimm(host, (void *) test_parttern2, 0x10040, 40); |
1253 | pdc20621_put_to_dimm(pe, (void *) test_parttern2, 0x40, 40); | 1250 | pdc20621_put_to_dimm(host, (void *) test_parttern2, 0x40, 40); |
1254 | 1251 | ||
1255 | pdc20621_put_to_dimm(pe, (void *) test_parttern1, 0x10040, 40); | 1252 | pdc20621_put_to_dimm(host, (void *) test_parttern1, 0x10040, 40); |
1256 | pdc20621_get_from_dimm(pe, (void *) test_parttern2, 0x40, 40); | 1253 | pdc20621_get_from_dimm(host, (void *) test_parttern2, 0x40, 40); |
1257 | printk(KERN_ERR "%x, %x, %s\n", test_parttern2[0], | 1254 | printk(KERN_ERR "%x, %x, %s\n", test_parttern2[0], |
1258 | test_parttern2[1], &(test_parttern2[2])); | 1255 | test_parttern2[1], &(test_parttern2[2])); |
1259 | pdc20621_get_from_dimm(pe, (void *) test_parttern2, 0x10040, | 1256 | pdc20621_get_from_dimm(host, (void *) test_parttern2, 0x10040, |
1260 | 40); | 1257 | 40); |
1261 | printk(KERN_ERR "%x, %x, %s\n", test_parttern2[0], | 1258 | printk(KERN_ERR "%x, %x, %s\n", test_parttern2[0], |
1262 | test_parttern2[1], &(test_parttern2[2])); | 1259 | test_parttern2[1], &(test_parttern2[2])); |
1263 | 1260 | ||
1264 | pdc20621_put_to_dimm(pe, (void *) test_parttern1, 0x40, 40); | 1261 | pdc20621_put_to_dimm(host, (void *) test_parttern1, 0x40, 40); |
1265 | pdc20621_get_from_dimm(pe, (void *) test_parttern2, 0x40, 40); | 1262 | pdc20621_get_from_dimm(host, (void *) test_parttern2, 0x40, 40); |
1266 | printk(KERN_ERR "%x, %x, %s\n", test_parttern2[0], | 1263 | printk(KERN_ERR "%x, %x, %s\n", test_parttern2[0], |
1267 | test_parttern2[1], &(test_parttern2[2])); | 1264 | test_parttern2[1], &(test_parttern2[2])); |
1268 | } | 1265 | } |
@@ -1270,14 +1267,14 @@ static unsigned int pdc20621_dimm_init(struct ata_probe_ent *pe) | |||
1270 | 1267 | ||
1271 | /* ECC initiliazation. */ | 1268 | /* ECC initiliazation. */ |
1272 | 1269 | ||
1273 | pdc20621_i2c_read(pe, PDC_DIMM0_SPD_DEV_ADDRESS, | 1270 | pdc20621_i2c_read(host, PDC_DIMM0_SPD_DEV_ADDRESS, |
1274 | PDC_DIMM_SPD_TYPE, &spd0); | 1271 | PDC_DIMM_SPD_TYPE, &spd0); |
1275 | if (spd0 == 0x02) { | 1272 | if (spd0 == 0x02) { |
1276 | VPRINTK("Start ECC initialization\n"); | 1273 | VPRINTK("Start ECC initialization\n"); |
1277 | addr = 0; | 1274 | addr = 0; |
1278 | length = size * 1024 * 1024; | 1275 | length = size * 1024 * 1024; |
1279 | while (addr < length) { | 1276 | while (addr < length) { |
1280 | pdc20621_put_to_dimm(pe, (void *) &tmp, addr, | 1277 | pdc20621_put_to_dimm(host, (void *) &tmp, addr, |
1281 | sizeof(u32)); | 1278 | sizeof(u32)); |
1282 | addr += sizeof(u32); | 1279 | addr += sizeof(u32); |
1283 | } | 1280 | } |
@@ -1287,10 +1284,10 @@ static unsigned int pdc20621_dimm_init(struct ata_probe_ent *pe) | |||
1287 | } | 1284 | } |
1288 | 1285 | ||
1289 | 1286 | ||
1290 | static void pdc_20621_init(struct ata_probe_ent *pe) | 1287 | static void pdc_20621_init(struct ata_host *host) |
1291 | { | 1288 | { |
1292 | u32 tmp; | 1289 | u32 tmp; |
1293 | void __iomem *mmio = pe->iomap[PDC_MMIO_BAR]; | 1290 | void __iomem *mmio = host->iomap[PDC_MMIO_BAR]; |
1294 | 1291 | ||
1295 | /* hard-code chip #0 */ | 1292 | /* hard-code chip #0 */ |
1296 | mmio += PDC_CHIP0_OFS; | 1293 | mmio += PDC_CHIP0_OFS; |
@@ -1321,15 +1318,25 @@ static void pdc_20621_init(struct ata_probe_ent *pe) | |||
1321 | static int pdc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 1318 | static int pdc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
1322 | { | 1319 | { |
1323 | static int printed_version; | 1320 | static int printed_version; |
1324 | struct ata_probe_ent *probe_ent; | 1321 | const struct ata_port_info *ppi[] = |
1322 | { &pdc_port_info[ent->driver_data], NULL }; | ||
1323 | struct ata_host *host; | ||
1325 | void __iomem *base; | 1324 | void __iomem *base; |
1326 | struct pdc_host_priv *hpriv; | 1325 | struct pdc_host_priv *hpriv; |
1327 | unsigned int board_idx = (unsigned int) ent->driver_data; | ||
1328 | int rc; | 1326 | int rc; |
1329 | 1327 | ||
1330 | if (!printed_version++) | 1328 | if (!printed_version++) |
1331 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 1329 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
1332 | 1330 | ||
1331 | /* allocate host */ | ||
1332 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, 4); | ||
1333 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); | ||
1334 | if (!host || !hpriv) | ||
1335 | return -ENOMEM; | ||
1336 | |||
1337 | host->private_data = hpriv; | ||
1338 | |||
1339 | /* acquire resources and fill host */ | ||
1333 | rc = pcim_enable_device(pdev); | 1340 | rc = pcim_enable_device(pdev); |
1334 | if (rc) | 1341 | if (rc) |
1335 | return rc; | 1342 | return rc; |
@@ -1340,7 +1347,15 @@ static int pdc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id * | |||
1340 | pcim_pin_device(pdev); | 1347 | pcim_pin_device(pdev); |
1341 | if (rc) | 1348 | if (rc) |
1342 | return rc; | 1349 | return rc; |
1350 | host->iomap = pcim_iomap_table(pdev); | ||
1351 | |||
1352 | base = host->iomap[PDC_MMIO_BAR] + PDC_CHIP0_OFS; | ||
1353 | pdc_sata_setup_port(&host->ports[0]->ioaddr, base + 0x200); | ||
1354 | pdc_sata_setup_port(&host->ports[1]->ioaddr, base + 0x280); | ||
1355 | pdc_sata_setup_port(&host->ports[2]->ioaddr, base + 0x300); | ||
1356 | pdc_sata_setup_port(&host->ports[3]->ioaddr, base + 0x380); | ||
1343 | 1357 | ||
1358 | /* configure and activate */ | ||
1344 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | 1359 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); |
1345 | if (rc) | 1360 | if (rc) |
1346 | return rc; | 1361 | return rc; |
@@ -1348,50 +1363,13 @@ static int pdc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id * | |||
1348 | if (rc) | 1363 | if (rc) |
1349 | return rc; | 1364 | return rc; |
1350 | 1365 | ||
1351 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | 1366 | if (pdc20621_dimm_init(host)) |
1352 | if (probe_ent == NULL) | ||
1353 | return -ENOMEM; | 1367 | return -ENOMEM; |
1354 | 1368 | pdc_20621_init(host); | |
1355 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
1356 | INIT_LIST_HEAD(&probe_ent->node); | ||
1357 | |||
1358 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); | ||
1359 | if (!hpriv) | ||
1360 | return -ENOMEM; | ||
1361 | |||
1362 | probe_ent->sht = pdc_port_info[board_idx].sht; | ||
1363 | probe_ent->port_flags = pdc_port_info[board_idx].flags; | ||
1364 | probe_ent->pio_mask = pdc_port_info[board_idx].pio_mask; | ||
1365 | probe_ent->mwdma_mask = pdc_port_info[board_idx].mwdma_mask; | ||
1366 | probe_ent->udma_mask = pdc_port_info[board_idx].udma_mask; | ||
1367 | probe_ent->port_ops = pdc_port_info[board_idx].port_ops; | ||
1368 | |||
1369 | probe_ent->irq = pdev->irq; | ||
1370 | probe_ent->irq_flags = IRQF_SHARED; | ||
1371 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
1372 | |||
1373 | probe_ent->private_data = hpriv; | ||
1374 | base = probe_ent->iomap[PDC_MMIO_BAR] + PDC_CHIP0_OFS; | ||
1375 | |||
1376 | probe_ent->n_ports = 4; | ||
1377 | pdc_sata_setup_port(&probe_ent->port[0], base + 0x200); | ||
1378 | pdc_sata_setup_port(&probe_ent->port[1], base + 0x280); | ||
1379 | pdc_sata_setup_port(&probe_ent->port[2], base + 0x300); | ||
1380 | pdc_sata_setup_port(&probe_ent->port[3], base + 0x380); | ||
1381 | 1369 | ||
1382 | pci_set_master(pdev); | 1370 | pci_set_master(pdev); |
1383 | 1371 | return ata_host_activate(host, pdev->irq, pdc20621_interrupt, | |
1384 | /* initialize adapter */ | 1372 | IRQF_SHARED, &pdc_sata_sht); |
1385 | /* initialize local dimm */ | ||
1386 | if (pdc20621_dimm_init(probe_ent)) | ||
1387 | return -ENOMEM; | ||
1388 | pdc_20621_init(probe_ent); | ||
1389 | |||
1390 | if (!ata_device_add(probe_ent)) | ||
1391 | return -ENODEV; | ||
1392 | |||
1393 | devm_kfree(&pdev->dev, probe_ent); | ||
1394 | return 0; | ||
1395 | } | 1373 | } |
1396 | 1374 | ||
1397 | 1375 | ||
diff --git a/drivers/ata/sata_uli.c b/drivers/ata/sata_uli.c index d659ace80f4..f74e383de08 100644 --- a/drivers/ata/sata_uli.c +++ b/drivers/ata/sata_uli.c | |||
@@ -115,7 +115,6 @@ static const struct ata_port_operations uli_ops = { | |||
115 | .error_handler = ata_bmdma_error_handler, | 115 | .error_handler = ata_bmdma_error_handler, |
116 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 116 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
117 | 117 | ||
118 | .irq_handler = ata_interrupt, | ||
119 | .irq_clear = ata_bmdma_irq_clear, | 118 | .irq_clear = ata_bmdma_irq_clear, |
120 | .irq_on = ata_irq_on, | 119 | .irq_on = ata_irq_on, |
121 | .irq_ack = ata_irq_ack, | 120 | .irq_ack = ata_irq_ack, |
@@ -127,7 +126,6 @@ static const struct ata_port_operations uli_ops = { | |||
127 | }; | 126 | }; |
128 | 127 | ||
129 | static struct ata_port_info uli_port_info = { | 128 | static struct ata_port_info uli_port_info = { |
130 | .sht = &uli_sht, | ||
131 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | 129 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | |
132 | ATA_FLAG_IGN_SIMPLEX, | 130 | ATA_FLAG_IGN_SIMPLEX, |
133 | .pio_mask = 0x1f, /* pio0-4 */ | 131 | .pio_mask = 0x1f, /* pio0-4 */ |
@@ -185,12 +183,13 @@ static void uli_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val) | |||
185 | static int uli_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 183 | static int uli_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
186 | { | 184 | { |
187 | static int printed_version; | 185 | static int printed_version; |
188 | struct ata_probe_ent *probe_ent; | 186 | const struct ata_port_info *ppi[] = { &uli_port_info, NULL }; |
189 | struct ata_port_info *ppi[2]; | ||
190 | int rc; | ||
191 | unsigned int board_idx = (unsigned int) ent->driver_data; | 187 | unsigned int board_idx = (unsigned int) ent->driver_data; |
188 | struct ata_host *host; | ||
192 | struct uli_priv *hpriv; | 189 | struct uli_priv *hpriv; |
193 | void __iomem * const *iomap; | 190 | void __iomem * const *iomap; |
191 | struct ata_ioports *ioaddr; | ||
192 | int n_ports, rc; | ||
194 | 193 | ||
195 | if (!printed_version++) | 194 | if (!printed_version++) |
196 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); | 195 | dev_printk(KERN_INFO, &pdev->dev, "version " DRV_VERSION "\n"); |
@@ -199,54 +198,42 @@ static int uli_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
199 | if (rc) | 198 | if (rc) |
200 | return rc; | 199 | return rc; |
201 | 200 | ||
202 | rc = pci_request_regions(pdev, DRV_NAME); | 201 | n_ports = 2; |
203 | if (rc) { | 202 | if (board_idx == uli_5287) |
204 | pcim_pin_device(pdev); | 203 | n_ports = 4; |
205 | return rc; | 204 | rc = ata_pci_prepare_native_host(pdev, ppi, n_ports, &host); |
206 | } | ||
207 | |||
208 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | ||
209 | if (rc) | ||
210 | return rc; | ||
211 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | ||
212 | if (rc) | 205 | if (rc) |
213 | return rc; | 206 | return rc; |
214 | 207 | ||
215 | ppi[0] = ppi[1] = &uli_port_info; | ||
216 | probe_ent = ata_pci_init_native_mode(pdev, ppi, ATA_PORT_PRIMARY | ATA_PORT_SECONDARY); | ||
217 | if (!probe_ent) | ||
218 | return -ENOMEM; | ||
219 | |||
220 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); | 208 | hpriv = devm_kzalloc(&pdev->dev, sizeof(*hpriv), GFP_KERNEL); |
221 | if (!hpriv) | 209 | if (!hpriv) |
222 | return -ENOMEM; | 210 | return -ENOMEM; |
211 | host->private_data = hpriv; | ||
223 | 212 | ||
224 | probe_ent->private_data = hpriv; | 213 | iomap = host->iomap; |
225 | |||
226 | iomap = pcim_iomap_table(pdev); | ||
227 | 214 | ||
228 | switch (board_idx) { | 215 | switch (board_idx) { |
229 | case uli_5287: | 216 | case uli_5287: |
230 | hpriv->scr_cfg_addr[0] = ULI5287_BASE; | 217 | hpriv->scr_cfg_addr[0] = ULI5287_BASE; |
231 | hpriv->scr_cfg_addr[1] = ULI5287_BASE + ULI5287_OFFS; | 218 | hpriv->scr_cfg_addr[1] = ULI5287_BASE + ULI5287_OFFS; |
232 | probe_ent->n_ports = 4; | ||
233 | 219 | ||
234 | probe_ent->port[2].cmd_addr = iomap[0] + 8; | 220 | ioaddr = &host->ports[2]->ioaddr; |
235 | probe_ent->port[2].altstatus_addr = | 221 | ioaddr->cmd_addr = iomap[0] + 8; |
236 | probe_ent->port[2].ctl_addr = (void __iomem *) | 222 | ioaddr->altstatus_addr = |
223 | ioaddr->ctl_addr = (void __iomem *) | ||
237 | ((unsigned long)iomap[1] | ATA_PCI_CTL_OFS) + 4; | 224 | ((unsigned long)iomap[1] | ATA_PCI_CTL_OFS) + 4; |
238 | probe_ent->port[2].bmdma_addr = iomap[4] + 16; | 225 | ioaddr->bmdma_addr = iomap[4] + 16; |
239 | hpriv->scr_cfg_addr[2] = ULI5287_BASE + ULI5287_OFFS*4; | 226 | hpriv->scr_cfg_addr[2] = ULI5287_BASE + ULI5287_OFFS*4; |
227 | ata_std_ports(ioaddr); | ||
240 | 228 | ||
241 | probe_ent->port[3].cmd_addr = iomap[2] + 8; | 229 | ioaddr = &host->ports[3]->ioaddr; |
242 | probe_ent->port[3].altstatus_addr = | 230 | ioaddr->cmd_addr = iomap[2] + 8; |
243 | probe_ent->port[3].ctl_addr = (void __iomem *) | 231 | ioaddr->altstatus_addr = |
232 | ioaddr->ctl_addr = (void __iomem *) | ||
244 | ((unsigned long)iomap[3] | ATA_PCI_CTL_OFS) + 4; | 233 | ((unsigned long)iomap[3] | ATA_PCI_CTL_OFS) + 4; |
245 | probe_ent->port[3].bmdma_addr = iomap[4] + 24; | 234 | ioaddr->bmdma_addr = iomap[4] + 24; |
246 | hpriv->scr_cfg_addr[3] = ULI5287_BASE + ULI5287_OFFS*5; | 235 | hpriv->scr_cfg_addr[3] = ULI5287_BASE + ULI5287_OFFS*5; |
247 | 236 | ata_std_ports(ioaddr); | |
248 | ata_std_ports(&probe_ent->port[2]); | ||
249 | ata_std_ports(&probe_ent->port[3]); | ||
250 | break; | 237 | break; |
251 | 238 | ||
252 | case uli_5289: | 239 | case uli_5289: |
@@ -266,12 +253,8 @@ static int uli_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
266 | 253 | ||
267 | pci_set_master(pdev); | 254 | pci_set_master(pdev); |
268 | pci_intx(pdev, 1); | 255 | pci_intx(pdev, 1); |
269 | 256 | return ata_host_activate(host, pdev->irq, ata_interrupt, IRQF_SHARED, | |
270 | if (!ata_device_add(probe_ent)) | 257 | &uli_sht); |
271 | return -ENODEV; | ||
272 | |||
273 | devm_kfree(&pdev->dev, probe_ent); | ||
274 | return 0; | ||
275 | } | 258 | } |
276 | 259 | ||
277 | static int __init uli_init(void) | 260 | static int __init uli_init(void) |
diff --git a/drivers/ata/sata_via.c b/drivers/ata/sata_via.c index 598e6a26a48..1d855f55f5f 100644 --- a/drivers/ata/sata_via.c +++ b/drivers/ata/sata_via.c | |||
@@ -64,8 +64,6 @@ enum { | |||
64 | PORT0 = (1 << 1), | 64 | PORT0 = (1 << 1), |
65 | PORT1 = (1 << 0), | 65 | PORT1 = (1 << 0), |
66 | ALL_PORTS = PORT0 | PORT1, | 66 | ALL_PORTS = PORT0 | PORT1, |
67 | PATA_PORT = 2, /* PATA is port 2 */ | ||
68 | N_PORTS = 3, | ||
69 | 67 | ||
70 | NATIVE_MODE_ALL = (1 << 7) | (1 << 6) | (1 << 5) | (1 << 4), | 68 | NATIVE_MODE_ALL = (1 << 7) | (1 << 6) | (1 << 5) | (1 << 4), |
71 | 69 | ||
@@ -78,11 +76,9 @@ static u32 svia_scr_read (struct ata_port *ap, unsigned int sc_reg); | |||
78 | static void svia_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); | 76 | static void svia_scr_write (struct ata_port *ap, unsigned int sc_reg, u32 val); |
79 | static void svia_noop_freeze(struct ata_port *ap); | 77 | static void svia_noop_freeze(struct ata_port *ap); |
80 | static void vt6420_error_handler(struct ata_port *ap); | 78 | static void vt6420_error_handler(struct ata_port *ap); |
81 | static void vt6421_sata_error_handler(struct ata_port *ap); | 79 | static int vt6421_pata_cable_detect(struct ata_port *ap); |
82 | static void vt6421_pata_error_handler(struct ata_port *ap); | ||
83 | static void vt6421_set_pio_mode(struct ata_port *ap, struct ata_device *adev); | 80 | static void vt6421_set_pio_mode(struct ata_port *ap, struct ata_device *adev); |
84 | static void vt6421_set_dma_mode(struct ata_port *ap, struct ata_device *adev); | 81 | static void vt6421_set_dma_mode(struct ata_port *ap, struct ata_device *adev); |
85 | static int vt6421_port_start(struct ata_port *ap); | ||
86 | 82 | ||
87 | static const struct pci_device_id svia_pci_tbl[] = { | 83 | static const struct pci_device_id svia_pci_tbl[] = { |
88 | { PCI_VDEVICE(VIA, 0x5337), vt6420 }, | 84 | { PCI_VDEVICE(VIA, 0x5337), vt6420 }, |
@@ -141,7 +137,6 @@ static const struct ata_port_operations vt6420_sata_ops = { | |||
141 | .error_handler = vt6420_error_handler, | 137 | .error_handler = vt6420_error_handler, |
142 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 138 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
143 | 139 | ||
144 | .irq_handler = ata_interrupt, | ||
145 | .irq_clear = ata_bmdma_irq_clear, | 140 | .irq_clear = ata_bmdma_irq_clear, |
146 | .irq_on = ata_irq_on, | 141 | .irq_on = ata_irq_on, |
147 | .irq_ack = ata_irq_ack, | 142 | .irq_ack = ata_irq_ack, |
@@ -172,15 +167,15 @@ static const struct ata_port_operations vt6421_pata_ops = { | |||
172 | 167 | ||
173 | .freeze = ata_bmdma_freeze, | 168 | .freeze = ata_bmdma_freeze, |
174 | .thaw = ata_bmdma_thaw, | 169 | .thaw = ata_bmdma_thaw, |
175 | .error_handler = vt6421_pata_error_handler, | 170 | .error_handler = ata_bmdma_error_handler, |
176 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 171 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
172 | .cable_detect = vt6421_pata_cable_detect, | ||
177 | 173 | ||
178 | .irq_handler = ata_interrupt, | ||
179 | .irq_clear = ata_bmdma_irq_clear, | 174 | .irq_clear = ata_bmdma_irq_clear, |
180 | .irq_on = ata_irq_on, | 175 | .irq_on = ata_irq_on, |
181 | .irq_ack = ata_irq_ack, | 176 | .irq_ack = ata_irq_ack, |
182 | 177 | ||
183 | .port_start = vt6421_port_start, | 178 | .port_start = ata_port_start, |
184 | }; | 179 | }; |
185 | 180 | ||
186 | static const struct ata_port_operations vt6421_sata_ops = { | 181 | static const struct ata_port_operations vt6421_sata_ops = { |
@@ -203,10 +198,10 @@ static const struct ata_port_operations vt6421_sata_ops = { | |||
203 | 198 | ||
204 | .freeze = ata_bmdma_freeze, | 199 | .freeze = ata_bmdma_freeze, |
205 | .thaw = ata_bmdma_thaw, | 200 | .thaw = ata_bmdma_thaw, |
206 | .error_handler = vt6421_sata_error_handler, | 201 | .error_handler = ata_bmdma_error_handler, |
207 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 202 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
203 | .cable_detect = ata_cable_sata, | ||
208 | 204 | ||
209 | .irq_handler = ata_interrupt, | ||
210 | .irq_clear = ata_bmdma_irq_clear, | 205 | .irq_clear = ata_bmdma_irq_clear, |
211 | .irq_on = ata_irq_on, | 206 | .irq_on = ata_irq_on, |
212 | .irq_ack = ata_irq_ack, | 207 | .irq_ack = ata_irq_ack, |
@@ -214,11 +209,10 @@ static const struct ata_port_operations vt6421_sata_ops = { | |||
214 | .scr_read = svia_scr_read, | 209 | .scr_read = svia_scr_read, |
215 | .scr_write = svia_scr_write, | 210 | .scr_write = svia_scr_write, |
216 | 211 | ||
217 | .port_start = vt6421_port_start, | 212 | .port_start = ata_port_start, |
218 | }; | 213 | }; |
219 | 214 | ||
220 | static struct ata_port_info vt6420_port_info = { | 215 | static const struct ata_port_info vt6420_port_info = { |
221 | .sht = &svia_sht, | ||
222 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY, | 216 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY, |
223 | .pio_mask = 0x1f, | 217 | .pio_mask = 0x1f, |
224 | .mwdma_mask = 0x07, | 218 | .mwdma_mask = 0x07, |
@@ -226,6 +220,22 @@ static struct ata_port_info vt6420_port_info = { | |||
226 | .port_ops = &vt6420_sata_ops, | 220 | .port_ops = &vt6420_sata_ops, |
227 | }; | 221 | }; |
228 | 222 | ||
223 | static struct ata_port_info vt6421_sport_info = { | ||
224 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY, | ||
225 | .pio_mask = 0x1f, | ||
226 | .mwdma_mask = 0x07, | ||
227 | .udma_mask = 0x7f, | ||
228 | .port_ops = &vt6421_sata_ops, | ||
229 | }; | ||
230 | |||
231 | static struct ata_port_info vt6421_pport_info = { | ||
232 | .flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_NO_LEGACY, | ||
233 | .pio_mask = 0x1f, | ||
234 | .mwdma_mask = 0, | ||
235 | .udma_mask = 0x7f, | ||
236 | .port_ops = &vt6421_pata_ops, | ||
237 | }; | ||
238 | |||
229 | MODULE_AUTHOR("Jeff Garzik"); | 239 | MODULE_AUTHOR("Jeff Garzik"); |
230 | MODULE_DESCRIPTION("SCSI low-level driver for VIA SATA controllers"); | 240 | MODULE_DESCRIPTION("SCSI low-level driver for VIA SATA controllers"); |
231 | MODULE_LICENSE("GPL"); | 241 | MODULE_LICENSE("GPL"); |
@@ -330,35 +340,15 @@ static void vt6420_error_handler(struct ata_port *ap) | |||
330 | NULL, ata_std_postreset); | 340 | NULL, ata_std_postreset); |
331 | } | 341 | } |
332 | 342 | ||
333 | static int vt6421_pata_prereset(struct ata_port *ap) | 343 | static int vt6421_pata_cable_detect(struct ata_port *ap) |
334 | { | 344 | { |
335 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); | 345 | struct pci_dev *pdev = to_pci_dev(ap->host->dev); |
336 | u8 tmp; | 346 | u8 tmp; |
337 | 347 | ||
338 | pci_read_config_byte(pdev, PATA_UDMA_TIMING, &tmp); | 348 | pci_read_config_byte(pdev, PATA_UDMA_TIMING, &tmp); |
339 | if (tmp & 0x10) | 349 | if (tmp & 0x10) |
340 | ap->cbl = ATA_CBL_PATA40; | 350 | return ATA_CBL_PATA40; |
341 | else | 351 | return ATA_CBL_PATA80; |
342 | ap->cbl = ATA_CBL_PATA80; | ||
343 | return 0; | ||
344 | } | ||
345 | |||
346 | static void vt6421_pata_error_handler(struct ata_port *ap) | ||
347 | { | ||
348 | return ata_bmdma_drive_eh(ap, vt6421_pata_prereset, ata_std_softreset, | ||
349 | NULL, ata_std_postreset); | ||
350 | } | ||
351 | |||
352 | static int vt6421_sata_prereset(struct ata_port *ap) | ||
353 | { | ||
354 | ap->cbl = ATA_CBL_SATA; | ||
355 | return 0; | ||
356 | } | ||
357 | |||
358 | static void vt6421_sata_error_handler(struct ata_port *ap) | ||
359 | { | ||
360 | return ata_bmdma_drive_eh(ap, vt6421_sata_prereset, ata_std_softreset, | ||
361 | NULL, ata_std_postreset); | ||
362 | } | 352 | } |
363 | 353 | ||
364 | static void vt6421_set_pio_mode(struct ata_port *ap, struct ata_device *adev) | 354 | static void vt6421_set_pio_mode(struct ata_port *ap, struct ata_device *adev) |
@@ -375,16 +365,6 @@ static void vt6421_set_dma_mode(struct ata_port *ap, struct ata_device *adev) | |||
375 | pci_write_config_byte(pdev, PATA_UDMA_TIMING, udma_bits[adev->pio_mode - XFER_UDMA_0]); | 365 | pci_write_config_byte(pdev, PATA_UDMA_TIMING, udma_bits[adev->pio_mode - XFER_UDMA_0]); |
376 | } | 366 | } |
377 | 367 | ||
378 | static int vt6421_port_start(struct ata_port *ap) | ||
379 | { | ||
380 | if (ap->port_no == PATA_PORT) { | ||
381 | ap->ops = &vt6421_pata_ops; | ||
382 | ap->mwdma_mask = 0; | ||
383 | ap->flags = ATA_FLAG_SLAVE_POSS | ATA_FLAG_NO_LEGACY | ATA_FLAG_SRST; | ||
384 | } | ||
385 | return ata_port_start(ap); | ||
386 | } | ||
387 | |||
388 | static const unsigned int svia_bar_sizes[] = { | 368 | static const unsigned int svia_bar_sizes[] = { |
389 | 8, 4, 8, 4, 16, 256 | 369 | 8, 4, 8, 4, 16, 256 |
390 | }; | 370 | }; |
@@ -403,79 +383,78 @@ static void __iomem * vt6421_scr_addr(void __iomem *addr, unsigned int port) | |||
403 | return addr + (port * 64); | 383 | return addr + (port * 64); |
404 | } | 384 | } |
405 | 385 | ||
406 | static void vt6421_init_addrs(struct ata_probe_ent *probe_ent, | 386 | static void vt6421_init_addrs(struct ata_port *ap) |
407 | void __iomem * const *iomap, unsigned int port) | ||
408 | { | 387 | { |
409 | void __iomem *reg_addr = iomap[port]; | 388 | void __iomem * const * iomap = ap->host->iomap; |
410 | void __iomem *bmdma_addr = iomap[4] + (port * 8); | 389 | void __iomem *reg_addr = iomap[ap->port_no]; |
411 | 390 | void __iomem *bmdma_addr = iomap[4] + (ap->port_no * 8); | |
412 | probe_ent->port[port].cmd_addr = reg_addr; | 391 | struct ata_ioports *ioaddr = &ap->ioaddr; |
413 | probe_ent->port[port].altstatus_addr = | 392 | |
414 | probe_ent->port[port].ctl_addr = (void __iomem *) | 393 | ioaddr->cmd_addr = reg_addr; |
394 | ioaddr->altstatus_addr = | ||
395 | ioaddr->ctl_addr = (void __iomem *) | ||
415 | ((unsigned long)(reg_addr + 8) | ATA_PCI_CTL_OFS); | 396 | ((unsigned long)(reg_addr + 8) | ATA_PCI_CTL_OFS); |
416 | probe_ent->port[port].bmdma_addr = bmdma_addr; | 397 | ioaddr->bmdma_addr = bmdma_addr; |
417 | probe_ent->port[port].scr_addr = vt6421_scr_addr(iomap[5], port); | 398 | ioaddr->scr_addr = vt6421_scr_addr(iomap[5], ap->port_no); |
418 | 399 | ||
419 | ata_std_ports(&probe_ent->port[port]); | 400 | ata_std_ports(ioaddr); |
420 | } | 401 | } |
421 | 402 | ||
422 | static struct ata_probe_ent *vt6420_init_probe_ent(struct pci_dev *pdev) | 403 | static int vt6420_prepare_host(struct pci_dev *pdev, struct ata_host **r_host) |
423 | { | 404 | { |
424 | struct ata_probe_ent *probe_ent; | 405 | const struct ata_port_info *ppi[] = { &vt6420_port_info, NULL }; |
425 | struct ata_port_info *ppi[2]; | 406 | struct ata_host *host; |
426 | void __iomem *bar5; | 407 | int rc; |
427 | 408 | ||
428 | ppi[0] = ppi[1] = &vt6420_port_info; | 409 | rc = ata_pci_prepare_native_host(pdev, ppi, 2, &host); |
429 | probe_ent = ata_pci_init_native_mode(pdev, ppi, ATA_PORT_PRIMARY | ATA_PORT_SECONDARY); | 410 | if (rc) |
430 | if (!probe_ent) | 411 | return rc; |
431 | return NULL; | 412 | *r_host = host; |
432 | 413 | ||
433 | bar5 = pcim_iomap(pdev, 5, 0); | 414 | rc = pcim_iomap_regions(pdev, 1 << 5, DRV_NAME); |
434 | if (!bar5) { | 415 | if (rc) { |
435 | dev_printk(KERN_ERR, &pdev->dev, "failed to iomap PCI BAR 5\n"); | 416 | dev_printk(KERN_ERR, &pdev->dev, "failed to iomap PCI BAR 5\n"); |
436 | return NULL; | 417 | return rc; |
437 | } | 418 | } |
438 | 419 | ||
439 | probe_ent->port[0].scr_addr = svia_scr_addr(bar5, 0); | 420 | host->ports[0]->ioaddr.scr_addr = svia_scr_addr(host->iomap[5], 0); |
440 | probe_ent->port[1].scr_addr = svia_scr_addr(bar5, 1); | 421 | host->ports[1]->ioaddr.scr_addr = svia_scr_addr(host->iomap[5], 1); |
441 | 422 | ||
442 | return probe_ent; | 423 | return 0; |
443 | } | 424 | } |
444 | 425 | ||
445 | static struct ata_probe_ent *vt6421_init_probe_ent(struct pci_dev *pdev) | 426 | static int vt6421_prepare_host(struct pci_dev *pdev, struct ata_host **r_host) |
446 | { | 427 | { |
447 | struct ata_probe_ent *probe_ent; | 428 | const struct ata_port_info *ppi[] = |
448 | unsigned int i; | 429 | { &vt6421_sport_info, &vt6421_sport_info, &vt6421_pport_info }; |
430 | struct ata_host *host; | ||
431 | int i, rc; | ||
432 | |||
433 | *r_host = host = ata_host_alloc_pinfo(&pdev->dev, ppi, ARRAY_SIZE(ppi)); | ||
434 | if (!host) { | ||
435 | dev_printk(KERN_ERR, &pdev->dev, "failed to allocate host\n"); | ||
436 | return -ENOMEM; | ||
437 | } | ||
449 | 438 | ||
450 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | 439 | rc = pcim_iomap_regions(pdev, 0x1f, DRV_NAME); |
451 | if (!probe_ent) | 440 | if (rc) { |
452 | return NULL; | 441 | dev_printk(KERN_ERR, &pdev->dev, "failed to request/iomap " |
453 | 442 | "PCI BARs (errno=%d)\n", rc); | |
454 | memset(probe_ent, 0, sizeof(*probe_ent)); | 443 | return rc; |
455 | probe_ent->dev = pci_dev_to_dev(pdev); | 444 | } |
456 | INIT_LIST_HEAD(&probe_ent->node); | 445 | host->iomap = pcim_iomap_table(pdev); |
457 | |||
458 | probe_ent->sht = &svia_sht; | ||
459 | probe_ent->port_flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY; | ||
460 | probe_ent->port_ops = &vt6421_sata_ops; | ||
461 | probe_ent->n_ports = N_PORTS; | ||
462 | probe_ent->irq = pdev->irq; | ||
463 | probe_ent->irq_flags = IRQF_SHARED; | ||
464 | probe_ent->pio_mask = 0x1f; | ||
465 | probe_ent->mwdma_mask = 0x07; | ||
466 | probe_ent->udma_mask = 0x7f; | ||
467 | |||
468 | for (i = 0; i < 6; i++) | ||
469 | if (!pcim_iomap(pdev, i, 0)) { | ||
470 | dev_printk(KERN_ERR, &pdev->dev, | ||
471 | "failed to iomap PCI BAR %d\n", i); | ||
472 | return NULL; | ||
473 | } | ||
474 | 446 | ||
475 | for (i = 0; i < N_PORTS; i++) | 447 | for (i = 0; i < host->n_ports; i++) |
476 | vt6421_init_addrs(probe_ent, pcim_iomap_table(pdev), i); | 448 | vt6421_init_addrs(host->ports[i]); |
477 | 449 | ||
478 | return probe_ent; | 450 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); |
451 | if (rc) | ||
452 | return rc; | ||
453 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | ||
454 | if (rc) | ||
455 | return rc; | ||
456 | |||
457 | return 0; | ||
479 | } | 458 | } |
480 | 459 | ||
481 | static void svia_configure(struct pci_dev *pdev) | 460 | static void svia_configure(struct pci_dev *pdev) |
@@ -522,7 +501,7 @@ static int svia_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
522 | static int printed_version; | 501 | static int printed_version; |
523 | unsigned int i; | 502 | unsigned int i; |
524 | int rc; | 503 | int rc; |
525 | struct ata_probe_ent *probe_ent; | 504 | struct ata_host *host; |
526 | int board_id = (int) ent->driver_data; | 505 | int board_id = (int) ent->driver_data; |
527 | const int *bar_sizes; | 506 | const int *bar_sizes; |
528 | u8 tmp8; | 507 | u8 tmp8; |
@@ -534,12 +513,6 @@ static int svia_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
534 | if (rc) | 513 | if (rc) |
535 | return rc; | 514 | return rc; |
536 | 515 | ||
537 | rc = pci_request_regions(pdev, DRV_NAME); | ||
538 | if (rc) { | ||
539 | pcim_pin_device(pdev); | ||
540 | return rc; | ||
541 | } | ||
542 | |||
543 | if (board_id == vt6420) { | 516 | if (board_id == vt6420) { |
544 | pci_read_config_byte(pdev, SATA_PATA_SHARING, &tmp8); | 517 | pci_read_config_byte(pdev, SATA_PATA_SHARING, &tmp8); |
545 | if (tmp8 & SATA_2DEV) { | 518 | if (tmp8 & SATA_2DEV) { |
@@ -565,32 +538,18 @@ static int svia_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | |||
565 | return -ENODEV; | 538 | return -ENODEV; |
566 | } | 539 | } |
567 | 540 | ||
568 | rc = pci_set_dma_mask(pdev, ATA_DMA_MASK); | ||
569 | if (rc) | ||
570 | return rc; | ||
571 | rc = pci_set_consistent_dma_mask(pdev, ATA_DMA_MASK); | ||
572 | if (rc) | ||
573 | return rc; | ||
574 | |||
575 | if (board_id == vt6420) | 541 | if (board_id == vt6420) |
576 | probe_ent = vt6420_init_probe_ent(pdev); | 542 | rc = vt6420_prepare_host(pdev, &host); |
577 | else | 543 | else |
578 | probe_ent = vt6421_init_probe_ent(pdev); | 544 | rc = vt6421_prepare_host(pdev, &host); |
579 | 545 | if (rc) | |
580 | if (!probe_ent) { | 546 | return rc; |
581 | dev_printk(KERN_ERR, &pdev->dev, "out of memory\n"); | ||
582 | return -ENOMEM; | ||
583 | } | ||
584 | 547 | ||
585 | svia_configure(pdev); | 548 | svia_configure(pdev); |
586 | 549 | ||
587 | pci_set_master(pdev); | 550 | pci_set_master(pdev); |
588 | 551 | return ata_host_activate(host, pdev->irq, ata_interrupt, IRQF_SHARED, | |
589 | if (!ata_device_add(probe_ent)) | 552 | &svia_sht); |
590 | return -ENODEV; | ||
591 | |||
592 | devm_kfree(&pdev->dev, probe_ent); | ||
593 | return 0; | ||
594 | } | 553 | } |
595 | 554 | ||
596 | static int __init svia_init(void) | 555 | static int __init svia_init(void) |
diff --git a/drivers/ata/sata_vsc.c b/drivers/ata/sata_vsc.c index 170bad1b415..80126f835d3 100644 --- a/drivers/ata/sata_vsc.c +++ b/drivers/ata/sata_vsc.c | |||
@@ -333,7 +333,6 @@ static const struct ata_port_operations vsc_sata_ops = { | |||
333 | .thaw = vsc_thaw, | 333 | .thaw = vsc_thaw, |
334 | .error_handler = ata_bmdma_error_handler, | 334 | .error_handler = ata_bmdma_error_handler, |
335 | .post_internal_cmd = ata_bmdma_post_internal_cmd, | 335 | .post_internal_cmd = ata_bmdma_post_internal_cmd, |
336 | .irq_handler = vsc_sata_interrupt, | ||
337 | .irq_clear = ata_bmdma_irq_clear, | 336 | .irq_clear = ata_bmdma_irq_clear, |
338 | .irq_on = ata_irq_on, | 337 | .irq_on = ata_irq_on, |
339 | .irq_ack = ata_irq_ack, | 338 | .irq_ack = ata_irq_ack, |
@@ -367,30 +366,50 @@ static void __devinit vsc_sata_setup_port(struct ata_ioports *port, | |||
367 | 366 | ||
368 | static int __devinit vsc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) | 367 | static int __devinit vsc_sata_init_one (struct pci_dev *pdev, const struct pci_device_id *ent) |
369 | { | 368 | { |
369 | static const struct ata_port_info pi = { | ||
370 | .flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
371 | ATA_FLAG_MMIO, | ||
372 | .pio_mask = 0x1f, | ||
373 | .mwdma_mask = 0x07, | ||
374 | .udma_mask = 0x7f, | ||
375 | .port_ops = &vsc_sata_ops, | ||
376 | }; | ||
377 | const struct ata_port_info *ppi[] = { &pi, NULL }; | ||
370 | static int printed_version; | 378 | static int printed_version; |
371 | struct ata_probe_ent *probe_ent; | 379 | struct ata_host *host; |
372 | void __iomem *mmio_base; | 380 | void __iomem *mmio_base; |
373 | int rc; | 381 | int i, rc; |
374 | u8 cls; | 382 | u8 cls; |
375 | 383 | ||
376 | if (!printed_version++) | 384 | if (!printed_version++) |
377 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 385 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
378 | 386 | ||
387 | /* allocate host */ | ||
388 | host = ata_host_alloc_pinfo(&pdev->dev, ppi, 4); | ||
389 | if (!host) | ||
390 | return -ENOMEM; | ||
391 | |||
379 | rc = pcim_enable_device(pdev); | 392 | rc = pcim_enable_device(pdev); |
380 | if (rc) | 393 | if (rc) |
381 | return rc; | 394 | return rc; |
382 | 395 | ||
383 | /* | 396 | /* check if we have needed resource mapped */ |
384 | * Check if we have needed resource mapped. | ||
385 | */ | ||
386 | if (pci_resource_len(pdev, 0) == 0) | 397 | if (pci_resource_len(pdev, 0) == 0) |
387 | return -ENODEV; | 398 | return -ENODEV; |
388 | 399 | ||
400 | /* map IO regions and intialize host accordingly */ | ||
389 | rc = pcim_iomap_regions(pdev, 1 << VSC_MMIO_BAR, DRV_NAME); | 401 | rc = pcim_iomap_regions(pdev, 1 << VSC_MMIO_BAR, DRV_NAME); |
390 | if (rc == -EBUSY) | 402 | if (rc == -EBUSY) |
391 | pcim_pin_device(pdev); | 403 | pcim_pin_device(pdev); |
392 | if (rc) | 404 | if (rc) |
393 | return rc; | 405 | return rc; |
406 | host->iomap = pcim_iomap_table(pdev); | ||
407 | |||
408 | mmio_base = host->iomap[VSC_MMIO_BAR]; | ||
409 | |||
410 | for (i = 0; i < host->n_ports; i++) | ||
411 | vsc_sata_setup_port(&host->ports[i]->ioaddr, | ||
412 | mmio_base + (i + 1) * VSC_SATA_PORT_OFFSET); | ||
394 | 413 | ||
395 | /* | 414 | /* |
396 | * Use 32 bit DMA mask, because 64 bit address support is poor. | 415 | * Use 32 bit DMA mask, because 64 bit address support is poor. |
@@ -402,12 +421,6 @@ static int __devinit vsc_sata_init_one (struct pci_dev *pdev, const struct pci_d | |||
402 | if (rc) | 421 | if (rc) |
403 | return rc; | 422 | return rc; |
404 | 423 | ||
405 | probe_ent = devm_kzalloc(&pdev->dev, sizeof(*probe_ent), GFP_KERNEL); | ||
406 | if (probe_ent == NULL) | ||
407 | return -ENOMEM; | ||
408 | probe_ent->dev = pci_dev_to_dev(pdev); | ||
409 | INIT_LIST_HEAD(&probe_ent->node); | ||
410 | |||
411 | /* | 424 | /* |
412 | * Due to a bug in the chip, the default cache line size can't be | 425 | * Due to a bug in the chip, the default cache line size can't be |
413 | * used (unless the default is non-zero). | 426 | * used (unless the default is non-zero). |
@@ -418,33 +431,6 @@ static int __devinit vsc_sata_init_one (struct pci_dev *pdev, const struct pci_d | |||
418 | 431 | ||
419 | if (pci_enable_msi(pdev) == 0) | 432 | if (pci_enable_msi(pdev) == 0) |
420 | pci_intx(pdev, 0); | 433 | pci_intx(pdev, 0); |
421 | else | ||
422 | probe_ent->irq_flags = IRQF_SHARED; | ||
423 | |||
424 | probe_ent->sht = &vsc_sata_sht; | ||
425 | probe_ent->port_flags = ATA_FLAG_SATA | ATA_FLAG_NO_LEGACY | | ||
426 | ATA_FLAG_MMIO; | ||
427 | probe_ent->port_ops = &vsc_sata_ops; | ||
428 | probe_ent->n_ports = 4; | ||
429 | probe_ent->irq = pdev->irq; | ||
430 | probe_ent->iomap = pcim_iomap_table(pdev); | ||
431 | |||
432 | /* We don't care much about the PIO/UDMA masks, but the core won't like us | ||
433 | * if we don't fill these | ||
434 | */ | ||
435 | probe_ent->pio_mask = 0x1f; | ||
436 | probe_ent->mwdma_mask = 0x07; | ||
437 | probe_ent->udma_mask = 0x7f; | ||
438 | |||
439 | mmio_base = probe_ent->iomap[VSC_MMIO_BAR]; | ||
440 | |||
441 | /* We have 4 ports per PCI function */ | ||
442 | vsc_sata_setup_port(&probe_ent->port[0], mmio_base + 1 * VSC_SATA_PORT_OFFSET); | ||
443 | vsc_sata_setup_port(&probe_ent->port[1], mmio_base + 2 * VSC_SATA_PORT_OFFSET); | ||
444 | vsc_sata_setup_port(&probe_ent->port[2], mmio_base + 3 * VSC_SATA_PORT_OFFSET); | ||
445 | vsc_sata_setup_port(&probe_ent->port[3], mmio_base + 4 * VSC_SATA_PORT_OFFSET); | ||
446 | |||
447 | pci_set_master(pdev); | ||
448 | 434 | ||
449 | /* | 435 | /* |
450 | * Config offset 0x98 is "Extended Control and Status Register 0" | 436 | * Config offset 0x98 is "Extended Control and Status Register 0" |
@@ -454,11 +440,9 @@ static int __devinit vsc_sata_init_one (struct pci_dev *pdev, const struct pci_d | |||
454 | */ | 440 | */ |
455 | pci_write_config_dword(pdev, 0x98, 0); | 441 | pci_write_config_dword(pdev, 0x98, 0); |
456 | 442 | ||
457 | if (!ata_device_add(probe_ent)) | 443 | pci_set_master(pdev); |
458 | return -ENODEV; | 444 | return ata_host_activate(host, pdev->irq, vsc_sata_interrupt, |
459 | 445 | IRQF_SHARED, &vsc_sata_sht); | |
460 | devm_kfree(&pdev->dev, probe_ent); | ||
461 | return 0; | ||
462 | } | 446 | } |
463 | 447 | ||
464 | static const struct pci_device_id vsc_sata_pci_tbl[] = { | 448 | static const struct pci_device_id vsc_sata_pci_tbl[] = { |