aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/ide-io.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/ide-io.c')
-rw-r--r--drivers/ide/ide-io.c16
1 files changed, 4 insertions, 12 deletions
diff --git a/drivers/ide/ide-io.c b/drivers/ide/ide-io.c
index 709163536015..4a6576f6146b 100644
--- a/drivers/ide/ide-io.c
+++ b/drivers/ide/ide-io.c
@@ -58,7 +58,6 @@
58static int __ide_end_request(ide_drive_t *drive, struct request *rq, 58static int __ide_end_request(ide_drive_t *drive, struct request *rq,
59 int uptodate, unsigned int nr_bytes, int dequeue) 59 int uptodate, unsigned int nr_bytes, int dequeue)
60{ 60{
61 unsigned long flags;
62 int ret = 1; 61 int ret = 1;
63 int error = 0; 62 int error = 0;
64 63
@@ -85,10 +84,8 @@ static int __ide_end_request(ide_drive_t *drive, struct request *rq,
85 ide_dma_on(drive); 84 ide_dma_on(drive);
86 } 85 }
87 86
88 spin_lock_irqsave(&ide_lock, flags); 87 if (!blk_end_request(rq, error, nr_bytes))
89 if (!__blk_end_request(rq, error, nr_bytes))
90 ret = 0; 88 ret = 0;
91 spin_unlock_irqrestore(&ide_lock, flags);
92 89
93 if (ret == 0 && dequeue) 90 if (ret == 0 && dequeue)
94 drive->hwif->hwgroup->rq = NULL; 91 drive->hwif->hwgroup->rq = NULL;
@@ -267,10 +264,8 @@ static void ide_complete_pm_request (ide_drive_t *drive, struct request *rq)
267 264
268 drive->hwif->hwgroup->rq = NULL; 265 drive->hwif->hwgroup->rq = NULL;
269 266
270 spin_lock_irqsave(&ide_lock, flags); 267 if (blk_end_request(rq, 0, 0))
271 if (__blk_end_request(rq, 0, 0))
272 BUG(); 268 BUG();
273 spin_unlock_irqrestore(&ide_lock, flags);
274} 269}
275 270
276/** 271/**
@@ -291,7 +286,6 @@ void ide_end_drive_cmd (ide_drive_t *drive, u8 stat, u8 err)
291{ 286{
292 ide_hwgroup_t *hwgroup = drive->hwif->hwgroup; 287 ide_hwgroup_t *hwgroup = drive->hwif->hwgroup;
293 struct request *rq = hwgroup->rq; 288 struct request *rq = hwgroup->rq;
294 unsigned long flags;
295 289
296 if (rq->cmd_type == REQ_TYPE_ATA_TASKFILE) { 290 if (rq->cmd_type == REQ_TYPE_ATA_TASKFILE) {
297 ide_task_t *task = (ide_task_t *)rq->special; 291 ide_task_t *task = (ide_task_t *)rq->special;
@@ -323,11 +317,9 @@ void ide_end_drive_cmd (ide_drive_t *drive, u8 stat, u8 err)
323 317
324 rq->errors = err; 318 rq->errors = err;
325 319
326 spin_lock_irqsave(&ide_lock, flags); 320 if (unlikely(blk_end_request(rq, (rq->errors ? -EIO : 0),
327 if (unlikely(__blk_end_request(rq, (rq->errors ? -EIO : 0), 321 blk_rq_bytes(rq))))
328 blk_rq_bytes(rq))))
329 BUG(); 322 BUG();
330 spin_unlock_irqrestore(&ide_lock, flags);
331} 323}
332EXPORT_SYMBOL(ide_end_drive_cmd); 324EXPORT_SYMBOL(ide_end_drive_cmd);
333 325