amd74xx.c revision e085b3cae85af47eb0a3eda3186bd898310fb322
1/* 2 * AMD 755/756/766/8111 and nVidia nForce/2/2s/3/3s/CK804/MCP04 3 * IDE driver for Linux. 4 * 5 * Copyright (c) 2000-2002 Vojtech Pavlik 6 * Copyright (c) 2007-2010 Bartlomiej Zolnierkiewicz 7 * 8 * Based on the work of: 9 * Andre Hedrick 10 */ 11 12/* 13 * This program is free software; you can redistribute it and/or modify it 14 * under the terms of the GNU General Public License version 2 as published by 15 * the Free Software Foundation. 16 */ 17 18#include <linux/module.h> 19#include <linux/kernel.h> 20#include <linux/pci.h> 21#include <linux/init.h> 22#include <linux/ide.h> 23 24#define DRV_NAME "amd74xx" 25 26enum { 27 AMD_IDE_CONFIG = 0x41, 28 AMD_CABLE_DETECT = 0x42, 29 AMD_DRIVE_TIMING = 0x48, 30 AMD_8BIT_TIMING = 0x4e, 31 AMD_ADDRESS_SETUP = 0x4c, 32 AMD_UDMA_TIMING = 0x50, 33}; 34 35static unsigned int amd_80w; 36static unsigned int amd_clock; 37 38static char *amd_dma[] = { "16", "25", "33", "44", "66", "100", "133" }; 39static unsigned char amd_cyc2udma[] = { 6, 6, 5, 4, 0, 1, 1, 2, 2, 3, 3, 3, 3, 3, 3, 7 }; 40 41static inline u8 amd_offset(struct pci_dev *dev) 42{ 43 return (dev->vendor == PCI_VENDOR_ID_NVIDIA) ? 0x10 : 0; 44} 45 46/* 47 * amd_set_speed() writes timing values to the chipset registers 48 */ 49 50static void amd_set_speed(struct pci_dev *dev, u8 dn, u8 udma_mask, 51 struct ide_timing *timing) 52{ 53 u8 t = 0, offset = amd_offset(dev); 54 55 pci_read_config_byte(dev, AMD_ADDRESS_SETUP + offset, &t); 56 t = (t & ~(3 << ((3 - dn) << 1))) | ((clamp_val(timing->setup, 1, 4) - 1) << ((3 - dn) << 1)); 57 pci_write_config_byte(dev, AMD_ADDRESS_SETUP + offset, t); 58 59 pci_write_config_byte(dev, AMD_8BIT_TIMING + offset + (1 - (dn >> 1)), 60 ((clamp_val(timing->act8b, 1, 16) - 1) << 4) | (clamp_val(timing->rec8b, 1, 16) - 1)); 61 62 pci_write_config_byte(dev, AMD_DRIVE_TIMING + offset + (3 - dn), 63 ((clamp_val(timing->active, 1, 16) - 1) << 4) | (clamp_val(timing->recover, 1, 16) - 1)); 64 65 switch (udma_mask) { 66 case ATA_UDMA2: t = timing->udma ? (0xc0 | (clamp_val(timing->udma, 2, 5) - 2)) : 0x03; break; 67 case ATA_UDMA4: t = timing->udma ? (0xc0 | amd_cyc2udma[clamp_val(timing->udma, 2, 10)]) : 0x03; break; 68 case ATA_UDMA5: t = timing->udma ? (0xc0 | amd_cyc2udma[clamp_val(timing->udma, 1, 10)]) : 0x03; break; 69 case ATA_UDMA6: t = timing->udma ? (0xc0 | amd_cyc2udma[clamp_val(timing->udma, 1, 15)]) : 0x03; break; 70 default: return; 71 } 72 73 if (timing->udma) 74 pci_write_config_byte(dev, AMD_UDMA_TIMING + offset + 3 - dn, t); 75} 76 77/* 78 * amd_set_drive() computes timing values and configures the chipset 79 * to a desired transfer mode. It also can be called by upper layers. 80 */ 81 82static void amd_set_drive(ide_drive_t *drive, const u8 speed) 83{ 84 ide_hwif_t *hwif = drive->hwif; 85 struct pci_dev *dev = to_pci_dev(hwif->dev); 86 ide_drive_t *peer = ide_get_pair_dev(drive); 87 struct ide_timing t, p; 88 int T, UT; 89 u8 udma_mask = hwif->ultra_mask; 90 91 T = 1000000000 / amd_clock; 92 UT = (udma_mask == ATA_UDMA2) ? T : (T / 2); 93 94 ide_timing_compute(drive, speed, &t, T, UT); 95 96 if (peer) { 97 ide_timing_compute(peer, peer->current_speed, &p, T, UT); 98 ide_timing_merge(&p, &t, &t, IDE_TIMING_8BIT); 99 } 100 101 if (speed == XFER_UDMA_5 && amd_clock <= 33333) t.udma = 1; 102 if (speed == XFER_UDMA_6 && amd_clock <= 33333) t.udma = 15; 103 104 amd_set_speed(dev, drive->dn, udma_mask, &t); 105} 106 107/* 108 * amd_set_pio_mode() is a callback from upper layers for PIO-only tuning. 109 */ 110 111static void amd_set_pio_mode(ide_hwif_t *hwif, ide_drive_t *drive) 112{ 113 amd_set_drive(drive, drive->pio_mode); 114} 115 116static void amd7409_cable_detect(struct pci_dev *dev) 117{ 118 /* no host side cable detection */ 119 amd_80w = 0x03; 120} 121 122static void amd7411_cable_detect(struct pci_dev *dev) 123{ 124 int i; 125 u32 u = 0; 126 u8 t = 0, offset = amd_offset(dev); 127 128 pci_read_config_byte(dev, AMD_CABLE_DETECT + offset, &t); 129 pci_read_config_dword(dev, AMD_UDMA_TIMING + offset, &u); 130 amd_80w = ((t & 0x3) ? 1 : 0) | ((t & 0xc) ? 2 : 0); 131 for (i = 24; i >= 0; i -= 8) 132 if (((u >> i) & 4) && !(amd_80w & (1 << (1 - (i >> 4))))) { 133 printk(KERN_WARNING DRV_NAME " %s: BIOS didn't set " 134 "cable bits correctly. Enabling workaround.\n", 135 pci_name(dev)); 136 amd_80w |= (1 << (1 - (i >> 4))); 137 } 138} 139 140/* 141 * The initialization callback. Initialize drive independent registers. 142 */ 143 144static int init_chipset_amd74xx(struct pci_dev *dev) 145{ 146 u8 t = 0, offset = amd_offset(dev); 147 148/* 149 * Check 80-wire cable presence. 150 */ 151 152 if (dev->vendor == PCI_VENDOR_ID_AMD && 153 dev->device == PCI_DEVICE_ID_AMD_COBRA_7401) 154 ; /* no UDMA > 2 */ 155 else if (dev->vendor == PCI_VENDOR_ID_AMD && 156 dev->device == PCI_DEVICE_ID_AMD_VIPER_7409) 157 amd7409_cable_detect(dev); 158 else 159 amd7411_cable_detect(dev); 160 161/* 162 * Take care of prefetch & postwrite. 163 */ 164 165 pci_read_config_byte(dev, AMD_IDE_CONFIG + offset, &t); 166 /* 167 * Check for broken FIFO support. 168 */ 169 if (dev->vendor == PCI_VENDOR_ID_AMD && 170 dev->device == PCI_DEVICE_ID_AMD_VIPER_7411) 171 t &= 0x0f; 172 else 173 t |= 0xf0; 174 pci_write_config_byte(dev, AMD_IDE_CONFIG + offset, t); 175 176 return 0; 177} 178 179static u8 amd_cable_detect(ide_hwif_t *hwif) 180{ 181 if ((amd_80w >> hwif->channel) & 1) 182 return ATA_CBL_PATA80; 183 else 184 return ATA_CBL_PATA40; 185} 186 187static const struct ide_port_ops amd_port_ops = { 188 .set_pio_mode = amd_set_pio_mode, 189 .set_dma_mode = amd_set_drive, 190 .cable_detect = amd_cable_detect, 191}; 192 193#define IDE_HFLAGS_AMD \ 194 (IDE_HFLAG_PIO_NO_BLACKLIST | \ 195 IDE_HFLAG_POST_SET_MODE | \ 196 IDE_HFLAG_IO_32BIT | \ 197 IDE_HFLAG_UNMASK_IRQS) 198 199#define DECLARE_AMD_DEV(swdma, udma) \ 200 { \ 201 .name = DRV_NAME, \ 202 .init_chipset = init_chipset_amd74xx, \ 203 .enablebits = {{0x40,0x02,0x02}, {0x40,0x01,0x01}}, \ 204 .port_ops = &amd_port_ops, \ 205 .host_flags = IDE_HFLAGS_AMD, \ 206 .pio_mask = ATA_PIO5, \ 207 .swdma_mask = swdma, \ 208 .mwdma_mask = ATA_MWDMA2, \ 209 .udma_mask = udma, \ 210 } 211 212#define DECLARE_NV_DEV(udma) \ 213 { \ 214 .name = DRV_NAME, \ 215 .init_chipset = init_chipset_amd74xx, \ 216 .enablebits = {{0x50,0x02,0x02}, {0x50,0x01,0x01}}, \ 217 .port_ops = &amd_port_ops, \ 218 .host_flags = IDE_HFLAGS_AMD, \ 219 .pio_mask = ATA_PIO5, \ 220 .swdma_mask = ATA_SWDMA2, \ 221 .mwdma_mask = ATA_MWDMA2, \ 222 .udma_mask = udma, \ 223 } 224 225static const struct ide_port_info amd74xx_chipsets[] __devinitdata = { 226 /* 0: AMD7401 */ DECLARE_AMD_DEV(0x00, ATA_UDMA2), 227 /* 1: AMD7409 */ DECLARE_AMD_DEV(ATA_SWDMA2, ATA_UDMA4), 228 /* 2: AMD7411/7441 */ DECLARE_AMD_DEV(ATA_SWDMA2, ATA_UDMA5), 229 /* 3: AMD8111 */ DECLARE_AMD_DEV(ATA_SWDMA2, ATA_UDMA6), 230 231 /* 4: NFORCE */ DECLARE_NV_DEV(ATA_UDMA5), 232 /* 5: >= NFORCE2 */ DECLARE_NV_DEV(ATA_UDMA6), 233 234 /* 6: AMD5536 */ DECLARE_AMD_DEV(ATA_SWDMA2, ATA_UDMA5), 235}; 236 237static int __devinit amd74xx_probe(struct pci_dev *dev, const struct pci_device_id *id) 238{ 239 struct ide_port_info d; 240 u8 idx = id->driver_data; 241 242 d = amd74xx_chipsets[idx]; 243 244 /* 245 * Check for bad SWDMA and incorrectly wired Serenade mainboards. 246 */ 247 if (idx == 1) { 248 if (dev->revision <= 7) 249 d.swdma_mask = 0; 250 d.host_flags |= IDE_HFLAG_CLEAR_SIMPLEX; 251 } else if (idx == 3) { 252 if (dev->subsystem_vendor == PCI_VENDOR_ID_AMD && 253 dev->subsystem_device == PCI_DEVICE_ID_AMD_SERENADE) 254 d.udma_mask = ATA_UDMA5; 255 } 256 257 /* 258 * It seems that on some nVidia controllers using AltStatus 259 * register can be unreliable so default to Status register 260 * if the device is in Compatibility Mode. 261 */ 262 if (dev->vendor == PCI_VENDOR_ID_NVIDIA && 263 ide_pci_is_in_compatibility_mode(dev)) 264 d.host_flags |= IDE_HFLAG_BROKEN_ALTSTATUS; 265 266 printk(KERN_INFO "%s %s: UDMA%s controller\n", 267 d.name, pci_name(dev), amd_dma[fls(d.udma_mask) - 1]); 268 269 /* 270 * Determine the system bus clock. 271 */ 272 amd_clock = (ide_pci_clk ? ide_pci_clk : 33) * 1000; 273 274 switch (amd_clock) { 275 case 33000: amd_clock = 33333; break; 276 case 37000: amd_clock = 37500; break; 277 case 41000: amd_clock = 41666; break; 278 } 279 280 if (amd_clock < 20000 || amd_clock > 50000) { 281 printk(KERN_WARNING "%s: User given PCI clock speed impossible" 282 " (%d), using 33 MHz instead.\n", 283 d.name, amd_clock); 284 amd_clock = 33333; 285 } 286 287 return ide_pci_init_one(dev, &d, NULL); 288} 289 290static const struct pci_device_id amd74xx_pci_tbl[] = { 291 { PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_COBRA_7401), 0 }, 292 { PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_VIPER_7409), 1 }, 293 { PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_VIPER_7411), 2 }, 294 { PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_OPUS_7441), 2 }, 295 { PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_8111_IDE), 3 }, 296 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_IDE), 4 }, 297 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE2_IDE), 5 }, 298 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE2S_IDE), 5 }, 299#ifdef CONFIG_BLK_DEV_IDE_SATA 300 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE2S_SATA), 5 }, 301#endif 302 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE3_IDE), 5 }, 303 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE3S_IDE), 5 }, 304#ifdef CONFIG_BLK_DEV_IDE_SATA 305 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA), 5 }, 306 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA2), 5 }, 307#endif 308 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_IDE), 5 }, 309 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_IDE), 5 }, 310 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_IDE), 5 }, 311 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_IDE), 5 }, 312 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_IDE), 5 }, 313 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP65_IDE), 5 }, 314 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP67_IDE), 5 }, 315 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_IDE), 5 }, 316 { PCI_VDEVICE(NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_MCP77_IDE), 5 }, 317 { PCI_VDEVICE(AMD, PCI_DEVICE_ID_AMD_CS5536_IDE), 6 }, 318 { 0, }, 319}; 320MODULE_DEVICE_TABLE(pci, amd74xx_pci_tbl); 321 322static struct pci_driver amd74xx_pci_driver = { 323 .name = "AMD_IDE", 324 .id_table = amd74xx_pci_tbl, 325 .probe = amd74xx_probe, 326 .remove = ide_pci_remove, 327 .suspend = ide_pci_suspend, 328 .resume = ide_pci_resume, 329}; 330 331static int __init amd74xx_ide_init(void) 332{ 333 return ide_pci_register_driver(&amd74xx_pci_driver); 334} 335 336static void __exit amd74xx_ide_exit(void) 337{ 338 pci_unregister_driver(&amd74xx_pci_driver); 339} 340 341module_init(amd74xx_ide_init); 342module_exit(amd74xx_ide_exit); 343 344MODULE_AUTHOR("Vojtech Pavlik, Bartlomiej Zolnierkiewicz"); 345MODULE_DESCRIPTION("AMD PCI IDE driver"); 346MODULE_LICENSE("GPL"); 347