[PATCH] 2.6.6 buffer.c: bio_alloc() check

From: Yury Umanets
Date: Wed Jun 02 2004 - 08:33:30 EST


[PATCH] 2.6.6 buffer.c: adds bio_alloc() check and error handling in
fs/buffer.c.

Signed-off-by: Yury Umanets <torque@xxxxxxxxxxx>

buffer.c | 25 +++++++++++++++++++++++++
1 files changed, 25 insertions(+)

diff -rupN ./linux-2.6.6/fs/buffer.c ./linux-2.6.6-modified/fs/buffer.c
--- ./linux-2.6.6/fs/buffer.c Mon May 10 05:32:38 2004
+++ ./linux-2.6.6-modified/fs/buffer.c Wed Jun 2 15:21:47 2004
@@ -2712,6 +2712,31 @@ void submit_bh(int rw, struct buffer_hea
* submit_bio -> generic_make_request may further map this bio around
*/
bio = bio_alloc(GFP_NOIO, 1);
+ if (bio == NULL) {
+ char b[BDEVNAME_SIZE];
+
+ printk(KERN_ERR "BIO allocation failed for buffer on device "
+ "%s, logical block %Lu\n", bdevname(bh->b_bdev, b),
+ (unsigned long long)bh->b_blocknr);
+
+ /*
+ * this is needed here as some of submit_bh() callers have to
+ * wait until buffer is unlocked (that is IO is finished on it)
+ * and check its state.
+ */
+ if (rw == WRITE)
+ set_buffer_write_io_error(bh);
+ clear_buffer_uptodate(bh);
+ SetPageError(bh->b_page);
+
+ /*
+ * making all future wait_on_buffer() callers do not wait
+ * this buffer as it is errorneous.
+ */
+ if (buffer_locked(bh))
+ unlock_buffer(bh);
+ return;
+ }

bio->bi_sector = bh->b_blocknr * (bh->b_size >> 9);
bio->bi_bdev = bh->b_bdev;


--
umka

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/