aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/pci/sc1200.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/pci/sc1200.c')
-rw-r--r--drivers/ide/pci/sc1200.c27
1 files changed, 12 insertions, 15 deletions
diff --git a/drivers/ide/pci/sc1200.c b/drivers/ide/pci/sc1200.c
index c0254b5e7d92..65dcabe48205 100644
--- a/drivers/ide/pci/sc1200.c
+++ b/drivers/ide/pci/sc1200.c
@@ -1,5 +1,5 @@
1/* 1/*
2 * linux/drivers/ide/pci/sc1200.c Version 0.92 Mar 10 2007 2 * linux/drivers/ide/pci/sc1200.c Version 0.93 Mar 10 2007
3 * 3 *
4 * Copyright (C) 2000-2002 Mark Lord <mlord@pobox.com> 4 * Copyright (C) 2000-2002 Mark Lord <mlord@pobox.com>
5 * Copyright (C) 2007 Bartlomiej Zolnierkiewicz 5 * Copyright (C) 2007 Bartlomiej Zolnierkiewicz
@@ -137,12 +137,6 @@ static int sc1200_config_dma2 (ide_drive_t *drive, int mode)
137 unsigned int basereg = hwif->channel ? 0x50 : 0x40; 137 unsigned int basereg = hwif->channel ? 0x50 : 0x40;
138 138
139 /* 139 /*
140 * Default to DMA-off in case we run into trouble here.
141 */
142 hwif->dma_off_quietly(drive); /* turn off DMA while we fiddle */
143 outb(inb(hwif->dma_base+2)&~(unit?0x40:0x20), hwif->dma_base+2); /* clear DMA_capable bit */
144
145 /*
146 * Tell the drive to switch to the new mode; abort on failure. 140 * Tell the drive to switch to the new mode; abort on failure.
147 */ 141 */
148 if (!mode || sc1200_set_xfer_mode(drive, mode)) { 142 if (!mode || sc1200_set_xfer_mode(drive, mode)) {
@@ -217,8 +211,6 @@ static int sc1200_config_dma2 (ide_drive_t *drive, int mode)
217 pci_write_config_dword(hwif->pci_dev, basereg+12, timings); 211 pci_write_config_dword(hwif->pci_dev, basereg+12, timings);
218 } 212 }
219 213
220 outb(inb(hwif->dma_base+2)|(unit?0x40:0x20), hwif->dma_base+2); /* set DMA_capable bit */
221
222 return 0; /* success */ 214 return 0; /* success */
223} 215}
224 216
@@ -277,6 +269,9 @@ static void sc1200_tuneproc (ide_drive_t *drive, byte pio) /* mode=255 means "au
277 static byte modes[5] = {XFER_PIO_0, XFER_PIO_1, XFER_PIO_2, XFER_PIO_3, XFER_PIO_4}; 269 static byte modes[5] = {XFER_PIO_0, XFER_PIO_1, XFER_PIO_2, XFER_PIO_3, XFER_PIO_4};
278 int mode = -1; 270 int mode = -1;
279 271
272 /*
273 * bad abuse of ->tuneproc interface
274 */
280 switch (pio) { 275 switch (pio) {
281 case 200: mode = XFER_UDMA_0; break; 276 case 200: mode = XFER_UDMA_0; break;
282 case 201: mode = XFER_UDMA_1; break; 277 case 201: mode = XFER_UDMA_1; break;
@@ -287,7 +282,9 @@ static void sc1200_tuneproc (ide_drive_t *drive, byte pio) /* mode=255 means "au
287 } 282 }
288 if (mode != -1) { 283 if (mode != -1) {
289 printk("SC1200: %s: changing (U)DMA mode\n", drive->name); 284 printk("SC1200: %s: changing (U)DMA mode\n", drive->name);
290 (void)sc1200_config_dma2(drive, mode); 285 hwif->dma_off_quietly(drive);
286 if (sc1200_config_dma2(drive, mode) == 0)
287 hwif->dma_host_on(drive);
291 return; 288 return;
292 } 289 }
293 290
@@ -421,12 +418,12 @@ static int sc1200_resume (struct pci_dev *dev)
421 for (d = 0; d < MAX_DRIVES; ++d) { 418 for (d = 0; d < MAX_DRIVES; ++d) {
422 ide_drive_t *drive = &(hwif->drives[d]); 419 ide_drive_t *drive = &(hwif->drives[d]);
423 if (drive->present && !__ide_dma_bad_drive(drive)) { 420 if (drive->present && !__ide_dma_bad_drive(drive)) {
424 int was_using_dma = drive->using_dma; 421 int enable_dma = drive->using_dma;
425 hwif->dma_off_quietly(drive); 422 hwif->dma_off_quietly(drive);
426 sc1200_config_dma(drive); 423 if (sc1200_config_dma(drive))
427 if (!was_using_dma && drive->using_dma) { 424 enable_dma = 0;
428 hwif->dma_off_quietly(drive); 425 if (enable_dma)
429 } 426 hwif->dma_host_on(drive);
430 } 427 }
431 } 428 }
432 } 429 }