diff options
-rw-r--r-- | drivers/ide/ide-cd.c | 28 |
1 files changed, 15 insertions, 13 deletions
diff --git a/drivers/ide/ide-cd.c b/drivers/ide/ide-cd.c index 6c31ce15210d..f0191f061775 100644 --- a/drivers/ide/ide-cd.c +++ b/drivers/ide/ide-cd.c | |||
@@ -626,6 +626,16 @@ static void ide_cd_pad_transfer(ide_drive_t *drive, xfer_func_t *xf, int len) | |||
626 | } | 626 | } |
627 | } | 627 | } |
628 | 628 | ||
629 | static void ide_cd_drain_data(ide_drive_t *drive, int nsects) | ||
630 | { | ||
631 | while (nsects > 0) { | ||
632 | static char dum[SECTOR_SIZE]; | ||
633 | |||
634 | drive->hwif->atapi_input_bytes(drive, dum, sizeof(dum)); | ||
635 | nsects--; | ||
636 | } | ||
637 | } | ||
638 | |||
629 | /* | 639 | /* |
630 | * Buffer up to SECTORS_TO_TRANSFER sectors from the drive in our sector | 640 | * Buffer up to SECTORS_TO_TRANSFER sectors from the drive in our sector |
631 | * buffer. Once the first sector is added, any subsequent sectors are | 641 | * buffer. Once the first sector is added, any subsequent sectors are |
@@ -664,11 +674,7 @@ static void cdrom_buffer_sectors (ide_drive_t *drive, unsigned long sector, | |||
664 | } | 674 | } |
665 | 675 | ||
666 | /* Throw away any remaining data. */ | 676 | /* Throw away any remaining data. */ |
667 | while (sectors_to_transfer > 0) { | 677 | ide_cd_drain_data(drive, sectors_to_transfer); |
668 | static char dum[SECTOR_SIZE]; | ||
669 | HWIF(drive)->atapi_input_bytes(drive, dum, sizeof (dum)); | ||
670 | --sectors_to_transfer; | ||
671 | } | ||
672 | } | 678 | } |
673 | 679 | ||
674 | /* | 680 | /* |
@@ -791,14 +797,10 @@ static ide_startstop_t cdrom_read_intr (ide_drive_t *drive) | |||
791 | any of the leading sectors. */ | 797 | any of the leading sectors. */ |
792 | nskip = min_t(int, rq->current_nr_sectors - bio_cur_sectors(rq->bio), sectors_to_transfer); | 798 | nskip = min_t(int, rq->current_nr_sectors - bio_cur_sectors(rq->bio), sectors_to_transfer); |
793 | 799 | ||
794 | while (nskip > 0) { | 800 | if (nskip > 0) { |
795 | /* We need to throw away a sector. */ | 801 | ide_cd_drain_data(drive, nskip); |
796 | static char dum[SECTOR_SIZE]; | 802 | rq->current_nr_sectors -= nskip; |
797 | HWIF(drive)->atapi_input_bytes(drive, dum, sizeof (dum)); | 803 | sectors_to_transfer -= nskip; |
798 | |||
799 | --rq->current_nr_sectors; | ||
800 | --nskip; | ||
801 | --sectors_to_transfer; | ||
802 | } | 804 | } |
803 | 805 | ||
804 | /* Now loop while we still have data to read from the drive. */ | 806 | /* Now loop while we still have data to read from the drive. */ |