diff options
| -rw-r--r-- | drivers/ata/sata_vsc.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/ata/sata_vsc.c b/drivers/ata/sata_vsc.c index 3d9daf231115..2fd037bde090 100644 --- a/drivers/ata/sata_vsc.c +++ b/drivers/ata/sata_vsc.c | |||
| @@ -346,6 +346,7 @@ static int __devinit vsc_sata_init_one (struct pci_dev *pdev, const struct pci_d | |||
| 346 | struct ata_probe_ent *probe_ent; | 346 | struct ata_probe_ent *probe_ent; |
| 347 | void __iomem *mmio_base; | 347 | void __iomem *mmio_base; |
| 348 | int rc; | 348 | int rc; |
| 349 | u8 cls; | ||
| 349 | 350 | ||
| 350 | if (!printed_version++) | 351 | if (!printed_version++) |
| 351 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); | 352 | dev_printk(KERN_DEBUG, &pdev->dev, "version " DRV_VERSION "\n"); |
| @@ -383,9 +384,12 @@ static int __devinit vsc_sata_init_one (struct pci_dev *pdev, const struct pci_d | |||
| 383 | INIT_LIST_HEAD(&probe_ent->node); | 384 | INIT_LIST_HEAD(&probe_ent->node); |
| 384 | 385 | ||
| 385 | /* | 386 | /* |
| 386 | * Due to a bug in the chip, the default cache line size can't be used | 387 | * Due to a bug in the chip, the default cache line size can't be |
| 388 | * used (unless the default is non-zero). | ||
| 387 | */ | 389 | */ |
| 388 | pci_write_config_byte(pdev, PCI_CACHE_LINE_SIZE, 0x80); | 390 | pci_read_config_byte(pdev, PCI_CACHE_LINE_SIZE, &cls); |
| 391 | if (cls == 0x00) | ||
| 392 | pci_write_config_byte(pdev, PCI_CACHE_LINE_SIZE, 0x80); | ||
| 389 | 393 | ||
| 390 | if (pci_enable_msi(pdev) == 0) | 394 | if (pci_enable_msi(pdev) == 0) |
| 391 | pci_intx(pdev, 0); | 395 | pci_intx(pdev, 0); |
