* [PATCH] ext2: skip pages past number of blocks in ext2_find_entry
@ 2006-12-21 18:58 Eric Sandeen
2006-12-21 19:05 ` Randy Dunlap
0 siblings, 1 reply; 4+ messages in thread
From: Eric Sandeen @ 2006-12-21 18:58 UTC (permalink / raw)
To: Linux Kernel Mailing List, ext4 development
This one was pointed out on the MOKB site:
http://kernelfun.blogspot.com/2006/11/mokb-09-11-2006-linux-26x-ext2checkpage.html
If a directory's i_size is corrupted, ext2_find_entry() will keep processing
pages until the i_size is reached, even if there are no more blocks associated
with the directory inode. This patch puts in some minimal sanity-checking
so that we don't keep checking pages (and issuing errors) if we know there
can be no more data to read, based on the block count of the directory inode.
This is somewhat similar in approach to the ext3 patch I sent earlier this
year.
Thanks,
-Eric
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Index: linux-2.6.19/fs/ext2/dir.c
===================================================================
--- linux-2.6.19.orig/fs/ext2/dir.c
+++ linux-2.6.19/fs/ext2/dir.c
@@ -368,6 +368,14 @@ struct ext2_dir_entry_2 * ext2_find_entr
}
if (++n >= npages)
n = 0;
+ /* next page is past the blocks we've got */
+ if (unlikely(n > (dir->i_blocks >> (PAGE_CACHE_SHIFT - 9)))) {
+ ext2_error(dir->i_sb, __FUNCTION__,
+ "dir %lu size %lld exceeds block count %llu",
+ dir->i_ino, dir->i_size,
+ (unsigned long long)dir->i_blocks);
+ goto out;
+ }
} while (n != start);
out:
return NULL;
^ permalink raw reply [flat|nested] 4+ messages in thread* Re: [PATCH] ext2: skip pages past number of blocks in ext2_find_entry
2006-12-21 18:58 [PATCH] ext2: skip pages past number of blocks in ext2_find_entry Eric Sandeen
@ 2006-12-21 19:05 ` Randy Dunlap
2006-12-21 19:11 ` Eric Sandeen
0 siblings, 1 reply; 4+ messages in thread
From: Randy Dunlap @ 2006-12-21 19:05 UTC (permalink / raw)
To: Eric Sandeen; +Cc: Linux Kernel Mailing List, ext4 development
On Thu, 21 Dec 2006 12:58:28 -0600 Eric Sandeen wrote:
> This one was pointed out on the MOKB site:
> http://kernelfun.blogspot.com/2006/11/mokb-09-11-2006-linux-26x-ext2checkpage.html
>
> If a directory's i_size is corrupted, ext2_find_entry() will keep processing
> pages until the i_size is reached, even if there are no more blocks associated
> with the directory inode. This patch puts in some minimal sanity-checking
> so that we don't keep checking pages (and issuing errors) if we know there
> can be no more data to read, based on the block count of the directory inode.
>
> This is somewhat similar in approach to the ext3 patch I sent earlier this
> year.
>
> Thanks,
>
> -Eric
>
> Signed-off-by: Eric Sandeen <sandeen@redhat.com>
>
> Index: linux-2.6.19/fs/ext2/dir.c
> ===================================================================
> --- linux-2.6.19.orig/fs/ext2/dir.c
> +++ linux-2.6.19/fs/ext2/dir.c
> @@ -368,6 +368,14 @@ struct ext2_dir_entry_2 * ext2_find_entr
> }
> if (++n >= npages)
> n = 0;
> + /* next page is past the blocks we've got */
> + if (unlikely(n > (dir->i_blocks >> (PAGE_CACHE_SHIFT - 9)))) {
> + ext2_error(dir->i_sb, __FUNCTION__,
> + "dir %lu size %lld exceeds block count %llu",
> + dir->i_ino, dir->i_size,
> + (unsigned long long)dir->i_blocks);
> + goto out;
Please don't hide the goto; un-indent 1 tab stop.
> + }
> } while (n != start);
> out:
> return NULL;
---
~Randy
^ permalink raw reply [flat|nested] 4+ messages in thread* Re: [PATCH] ext2: skip pages past number of blocks in ext2_find_entry
2006-12-21 19:05 ` Randy Dunlap
@ 2006-12-21 19:11 ` Eric Sandeen
2006-12-21 19:14 ` Randy Dunlap
0 siblings, 1 reply; 4+ messages in thread
From: Eric Sandeen @ 2006-12-21 19:11 UTC (permalink / raw)
To: Randy Dunlap; +Cc: Linux Kernel Mailing List, ext4 development
Randy Dunlap wrote:
> Please don't hide the goto; un-indent 1 tab stop.
Whoops, thanks Randy - it wasn't intentional. :)
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Index: linux-2.6.19/fs/ext2/dir.c
===================================================================
--- linux-2.6.19.orig/fs/ext2/dir.c
+++ linux-2.6.19/fs/ext2/dir.c
@@ -368,6 +368,14 @@ struct ext2_dir_entry_2 * ext2_find_entr
}
if (++n >= npages)
n = 0;
+ /* next page is past the blocks we've got */
+ if (unlikely(n > (dir->i_blocks >> (PAGE_CACHE_SHIFT - 9)))) {
+ ext2_error(dir->i_sb, __FUNCTION__,
+ "dir %lu size %lld exceeds block count %llu",
+ dir->i_ino, dir->i_size,
+ (unsigned long long)dir->i_blocks);
+ goto out;
+ }
} while (n != start);
out:
return NULL;
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2006-12-21 19:14 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-12-21 18:58 [PATCH] ext2: skip pages past number of blocks in ext2_find_entry Eric Sandeen
2006-12-21 19:05 ` Randy Dunlap
2006-12-21 19:11 ` Eric Sandeen
2006-12-21 19:14 ` Randy Dunlap
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).