aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/pci/piix.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/pci/piix.c')
-rw-r--r--drivers/ide/pci/piix.c63
1 files changed, 48 insertions, 15 deletions
diff --git a/drivers/ide/pci/piix.c b/drivers/ide/pci/piix.c
index 52cfc2ac22c1..af65b0888bbb 100644
--- a/drivers/ide/pci/piix.c
+++ b/drivers/ide/pci/piix.c
@@ -410,17 +410,14 @@ fast_ata_pio:
410} 410}
411 411
412/** 412/**
413 * init_chipset_piix - set up the PIIX chipset 413 * piix_is_ichx - check if ICHx
414 * @dev: PCI device to set up 414 * @dev: PCI device to check
415 * @name: Name of the device
416 * 415 *
417 * Initialize the PCI device as required. For the PIIX this turns 416 * returns 1 if ICHx, 0 otherwise.
418 * out to be nice and simple
419 */ 417 */
420 418static int piix_is_ichx(struct pci_dev *dev)
421static unsigned int __devinit init_chipset_piix (struct pci_dev *dev, const char *name)
422{ 419{
423 switch(dev->device) { 420 switch (dev->device) {
424 case PCI_DEVICE_ID_INTEL_82801EB_1: 421 case PCI_DEVICE_ID_INTEL_82801EB_1:
425 case PCI_DEVICE_ID_INTEL_82801AA_1: 422 case PCI_DEVICE_ID_INTEL_82801AA_1:
426 case PCI_DEVICE_ID_INTEL_82801AB_1: 423 case PCI_DEVICE_ID_INTEL_82801AB_1:
@@ -438,19 +435,51 @@ static unsigned int __devinit init_chipset_piix (struct pci_dev *dev, const char
438 case PCI_DEVICE_ID_INTEL_ICH7_21: 435 case PCI_DEVICE_ID_INTEL_ICH7_21:
439 case PCI_DEVICE_ID_INTEL_ESB2_18: 436 case PCI_DEVICE_ID_INTEL_ESB2_18:
440 case PCI_DEVICE_ID_INTEL_ICH8_6: 437 case PCI_DEVICE_ID_INTEL_ICH8_6:
441 { 438 return 1;
442 unsigned int extra = 0;
443 pci_read_config_dword(dev, 0x54, &extra);
444 pci_write_config_dword(dev, 0x54, extra|0x400);
445 }
446 default:
447 break;
448 } 439 }
449 440
450 return 0; 441 return 0;
451} 442}
452 443
453/** 444/**
445 * init_chipset_piix - set up the PIIX chipset
446 * @dev: PCI device to set up
447 * @name: Name of the device
448 *
449 * Initialize the PCI device as required. For the PIIX this turns
450 * out to be nice and simple
451 */
452
453static unsigned int __devinit init_chipset_piix (struct pci_dev *dev, const char *name)
454{
455 if (piix_is_ichx(dev)) {
456 unsigned int extra = 0;
457 pci_read_config_dword(dev, 0x54, &extra);
458 pci_write_config_dword(dev, 0x54, extra|0x400);
459 }
460
461 return 0;
462}
463
464/**
465 * piix_dma_clear_irq - clear BMDMA status
466 * @drive: IDE drive to clear
467 *
468 * Called from ide_intr() for PIO interrupts
469 * to clear BMDMA status as needed by ICHx
470 */
471static void piix_dma_clear_irq(ide_drive_t *drive)
472{
473 ide_hwif_t *hwif = HWIF(drive);
474 u8 dma_stat;
475
476 /* clear the INTR & ERROR bits */
477 dma_stat = hwif->INB(hwif->dma_status);
478 /* Should we force the bit as well ? */
479 hwif->OUTB(dma_stat, hwif->dma_status);
480}
481
482/**
454 * init_hwif_piix - fill in the hwif for the PIIX 483 * init_hwif_piix - fill in the hwif for the PIIX
455 * @hwif: IDE interface 484 * @hwif: IDE interface
456 * 485 *
@@ -486,6 +515,10 @@ static void __devinit init_hwif_piix(ide_hwif_t *hwif)
486 if (!hwif->dma_base) 515 if (!hwif->dma_base)
487 return; 516 return;
488 517
518 /* ICHx need to clear the bmdma status for all interrupts */
519 if (piix_is_ichx(hwif->pci_dev))
520 hwif->ide_dma_clear_irq = &piix_dma_clear_irq;
521
489 hwif->atapi_dma = 1; 522 hwif->atapi_dma = 1;
490 hwif->ultra_mask = 0x3f; 523 hwif->ultra_mask = 0x3f;
491 hwif->mwdma_mask = 0x06; 524 hwif->mwdma_mask = 0x06;