diff options
Diffstat (limited to 'drivers/ide/ide-io.c')
-rw-r--r-- | drivers/ide/ide-io.c | 28 |
1 files changed, 9 insertions, 19 deletions
diff --git a/drivers/ide/ide-io.c b/drivers/ide/ide-io.c index 8afe7b15decf..709163536015 100644 --- a/drivers/ide/ide-io.c +++ b/drivers/ide/ide-io.c | |||
@@ -58,6 +58,7 @@ | |||
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; | ||
61 | int ret = 1; | 62 | int ret = 1; |
62 | int error = 0; | 63 | int error = 0; |
63 | 64 | ||
@@ -84,11 +85,13 @@ static int __ide_end_request(ide_drive_t *drive, struct request *rq, | |||
84 | ide_dma_on(drive); | 85 | ide_dma_on(drive); |
85 | } | 86 | } |
86 | 87 | ||
87 | if (!__blk_end_request(rq, error, nr_bytes)) { | 88 | spin_lock_irqsave(&ide_lock, flags); |
88 | if (dequeue) | 89 | if (!__blk_end_request(rq, error, nr_bytes)) |
89 | HWGROUP(drive)->rq = NULL; | ||
90 | ret = 0; | 90 | ret = 0; |
91 | } | 91 | spin_unlock_irqrestore(&ide_lock, flags); |
92 | |||
93 | if (ret == 0 && dequeue) | ||
94 | drive->hwif->hwgroup->rq = NULL; | ||
92 | 95 | ||
93 | return ret; | 96 | return ret; |
94 | } | 97 | } |
@@ -108,8 +111,6 @@ int ide_end_request (ide_drive_t *drive, int uptodate, int nr_sectors) | |||
108 | { | 111 | { |
109 | unsigned int nr_bytes = nr_sectors << 9; | 112 | unsigned int nr_bytes = nr_sectors << 9; |
110 | struct request *rq = drive->hwif->hwgroup->rq; | 113 | struct request *rq = drive->hwif->hwgroup->rq; |
111 | unsigned long flags; | ||
112 | int ret = 1; | ||
113 | 114 | ||
114 | if (!nr_bytes) { | 115 | if (!nr_bytes) { |
115 | if (blk_pc_request(rq)) | 116 | if (blk_pc_request(rq)) |
@@ -118,11 +119,7 @@ int ide_end_request (ide_drive_t *drive, int uptodate, int nr_sectors) | |||
118 | nr_bytes = rq->hard_cur_sectors << 9; | 119 | nr_bytes = rq->hard_cur_sectors << 9; |
119 | } | 120 | } |
120 | 121 | ||
121 | spin_lock_irqsave(&ide_lock, flags); | 122 | return __ide_end_request(drive, rq, uptodate, nr_bytes, 1); |
122 | ret = __ide_end_request(drive, rq, uptodate, nr_bytes, 1); | ||
123 | spin_unlock_irqrestore(&ide_lock, flags); | ||
124 | |||
125 | return ret; | ||
126 | } | 123 | } |
127 | EXPORT_SYMBOL(ide_end_request); | 124 | EXPORT_SYMBOL(ide_end_request); |
128 | 125 | ||
@@ -236,16 +233,9 @@ out_do_tf: | |||
236 | int ide_end_dequeued_request(ide_drive_t *drive, struct request *rq, | 233 | int ide_end_dequeued_request(ide_drive_t *drive, struct request *rq, |
237 | int uptodate, int nr_sectors) | 234 | int uptodate, int nr_sectors) |
238 | { | 235 | { |
239 | unsigned long flags; | ||
240 | int ret; | ||
241 | |||
242 | BUG_ON(!blk_rq_started(rq)); | 236 | BUG_ON(!blk_rq_started(rq)); |
243 | 237 | ||
244 | spin_lock_irqsave(&ide_lock, flags); | 238 | return __ide_end_request(drive, rq, uptodate, nr_sectors << 9, 0); |
245 | ret = __ide_end_request(drive, rq, uptodate, nr_sectors << 9, 0); | ||
246 | spin_unlock_irqrestore(&ide_lock, flags); | ||
247 | |||
248 | return ret; | ||
249 | } | 239 | } |
250 | EXPORT_SYMBOL_GPL(ide_end_dequeued_request); | 240 | EXPORT_SYMBOL_GPL(ide_end_dequeued_request); |
251 | 241 | ||