aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide
diff options
context:
space:
mode:
authorBartlomiej Zolnierkiewicz <bzolnier@gmail.com>2008-04-17 18:46:26 -0400
committerBartlomiej Zolnierkiewicz <bzolnier@gmail.com>2008-04-17 18:46:26 -0400
commit7616c0ad2087c7d244b8985390c63059a6223c45 (patch)
treec65d7e5dce8b6ec314b56ad2903c8760e2659753 /drivers/ide
parent3ad6776cca21f2456b7288f44f224b344ac3c4d0 (diff)
ide: add ide_atapi_{discard_data,write_zeros} inline helpers
Add ide_atapi_{discard_data,write_zeros} inline helpers to <linux/ide.h> and use them instead of home-brewn helpers in ide-{floppy,tape,scsi}. There should be no functional changes caused by this patch. Cc: Borislav Petkov <petkovbb@gmail.com> Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Diffstat (limited to 'drivers/ide')
-rw-r--r--drivers/ide/ide-floppy.c24
-rw-r--r--drivers/ide/ide-tape.c14
2 files changed, 5 insertions, 33 deletions
diff --git a/drivers/ide/ide-floppy.c b/drivers/ide/ide-floppy.c
index 973f5f6c815e..170c60d93f55 100644
--- a/drivers/ide/ide-floppy.c
+++ b/drivers/ide/ide-floppy.c
@@ -230,23 +230,6 @@ static void ide_floppy_put(struct ide_floppy_obj *floppy)
230} 230}
231 231
232/* 232/*
233 * Too bad. The drive wants to send us data which we are not ready to accept.
234 * Just throw it away.
235 */
236static void idefloppy_discard_data(ide_drive_t *drive, unsigned int bcount)
237{
238 while (bcount--)
239 (void) HWIF(drive)->INB(IDE_DATA_REG);
240}
241
242static void idefloppy_write_zeros(ide_drive_t *drive, unsigned int bcount)
243{
244 while (bcount--)
245 HWIF(drive)->OUTB(0, IDE_DATA_REG);
246}
247
248
249/*
250 * Used to finish servicing a request. For read/write requests, we will call 233 * Used to finish servicing a request. For read/write requests, we will call
251 * ide_end_request to pass to the next buffer. 234 * ide_end_request to pass to the next buffer.
252 */ 235 */
@@ -313,10 +296,9 @@ static void ide_floppy_io_buffers(ide_drive_t *drive, idefloppy_pc_t *pc,
313 printk(KERN_ERR "%s: leftover data in %s, bcount == %d\n", 296 printk(KERN_ERR "%s: leftover data in %s, bcount == %d\n",
314 drive->name, __func__, bcount); 297 drive->name, __func__, bcount);
315 if (direction) 298 if (direction)
316 idefloppy_write_zeros(drive, bcount); 299 ide_atapi_write_zeros(drive, bcount);
317 else 300 else
318 idefloppy_discard_data(drive, bcount); 301 ide_atapi_discard_data(drive, bcount);
319
320 } 302 }
321} 303}
322 304
@@ -541,7 +523,7 @@ static ide_startstop_t idefloppy_pc_intr (ide_drive_t *drive)
541 printk(KERN_ERR "ide-floppy: The floppy wants " 523 printk(KERN_ERR "ide-floppy: The floppy wants "
542 "to send us more data than expected " 524 "to send us more data than expected "
543 "- discarding data\n"); 525 "- discarding data\n");
544 idefloppy_discard_data(drive, bcount); 526 ide_atapi_discard_data(drive, bcount);
545 527
546 ide_set_handler(drive, 528 ide_set_handler(drive,
547 &idefloppy_pc_intr, 529 &idefloppy_pc_intr,
diff --git a/drivers/ide/ide-tape.c b/drivers/ide/ide-tape.c
index 0598ecfd5f37..bfdc4f449797 100644
--- a/drivers/ide/ide-tape.c
+++ b/drivers/ide/ide-tape.c
@@ -518,16 +518,6 @@ static struct ide_tape_obj *ide_tape_chrdev_get(unsigned int i)
518 return tape; 518 return tape;
519} 519}
520 520
521/*
522 * Too bad. The drive wants to send us data which we are not ready to accept.
523 * Just throw it away.
524 */
525static void idetape_discard_data(ide_drive_t *drive, unsigned int bcount)
526{
527 while (bcount--)
528 (void) HWIF(drive)->INB(IDE_DATA_REG);
529}
530
531static void idetape_input_buffers(ide_drive_t *drive, idetape_pc_t *pc, 521static void idetape_input_buffers(ide_drive_t *drive, idetape_pc_t *pc,
532 unsigned int bcount) 522 unsigned int bcount)
533{ 523{
@@ -538,7 +528,7 @@ static void idetape_input_buffers(ide_drive_t *drive, idetape_pc_t *pc,
538 if (bh == NULL) { 528 if (bh == NULL) {
539 printk(KERN_ERR "ide-tape: bh == NULL in " 529 printk(KERN_ERR "ide-tape: bh == NULL in "
540 "idetape_input_buffers\n"); 530 "idetape_input_buffers\n");
541 idetape_discard_data(drive, bcount); 531 ide_atapi_discard_data(drive, bcount);
542 return; 532 return;
543 } 533 }
544 count = min( 534 count = min(
@@ -1152,7 +1142,7 @@ static ide_startstop_t idetape_pc_intr(ide_drive_t *drive)
1152 printk(KERN_ERR "ide-tape: The tape wants to " 1142 printk(KERN_ERR "ide-tape: The tape wants to "
1153 "send us more data than expected " 1143 "send us more data than expected "
1154 "- discarding data\n"); 1144 "- discarding data\n");
1155 idetape_discard_data(drive, bcount); 1145 ide_atapi_discard_data(drive, bcount);
1156 ide_set_handler(drive, &idetape_pc_intr, 1146 ide_set_handler(drive, &idetape_pc_intr,
1157 IDETAPE_WAIT_CMD, NULL); 1147 IDETAPE_WAIT_CMD, NULL);
1158 return ide_started; 1148 return ide_started;