diff options
Diffstat (limited to 'drivers/ide/pci/siimage.c')
-rw-r--r-- | drivers/ide/pci/siimage.c | 564 |
1 files changed, 260 insertions, 304 deletions
diff --git a/drivers/ide/pci/siimage.c b/drivers/ide/pci/siimage.c index 1fffea3211bd..4cf8fc54aa2a 100644 --- a/drivers/ide/pci/siimage.c +++ b/drivers/ide/pci/siimage.c | |||
@@ -1,8 +1,8 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (C) 2001-2002 Andre Hedrick <andre@linux-ide.org> | 2 | * Copyright (C) 2001-2002 Andre Hedrick <andre@linux-ide.org> |
3 | * Copyright (C) 2003 Red Hat <alan@redhat.com> | 3 | * Copyright (C) 2003 Red Hat <alan@redhat.com> |
4 | * Copyright (C) 2007 MontaVista Software, Inc. | 4 | * Copyright (C) 2007-2008 MontaVista Software, Inc. |
5 | * Copyright (C) 2007 Bartlomiej Zolnierkiewicz | 5 | * Copyright (C) 2007-2008 Bartlomiej Zolnierkiewicz |
6 | * | 6 | * |
7 | * May be copied or modified under the terms of the GNU General Public License | 7 | * May be copied or modified under the terms of the GNU General Public License |
8 | * | 8 | * |
@@ -17,10 +17,10 @@ | |||
17 | * | 17 | * |
18 | * FAQ Items: | 18 | * FAQ Items: |
19 | * If you are using Marvell SATA-IDE adapters with Maxtor drives | 19 | * If you are using Marvell SATA-IDE adapters with Maxtor drives |
20 | * ensure the system is set up for ATA100/UDMA5 not UDMA6. | 20 | * ensure the system is set up for ATA100/UDMA5, not UDMA6. |
21 | * | 21 | * |
22 | * If you are using WD drives with SATA bridges you must set the | 22 | * If you are using WD drives with SATA bridges you must set the |
23 | * drive to "Single". "Master" will hang | 23 | * drive to "Single". "Master" will hang. |
24 | * | 24 | * |
25 | * If you have strange problems with nVidia chipset systems please | 25 | * If you have strange problems with nVidia chipset systems please |
26 | * see the SI support documentation and update your system BIOS | 26 | * see the SI support documentation and update your system BIOS |
@@ -42,25 +42,24 @@ | |||
42 | #include <linux/hdreg.h> | 42 | #include <linux/hdreg.h> |
43 | #include <linux/ide.h> | 43 | #include <linux/ide.h> |
44 | #include <linux/init.h> | 44 | #include <linux/init.h> |
45 | 45 | #include <linux/io.h> | |
46 | #include <asm/io.h> | ||
47 | 46 | ||
48 | /** | 47 | /** |
49 | * pdev_is_sata - check if device is SATA | 48 | * pdev_is_sata - check if device is SATA |
50 | * @pdev: PCI device to check | 49 | * @pdev: PCI device to check |
51 | * | 50 | * |
52 | * Returns true if this is a SATA controller | 51 | * Returns true if this is a SATA controller |
53 | */ | 52 | */ |
54 | 53 | ||
55 | static int pdev_is_sata(struct pci_dev *pdev) | 54 | static int pdev_is_sata(struct pci_dev *pdev) |
56 | { | 55 | { |
57 | #ifdef CONFIG_BLK_DEV_IDE_SATA | 56 | #ifdef CONFIG_BLK_DEV_IDE_SATA |
58 | switch(pdev->device) { | 57 | switch (pdev->device) { |
59 | case PCI_DEVICE_ID_SII_3112: | 58 | case PCI_DEVICE_ID_SII_3112: |
60 | case PCI_DEVICE_ID_SII_1210SA: | 59 | case PCI_DEVICE_ID_SII_1210SA: |
61 | return 1; | 60 | return 1; |
62 | case PCI_DEVICE_ID_SII_680: | 61 | case PCI_DEVICE_ID_SII_680: |
63 | return 0; | 62 | return 0; |
64 | } | 63 | } |
65 | BUG(); | 64 | BUG(); |
66 | #endif | 65 | #endif |
@@ -70,10 +69,10 @@ static int pdev_is_sata(struct pci_dev *pdev) | |||
70 | /** | 69 | /** |
71 | * is_sata - check if hwif is SATA | 70 | * is_sata - check if hwif is SATA |
72 | * @hwif: interface to check | 71 | * @hwif: interface to check |
73 | * | 72 | * |
74 | * Returns true if this is a SATA controller | 73 | * Returns true if this is a SATA controller |
75 | */ | 74 | */ |
76 | 75 | ||
77 | static inline int is_sata(ide_hwif_t *hwif) | 76 | static inline int is_sata(ide_hwif_t *hwif) |
78 | { | 77 | { |
79 | return pdev_is_sata(to_pci_dev(hwif->dev)); | 78 | return pdev_is_sata(to_pci_dev(hwif->dev)); |
@@ -86,21 +85,22 @@ static inline int is_sata(ide_hwif_t *hwif) | |||
86 | * | 85 | * |
87 | * Turn a config register offset into the right address in either | 86 | * Turn a config register offset into the right address in either |
88 | * PCI space or MMIO space to access the control register in question | 87 | * PCI space or MMIO space to access the control register in question |
89 | * Thankfully this is a configuration operation so isnt performance | 88 | * Thankfully this is a configuration operation, so isn't performance |
90 | * criticial. | 89 | * critical. |
91 | */ | 90 | */ |
92 | 91 | ||
93 | static unsigned long siimage_selreg(ide_hwif_t *hwif, int r) | 92 | static unsigned long siimage_selreg(ide_hwif_t *hwif, int r) |
94 | { | 93 | { |
95 | unsigned long base = (unsigned long)hwif->hwif_data; | 94 | unsigned long base = (unsigned long)hwif->hwif_data; |
95 | |||
96 | base += 0xA0 + r; | 96 | base += 0xA0 + r; |
97 | if(hwif->mmio) | 97 | if (hwif->mmio) |
98 | base += (hwif->channel << 6); | 98 | base += hwif->channel << 6; |
99 | else | 99 | else |
100 | base += (hwif->channel << 4); | 100 | base += hwif->channel << 4; |
101 | return base; | 101 | return base; |
102 | } | 102 | } |
103 | 103 | ||
104 | /** | 104 | /** |
105 | * siimage_seldev - return register base | 105 | * siimage_seldev - return register base |
106 | * @hwif: interface | 106 | * @hwif: interface |
@@ -110,20 +110,69 @@ static unsigned long siimage_selreg(ide_hwif_t *hwif, int r) | |||
110 | * PCI space or MMIO space to access the control register in question | 110 | * PCI space or MMIO space to access the control register in question |
111 | * including accounting for the unit shift. | 111 | * including accounting for the unit shift. |
112 | */ | 112 | */ |
113 | 113 | ||
114 | static inline unsigned long siimage_seldev(ide_drive_t *drive, int r) | 114 | static inline unsigned long siimage_seldev(ide_drive_t *drive, int r) |
115 | { | 115 | { |
116 | ide_hwif_t *hwif = HWIF(drive); | 116 | ide_hwif_t *hwif = HWIF(drive); |
117 | unsigned long base = (unsigned long)hwif->hwif_data; | 117 | unsigned long base = (unsigned long)hwif->hwif_data; |
118 | |||
118 | base += 0xA0 + r; | 119 | base += 0xA0 + r; |
119 | if(hwif->mmio) | 120 | if (hwif->mmio) |
120 | base += (hwif->channel << 6); | 121 | base += hwif->channel << 6; |
121 | else | 122 | else |
122 | base += (hwif->channel << 4); | 123 | base += hwif->channel << 4; |
123 | base |= drive->select.b.unit << drive->select.b.unit; | 124 | base |= drive->select.b.unit << drive->select.b.unit; |
124 | return base; | 125 | return base; |
125 | } | 126 | } |
126 | 127 | ||
128 | static u8 sil_ioread8(struct pci_dev *dev, unsigned long addr) | ||
129 | { | ||
130 | u8 tmp = 0; | ||
131 | |||
132 | if (pci_get_drvdata(dev)) | ||
133 | tmp = readb((void __iomem *)addr); | ||
134 | else | ||
135 | pci_read_config_byte(dev, addr, &tmp); | ||
136 | |||
137 | return tmp; | ||
138 | } | ||
139 | |||
140 | static u16 sil_ioread16(struct pci_dev *dev, unsigned long addr) | ||
141 | { | ||
142 | u16 tmp = 0; | ||
143 | |||
144 | if (pci_get_drvdata(dev)) | ||
145 | tmp = readw((void __iomem *)addr); | ||
146 | else | ||
147 | pci_read_config_word(dev, addr, &tmp); | ||
148 | |||
149 | return tmp; | ||
150 | } | ||
151 | |||
152 | static void sil_iowrite8(struct pci_dev *dev, u8 val, unsigned long addr) | ||
153 | { | ||
154 | if (pci_get_drvdata(dev)) | ||
155 | writeb(val, (void __iomem *)addr); | ||
156 | else | ||
157 | pci_write_config_byte(dev, addr, val); | ||
158 | } | ||
159 | |||
160 | static void sil_iowrite16(struct pci_dev *dev, u16 val, unsigned long addr) | ||
161 | { | ||
162 | if (pci_get_drvdata(dev)) | ||
163 | writew(val, (void __iomem *)addr); | ||
164 | else | ||
165 | pci_write_config_word(dev, addr, val); | ||
166 | } | ||
167 | |||
168 | static void sil_iowrite32(struct pci_dev *dev, u32 val, unsigned long addr) | ||
169 | { | ||
170 | if (pci_get_drvdata(dev)) | ||
171 | writel(val, (void __iomem *)addr); | ||
172 | else | ||
173 | pci_write_config_dword(dev, addr, val); | ||
174 | } | ||
175 | |||
127 | /** | 176 | /** |
128 | * sil_udma_filter - compute UDMA mask | 177 | * sil_udma_filter - compute UDMA mask |
129 | * @drive: IDE device | 178 | * @drive: IDE device |
@@ -136,24 +185,26 @@ static inline unsigned long siimage_seldev(ide_drive_t *drive, int r) | |||
136 | 185 | ||
137 | static u8 sil_pata_udma_filter(ide_drive_t *drive) | 186 | static u8 sil_pata_udma_filter(ide_drive_t *drive) |
138 | { | 187 | { |
139 | ide_hwif_t *hwif = drive->hwif; | 188 | ide_hwif_t *hwif = drive->hwif; |
140 | struct pci_dev *dev = to_pci_dev(hwif->dev); | 189 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
141 | unsigned long base = (unsigned long) hwif->hwif_data; | 190 | unsigned long base = (unsigned long)hwif->hwif_data; |
142 | u8 mask = 0, scsc = 0; | 191 | u8 scsc, mask = 0; |
143 | 192 | ||
144 | if (hwif->mmio) | 193 | scsc = sil_ioread8(dev, base + (hwif->mmio ? 0x4A : 0x8A)); |
145 | scsc = hwif->INB(base + 0x4A); | ||
146 | else | ||
147 | pci_read_config_byte(dev, 0x8A, &scsc); | ||
148 | 194 | ||
149 | if ((scsc & 0x30) == 0x10) /* 133 */ | 195 | switch (scsc & 0x30) { |
196 | case 0x10: /* 133 */ | ||
150 | mask = ATA_UDMA6; | 197 | mask = ATA_UDMA6; |
151 | else if ((scsc & 0x30) == 0x20) /* 2xPCI */ | 198 | break; |
199 | case 0x20: /* 2xPCI */ | ||
152 | mask = ATA_UDMA6; | 200 | mask = ATA_UDMA6; |
153 | else if ((scsc & 0x30) == 0x00) /* 100 */ | 201 | break; |
202 | case 0x00: /* 100 */ | ||
154 | mask = ATA_UDMA5; | 203 | mask = ATA_UDMA5; |
155 | else /* Disabled ? */ | 204 | break; |
205 | default: /* Disabled ? */ | ||
156 | BUG(); | 206 | BUG(); |
207 | } | ||
157 | 208 | ||
158 | return mask; | 209 | return mask; |
159 | } | 210 | } |
@@ -175,15 +226,16 @@ static u8 sil_sata_udma_filter(ide_drive_t *drive) | |||
175 | 226 | ||
176 | static void sil_set_pio_mode(ide_drive_t *drive, u8 pio) | 227 | static void sil_set_pio_mode(ide_drive_t *drive, u8 pio) |
177 | { | 228 | { |
178 | const u16 tf_speed[] = { 0x328a, 0x2283, 0x1281, 0x10c3, 0x10c1 }; | 229 | static const u16 tf_speed[] = { 0x328a, 0x2283, 0x1281, 0x10c3, 0x10c1 }; |
179 | const u16 data_speed[] = { 0x328a, 0x2283, 0x1104, 0x10c3, 0x10c1 }; | 230 | static const u16 data_speed[] = { 0x328a, 0x2283, 0x1104, 0x10c3, 0x10c1 }; |
180 | 231 | ||
181 | ide_hwif_t *hwif = HWIF(drive); | 232 | ide_hwif_t *hwif = HWIF(drive); |
233 | struct pci_dev *dev = to_pci_dev(hwif->dev); | ||
182 | ide_drive_t *pair = ide_get_paired_drive(drive); | 234 | ide_drive_t *pair = ide_get_paired_drive(drive); |
183 | u32 speedt = 0; | 235 | u32 speedt = 0; |
184 | u16 speedp = 0; | 236 | u16 speedp = 0; |
185 | unsigned long addr = siimage_seldev(drive, 0x04); | 237 | unsigned long addr = siimage_seldev(drive, 0x04); |
186 | unsigned long tfaddr = siimage_selreg(hwif, 0x02); | 238 | unsigned long tfaddr = siimage_selreg(hwif, 0x02); |
187 | unsigned long base = (unsigned long)hwif->hwif_data; | 239 | unsigned long base = (unsigned long)hwif->hwif_data; |
188 | u8 tf_pio = pio; | 240 | u8 tf_pio = pio; |
189 | u8 addr_mask = hwif->channel ? (hwif->mmio ? 0xF4 : 0x84) | 241 | u8 addr_mask = hwif->channel ? (hwif->mmio ? 0xF4 : 0x84) |
@@ -203,36 +255,20 @@ static void sil_set_pio_mode(ide_drive_t *drive, u8 pio) | |||
203 | speedp = data_speed[pio]; | 255 | speedp = data_speed[pio]; |
204 | speedt = tf_speed[tf_pio]; | 256 | speedt = tf_speed[tf_pio]; |
205 | 257 | ||
206 | if (hwif->mmio) { | 258 | sil_iowrite16(dev, speedp, addr); |
207 | hwif->OUTW(speedp, addr); | 259 | sil_iowrite16(dev, speedt, tfaddr); |
208 | hwif->OUTW(speedt, tfaddr); | 260 | |
209 | /* Now set up IORDY */ | 261 | /* now set up IORDY */ |
210 | if (pio > 2) | 262 | speedp = sil_ioread16(dev, tfaddr - 2); |
211 | hwif->OUTW(hwif->INW(tfaddr-2)|0x200, tfaddr-2); | 263 | speedp &= ~0x200; |
212 | else | 264 | if (pio > 2) |
213 | hwif->OUTW(hwif->INW(tfaddr-2)&~0x200, tfaddr-2); | 265 | speedp |= 0x200; |
214 | 266 | sil_iowrite16(dev, speedp, tfaddr - 2); | |
215 | mode = hwif->INB(base + addr_mask); | 267 | |
216 | mode &= ~(unit ? 0x30 : 0x03); | 268 | mode = sil_ioread8(dev, base + addr_mask); |
217 | mode |= (unit ? 0x10 : 0x01); | 269 | mode &= ~(unit ? 0x30 : 0x03); |
218 | hwif->OUTB(mode, base + addr_mask); | 270 | mode |= unit ? 0x10 : 0x01; |
219 | } else { | 271 | sil_iowrite8(dev, mode, base + addr_mask); |
220 | struct pci_dev *dev = to_pci_dev(hwif->dev); | ||
221 | |||
222 | pci_write_config_word(dev, addr, speedp); | ||
223 | pci_write_config_word(dev, tfaddr, speedt); | ||
224 | pci_read_config_word(dev, tfaddr - 2, &speedp); | ||
225 | speedp &= ~0x200; | ||
226 | /* Set IORDY for mode 3 or 4 */ | ||
227 | if (pio > 2) | ||
228 | speedp |= 0x200; | ||
229 | pci_write_config_word(dev, tfaddr - 2, speedp); | ||
230 | |||
231 | pci_read_config_byte(dev, addr_mask, &mode); | ||
232 | mode &= ~(unit ? 0x30 : 0x03); | ||
233 | mode |= (unit ? 0x10 : 0x01); | ||
234 | pci_write_config_byte(dev, addr_mask, mode); | ||
235 | } | ||
236 | } | 272 | } |
237 | 273 | ||
238 | /** | 274 | /** |
@@ -245,59 +281,45 @@ static void sil_set_pio_mode(ide_drive_t *drive, u8 pio) | |||
245 | 281 | ||
246 | static void sil_set_dma_mode(ide_drive_t *drive, const u8 speed) | 282 | static void sil_set_dma_mode(ide_drive_t *drive, const u8 speed) |
247 | { | 283 | { |
248 | u8 ultra6[] = { 0x0F, 0x0B, 0x07, 0x05, 0x03, 0x02, 0x01 }; | 284 | static const u8 ultra6[] = { 0x0F, 0x0B, 0x07, 0x05, 0x03, 0x02, 0x01 }; |
249 | u8 ultra5[] = { 0x0C, 0x07, 0x05, 0x04, 0x02, 0x01 }; | 285 | static const u8 ultra5[] = { 0x0C, 0x07, 0x05, 0x04, 0x02, 0x01 }; |
250 | u16 dma[] = { 0x2208, 0x10C2, 0x10C1 }; | 286 | static const u16 dma[] = { 0x2208, 0x10C2, 0x10C1 }; |
251 | 287 | ||
252 | ide_hwif_t *hwif = HWIF(drive); | 288 | ide_hwif_t *hwif = HWIF(drive); |
253 | struct pci_dev *dev = to_pci_dev(hwif->dev); | 289 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
254 | u16 ultra = 0, multi = 0; | 290 | u16 ultra = 0, multi = 0; |
255 | u8 mode = 0, unit = drive->select.b.unit; | 291 | u8 mode = 0, unit = drive->select.b.unit; |
256 | unsigned long base = (unsigned long)hwif->hwif_data; | 292 | unsigned long base = (unsigned long)hwif->hwif_data; |
257 | u8 scsc = 0, addr_mask = ((hwif->channel) ? | 293 | u8 scsc = 0, addr_mask = hwif->channel ? |
258 | ((hwif->mmio) ? 0xF4 : 0x84) : | 294 | (hwif->mmio ? 0xF4 : 0x84) : |
259 | ((hwif->mmio) ? 0xB4 : 0x80)); | 295 | (hwif->mmio ? 0xB4 : 0x80); |
260 | |||
261 | unsigned long ma = siimage_seldev(drive, 0x08); | 296 | unsigned long ma = siimage_seldev(drive, 0x08); |
262 | unsigned long ua = siimage_seldev(drive, 0x0C); | 297 | unsigned long ua = siimage_seldev(drive, 0x0C); |
263 | 298 | ||
264 | if (hwif->mmio) { | 299 | scsc = sil_ioread8 (dev, base + (hwif->mmio ? 0x4A : 0x8A)); |
265 | scsc = hwif->INB(base + 0x4A); | 300 | mode = sil_ioread8 (dev, base + addr_mask); |
266 | mode = hwif->INB(base + addr_mask); | 301 | multi = sil_ioread16(dev, ma); |
267 | multi = hwif->INW(ma); | 302 | ultra = sil_ioread16(dev, ua); |
268 | ultra = hwif->INW(ua); | ||
269 | } else { | ||
270 | pci_read_config_byte(dev, 0x8A, &scsc); | ||
271 | pci_read_config_byte(dev, addr_mask, &mode); | ||
272 | pci_read_config_word(dev, ma, &multi); | ||
273 | pci_read_config_word(dev, ua, &ultra); | ||
274 | } | ||
275 | 303 | ||
276 | mode &= ~((unit) ? 0x30 : 0x03); | 304 | mode &= ~(unit ? 0x30 : 0x03); |
277 | ultra &= ~0x3F; | 305 | ultra &= ~0x3F; |
278 | scsc = ((scsc & 0x30) == 0x00) ? 0 : 1; | 306 | scsc = ((scsc & 0x30) == 0x00) ? 0 : 1; |
279 | 307 | ||
280 | scsc = is_sata(hwif) ? 1 : scsc; | 308 | scsc = is_sata(hwif) ? 1 : scsc; |
281 | 309 | ||
282 | if (speed >= XFER_UDMA_0) { | 310 | if (speed >= XFER_UDMA_0) { |
283 | multi = dma[2]; | 311 | multi = dma[2]; |
284 | ultra |= (scsc ? ultra6[speed - XFER_UDMA_0] : | 312 | ultra |= scsc ? ultra6[speed - XFER_UDMA_0] : |
285 | ultra5[speed - XFER_UDMA_0]); | 313 | ultra5[speed - XFER_UDMA_0]; |
286 | mode |= (unit ? 0x30 : 0x03); | 314 | mode |= unit ? 0x30 : 0x03; |
287 | } else { | 315 | } else { |
288 | multi = dma[speed - XFER_MW_DMA_0]; | 316 | multi = dma[speed - XFER_MW_DMA_0]; |
289 | mode |= (unit ? 0x20 : 0x02); | 317 | mode |= unit ? 0x20 : 0x02; |
290 | } | 318 | } |
291 | 319 | ||
292 | if (hwif->mmio) { | 320 | sil_iowrite8 (dev, mode, base + addr_mask); |
293 | hwif->OUTB(mode, base + addr_mask); | 321 | sil_iowrite16(dev, multi, ma); |
294 | hwif->OUTW(multi, ma); | 322 | sil_iowrite16(dev, ultra, ua); |
295 | hwif->OUTW(ultra, ua); | ||
296 | } else { | ||
297 | pci_write_config_byte(dev, addr_mask, mode); | ||
298 | pci_write_config_word(dev, ma, multi); | ||
299 | pci_write_config_word(dev, ua, ultra); | ||
300 | } | ||
301 | } | 323 | } |
302 | 324 | ||
303 | /* returns 1 if dma irq issued, 0 otherwise */ | 325 | /* returns 1 if dma irq issued, 0 otherwise */ |
@@ -309,13 +331,14 @@ static int siimage_io_dma_test_irq(ide_drive_t *drive) | |||
309 | unsigned long addr = siimage_selreg(hwif, 1); | 331 | unsigned long addr = siimage_selreg(hwif, 1); |
310 | 332 | ||
311 | /* return 1 if INTR asserted */ | 333 | /* return 1 if INTR asserted */ |
312 | if ((hwif->INB(hwif->dma_status) & 4) == 4) | 334 | if (hwif->INB(hwif->dma_status) & 4) |
313 | return 1; | 335 | return 1; |
314 | 336 | ||
315 | /* return 1 if Device INTR asserted */ | 337 | /* return 1 if Device INTR asserted */ |
316 | pci_read_config_byte(dev, addr, &dma_altstat); | 338 | pci_read_config_byte(dev, addr, &dma_altstat); |
317 | if (dma_altstat & 8) | 339 | if (dma_altstat & 8) |
318 | return 0; //return 1; | 340 | return 0; /* return 1; */ |
341 | |||
319 | return 0; | 342 | return 0; |
320 | } | 343 | } |
321 | 344 | ||
@@ -335,9 +358,9 @@ static int siimage_mmio_dma_test_irq(ide_drive_t *drive) | |||
335 | = (void __iomem *)hwif->sata_scr[SATA_ERROR_OFFSET]; | 358 | = (void __iomem *)hwif->sata_scr[SATA_ERROR_OFFSET]; |
336 | 359 | ||
337 | if (sata_error_addr) { | 360 | if (sata_error_addr) { |
338 | unsigned long base = (unsigned long)hwif->hwif_data; | 361 | unsigned long base = (unsigned long)hwif->hwif_data; |
339 | u32 ext_stat = readl((void __iomem *)(base + 0x10)); | 362 | u32 ext_stat = readl((void __iomem *)(base + 0x10)); |
340 | u8 watchdog = 0; | 363 | u8 watchdog = 0; |
341 | 364 | ||
342 | if (ext_stat & ((hwif->channel) ? 0x40 : 0x10)) { | 365 | if (ext_stat & ((hwif->channel) ? 0x40 : 0x10)) { |
343 | u32 sata_error = readl(sata_error_addr); | 366 | u32 sata_error = readl(sata_error_addr); |
@@ -346,25 +369,22 @@ static int siimage_mmio_dma_test_irq(ide_drive_t *drive) | |||
346 | watchdog = (sata_error & 0x00680000) ? 1 : 0; | 369 | watchdog = (sata_error & 0x00680000) ? 1 : 0; |
347 | printk(KERN_WARNING "%s: sata_error = 0x%08x, " | 370 | printk(KERN_WARNING "%s: sata_error = 0x%08x, " |
348 | "watchdog = %d, %s\n", | 371 | "watchdog = %d, %s\n", |
349 | drive->name, sata_error, watchdog, | 372 | drive->name, sata_error, watchdog, __func__); |
350 | __func__); | 373 | } else |
351 | |||
352 | } else { | ||
353 | watchdog = (ext_stat & 0x8000) ? 1 : 0; | 374 | watchdog = (ext_stat & 0x8000) ? 1 : 0; |
354 | } | ||
355 | ext_stat >>= 16; | ||
356 | 375 | ||
376 | ext_stat >>= 16; | ||
357 | if (!(ext_stat & 0x0404) && !watchdog) | 377 | if (!(ext_stat & 0x0404) && !watchdog) |
358 | return 0; | 378 | return 0; |
359 | } | 379 | } |
360 | 380 | ||
361 | /* return 1 if INTR asserted */ | 381 | /* return 1 if INTR asserted */ |
362 | if ((readb((void __iomem *)hwif->dma_status) & 0x04) == 0x04) | 382 | if (readb((void __iomem *)hwif->dma_status) & 0x04) |
363 | return 1; | 383 | return 1; |
364 | 384 | ||
365 | /* return 1 if Device INTR asserted */ | 385 | /* return 1 if Device INTR asserted */ |
366 | if ((readb((void __iomem *)addr) & 8) == 8) | 386 | if (readb((void __iomem *)addr) & 8) |
367 | return 0; //return 1; | 387 | return 0; /* return 1; */ |
368 | 388 | ||
369 | return 0; | 389 | return 0; |
370 | } | 390 | } |
@@ -423,63 +443,33 @@ static void sil_sata_pre_reset(ide_drive_t *drive) | |||
423 | } | 443 | } |
424 | 444 | ||
425 | /** | 445 | /** |
426 | * proc_reports_siimage - add siimage controller to proc | 446 | * setup_mmio_siimage - switch controller into MMIO mode |
427 | * @dev: PCI device | ||
428 | * @clocking: SCSC value | ||
429 | * @name: controller name | ||
430 | * | ||
431 | * Report the clocking mode of the controller and add it to | ||
432 | * the /proc interface layer | ||
433 | */ | ||
434 | |||
435 | static void proc_reports_siimage (struct pci_dev *dev, u8 clocking, const char *name) | ||
436 | { | ||
437 | if (!pdev_is_sata(dev)) { | ||
438 | printk(KERN_INFO "%s: BASE CLOCK ", name); | ||
439 | clocking &= 0x03; | ||
440 | switch (clocking) { | ||
441 | case 0x03: printk("DISABLED!\n"); break; | ||
442 | case 0x02: printk("== 2X PCI\n"); break; | ||
443 | case 0x01: printk("== 133\n"); break; | ||
444 | case 0x00: printk("== 100\n"); break; | ||
445 | } | ||
446 | } | ||
447 | } | ||
448 | |||
449 | /** | ||
450 | * setup_mmio_siimage - switch an SI controller into MMIO | ||
451 | * @dev: PCI device we are configuring | 447 | * @dev: PCI device we are configuring |
452 | * @name: device name | 448 | * @name: device name |
453 | * | 449 | * |
454 | * Attempt to put the device into mmio mode. There are some slight | 450 | * Attempt to put the device into MMIO mode. There are some slight |
455 | * complications here with certain systems where the mmio bar isnt | 451 | * complications here with certain systems where the MMIO BAR isn't |
456 | * mapped so we have to be sure we can fall back to I/O. | 452 | * mapped, so we have to be sure that we can fall back to I/O. |
457 | */ | 453 | */ |
458 | 454 | ||
459 | static unsigned int setup_mmio_siimage (struct pci_dev *dev, const char *name) | 455 | static unsigned int setup_mmio_siimage(struct pci_dev *dev, const char *name) |
460 | { | 456 | { |
461 | resource_size_t bar5 = pci_resource_start(dev, 5); | 457 | resource_size_t bar5 = pci_resource_start(dev, 5); |
462 | unsigned long barsize = pci_resource_len(dev, 5); | 458 | unsigned long barsize = pci_resource_len(dev, 5); |
463 | u8 tmpbyte = 0; | ||
464 | void __iomem *ioaddr; | 459 | void __iomem *ioaddr; |
465 | u32 tmp, irq_mask; | ||
466 | 460 | ||
467 | /* | 461 | /* |
468 | * Drop back to PIO if we can't map the mmio. Some | 462 | * Drop back to PIO if we can't map the MMIO. Some systems |
469 | * systems seem to get terminally confused in the PCI | 463 | * seem to get terminally confused in the PCI spaces. |
470 | * spaces. | ||
471 | */ | 464 | */ |
472 | 465 | if (!request_mem_region(bar5, barsize, name)) { | |
473 | if(!request_mem_region(bar5, barsize, name)) | 466 | printk(KERN_WARNING "siimage: IDE controller MMIO ports not " |
474 | { | 467 | "available.\n"); |
475 | printk(KERN_WARNING "siimage: IDE controller MMIO ports not available.\n"); | ||
476 | return 0; | 468 | return 0; |
477 | } | 469 | } |
478 | |||
479 | ioaddr = ioremap(bar5, barsize); | ||
480 | 470 | ||
481 | if (ioaddr == NULL) | 471 | ioaddr = ioremap(bar5, barsize); |
482 | { | 472 | if (ioaddr == NULL) { |
483 | release_mem_region(bar5, barsize); | 473 | release_mem_region(bar5, barsize); |
484 | return 0; | 474 | return 0; |
485 | } | 475 | } |
@@ -487,62 +477,6 @@ static unsigned int setup_mmio_siimage (struct pci_dev *dev, const char *name) | |||
487 | pci_set_master(dev); | 477 | pci_set_master(dev); |
488 | pci_set_drvdata(dev, (void *) ioaddr); | 478 | pci_set_drvdata(dev, (void *) ioaddr); |
489 | 479 | ||
490 | if (pdev_is_sata(dev)) { | ||
491 | /* make sure IDE0/1 interrupts are not masked */ | ||
492 | irq_mask = (1 << 22) | (1 << 23); | ||
493 | tmp = readl(ioaddr + 0x48); | ||
494 | if (tmp & irq_mask) { | ||
495 | tmp &= ~irq_mask; | ||
496 | writel(tmp, ioaddr + 0x48); | ||
497 | readl(ioaddr + 0x48); /* flush */ | ||
498 | } | ||
499 | writel(0, ioaddr + 0x148); | ||
500 | writel(0, ioaddr + 0x1C8); | ||
501 | } | ||
502 | |||
503 | writeb(0, ioaddr + 0xB4); | ||
504 | writeb(0, ioaddr + 0xF4); | ||
505 | tmpbyte = readb(ioaddr + 0x4A); | ||
506 | |||
507 | switch(tmpbyte & 0x30) { | ||
508 | case 0x00: | ||
509 | /* In 100 MHz clocking, try and switch to 133 */ | ||
510 | writeb(tmpbyte|0x10, ioaddr + 0x4A); | ||
511 | break; | ||
512 | case 0x10: | ||
513 | /* On 133Mhz clocking */ | ||
514 | break; | ||
515 | case 0x20: | ||
516 | /* On PCIx2 clocking */ | ||
517 | break; | ||
518 | case 0x30: | ||
519 | /* Clocking is disabled */ | ||
520 | /* 133 clock attempt to force it on */ | ||
521 | writeb(tmpbyte & ~0x20, ioaddr + 0x4A); | ||
522 | break; | ||
523 | } | ||
524 | |||
525 | writeb( 0x72, ioaddr + 0xA1); | ||
526 | writew( 0x328A, ioaddr + 0xA2); | ||
527 | writel(0x62DD62DD, ioaddr + 0xA4); | ||
528 | writel(0x43924392, ioaddr + 0xA8); | ||
529 | writel(0x40094009, ioaddr + 0xAC); | ||
530 | writeb( 0x72, ioaddr + 0xE1); | ||
531 | writew( 0x328A, ioaddr + 0xE2); | ||
532 | writel(0x62DD62DD, ioaddr + 0xE4); | ||
533 | writel(0x43924392, ioaddr + 0xE8); | ||
534 | writel(0x40094009, ioaddr + 0xEC); | ||
535 | |||
536 | if (pdev_is_sata(dev)) { | ||
537 | writel(0xFFFF0000, ioaddr + 0x108); | ||
538 | writel(0xFFFF0000, ioaddr + 0x188); | ||
539 | writel(0x00680000, ioaddr + 0x148); | ||
540 | writel(0x00680000, ioaddr + 0x1C8); | ||
541 | } | ||
542 | |||
543 | tmpbyte = readb(ioaddr + 0x4A); | ||
544 | |||
545 | proc_reports_siimage(dev, (tmpbyte>>4), name); | ||
546 | return 1; | 480 | return 1; |
547 | } | 481 | } |
548 | 482 | ||
@@ -552,55 +486,92 @@ static unsigned int setup_mmio_siimage (struct pci_dev *dev, const char *name) | |||
552 | * @name: device name | 486 | * @name: device name |
553 | * | 487 | * |
554 | * Perform the initial PCI set up for this device. Attempt to switch | 488 | * Perform the initial PCI set up for this device. Attempt to switch |
555 | * to 133MHz clocking if the system isn't already set up to do it. | 489 | * to 133 MHz clocking if the system isn't already set up to do it. |
556 | */ | 490 | */ |
557 | 491 | ||
558 | static unsigned int __devinit init_chipset_siimage(struct pci_dev *dev, const char *name) | 492 | static unsigned int __devinit init_chipset_siimage(struct pci_dev *dev, |
493 | const char *name) | ||
559 | { | 494 | { |
560 | u8 rev = dev->revision, tmpbyte = 0, BA5_EN = 0; | 495 | unsigned long base, scsc_addr; |
496 | void __iomem *ioaddr = NULL; | ||
497 | u8 rev = dev->revision, tmp, BA5_EN; | ||
561 | 498 | ||
562 | pci_write_config_byte(dev, PCI_CACHE_LINE_SIZE, rev ? 1 : 255); | 499 | pci_write_config_byte(dev, PCI_CACHE_LINE_SIZE, rev ? 1 : 255); |
563 | 500 | ||
564 | pci_read_config_byte(dev, 0x8A, &BA5_EN); | 501 | pci_read_config_byte(dev, 0x8A, &BA5_EN); |
565 | if ((BA5_EN & 0x01) || (pci_resource_start(dev, 5))) { | 502 | |
566 | if (setup_mmio_siimage(dev, name)) { | 503 | if ((BA5_EN & 0x01) || pci_resource_start(dev, 5)) |
567 | return 0; | 504 | if (setup_mmio_siimage(dev, name)) |
505 | ioaddr = pci_get_drvdata(dev); | ||
506 | |||
507 | base = (unsigned long)ioaddr; | ||
508 | |||
509 | if (ioaddr && pdev_is_sata(dev)) { | ||
510 | u32 tmp32, irq_mask; | ||
511 | |||
512 | /* make sure IDE0/1 interrupts are not masked */ | ||
513 | irq_mask = (1 << 22) | (1 << 23); | ||
514 | tmp32 = readl(ioaddr + 0x48); | ||
515 | if (tmp32 & irq_mask) { | ||
516 | tmp32 &= ~irq_mask; | ||
517 | writel(tmp32, ioaddr + 0x48); | ||
518 | readl(ioaddr + 0x48); /* flush */ | ||
568 | } | 519 | } |
520 | writel(0, ioaddr + 0x148); | ||
521 | writel(0, ioaddr + 0x1C8); | ||
522 | } | ||
523 | |||
524 | sil_iowrite8(dev, 0, base ? (base + 0xB4) : 0x80); | ||
525 | sil_iowrite8(dev, 0, base ? (base + 0xF4) : 0x84); | ||
526 | |||
527 | scsc_addr = base ? (base + 0x4A) : 0x8A; | ||
528 | tmp = sil_ioread8(dev, scsc_addr); | ||
529 | |||
530 | switch (tmp & 0x30) { | ||
531 | case 0x00: | ||
532 | /* On 100 MHz clocking, try and switch to 133 MHz */ | ||
533 | sil_iowrite8(dev, tmp | 0x10, scsc_addr); | ||
534 | break; | ||
535 | case 0x30: | ||
536 | /* Clocking is disabled, attempt to force 133MHz clocking. */ | ||
537 | sil_iowrite8(dev, tmp & ~0x20, scsc_addr); | ||
538 | case 0x10: | ||
539 | /* On 133Mhz clocking. */ | ||
540 | break; | ||
541 | case 0x20: | ||
542 | /* On PCIx2 clocking. */ | ||
543 | break; | ||
569 | } | 544 | } |
570 | 545 | ||
571 | pci_write_config_byte(dev, 0x80, 0x00); | 546 | tmp = sil_ioread8(dev, scsc_addr); |
572 | pci_write_config_byte(dev, 0x84, 0x00); | 547 | |
573 | pci_read_config_byte(dev, 0x8A, &tmpbyte); | 548 | sil_iowrite8 (dev, 0x72, base + 0xA1); |
574 | switch(tmpbyte & 0x30) { | 549 | sil_iowrite16(dev, 0x328A, base + 0xA2); |
575 | case 0x00: | 550 | sil_iowrite32(dev, 0x62DD62DD, base + 0xA4); |
576 | /* 133 clock attempt to force it on */ | 551 | sil_iowrite32(dev, 0x43924392, base + 0xA8); |
577 | pci_write_config_byte(dev, 0x8A, tmpbyte|0x10); | 552 | sil_iowrite32(dev, 0x40094009, base + 0xAC); |
578 | case 0x30: | 553 | sil_iowrite8 (dev, 0x72, base ? (base + 0xE1) : 0xB1); |
579 | /* if clocking is disabled */ | 554 | sil_iowrite16(dev, 0x328A, base ? (base + 0xE2) : 0xB2); |
580 | /* 133 clock attempt to force it on */ | 555 | sil_iowrite32(dev, 0x62DD62DD, base ? (base + 0xE4) : 0xB4); |
581 | pci_write_config_byte(dev, 0x8A, tmpbyte & ~0x20); | 556 | sil_iowrite32(dev, 0x43924392, base ? (base + 0xE8) : 0xB8); |
582 | case 0x10: | 557 | sil_iowrite32(dev, 0x40094009, base ? (base + 0xEC) : 0xBC); |
583 | /* 133 already */ | 558 | |
584 | break; | 559 | if (base && pdev_is_sata(dev)) { |
585 | case 0x20: | 560 | writel(0xFFFF0000, ioaddr + 0x108); |
586 | /* BIOS set PCI x2 clocking */ | 561 | writel(0xFFFF0000, ioaddr + 0x188); |
587 | break; | 562 | writel(0x00680000, ioaddr + 0x148); |
563 | writel(0x00680000, ioaddr + 0x1C8); | ||
588 | } | 564 | } |
589 | 565 | ||
590 | pci_read_config_byte(dev, 0x8A, &tmpbyte); | 566 | /* report the clocking mode of the controller */ |
567 | if (!pdev_is_sata(dev)) { | ||
568 | static const char *clk_str[] = | ||
569 | { "== 100", "== 133", "== 2X PCI", "DISABLED!" }; | ||
591 | 570 | ||
592 | pci_write_config_byte(dev, 0xA1, 0x72); | 571 | tmp >>= 4; |
593 | pci_write_config_word(dev, 0xA2, 0x328A); | 572 | printk(KERN_INFO "%s: BASE CLOCK %s\n", name, clk_str[tmp & 3]); |
594 | pci_write_config_dword(dev, 0xA4, 0x62DD62DD); | 573 | } |
595 | pci_write_config_dword(dev, 0xA8, 0x43924392); | ||
596 | pci_write_config_dword(dev, 0xAC, 0x40094009); | ||
597 | pci_write_config_byte(dev, 0xB1, 0x72); | ||
598 | pci_write_config_word(dev, 0xB2, 0x328A); | ||
599 | pci_write_config_dword(dev, 0xB4, 0x62DD62DD); | ||
600 | pci_write_config_dword(dev, 0xB8, 0x43924392); | ||
601 | pci_write_config_dword(dev, 0xBC, 0x40094009); | ||
602 | 574 | ||
603 | proc_reports_siimage(dev, (tmpbyte>>4), name); | ||
604 | return 0; | 575 | return 0; |
605 | } | 576 | } |
606 | 577 | ||
@@ -610,8 +581,7 @@ static unsigned int __devinit init_chipset_siimage(struct pci_dev *dev, const ch | |||
610 | * | 581 | * |
611 | * The basic setup here is fairly simple, we can use standard MMIO | 582 | * The basic setup here is fairly simple, we can use standard MMIO |
612 | * operations. However we do have to set the taskfile register offsets | 583 | * operations. However we do have to set the taskfile register offsets |
613 | * by hand as there isnt a standard defined layout for them this | 584 | * by hand as there isn't a standard defined layout for them this time. |
614 | * time. | ||
615 | * | 585 | * |
616 | * The hardware supports buffered taskfiles and also some rather nice | 586 | * The hardware supports buffered taskfiles and also some rather nice |
617 | * extended PRD tables. For better SI3112 support use the libata driver | 587 | * extended PRD tables. For better SI3112 support use the libata driver |
@@ -622,23 +592,21 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif) | |||
622 | struct pci_dev *dev = to_pci_dev(hwif->dev); | 592 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
623 | void *addr = pci_get_drvdata(dev); | 593 | void *addr = pci_get_drvdata(dev); |
624 | u8 ch = hwif->channel; | 594 | u8 ch = hwif->channel; |
625 | hw_regs_t hw; | 595 | struct ide_io_ports *io_ports = &hwif->io_ports; |
626 | unsigned long base; | 596 | unsigned long base; |
627 | 597 | ||
628 | /* | 598 | /* |
629 | * Fill in the basic HWIF bits | 599 | * Fill in the basic hwif bits |
630 | */ | 600 | */ |
631 | 601 | hwif->host_flags |= IDE_HFLAG_MMIO; | |
632 | default_hwif_mmiops(hwif); | 602 | default_hwif_mmiops(hwif); |
633 | hwif->hwif_data = addr; | 603 | hwif->hwif_data = addr; |
634 | 604 | ||
635 | /* | 605 | /* |
636 | * Now set up the hw. We have to do this ourselves as | 606 | * Now set up the hw. We have to do this ourselves as the |
637 | * the MMIO layout isnt the same as the standard port | 607 | * MMIO layout isn't the same as the standard port based I/O. |
638 | * based I/O | ||
639 | */ | 608 | */ |
640 | 609 | memset(io_ports, 0, sizeof(*io_ports)); | |
641 | memset(&hw, 0, sizeof(hw_regs_t)); | ||
642 | 610 | ||
643 | base = (unsigned long)addr; | 611 | base = (unsigned long)addr; |
644 | if (ch) | 612 | if (ch) |
@@ -647,21 +615,18 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif) | |||
647 | base += 0x80; | 615 | base += 0x80; |
648 | 616 | ||
649 | /* | 617 | /* |
650 | * The buffered task file doesn't have status/control | 618 | * The buffered task file doesn't have status/control, so we |
651 | * so we can't currently use it sanely since we want to | 619 | * can't currently use it sanely since we want to use LBA48 mode. |
652 | * use LBA48 mode. | 620 | */ |
653 | */ | 621 | io_ports->data_addr = base; |
654 | hw.io_ports[IDE_DATA_OFFSET] = base; | 622 | io_ports->error_addr = base + 1; |
655 | hw.io_ports[IDE_ERROR_OFFSET] = base + 1; | 623 | io_ports->nsect_addr = base + 2; |
656 | hw.io_ports[IDE_NSECTOR_OFFSET] = base + 2; | 624 | io_ports->lbal_addr = base + 3; |
657 | hw.io_ports[IDE_SECTOR_OFFSET] = base + 3; | 625 | io_ports->lbam_addr = base + 4; |
658 | hw.io_ports[IDE_LCYL_OFFSET] = base + 4; | 626 | io_ports->lbah_addr = base + 5; |
659 | hw.io_ports[IDE_HCYL_OFFSET] = base + 5; | 627 | io_ports->device_addr = base + 6; |
660 | hw.io_ports[IDE_SELECT_OFFSET] = base + 6; | 628 | io_ports->status_addr = base + 7; |
661 | hw.io_ports[IDE_STATUS_OFFSET] = base + 7; | 629 | io_ports->ctl_addr = base + 10; |
662 | hw.io_ports[IDE_CONTROL_OFFSET] = base + 10; | ||
663 | |||
664 | hw.io_ports[IDE_IRQ_OFFSET] = 0; | ||
665 | 630 | ||
666 | if (pdev_is_sata(dev)) { | 631 | if (pdev_is_sata(dev)) { |
667 | base = (unsigned long)addr; | 632 | base = (unsigned long)addr; |
@@ -672,8 +637,6 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif) | |||
672 | hwif->sata_scr[SATA_CONTROL_OFFSET] = base + 0x100; | 637 | hwif->sata_scr[SATA_CONTROL_OFFSET] = base + 0x100; |
673 | } | 638 | } |
674 | 639 | ||
675 | memcpy(hwif->io_ports, hw.io_ports, sizeof(hwif->io_ports)); | ||
676 | |||
677 | hwif->irq = dev->irq; | 640 | hwif->irq = dev->irq; |
678 | 641 | ||
679 | hwif->dma_base = (unsigned long)addr + (ch ? 0x08 : 0x00); | 642 | hwif->dma_base = (unsigned long)addr + (ch ? 0x08 : 0x00); |
@@ -683,19 +646,17 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif) | |||
683 | 646 | ||
684 | static int is_dev_seagate_sata(ide_drive_t *drive) | 647 | static int is_dev_seagate_sata(ide_drive_t *drive) |
685 | { | 648 | { |
686 | const char *s = &drive->id->model[0]; | 649 | const char *s = &drive->id->model[0]; |
687 | unsigned len; | 650 | unsigned len = strnlen(s, sizeof(drive->id->model)); |
688 | |||
689 | len = strnlen(s, sizeof(drive->id->model)); | ||
690 | 651 | ||
691 | if ((len > 4) && (!memcmp(s, "ST", 2))) { | 652 | if ((len > 4) && (!memcmp(s, "ST", 2))) |
692 | if ((!memcmp(s + len - 2, "AS", 2)) || | 653 | if ((!memcmp(s + len - 2, "AS", 2)) || |
693 | (!memcmp(s + len - 3, "ASL", 3))) { | 654 | (!memcmp(s + len - 3, "ASL", 3))) { |
694 | printk(KERN_INFO "%s: applying pessimistic Seagate " | 655 | printk(KERN_INFO "%s: applying pessimistic Seagate " |
695 | "errata fix\n", drive->name); | 656 | "errata fix\n", drive->name); |
696 | return 1; | 657 | return 1; |
697 | } | 658 | } |
698 | } | 659 | |
699 | return 0; | 660 | return 0; |
700 | } | 661 | } |
701 | 662 | ||
@@ -712,7 +673,7 @@ static void __devinit sil_quirkproc(ide_drive_t *drive) | |||
712 | { | 673 | { |
713 | ide_hwif_t *hwif = drive->hwif; | 674 | ide_hwif_t *hwif = drive->hwif; |
714 | 675 | ||
715 | /* Try and raise the rqsize */ | 676 | /* Try and rise the rqsize */ |
716 | if (!is_sata(hwif) || !is_dev_seagate_sata(drive)) | 677 | if (!is_sata(hwif) || !is_dev_seagate_sata(drive)) |
717 | hwif->rqsize = 128; | 678 | hwif->rqsize = 128; |
718 | } | 679 | } |
@@ -746,20 +707,14 @@ static void __devinit init_iops_siimage(ide_hwif_t *hwif) | |||
746 | * sil_cable_detect - cable detection | 707 | * sil_cable_detect - cable detection |
747 | * @hwif: interface to check | 708 | * @hwif: interface to check |
748 | * | 709 | * |
749 | * Check for the presence of an ATA66 capable cable on the | 710 | * Check for the presence of an ATA66 capable cable on the interface. |
750 | * interface. | ||
751 | */ | 711 | */ |
752 | 712 | ||
753 | static u8 __devinit sil_cable_detect(ide_hwif_t *hwif) | 713 | static u8 __devinit sil_cable_detect(ide_hwif_t *hwif) |
754 | { | 714 | { |
755 | struct pci_dev *dev = to_pci_dev(hwif->dev); | 715 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
756 | unsigned long addr = siimage_selreg(hwif, 0); | 716 | unsigned long addr = siimage_selreg(hwif, 0); |
757 | u8 ata66 = 0; | 717 | u8 ata66 = sil_ioread8(dev, addr); |
758 | |||
759 | if (pci_get_drvdata(dev) == NULL) | ||
760 | pci_read_config_byte(dev, addr, &ata66); | ||
761 | else | ||
762 | ata66 = hwif->INB(addr); | ||
763 | 718 | ||
764 | return (ata66 & 0x01) ? ATA_CBL_PATA80 : ATA_CBL_PATA40; | 719 | return (ata66 & 0x01) ? ATA_CBL_PATA80 : ATA_CBL_PATA40; |
765 | } | 720 | } |
@@ -805,15 +760,16 @@ static const struct ide_port_info siimage_chipsets[] __devinitdata = { | |||
805 | }; | 760 | }; |
806 | 761 | ||
807 | /** | 762 | /** |
808 | * siimage_init_one - pci layer discovery entry | 763 | * siimage_init_one - PCI layer discovery entry |
809 | * @dev: PCI device | 764 | * @dev: PCI device |
810 | * @id: ident table entry | 765 | * @id: ident table entry |
811 | * | 766 | * |
812 | * Called by the PCI code when it finds an SI680 or SI3112 controller. | 767 | * Called by the PCI code when it finds an SiI680 or SiI3112 controller. |
813 | * We then use the IDE PCI generic helper to do most of the work. | 768 | * We then use the IDE PCI generic helper to do most of the work. |
814 | */ | 769 | */ |
815 | 770 | ||
816 | static int __devinit siimage_init_one(struct pci_dev *dev, const struct pci_device_id *id) | 771 | static int __devinit siimage_init_one(struct pci_dev *dev, |
772 | const struct pci_device_id *id) | ||
817 | { | 773 | { |
818 | struct ide_port_info d; | 774 | struct ide_port_info d; |
819 | u8 idx = id->driver_data; | 775 | u8 idx = id->driver_data; |