end_request error procedure in 2.5?

Peter T. Breuer (ptb@it.uc3m.es)
Mon, 16 Sep 2002 15:49:42 +0200 (MET DST)


Can someone tell me why this block end_request routine works fine with a
request that isn't errored, but locks the machine a milisecond or two
later if the request is marked for erroring?

call as

end_request( req, (req->errors == 0) ? 1 : 0 );
..

static void end_request(struct request *req, int uptodate) {
struct bio *bio;
while ((bio = req->bio) != NULL) {
blk_finished_io(bio_sectors(bio));
req->bio = bio->bi_next;
bio->bi_next = NULL;
bio_endio(bio, uptodate);
}
blk_put_request(req);
}

It works fine except on error. Kernel 2.5.31. I understand that
put_request adds the request back to a free list (if gotten from there
via get_request). The request is ordinary, except out of range ...
it's produced by an e2fsck of the device when the device itself is
unformatted, and the out of range request gets passed to the driver and
is errored there, and "kapow" ..

Peter
-
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/