diff options
Diffstat (limited to 'drivers/ide')
-rw-r--r-- | drivers/ide/ide-cd.c | 12 | ||||
-rw-r--r-- | drivers/ide/ide-io.c | 16 |
2 files changed, 7 insertions, 21 deletions
diff --git a/drivers/ide/ide-cd.c b/drivers/ide/ide-cd.c index 31f398577ed4..ac607bbde45c 100644 --- a/drivers/ide/ide-cd.c +++ b/drivers/ide/ide-cd.c | |||
@@ -262,7 +262,6 @@ static void cdrom_end_request(ide_drive_t *drive, int uptodate) | |||
262 | struct request *failed = (struct request *) rq->buffer; | 262 | struct request *failed = (struct request *) rq->buffer; |
263 | struct cdrom_info *info = drive->driver_data; | 263 | struct cdrom_info *info = drive->driver_data; |
264 | void *sense = &info->sense_data; | 264 | void *sense = &info->sense_data; |
265 | unsigned long flags; | ||
266 | 265 | ||
267 | if (failed) { | 266 | if (failed) { |
268 | if (failed->sense) { | 267 | if (failed->sense) { |
@@ -278,11 +277,9 @@ static void cdrom_end_request(ide_drive_t *drive, int uptodate) | |||
278 | failed->hard_nr_sectors)) | 277 | failed->hard_nr_sectors)) |
279 | BUG(); | 278 | BUG(); |
280 | } else { | 279 | } else { |
281 | spin_lock_irqsave(&ide_lock, flags); | 280 | if (blk_end_request(failed, -EIO, |
282 | if (__blk_end_request(failed, -EIO, | 281 | failed->data_len)) |
283 | failed->data_len)) | ||
284 | BUG(); | 282 | BUG(); |
285 | spin_unlock_irqrestore(&ide_lock, flags); | ||
286 | } | 283 | } |
287 | } else | 284 | } else |
288 | cdrom_analyze_sense_data(drive, NULL, sense); | 285 | cdrom_analyze_sense_data(drive, NULL, sense); |
@@ -1151,16 +1148,13 @@ static ide_startstop_t cdrom_newpc_intr(ide_drive_t *drive) | |||
1151 | 1148 | ||
1152 | end_request: | 1149 | end_request: |
1153 | if (blk_pc_request(rq)) { | 1150 | if (blk_pc_request(rq)) { |
1154 | unsigned long flags; | ||
1155 | unsigned int dlen = rq->data_len; | 1151 | unsigned int dlen = rq->data_len; |
1156 | 1152 | ||
1157 | if (dma) | 1153 | if (dma) |
1158 | rq->data_len = 0; | 1154 | rq->data_len = 0; |
1159 | 1155 | ||
1160 | spin_lock_irqsave(&ide_lock, flags); | 1156 | if (blk_end_request(rq, 0, dlen)) |
1161 | if (__blk_end_request(rq, 0, dlen)) | ||
1162 | BUG(); | 1157 | BUG(); |
1163 | spin_unlock_irqrestore(&ide_lock, flags); | ||
1164 | 1158 | ||
1165 | hwgroup->rq = NULL; | 1159 | hwgroup->rq = NULL; |
1166 | } else { | 1160 | } else { |
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 @@ | |||
58 | static int __ide_end_request(ide_drive_t *drive, struct request *rq, | 58 | static 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 | } |
332 | EXPORT_SYMBOL(ide_end_drive_cmd); | 324 | EXPORT_SYMBOL(ide_end_drive_cmd); |
333 | 325 | ||