[PATCH] blk: fix dangling pointer access in __elv_add_request
From: Tejun Heo (htejun_at_gmail.com)
Date: 11/01/05
- Previous message: Torsten Foertsch: "Re: /proc/*/smaps"
- Next in thread: Jens Axboe: "Re: [PATCH] blk: fix dangling pointer access in __elv_add_request"
- Reply: Jens Axboe: "Re: [PATCH] blk: fix dangling pointer access in __elv_add_request"
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
Date: Tue, 1 Nov 2005 17:23:49 +0900 To: torvalds@osdl.org, axboe@suse.de, acme@mandriva.com
cfq's add_req_fn callback may invoke q->request_fn directly and
depending on low-level driver used and timing, a queued request may be
finished & deallocated before add_req_fn callback returns. So,
__elv_add_request must not access rq after it's passed to add_req_fn
callback.
This patch moves rq_mergeable test above add_req_fn(). This may
result in q->last_merge pointing to REQ_NOMERGE request if add_req_fn
callback sets it but as RQ_NOMERGE is checked again when blk layer
actually tries to merge requests, this does not cause any problem.
Signed-off-by: Tejun Heo <htejun@gmail.com>
--- Arnaldo, I think this patch should fix the oops you're seeing. Please let me know how it works. And thanks again for detailed reporting. Jens, does generalizing queue kicking functions and disallowing ioscheds from directly calling q->request_fn sound like a good idea? Linus, with or without Arnaldo's confirmation, this patch fixes an existing bug. Please apply. Thanks. diff --git a/drivers/block/elevator.c b/drivers/block/elevator.c --- a/drivers/block/elevator.c +++ b/drivers/block/elevator.c @@ -369,9 +369,14 @@ void __elv_add_request(request_queue_t * case ELEVATOR_INSERT_SORT: BUG_ON(!blk_fs_request(rq)); rq->flags |= REQ_SORTED; - q->elevator->ops->elevator_add_req_fn(q, rq); if (q->last_merge == NULL && rq_mergeable(rq)) q->last_merge = rq; + /* + * Some ioscheds (cfq) run q->request_fn directly, so + * rq cannot be accessed after calling + * elevator_add_req_fn. + */ + q->elevator->ops->elevator_add_req_fn(q, rq); break; default: - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
- Previous message: Torsten Foertsch: "Re: /proc/*/smaps"
- Next in thread: Jens Axboe: "Re: [PATCH] blk: fix dangling pointer access in __elv_add_request"
- Reply: Jens Axboe: "Re: [PATCH] blk: fix dangling pointer access in __elv_add_request"
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
Relevant Pages
|
|