|
@@ -624,14 +624,14 @@ static void gdrom_readdisk_dma(struct work_struct *work)
|
|
|
ctrl_outb(1, GDROM_DMA_STATUS_REG);
|
|
|
wait_event_interruptible_timeout(request_queue,
|
|
|
gd.transfer == 0, GDROM_DEFAULT_TIMEOUT);
|
|
|
- err = gd.transfer;
|
|
|
+ err = gd.transfer ? -EIO : 0;
|
|
|
gd.transfer = 0;
|
|
|
gd.pending = 0;
|
|
|
/* now seek to take the request spinlock
|
|
|
* before handling ending the request */
|
|
|
spin_lock(&gdrom_lock);
|
|
|
list_del_init(&req->queuelist);
|
|
|
- end_dequeued_request(req, 1 - err);
|
|
|
+ __blk_end_request(req, err, blk_rq_bytes(req));
|
|
|
}
|
|
|
spin_unlock(&gdrom_lock);
|
|
|
kfree(read_command);
|