From 7044219a57013fdab3e174503f81250a33a3ad8e Mon Sep 17 00:00:00 2001 From: Bartlomiej Zolnierkiewicz Date: Fri, 27 Mar 2009 12:46:44 +0100 Subject: [PATCH] --- yaml --- r: 137680 b: refs/heads/master c: a9587fd8c48415cc93fef7f4ba7748a5d3477e7b h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/ide/ide-io.c | 10 ++++++---- trunk/include/linux/ide.h | 2 +- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/[refs] b/[refs] index 04d7baccfe94..7a959691bcce 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 89f78b3261f7e331e41753ea2459fbb9b60a6f7a +refs/heads/master: a9587fd8c48415cc93fef7f4ba7748a5d3477e7b diff --git a/trunk/drivers/ide/ide-io.c b/trunk/drivers/ide/ide-io.c index 28ac463dde1c..4a79d28600f5 100644 --- a/trunk/drivers/ide/ide-io.c +++ b/trunk/drivers/ide/ide-io.c @@ -141,15 +141,17 @@ void ide_complete_cmd(ide_drive_t *drive, struct ide_cmd *cmd, u8 stat, u8 err) kfree(cmd); } -void ide_complete_rq(ide_drive_t *drive, int error) +int ide_complete_rq(ide_drive_t *drive, int error) { ide_hwif_t *hwif = drive->hwif; struct request *rq = hwif->rq; + int rc; - hwif->rq = NULL; + rc = blk_end_request(rq, error, blk_rq_bytes(rq)); + if (rc == 0) + hwif->rq = NULL; - if (unlikely(blk_end_request(rq, error, blk_rq_bytes(rq)))) - BUG(); + return rc; } EXPORT_SYMBOL(ide_complete_rq); diff --git a/trunk/include/linux/ide.h b/trunk/include/linux/ide.h index 32369d5797de..bb62bfaf02e0 100644 --- a/trunk/include/linux/ide.h +++ b/trunk/include/linux/ide.h @@ -1166,7 +1166,7 @@ extern int ide_devset_execute(ide_drive_t *drive, const struct ide_devset *setting, int arg); void ide_complete_cmd(ide_drive_t *, struct ide_cmd *, u8, u8); -void ide_complete_rq(ide_drive_t *, int); +int ide_complete_rq(ide_drive_t *, int); void ide_tf_dump(const char *, struct ide_taskfile *);