From: "Aneesh Kumar K.V" <aneesh.kumar@linux.vnet.ibm.com>
To: Jan Kara <jack@suse.cz>
Cc: Sami Liedes <sliedes@cc.hut.fi>,
Andrew Morton <akpm@linux-foundation.org>,
bugme-daemon@bugzilla.kernel.org, linux-ext4@vger.kernel.org
Subject: Re: [Bugme-new] [Bug 11266] New: unable to handle kernel paging request in ext2_free_blocks
Date: Mon, 18 Aug 2008 22:21:31 +0530 [thread overview]
Message-ID: <20080818165131.GC6491@skywalker> (raw)
In-Reply-To: <20080818145841.GC10621@atrey.karlin.mff.cuni.cz>
On Mon, Aug 18, 2008 at 04:58:41PM +0200, Jan Kara wrote:
>
> From 06953717138efe3ad535e78343beb7204ac0d274 Mon Sep 17 00:00:00 2001
> From: Jan Kara <jack@suse.cz>
> Date: Mon, 18 Aug 2008 16:45:11 +0200
> Subject: [PATCH] ext2: Check for corrupted group descriptor before using data in it
>
> We have to check whether a group descriptor isn't corrupted in
> read_block_bitmap(). Otherwise ext2_valid_block_bitmap() will try
> to access bits outside of bitmap and Oops happens.
>
> CC: Vegard Nossum <vegard.nossum@gmail.com>
> CC: Sami Liedes <sliedes@cc.hut.fi>
> Signed-off-by: Jan Kara <jack@suse.cz>
> ---
> fs/ext2/balloc.c | 29 +++++++++++++++++++++++++++++
> 1 files changed, 29 insertions(+), 0 deletions(-)
>
> diff --git a/fs/ext2/balloc.c b/fs/ext2/balloc.c
> index 10bb02c..9104712 100644
> --- a/fs/ext2/balloc.c
> +++ b/fs/ext2/balloc.c
> @@ -113,6 +113,17 @@ err_out:
> return 0;
> }
>
> +static int ext2_block_in_group(struct super_block *sb,
> + unsigned int block_group, ext2_fsblk_t block)
> +{
> + if (block < ext2_group_first_block_no(sb, block_group))
> + return 0;
> + if (block >= ext2_group_first_block_no(sb, block_group) +
> + EXT2_BLOCKS_PER_GROUP(sb))
> + return 0;
> + return 1;
> +}
> +
> /*
> * Read the bitmap for a given block_group,and validate the
> * bits for block/inode/inode tables are set in the bitmaps
> @@ -129,6 +140,24 @@ read_block_bitmap(struct super_block *sb, unsigned int block_group)
> desc = ext2_get_group_desc(sb, block_group, NULL);
> if (!desc)
> return NULL;
> + if (!ext2_block_in_group(sb, block_group,
> + le32_to_cpu(desc->bg_block_bitmap)) ||
> + !ext2_block_in_group(sb, block_group,
> + le32_to_cpu(desc->bg_inode_bitmap)) ||
> + !ext2_block_in_group(sb, block_group,
> + le32_to_cpu(desc->bg_inode_table)) ||
> + !ext2_block_in_group(sb, block_group,
> + le32_to_cpu(desc->bg_inode_table) +
> + EXT2_SB(sb)->s_itb_per_group - 1)) {
> + ext2_error(sb, __func__, "Corrupted group descriptor - "
> + "block_group = %u, block_bitmap = %u, "
> + "inode_bitmap = %u, inode_table = %u",
> + block_group,
> + le32_to_cpu(desc->bg_block_bitmap),
> + le32_to_cpu(desc->bg_inode_bitmap),
> + le32_to_cpu(desc->bg_inode_table));
> + return NULL;
> + }
> bitmap_blk = le32_to_cpu(desc->bg_block_bitmap);
> bh = sb_getblk(sb, bitmap_blk);
> if (unlikely(!bh)) {
Do we need to do this validation every time we do a read_block_bitmap ?
I guess we need to move the validation where we read the desc blocks
from the disk.
-aneesh
next prev parent reply other threads:[~2008-08-18 16:51 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <bug-11266-10286@http.bugzilla.kernel.org/>
2008-08-07 17:52 ` [Bugme-new] [Bug 11266] New: unable to handle kernel paging request in ext2_free_blocks Andrew Morton
[not found] ` <0K5800031SEDU2@smtp02.hut-mail>
2008-08-07 20:07 ` Sami Liedes
2008-08-07 20:28 ` Sami Liedes
2008-08-18 14:58 ` Jan Kara
2008-08-18 16:51 ` Aneesh Kumar K.V [this message]
2008-08-19 3:24 ` Andreas Dilger
2008-08-19 9:13 ` Jan Kara
2008-08-19 10:51 ` Sami Liedes
2008-08-20 10:25 ` Jan Kara
2008-08-20 13:29 ` Sami Liedes
2008-08-20 19:07 ` Andreas Dilger
2008-11-02 5:27 ` Sami Liedes
2008-08-19 21:43 ` Sami Liedes
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20080818165131.GC6491@skywalker \
--to=aneesh.kumar@linux.vnet.ibm.com \
--cc=akpm@linux-foundation.org \
--cc=bugme-daemon@bugzilla.kernel.org \
--cc=jack@suse.cz \
--cc=linux-ext4@vger.kernel.org \
--cc=sliedes@cc.hut.fi \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.