Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
[linux-2.6] / drivers / ide / pci / pdc202xx_old.c
1 /*
2  *  linux/drivers/ide/pci/pdc202xx_old.c        Version 0.36    Sept 11, 2002
3  *
4  *  Copyright (C) 1998-2002             Andre Hedrick <andre@linux-ide.org>
5  *
6  *  Promise Ultra33 cards with BIOS v1.20 through 1.28 will need this
7  *  compiled into the kernel if you have more than one card installed.
8  *  Note that BIOS v1.29 is reported to fix the problem.  Since this is
9  *  safe chipset tuning, including this support is harmless
10  *
11  *  Promise Ultra66 cards with BIOS v1.11 this
12  *  compiled into the kernel if you have more than one card installed.
13  *
14  *  Promise Ultra100 cards.
15  *
16  *  The latest chipset code will support the following ::
17  *  Three Ultra33 controllers and 12 drives.
18  *  8 are UDMA supported and 4 are limited to DMA mode 2 multi-word.
19  *  The 8/4 ratio is a BIOS code limit by promise.
20  *
21  *  UNLESS you enable "CONFIG_PDC202XX_BURST"
22  *
23  */
24
25 /*
26  *  Portions Copyright (C) 1999 Promise Technology, Inc.
27  *  Author: Frank Tiernan (frankt@promise.com)
28  *  Released under terms of General Public License
29  */
30
31 #include <linux/config.h>
32 #include <linux/types.h>
33 #include <linux/module.h>
34 #include <linux/kernel.h>
35 #include <linux/delay.h>
36 #include <linux/timer.h>
37 #include <linux/mm.h>
38 #include <linux/ioport.h>
39 #include <linux/blkdev.h>
40 #include <linux/hdreg.h>
41 #include <linux/interrupt.h>
42 #include <linux/pci.h>
43 #include <linux/init.h>
44 #include <linux/ide.h>
45
46 #include <asm/io.h>
47 #include <asm/irq.h>
48
49 #define PDC202_DEBUG_CABLE              0
50 #define PDC202XX_DEBUG_DRIVE_INFO       0
51
52 static const char *pdc_quirk_drives[] = {
53         "QUANTUM FIREBALLlct08 08",
54         "QUANTUM FIREBALLP KA6.4",
55         "QUANTUM FIREBALLP KA9.1",
56         "QUANTUM FIREBALLP LM20.4",
57         "QUANTUM FIREBALLP KX13.6",
58         "QUANTUM FIREBALLP KX20.5",
59         "QUANTUM FIREBALLP KX27.3",
60         "QUANTUM FIREBALLP LM20.5",
61         NULL
62 };
63
64 /* A Register */
65 #define SYNC_ERRDY_EN   0xC0
66
67 #define SYNC_IN         0x80    /* control bit, different for master vs. slave drives */
68 #define ERRDY_EN        0x40    /* control bit, different for master vs. slave drives */
69 #define IORDY_EN        0x20    /* PIO: IOREADY */
70 #define PREFETCH_EN     0x10    /* PIO: PREFETCH */
71
72 #define PA3             0x08    /* PIO"A" timing */
73 #define PA2             0x04    /* PIO"A" timing */
74 #define PA1             0x02    /* PIO"A" timing */
75 #define PA0             0x01    /* PIO"A" timing */
76
77 /* B Register */
78
79 #define MB2             0x80    /* DMA"B" timing */
80 #define MB1             0x40    /* DMA"B" timing */
81 #define MB0             0x20    /* DMA"B" timing */
82
83 #define PB4             0x10    /* PIO_FORCE 1:0 */
84
85 #define PB3             0x08    /* PIO"B" timing */     /* PIO flow Control mode */
86 #define PB2             0x04    /* PIO"B" timing */     /* PIO 4 */
87 #define PB1             0x02    /* PIO"B" timing */     /* PIO 3 half */
88 #define PB0             0x01    /* PIO"B" timing */     /* PIO 3 other half */
89
90 /* C Register */
91 #define IORDYp_NO_SPEED 0x4F
92 #define SPEED_DIS       0x0F
93
94 #define DMARQp          0x80
95 #define IORDYp          0x40
96 #define DMAR_EN         0x20
97 #define DMAW_EN         0x10
98
99 #define MC3             0x08    /* DMA"C" timing */
100 #define MC2             0x04    /* DMA"C" timing */
101 #define MC1             0x02    /* DMA"C" timing */
102 #define MC0             0x01    /* DMA"C" timing */
103
104 #if 0
105         unsigned long bibma  = pci_resource_start(dev, 4);
106         u8 hi = 0, lo = 0;
107
108         u8 sc1c = inb_p((u16)bibma + 0x1c); 
109         u8 sc1e = inb_p((u16)bibma + 0x1e);
110         u8 sc1f = inb_p((u16)bibma + 0x1f);
111
112         p += sprintf(p, "Host Mode                            : %s\n",
113                 (sc1f & 0x08) ? "Tri-Stated" : "Normal");
114         p += sprintf(p, "Bus Clocking                         : %s\n",
115                 ((sc1f & 0xC0) == 0xC0) ? "100 External" :
116                 ((sc1f & 0x80) == 0x80) ? "66 External" :
117                 ((sc1f & 0x40) == 0x40) ? "33 External" : "33 PCI Internal");
118         p += sprintf(p, "IO pad select                        : %s mA\n",
119                 ((sc1c & 0x03) == 0x03) ? "10" :
120                 ((sc1c & 0x02) == 0x02) ? "8" :
121                 ((sc1c & 0x01) == 0x01) ? "6" :
122                 ((sc1c & 0x00) == 0x00) ? "4" : "??");
123         hi = sc1e >> 4;
124         lo = sc1e & 0xf;
125         p += sprintf(p, "Status Polling Period                : %d\n", hi);
126         p += sprintf(p, "Interrupt Check Status Polling Delay : %d\n", lo);
127 #endif
128
129 static u8 pdc202xx_ratemask (ide_drive_t *drive)
130 {
131         u8 mode;
132
133         switch(HWIF(drive)->pci_dev->device) {
134                 case PCI_DEVICE_ID_PROMISE_20267:
135                 case PCI_DEVICE_ID_PROMISE_20265:
136                         mode = 3;
137                         break;
138                 case PCI_DEVICE_ID_PROMISE_20263:
139                 case PCI_DEVICE_ID_PROMISE_20262:
140                         mode = 2;
141                         break;
142                 case PCI_DEVICE_ID_PROMISE_20246:
143                         return 1;
144                 default:
145                         return 0;
146         }
147         if (!eighty_ninty_three(drive))
148                 mode = min(mode, (u8)1);
149         return mode;
150 }
151
152 static int check_in_drive_lists (ide_drive_t *drive, const char **list)
153 {
154         struct hd_driveid *id = drive->id;
155
156         if (pdc_quirk_drives == list) {
157                 while (*list) {
158                         if (strstr(id->model, *list++)) {
159                                 return 2;
160                         }
161                 }
162         } else {
163                 while (*list) {
164                         if (!strcmp(*list++,id->model)) {
165                                 return 1;
166                         }
167                 }
168         }
169         return 0;
170 }
171
172 static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
173 {
174         ide_hwif_t *hwif        = HWIF(drive);
175         struct pci_dev *dev     = hwif->pci_dev;
176         u8 drive_pci            = 0x60 + (drive->dn << 2);
177         u8 speed        = ide_rate_filter(pdc202xx_ratemask(drive), xferspeed);
178
179         u32                     drive_conf;
180         u8                      AP, BP, CP, DP;
181         u8                      TA = 0, TB = 0, TC = 0;
182
183         if ((drive->media != ide_disk) && (speed < XFER_SW_DMA_0))
184                 return -1;
185
186         pci_read_config_dword(dev, drive_pci, &drive_conf);
187         pci_read_config_byte(dev, (drive_pci), &AP);
188         pci_read_config_byte(dev, (drive_pci)|0x01, &BP);
189         pci_read_config_byte(dev, (drive_pci)|0x02, &CP);
190         pci_read_config_byte(dev, (drive_pci)|0x03, &DP);
191
192         if (speed < XFER_SW_DMA_0) {
193                 if ((AP & 0x0F) || (BP & 0x07)) {
194                         /* clear PIO modes of lower 8421 bits of A Register */
195                         pci_write_config_byte(dev, (drive_pci), AP &~0x0F);
196                         pci_read_config_byte(dev, (drive_pci), &AP);
197
198                         /* clear PIO modes of lower 421 bits of B Register */
199                         pci_write_config_byte(dev, (drive_pci)|0x01, BP &~0x07);
200                         pci_read_config_byte(dev, (drive_pci)|0x01, &BP);
201
202                         pci_read_config_byte(dev, (drive_pci), &AP);
203                         pci_read_config_byte(dev, (drive_pci)|0x01, &BP);
204                 }
205         } else {
206                 if ((BP & 0xF0) && (CP & 0x0F)) {
207                         /* clear DMA modes of upper 842 bits of B Register */
208                         /* clear PIO forced mode upper 1 bit of B Register */
209                         pci_write_config_byte(dev, (drive_pci)|0x01, BP &~0xF0);
210                         pci_read_config_byte(dev, (drive_pci)|0x01, &BP);
211
212                         /* clear DMA modes of lower 8421 bits of C Register */
213                         pci_write_config_byte(dev, (drive_pci)|0x02, CP &~0x0F);
214                         pci_read_config_byte(dev, (drive_pci)|0x02, &CP);
215                 }
216         }
217
218         pci_read_config_byte(dev, (drive_pci), &AP);
219         pci_read_config_byte(dev, (drive_pci)|0x01, &BP);
220         pci_read_config_byte(dev, (drive_pci)|0x02, &CP);
221
222         switch(speed) {
223                 case XFER_UDMA_6:       speed = XFER_UDMA_5;
224                 case XFER_UDMA_5:
225                 case XFER_UDMA_4:       TB = 0x20; TC = 0x01; break;
226                 case XFER_UDMA_2:       TB = 0x20; TC = 0x01; break;
227                 case XFER_UDMA_3:
228                 case XFER_UDMA_1:       TB = 0x40; TC = 0x02; break;
229                 case XFER_UDMA_0:
230                 case XFER_MW_DMA_2:     TB = 0x60; TC = 0x03; break;
231                 case XFER_MW_DMA_1:     TB = 0x60; TC = 0x04; break;
232                 case XFER_MW_DMA_0:
233                 case XFER_SW_DMA_2:     TB = 0x60; TC = 0x05; break;
234                 case XFER_SW_DMA_1:     TB = 0x80; TC = 0x06; break;
235                 case XFER_SW_DMA_0:     TB = 0xC0; TC = 0x0B; break;
236                 case XFER_PIO_4:        TA = 0x01; TB = 0x04; break;
237                 case XFER_PIO_3:        TA = 0x02; TB = 0x06; break;
238                 case XFER_PIO_2:        TA = 0x03; TB = 0x08; break;
239                 case XFER_PIO_1:        TA = 0x05; TB = 0x0C; break;
240                 case XFER_PIO_0:
241                 default:                TA = 0x09; TB = 0x13; break;
242         }
243
244         if (speed < XFER_SW_DMA_0) {
245                 pci_write_config_byte(dev, (drive_pci), AP|TA);
246                 pci_write_config_byte(dev, (drive_pci)|0x01, BP|TB);
247         } else {
248                 pci_write_config_byte(dev, (drive_pci)|0x01, BP|TB);
249                 pci_write_config_byte(dev, (drive_pci)|0x02, CP|TC);
250         }
251
252 #if PDC202XX_DEBUG_DRIVE_INFO
253         printk(KERN_DEBUG "%s: %s drive%d 0x%08x ",
254                 drive->name, ide_xfer_verbose(speed),
255                 drive->dn, drive_conf);
256                 pci_read_config_dword(dev, drive_pci, &drive_conf);
257         printk("0x%08x\n", drive_conf);
258 #endif /* PDC202XX_DEBUG_DRIVE_INFO */
259
260         return (ide_config_drive_speed(drive, speed));
261 }
262
263
264 /*   0    1    2    3    4    5    6   7   8
265  * 960, 480, 390, 300, 240, 180, 120, 90, 60
266  *           180, 150, 120,  90,  60
267  * DMA_Speed
268  * 180, 120,  90,  90,  90,  60,  30
269  *  11,   5,   4,   3,   2,   1,   0
270  */
271 static void config_chipset_for_pio (ide_drive_t *drive, u8 pio)
272 {
273         u8 speed = 0;
274
275         if (pio == 5) pio = 4;
276         speed = XFER_PIO_0 + ide_get_best_pio_mode(drive, 255, pio, NULL);
277         
278         pdc202xx_tune_chipset(drive, speed);
279 }
280
281 static u8 pdc202xx_old_cable_detect (ide_hwif_t *hwif)
282 {
283         u16 CIS = 0, mask = (hwif->channel) ? (1<<11) : (1<<10);
284         pci_read_config_word(hwif->pci_dev, 0x50, &CIS);
285         return (CIS & mask) ? 1 : 0;
286 }
287
288 /*
289  * Set the control register to use the 66MHz system
290  * clock for UDMA 3/4/5 mode operation when necessary.
291  *
292  * It may also be possible to leave the 66MHz clock on
293  * and readjust the timing parameters.
294  */
295 static void pdc_old_enable_66MHz_clock(ide_hwif_t *hwif)
296 {
297         unsigned long clock_reg = hwif->dma_master + 0x11;
298         u8 clock = hwif->INB(clock_reg);
299
300         hwif->OUTB(clock | (hwif->channel ? 0x08 : 0x02), clock_reg);
301 }
302
303 static void pdc_old_disable_66MHz_clock(ide_hwif_t *hwif)
304 {
305         unsigned long clock_reg = hwif->dma_master + 0x11;
306         u8 clock = hwif->INB(clock_reg);
307
308         hwif->OUTB(clock & ~(hwif->channel ? 0x08 : 0x02), clock_reg);
309 }
310
311 static int config_chipset_for_dma (ide_drive_t *drive)
312 {
313         struct hd_driveid *id   = drive->id;
314         ide_hwif_t *hwif        = HWIF(drive);
315         struct pci_dev *dev     = hwif->pci_dev;
316         u32 drive_conf          = 0;
317         u8 drive_pci            = 0x60 + (drive->dn << 2);
318         u8 test1 = 0, test2 = 0, speed = -1;
319         u8 AP = 0, cable = 0;
320
321         u8 ultra_66             = ((id->dma_ultra & 0x0010) ||
322                                    (id->dma_ultra & 0x0008)) ? 1 : 0;
323
324         if (dev->device != PCI_DEVICE_ID_PROMISE_20246)
325                 cable = pdc202xx_old_cable_detect(hwif);
326         else
327                 ultra_66 = 0;
328
329         if (ultra_66 && cable) {
330                 printk(KERN_WARNING "Warning: %s channel requires an 80-pin cable for operation.\n", hwif->channel ? "Secondary":"Primary");
331                 printk(KERN_WARNING "%s reduced to Ultra33 mode.\n", drive->name);
332         }
333
334         if (dev->device != PCI_DEVICE_ID_PROMISE_20246)
335                 pdc_old_disable_66MHz_clock(drive->hwif);
336
337         drive_pci = 0x60 + (drive->dn << 2);
338         pci_read_config_dword(dev, drive_pci, &drive_conf);
339         if ((drive_conf != 0x004ff304) && (drive_conf != 0x004ff3c4))
340                 goto chipset_is_set;
341
342         pci_read_config_byte(dev, drive_pci, &test1);
343         if (!(test1 & SYNC_ERRDY_EN)) {
344                 if (drive->select.b.unit & 0x01) {
345                         pci_read_config_byte(dev, drive_pci - 4, &test2);
346                         if ((test2 & SYNC_ERRDY_EN) &&
347                             !(test1 & SYNC_ERRDY_EN)) {
348                                 pci_write_config_byte(dev, drive_pci,
349                                         test1|SYNC_ERRDY_EN);
350                         }
351                 } else {
352                         pci_write_config_byte(dev, drive_pci,
353                                 test1|SYNC_ERRDY_EN);
354                 }
355         }
356
357 chipset_is_set:
358
359         if (drive->media == ide_disk) {
360                 pci_read_config_byte(dev, (drive_pci), &AP);
361                 if (id->capability & 4) /* IORDY_EN */
362                         pci_write_config_byte(dev, (drive_pci), AP|IORDY_EN);
363                 pci_read_config_byte(dev, (drive_pci), &AP);
364                 if (drive->media == ide_disk)   /* PREFETCH_EN */
365                         pci_write_config_byte(dev, (drive_pci), AP|PREFETCH_EN);
366         }
367
368         speed = ide_dma_speed(drive, pdc202xx_ratemask(drive));
369
370         if (!(speed)) {
371                 /* restore original pci-config space */
372                 pci_write_config_dword(dev, drive_pci, drive_conf);
373                 return 0;
374         }
375
376         (void) hwif->speedproc(drive, speed);
377         return ide_dma_enable(drive);
378 }
379
380 static int pdc202xx_config_drive_xfer_rate (ide_drive_t *drive)
381 {
382         ide_hwif_t *hwif        = HWIF(drive);
383         struct hd_driveid *id   = drive->id;
384
385         drive->init_speed = 0;
386
387         if (id && (id->capability & 1) && drive->autodma) {
388
389                 if (ide_use_dma(drive)) {
390                         if (config_chipset_for_dma(drive))
391                                 return hwif->ide_dma_on(drive);
392                 }
393
394                 goto fast_ata_pio;
395
396         } else if ((id->capability & 8) || (id->field_valid & 2)) {
397 fast_ata_pio:
398                 hwif->tuneproc(drive, 5);
399                 return hwif->ide_dma_off_quietly(drive);
400         }
401         /* IORDY not supported */
402         return 0;
403 }
404
405 static int pdc202xx_quirkproc (ide_drive_t *drive)
406 {
407         return ((int) check_in_drive_lists(drive, pdc_quirk_drives));
408 }
409
410 static void pdc202xx_old_ide_dma_start(ide_drive_t *drive)
411 {
412         if (drive->current_speed > XFER_UDMA_2)
413                 pdc_old_enable_66MHz_clock(drive->hwif);
414         if (drive->addressing == 1) {
415                 struct request *rq      = HWGROUP(drive)->rq;
416                 ide_hwif_t *hwif        = HWIF(drive);
417                 unsigned long high_16   = hwif->dma_master;
418                 unsigned long atapi_reg = high_16 + (hwif->channel ? 0x24 : 0x20);
419                 u32 word_count  = 0;
420                 u8 clock = hwif->INB(high_16 + 0x11);
421
422                 hwif->OUTB(clock|(hwif->channel ? 0x08 : 0x02), high_16+0x11);
423                 word_count = (rq->nr_sectors << 8);
424                 word_count = (rq_data_dir(rq) == READ) ?
425                                         word_count | 0x05000000 :
426                                         word_count | 0x06000000;
427                 hwif->OUTL(word_count, atapi_reg);
428         }
429         ide_dma_start(drive);
430 }
431
432 static int pdc202xx_old_ide_dma_end(ide_drive_t *drive)
433 {
434         if (drive->addressing == 1) {
435                 ide_hwif_t *hwif        = HWIF(drive);
436                 unsigned long high_16   = hwif->dma_master;
437                 unsigned long atapi_reg = high_16 + (hwif->channel ? 0x24 : 0x20);
438                 u8 clock                = 0;
439
440                 hwif->OUTL(0, atapi_reg); /* zero out extra */
441                 clock = hwif->INB(high_16 + 0x11);
442                 hwif->OUTB(clock & ~(hwif->channel ? 0x08:0x02), high_16+0x11);
443         }
444         if (drive->current_speed > XFER_UDMA_2)
445                 pdc_old_disable_66MHz_clock(drive->hwif);
446         return __ide_dma_end(drive);
447 }
448
449 static int pdc202xx_old_ide_dma_test_irq(ide_drive_t *drive)
450 {
451         ide_hwif_t *hwif        = HWIF(drive);
452         unsigned long high_16   = hwif->dma_master;
453         u8 dma_stat             = hwif->INB(hwif->dma_status);
454         u8 sc1d                 = hwif->INB((high_16 + 0x001d));
455
456         if (hwif->channel) {
457                 /* bit7: Error, bit6: Interrupting, bit5: FIFO Full, bit4: FIFO Empty */
458                 if ((sc1d & 0x50) == 0x50)
459                         goto somebody_else;
460                 else if ((sc1d & 0x40) == 0x40)
461                         return (dma_stat & 4) == 4;
462         } else {
463                 /* bit3: Error, bit2: Interrupting, bit1: FIFO Full, bit0: FIFO Empty */
464                 if ((sc1d & 0x05) == 0x05)
465                         goto somebody_else;
466                 else if ((sc1d & 0x04) == 0x04)
467                         return (dma_stat & 4) == 4;
468         }
469 somebody_else:
470         return (dma_stat & 4) == 4;     /* return 1 if INTR asserted */
471 }
472
473 static int pdc202xx_ide_dma_lostirq(ide_drive_t *drive)
474 {
475         if (HWIF(drive)->resetproc != NULL)
476                 HWIF(drive)->resetproc(drive);
477         return __ide_dma_lostirq(drive);
478 }
479
480 static int pdc202xx_ide_dma_timeout(ide_drive_t *drive)
481 {
482         if (HWIF(drive)->resetproc != NULL)
483                 HWIF(drive)->resetproc(drive);
484         return __ide_dma_timeout(drive);
485 }
486
487 static void pdc202xx_reset_host (ide_hwif_t *hwif)
488 {
489         unsigned long high_16   = hwif->dma_master;
490         u8 udma_speed_flag      = hwif->INB(high_16|0x001f);
491
492         hwif->OUTB((udma_speed_flag | 0x10), (high_16|0x001f));
493         mdelay(100);
494         hwif->OUTB((udma_speed_flag & ~0x10), (high_16|0x001f));
495         mdelay(2000);   /* 2 seconds ?! */
496
497         printk(KERN_WARNING "PDC202XX: %s channel reset.\n",
498                 hwif->channel ? "Secondary" : "Primary");
499 }
500
501 static void pdc202xx_reset (ide_drive_t *drive)
502 {
503         ide_hwif_t *hwif        = HWIF(drive);
504         ide_hwif_t *mate        = hwif->mate;
505         
506         pdc202xx_reset_host(hwif);
507         pdc202xx_reset_host(mate);
508 #if 0
509         /*
510          * FIXME: Have to kick all the drives again :-/
511          * What a pain in the ACE!
512          */
513         if (hwif->present) {
514                 u16 hunit = 0;
515                 for (hunit = 0; hunit < MAX_DRIVES; ++hunit) {
516                         ide_drive_t *hdrive = &hwif->drives[hunit];
517                         if (hdrive->present) {
518                                 if (hwif->ide_dma_check)
519                                         hwif->ide_dma_check(hdrive);
520                                 else
521                                         hwif->tuneproc(hdrive, 5);
522                         }
523                 }
524         }
525         if (mate->present) {
526                 u16 munit = 0;
527                 for (munit = 0; munit < MAX_DRIVES; ++munit) {
528                         ide_drive_t *mdrive = &mate->drives[munit];
529                         if (mdrive->present) {
530                                 if (mate->ide_dma_check) 
531                                         mate->ide_dma_check(mdrive);
532                                 else
533                                         mate->tuneproc(mdrive, 5);
534                         }
535                 }
536         }
537 #else
538         hwif->tuneproc(drive, 5);
539 #endif
540 }
541
542 static unsigned int __devinit init_chipset_pdc202xx(struct pci_dev *dev, const char *name)
543 {
544         if (dev->resource[PCI_ROM_RESOURCE].start) {
545                 pci_write_config_dword(dev, PCI_ROM_ADDRESS,
546                         dev->resource[PCI_ROM_RESOURCE].start | PCI_ROM_ADDRESS_ENABLE);
547                 printk(KERN_INFO "%s: ROM enabled at 0x%08lx\n",
548                         name, dev->resource[PCI_ROM_RESOURCE].start);
549         }
550
551         /*
552          * software reset -  this is required because the bios
553          * will set UDMA timing on if the hdd supports it. The
554          * user may want to turn udma off. A bug in the pdc20262
555          * is that it cannot handle a downgrade in timing from
556          * UDMA to DMA. Disk accesses after issuing a set
557          * feature command will result in errors. A software
558          * reset leaves the timing registers intact,
559          * but resets the drives.
560          */
561 #if 0
562         if ((dev->device == PCI_DEVICE_ID_PROMISE_20267) ||
563             (dev->device == PCI_DEVICE_ID_PROMISE_20265) ||
564             (dev->device == PCI_DEVICE_ID_PROMISE_20263) ||
565             (dev->device == PCI_DEVICE_ID_PROMISE_20262)) {
566                 unsigned long high_16   = pci_resource_start(dev, 4);
567                 byte udma_speed_flag    = inb(high_16 + 0x001f);
568                 outb(udma_speed_flag | 0x10, high_16 + 0x001f);
569                 mdelay(100);
570                 outb(udma_speed_flag & ~0x10, high_16 + 0x001f);
571                 mdelay(2000);   /* 2 seconds ?! */
572         }
573
574 #endif
575         return dev->irq;
576 }
577
578 static void __devinit init_hwif_pdc202xx(ide_hwif_t *hwif)
579 {
580         struct pci_dev *dev = hwif->pci_dev;
581
582         /* PDC20265 has problems with large LBA48 requests */
583         if ((dev->device == PCI_DEVICE_ID_PROMISE_20267) ||
584             (dev->device == PCI_DEVICE_ID_PROMISE_20265))
585                 hwif->rqsize = 256;
586
587         hwif->autodma = 0;
588         hwif->tuneproc  = &config_chipset_for_pio;
589         hwif->quirkproc = &pdc202xx_quirkproc;
590
591         if (hwif->pci_dev->device != PCI_DEVICE_ID_PROMISE_20246)
592                 hwif->resetproc = &pdc202xx_reset;
593
594         hwif->speedproc = &pdc202xx_tune_chipset;
595
596         hwif->drives[0].autotune = hwif->drives[1].autotune = 1;
597
598         hwif->ultra_mask = 0x3f;
599         hwif->mwdma_mask = 0x07;
600         hwif->swdma_mask = 0x07;
601
602         hwif->ide_dma_check = &pdc202xx_config_drive_xfer_rate;
603         hwif->ide_dma_lostirq = &pdc202xx_ide_dma_lostirq;
604         hwif->ide_dma_timeout = &pdc202xx_ide_dma_timeout;
605
606         if (hwif->pci_dev->device != PCI_DEVICE_ID_PROMISE_20246) {
607                 if (!(hwif->udma_four))
608                         hwif->udma_four = (pdc202xx_old_cable_detect(hwif)) ? 0 : 1;
609                 hwif->dma_start = &pdc202xx_old_ide_dma_start;
610                 hwif->ide_dma_end = &pdc202xx_old_ide_dma_end;
611         } 
612         hwif->ide_dma_test_irq = &pdc202xx_old_ide_dma_test_irq;
613
614         if (!noautodma)
615                 hwif->autodma = 1;
616         hwif->drives[0].autodma = hwif->drives[1].autodma = hwif->autodma;
617 #if PDC202_DEBUG_CABLE
618         printk(KERN_DEBUG "%s: %s-pin cable\n",
619                 hwif->name, hwif->udma_four ? "80" : "40");
620 #endif /* PDC202_DEBUG_CABLE */ 
621 }
622
623 static void __devinit init_dma_pdc202xx(ide_hwif_t *hwif, unsigned long dmabase)
624 {
625         u8 udma_speed_flag = 0, primary_mode = 0, secondary_mode = 0;
626
627         if (hwif->channel) {
628                 ide_setup_dma(hwif, dmabase, 8);
629                 return;
630         }
631
632         udma_speed_flag = hwif->INB((dmabase|0x1f));
633         primary_mode    = hwif->INB((dmabase|0x1a));
634         secondary_mode  = hwif->INB((dmabase|0x1b));
635         printk(KERN_INFO "%s: (U)DMA Burst Bit %sABLED " \
636                 "Primary %s Mode " \
637                 "Secondary %s Mode.\n", hwif->cds->name,
638                 (udma_speed_flag & 1) ? "EN" : "DIS",
639                 (primary_mode & 1) ? "MASTER" : "PCI",
640                 (secondary_mode & 1) ? "MASTER" : "PCI" );
641
642 #ifdef CONFIG_PDC202XX_BURST
643         if (!(udma_speed_flag & 1)) {
644                 printk(KERN_INFO "%s: FORCING BURST BIT 0x%02x->0x%02x ",
645                         hwif->cds->name, udma_speed_flag,
646                         (udma_speed_flag|1));
647                 hwif->OUTB(udma_speed_flag|1,(dmabase|0x1f));
648                 printk("%sACTIVE\n",
649                         (hwif->INB(dmabase|0x1f)&1) ? "":"IN");
650         }
651 #endif /* CONFIG_PDC202XX_BURST */
652 #ifdef CONFIG_PDC202XX_MASTER
653         if (!(primary_mode & 1)) {
654                 printk(KERN_INFO "%s: FORCING PRIMARY MODE BIT "
655                         "0x%02x -> 0x%02x ", hwif->cds->name,
656                         primary_mode, (primary_mode|1));
657                 hwif->OUTB(primary_mode|1, (dmabase|0x1a));
658                 printk("%s\n",
659                         (hwif->INB((dmabase|0x1a)) & 1) ? "MASTER" : "PCI");
660         }
661
662         if (!(secondary_mode & 1)) {
663                 printk(KERN_INFO "%s: FORCING SECONDARY MODE BIT "
664                         "0x%02x -> 0x%02x ", hwif->cds->name,
665                         secondary_mode, (secondary_mode|1));
666                 hwif->OUTB(secondary_mode|1, (dmabase|0x1b));
667                 printk("%s\n",
668                         (hwif->INB((dmabase|0x1b)) & 1) ? "MASTER" : "PCI");
669         }
670 #endif /* CONFIG_PDC202XX_MASTER */
671
672         ide_setup_dma(hwif, dmabase, 8);
673 }
674
675 static int __devinit init_setup_pdc202ata4(struct pci_dev *dev,
676                                            ide_pci_device_t *d)
677 {
678         if ((dev->class >> 8) != PCI_CLASS_STORAGE_IDE) {
679                 u8 irq = 0, irq2 = 0;
680                 pci_read_config_byte(dev, PCI_INTERRUPT_LINE, &irq);
681                 /* 0xbc */
682                 pci_read_config_byte(dev, (PCI_INTERRUPT_LINE)|0x80, &irq2);
683                 if (irq != irq2) {
684                         pci_write_config_byte(dev,
685                                 (PCI_INTERRUPT_LINE)|0x80, irq);     /* 0xbc */
686                         printk(KERN_INFO "%s: pci-config space interrupt "
687                                 "mirror fixed.\n", d->name);
688                 }
689         }
690
691 #if 0
692         if (dev->device == PCI_DEVICE_ID_PROMISE_20262)
693         if (e->reg && (pci_read_config_byte(dev, e->reg, &tmp) ||
694              (tmp & e->mask) != e->val))
695
696         if (d->enablebits[0].reg != d->enablebits[1].reg) {
697                 d->enablebits[0].reg    = d->enablebits[1].reg;
698                 d->enablebits[0].mask   = d->enablebits[1].mask;
699                 d->enablebits[0].val    = d->enablebits[1].val;
700         }
701 #endif
702
703         return ide_setup_pci_device(dev, d);
704 }
705
706 static int __devinit init_setup_pdc20265(struct pci_dev *dev,
707                                          ide_pci_device_t *d)
708 {
709         if ((dev->bus->self) &&
710             (dev->bus->self->vendor == PCI_VENDOR_ID_INTEL) &&
711             ((dev->bus->self->device == PCI_DEVICE_ID_INTEL_I960) ||
712              (dev->bus->self->device == PCI_DEVICE_ID_INTEL_I960RM))) {
713                 printk(KERN_INFO "ide: Skipping Promise PDC20265 "
714                         "attached to I2O RAID controller.\n");
715                 return -ENODEV;
716         }
717
718 #if 0
719         {
720                 u8 pri = 0, sec = 0;
721
722         if (e->reg && (pci_read_config_byte(dev, e->reg, &tmp) ||
723              (tmp & e->mask) != e->val))
724
725         if (d->enablebits[0].reg != d->enablebits[1].reg) {
726                 d->enablebits[0].reg    = d->enablebits[1].reg;
727                 d->enablebits[0].mask   = d->enablebits[1].mask;
728                 d->enablebits[0].val    = d->enablebits[1].val;
729         }
730         }
731 #endif
732
733         return ide_setup_pci_device(dev, d);
734 }
735
736 static int __devinit init_setup_pdc202xx(struct pci_dev *dev,
737                                          ide_pci_device_t *d)
738 {
739         return ide_setup_pci_device(dev, d);
740 }
741
742 static ide_pci_device_t pdc202xx_chipsets[] __devinitdata = {
743         {       /* 0 */
744                 .name           = "PDC20246",
745                 .init_setup     = init_setup_pdc202ata4,
746                 .init_chipset   = init_chipset_pdc202xx,
747                 .init_hwif      = init_hwif_pdc202xx,
748                 .init_dma       = init_dma_pdc202xx,
749                 .channels       = 2,
750                 .autodma        = AUTODMA,
751                 .bootable       = OFF_BOARD,
752                 .extra          = 16,
753         },{     /* 1 */
754                 .name           = "PDC20262",
755                 .init_setup     = init_setup_pdc202ata4,
756                 .init_chipset   = init_chipset_pdc202xx,
757                 .init_hwif      = init_hwif_pdc202xx,
758                 .init_dma       = init_dma_pdc202xx,
759                 .channels       = 2,
760                 .autodma        = AUTODMA,
761                 .bootable       = OFF_BOARD,
762                 .extra          = 48,
763         },{     /* 2 */
764                 .name           = "PDC20263",
765                 .init_setup     = init_setup_pdc202ata4,
766                 .init_chipset   = init_chipset_pdc202xx,
767                 .init_hwif      = init_hwif_pdc202xx,
768                 .init_dma       = init_dma_pdc202xx,
769                 .channels       = 2,
770                 .autodma        = AUTODMA,
771                 .bootable       = OFF_BOARD,
772                 .extra          = 48,
773         },{     /* 3 */
774                 .name           = "PDC20265",
775                 .init_setup     = init_setup_pdc20265,
776                 .init_chipset   = init_chipset_pdc202xx,
777                 .init_hwif      = init_hwif_pdc202xx,
778                 .init_dma       = init_dma_pdc202xx,
779                 .channels       = 2,
780                 .autodma        = AUTODMA,
781                 .bootable       = OFF_BOARD,
782                 .extra          = 48,
783         },{     /* 4 */
784                 .name           = "PDC20267",
785                 .init_setup     = init_setup_pdc202xx,
786                 .init_chipset   = init_chipset_pdc202xx,
787                 .init_hwif      = init_hwif_pdc202xx,
788                 .init_dma       = init_dma_pdc202xx,
789                 .channels       = 2,
790                 .autodma        = AUTODMA,
791                 .bootable       = OFF_BOARD,
792                 .extra          = 48,
793         }
794 };
795
796 /**
797  *      pdc202xx_init_one       -       called when a PDC202xx is found
798  *      @dev: the pdc202xx device
799  *      @id: the matching pci id
800  *
801  *      Called when the PCI registration layer (or the IDE initialization)
802  *      finds a device matching our IDE device tables.
803  */
804  
805 static int __devinit pdc202xx_init_one(struct pci_dev *dev, const struct pci_device_id *id)
806 {
807         ide_pci_device_t *d = &pdc202xx_chipsets[id->driver_data];
808
809         return d->init_setup(dev, d);
810 }
811
812 static struct pci_device_id pdc202xx_pci_tbl[] = {
813         { PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20246, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
814         { PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20262, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 1},
815         { PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20263, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 2},
816         { PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20265, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 3},
817         { PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20267, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 4},
818         { 0, },
819 };
820 MODULE_DEVICE_TABLE(pci, pdc202xx_pci_tbl);
821
822 static struct pci_driver driver = {
823         .name           = "Promise_Old_IDE",
824         .id_table       = pdc202xx_pci_tbl,
825         .probe          = pdc202xx_init_one,
826 };
827
828 static int pdc202xx_ide_init(void)
829 {
830         return ide_pci_register_driver(&driver);
831 }
832
833 module_init(pdc202xx_ide_init);
834
835 MODULE_AUTHOR("Andre Hedrick, Frank Tiernan");
836 MODULE_DESCRIPTION("PCI driver module for older Promise IDE");
837 MODULE_LICENSE("GPL");