aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ide/ide-cd.c12
-rw-r--r--drivers/ide/ide-io.c40
-rw-r--r--drivers/ide/ide-lib.c7
3 files changed, 28 insertions, 31 deletions
diff --git a/drivers/ide/ide-cd.c b/drivers/ide/ide-cd.c
index 42ab6d8715f2..31f398577ed4 100644
--- a/drivers/ide/ide-cd.c
+++ b/drivers/ide/ide-cd.c
@@ -317,7 +317,8 @@ static void ide_dump_status_no_sense(ide_drive_t *drive, const char *msg, u8 st)
317static int cdrom_decode_status(ide_drive_t *drive, int good_stat, int *stat_ret) 317static int cdrom_decode_status(ide_drive_t *drive, int good_stat, int *stat_ret)
318{ 318{
319 ide_hwif_t *hwif = drive->hwif; 319 ide_hwif_t *hwif = drive->hwif;
320 struct request *rq = hwif->hwgroup->rq; 320 ide_hwgroup_t *hwgroup = hwif->hwgroup;
321 struct request *rq = hwgroup->rq;
321 int stat, err, sense_key; 322 int stat, err, sense_key;
322 323
323 /* check for errors */ 324 /* check for errors */
@@ -508,9 +509,10 @@ end_request:
508 509
509 spin_lock_irqsave(&ide_lock, flags); 510 spin_lock_irqsave(&ide_lock, flags);
510 blkdev_dequeue_request(rq); 511 blkdev_dequeue_request(rq);
511 HWGROUP(drive)->rq = NULL;
512 spin_unlock_irqrestore(&ide_lock, flags); 512 spin_unlock_irqrestore(&ide_lock, flags);
513 513
514 hwgroup->rq = NULL;
515
514 cdrom_queue_request_sense(drive, rq->sense, rq); 516 cdrom_queue_request_sense(drive, rq->sense, rq);
515 } else 517 } else
516 cdrom_end_request(drive, 0); 518 cdrom_end_request(drive, 0);
@@ -950,7 +952,8 @@ static int cdrom_newpc_intr_dummy_cb(struct request *rq)
950static ide_startstop_t cdrom_newpc_intr(ide_drive_t *drive) 952static ide_startstop_t cdrom_newpc_intr(ide_drive_t *drive)
951{ 953{
952 ide_hwif_t *hwif = drive->hwif; 954 ide_hwif_t *hwif = drive->hwif;
953 struct request *rq = HWGROUP(drive)->rq; 955 ide_hwgroup_t *hwgroup = hwif->hwgroup;
956 struct request *rq = hwgroup->rq;
954 xfer_func_t *xferfunc; 957 xfer_func_t *xferfunc;
955 ide_expiry_t *expiry = NULL; 958 ide_expiry_t *expiry = NULL;
956 int dma_error = 0, dma, stat, thislen, uptodate = 0; 959 int dma_error = 0, dma, stat, thislen, uptodate = 0;
@@ -1157,8 +1160,9 @@ end_request:
1157 spin_lock_irqsave(&ide_lock, flags); 1160 spin_lock_irqsave(&ide_lock, flags);
1158 if (__blk_end_request(rq, 0, dlen)) 1161 if (__blk_end_request(rq, 0, dlen))
1159 BUG(); 1162 BUG();
1160 HWGROUP(drive)->rq = NULL;
1161 spin_unlock_irqrestore(&ide_lock, flags); 1163 spin_unlock_irqrestore(&ide_lock, flags);
1164
1165 hwgroup->rq = NULL;
1162 } else { 1166 } else {
1163 if (!uptodate) 1167 if (!uptodate)
1164 rq->cmd_flags |= REQ_FAILED; 1168 rq->cmd_flags |= REQ_FAILED;
diff --git a/drivers/ide/ide-io.c b/drivers/ide/ide-io.c
index 35b625882803..8afe7b15decf 100644
--- a/drivers/ide/ide-io.c
+++ b/drivers/ide/ide-io.c
@@ -107,17 +107,10 @@ static int __ide_end_request(ide_drive_t *drive, struct request *rq,
107int ide_end_request (ide_drive_t *drive, int uptodate, int nr_sectors) 107int ide_end_request (ide_drive_t *drive, int uptodate, int nr_sectors)
108{ 108{
109 unsigned int nr_bytes = nr_sectors << 9; 109 unsigned int nr_bytes = nr_sectors << 9;
110 struct request *rq; 110 struct request *rq = drive->hwif->hwgroup->rq;
111 unsigned long flags; 111 unsigned long flags;
112 int ret = 1; 112 int ret = 1;
113 113
114 /*
115 * room for locking improvements here, the calls below don't
116 * need the queue lock held at all
117 */
118 spin_lock_irqsave(&ide_lock, flags);
119 rq = HWGROUP(drive)->rq;
120
121 if (!nr_bytes) { 114 if (!nr_bytes) {
122 if (blk_pc_request(rq)) 115 if (blk_pc_request(rq))
123 nr_bytes = rq->data_len; 116 nr_bytes = rq->data_len;
@@ -125,9 +118,10 @@ int ide_end_request (ide_drive_t *drive, int uptodate, int nr_sectors)
125 nr_bytes = rq->hard_cur_sectors << 9; 118 nr_bytes = rq->hard_cur_sectors << 9;
126 } 119 }
127 120
121 spin_lock_irqsave(&ide_lock, flags);
128 ret = __ide_end_request(drive, rq, uptodate, nr_bytes, 1); 122 ret = __ide_end_request(drive, rq, uptodate, nr_bytes, 1);
129
130 spin_unlock_irqrestore(&ide_lock, flags); 123 spin_unlock_irqrestore(&ide_lock, flags);
124
131 return ret; 125 return ret;
132} 126}
133EXPORT_SYMBOL(ide_end_request); 127EXPORT_SYMBOL(ide_end_request);
@@ -245,8 +239,9 @@ int ide_end_dequeued_request(ide_drive_t *drive, struct request *rq,
245 unsigned long flags; 239 unsigned long flags;
246 int ret; 240 int ret;
247 241
248 spin_lock_irqsave(&ide_lock, flags);
249 BUG_ON(!blk_rq_started(rq)); 242 BUG_ON(!blk_rq_started(rq));
243
244 spin_lock_irqsave(&ide_lock, flags);
250 ret = __ide_end_request(drive, rq, uptodate, nr_sectors << 9, 0); 245 ret = __ide_end_request(drive, rq, uptodate, nr_sectors << 9, 0);
251 spin_unlock_irqrestore(&ide_lock, flags); 246 spin_unlock_irqrestore(&ide_lock, flags);
252 247
@@ -278,7 +273,11 @@ static void ide_complete_pm_request (ide_drive_t *drive, struct request *rq)
278 drive->dev_flags &= ~IDE_DFLAG_BLOCKED; 273 drive->dev_flags &= ~IDE_DFLAG_BLOCKED;
279 blk_start_queue(drive->queue); 274 blk_start_queue(drive->queue);
280 } 275 }
281 HWGROUP(drive)->rq = NULL; 276 spin_unlock_irqrestore(&ide_lock, flags);
277
278 drive->hwif->hwgroup->rq = NULL;
279
280 spin_lock_irqsave(&ide_lock, flags);
282 if (__blk_end_request(rq, 0, 0)) 281 if (__blk_end_request(rq, 0, 0))
283 BUG(); 282 BUG();
284 spin_unlock_irqrestore(&ide_lock, flags); 283 spin_unlock_irqrestore(&ide_lock, flags);
@@ -300,12 +299,9 @@ static void ide_complete_pm_request (ide_drive_t *drive, struct request *rq)
300 299
301void ide_end_drive_cmd (ide_drive_t *drive, u8 stat, u8 err) 300void ide_end_drive_cmd (ide_drive_t *drive, u8 stat, u8 err)
302{ 301{
302 ide_hwgroup_t *hwgroup = drive->hwif->hwgroup;
303 struct request *rq = hwgroup->rq;
303 unsigned long flags; 304 unsigned long flags;
304 struct request *rq;
305
306 spin_lock_irqsave(&ide_lock, flags);
307 rq = HWGROUP(drive)->rq;
308 spin_unlock_irqrestore(&ide_lock, flags);
309 305
310 if (rq->cmd_type == REQ_TYPE_ATA_TASKFILE) { 306 if (rq->cmd_type == REQ_TYPE_ATA_TASKFILE) {
311 ide_task_t *task = (ide_task_t *)rq->special; 307 ide_task_t *task = (ide_task_t *)rq->special;
@@ -333,15 +329,16 @@ void ide_end_drive_cmd (ide_drive_t *drive, u8 stat, u8 err)
333 return; 329 return;
334 } 330 }
335 331
336 spin_lock_irqsave(&ide_lock, flags); 332 hwgroup->rq = NULL;
337 HWGROUP(drive)->rq = NULL; 333
338 rq->errors = err; 334 rq->errors = err;
335
336 spin_lock_irqsave(&ide_lock, flags);
339 if (unlikely(__blk_end_request(rq, (rq->errors ? -EIO : 0), 337 if (unlikely(__blk_end_request(rq, (rq->errors ? -EIO : 0),
340 blk_rq_bytes(rq)))) 338 blk_rq_bytes(rq))))
341 BUG(); 339 BUG();
342 spin_unlock_irqrestore(&ide_lock, flags); 340 spin_unlock_irqrestore(&ide_lock, flags);
343} 341}
344
345EXPORT_SYMBOL(ide_end_drive_cmd); 342EXPORT_SYMBOL(ide_end_drive_cmd);
346 343
347static void ide_kill_rq(ide_drive_t *drive, struct request *rq) 344static void ide_kill_rq(ide_drive_t *drive, struct request *rq)
@@ -1489,11 +1486,12 @@ out:
1489 1486
1490void ide_do_drive_cmd(ide_drive_t *drive, struct request *rq) 1487void ide_do_drive_cmd(ide_drive_t *drive, struct request *rq)
1491{ 1488{
1489 ide_hwgroup_t *hwgroup = drive->hwif->hwgroup;
1492 unsigned long flags; 1490 unsigned long flags;
1493 ide_hwgroup_t *hwgroup = HWGROUP(drive);
1494 1491
1495 spin_lock_irqsave(&ide_lock, flags);
1496 hwgroup->rq = NULL; 1492 hwgroup->rq = NULL;
1493
1494 spin_lock_irqsave(&ide_lock, flags);
1497 __elv_add_request(drive->queue, rq, ELEVATOR_INSERT_FRONT, 0); 1495 __elv_add_request(drive->queue, rq, ELEVATOR_INSERT_FRONT, 0);
1498 blk_start_queueing(drive->queue); 1496 blk_start_queueing(drive->queue);
1499 spin_unlock_irqrestore(&ide_lock, flags); 1497 spin_unlock_irqrestore(&ide_lock, flags);
diff --git a/drivers/ide/ide-lib.c b/drivers/ide/ide-lib.c
index 9fc4cfb2a272..1932119dfa00 100644
--- a/drivers/ide/ide-lib.c
+++ b/drivers/ide/ide-lib.c
@@ -277,14 +277,9 @@ int ide_set_xfer_rate(ide_drive_t *drive, u8 rate)
277 277
278static void ide_dump_opcode(ide_drive_t *drive) 278static void ide_dump_opcode(ide_drive_t *drive)
279{ 279{
280 struct request *rq; 280 struct request *rq = drive->hwif->hwgroup->rq;
281 ide_task_t *task = NULL; 281 ide_task_t *task = NULL;
282 282
283 spin_lock(&ide_lock);
284 rq = NULL;
285 if (HWGROUP(drive))
286 rq = HWGROUP(drive)->rq;
287 spin_unlock(&ide_lock);
288 if (!rq) 283 if (!rq)
289 return; 284 return;
290 285