Skip to content

Commit

Permalink
ide: cleanup ide_set_dma()
Browse files Browse the repository at this point in the history
* ->dma_off_quietly is always called before ide_set_dma()
  so the call can be moved inside ide_set_dma().

* ide_dma_check() doesn't touch hardware so ->dma_off_quietly
  call for 'rc == -1' case is redundant, remove it.

* '0' and '-1' are the only values returned by ide_dma_check()
  so remove dead code for other cases.

There should be no functionality changes caused by this patch.

Acked-by: Sergei Shtylyov <sshtylyov@ru.mvista.com>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
  • Loading branch information
Bartlomiej Zolnierkiewicz committed Jan 25, 2008
1 parent 23b1bd4 commit 7b90599
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 25 deletions.
25 changes: 11 additions & 14 deletions drivers/ide/ide-dma.c
Original file line number Diff line number Diff line change
Expand Up @@ -827,22 +827,19 @@ int ide_set_dma(ide_drive_t *drive)
ide_hwif_t *hwif = drive->hwif;
int rc;

rc = ide_dma_check(drive);
/*
* Force DMAing for the beginning of the check.
* Some chipsets appear to do interesting
* things, if not checked and cleared.
* PARANOIA!!!
*/
hwif->dma_off_quietly(drive);

switch(rc) {
case -1: /* DMA needs to be disabled */
hwif->dma_off_quietly(drive);
return -1;
case 0: /* DMA needs to be enabled */
return hwif->ide_dma_on(drive);
case 1: /* DMA setting cannot be changed */
break;
default:
BUG();
break;
}
rc = ide_dma_check(drive);
if (rc)
return rc;

return rc;
return hwif->ide_dma_on(drive);
}

#ifdef CONFIG_BLK_DEV_IDEDMA_PCI
Expand Down
1 change: 0 additions & 1 deletion drivers/ide/ide-io.c
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,6 @@ static ide_startstop_t ide_start_power_step(ide_drive_t *drive, struct request *
*/
if (drive->hwif->ide_dma_on == NULL)
break;
drive->hwif->dma_off_quietly(drive);
/*
* TODO: respect ->using_dma setting
*/
Expand Down
10 changes: 1 addition & 9 deletions drivers/ide/ide-probe.c
Original file line number Diff line number Diff line change
Expand Up @@ -833,16 +833,8 @@ static void probe_hwif(ide_hwif_t *hwif)

drive->nice1 = 1;

if (hwif->ide_dma_on) {
/*
* Force DMAing for the beginning of the check.
* Some chipsets appear to do interesting
* things, if not checked and cleared.
* PARANOIA!!!
*/
hwif->dma_off_quietly(drive);
if (hwif->ide_dma_on)
ide_set_dma(drive);
}
}
}

Expand Down
1 change: 0 additions & 1 deletion drivers/ide/ide.c
Original file line number Diff line number Diff line change
Expand Up @@ -851,7 +851,6 @@ int set_using_dma(ide_drive_t *drive, int arg)
err = 0;

if (arg) {
hwif->dma_off_quietly(drive);
if (ide_set_dma(drive))
err = -EIO;
} else
Expand Down

0 comments on commit 7b90599

Please sign in to comment.