Rock Lee
2012-Oct-25  16:12 UTC
[PATCH V2][BTRFS-PROGS] [BUG] Fix Bug to corrupt the img file
Fix Bug to corrupt the img file
Reproduce steps:
  > dd if=/dev/zero of=btrfs-small.img bs=1M count=1
  > ls -lh btrfs-small.img
  -rw-rw-r--. 1 rock rock 1.0M Oct 24 09:51 btrfs-small.img
                                      ^^^
  > mkfs.btrfs btrfs-small.img
  -rw-rw-r--. 1 rock rock 2.0M Oct 24 09:53 btrfs-small.img
                                      ^^^
Here you can see the original img file''s size goes larger to 2Mb.
Signed-off-by: Rock Lee <zimilo@code-trick.com>
---
 utils.c |    6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/utils.c b/utils.c
index 205e667..7ba746e 100644
--- a/utils.c
+++ b/utils.c
@@ -557,6 +557,12 @@ int btrfs_prepare_device(int fd, char *file, int
zero_end, u64 *block_count_ret,
        }
        if (max_block_count)
                block_count = min(block_count, max_block_count);
+
+       if (block_count < 2 * 1024 * 1024) {
+               fprintf(stderr, "size of %s is too small(less than
2Mb)\n", file);
+               exit(1);
+       }
+
        zero_end = 1;
        if (block_count < 1024 * 1024 * 1024 && !(*mixed)) {
-- 
1.7.9.5
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs"
in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
David Sterba
2012-Oct-25  16:43 UTC
Re: [PATCH V2][BTRFS-PROGS] [BUG] Fix Bug to corrupt the img file Reply-To: dave@jikos.cz
On Fri, Oct 26, 2012 at 12:12:24AM +0800, Rock Lee wrote:> Fix Bug to corrupt the img file > > Reproduce steps: > > dd if=/dev/zero of=btrfs-small.img bs=1M count=1 > > ls -lh btrfs-small.img > -rw-rw-r--. 1 rock rock 1.0M Oct 24 09:51 btrfs-small.img > ^^^ > > mkfs.btrfs btrfs-small.img > -rw-rw-r--. 1 rock rock 2.0M Oct 24 09:53 btrfs-small.img > ^^^ > > Here you can see the original img file''s size goes larger to 2Mb.Thanks, fixes this particular bug; although it crashes later at mkfs.btrfs: volumes.c:796: btrfs_alloc_chunk: Assertion `!(ret)'' failed but this is a separate issue and you''ve sent patches for that IIRC.> --- a/utils.c > +++ b/utils.c > @@ -557,6 +557,12 @@ int btrfs_prepare_device(int fd, char *file, int > zero_end, u64 *block_count_ret, > } > if (max_block_count) > block_count = min(block_count, max_block_count); > + > + if (block_count < 2 * 1024 * 1024) { > + fprintf(stderr, "size of %s is too small(less than > 2Mb)\n", file);line wrapped, please check your mailer (easy to fix but additional unnecessary work)> + exit(1); > + } > +Otherwise ack from me. david -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Rock Lee
2012-Oct-25  23:36 UTC
Re: [PATCH V2][BTRFS-PROGS] [BUG] Fix Bug to corrupt the img file Reply-To: dave@jikos.cz
Thanks for your review. Sorry for the problem line wrapped, I will resend the patch. Thanks -Rock 2012/10/26 David Sterba <dave@jikos.cz>:> On Fri, Oct 26, 2012 at 12:12:24AM +0800, Rock Lee wrote: >> Fix Bug to corrupt the img file >> >> Reproduce steps: >> > dd if=/dev/zero of=btrfs-small.img bs=1M count=1 >> > ls -lh btrfs-small.img >> -rw-rw-r--. 1 rock rock 1.0M Oct 24 09:51 btrfs-small.img >> ^^^ >> > mkfs.btrfs btrfs-small.img >> -rw-rw-r--. 1 rock rock 2.0M Oct 24 09:53 btrfs-small.img >> ^^^ >> >> Here you can see the original img file''s size goes larger to 2Mb. > > Thanks, fixes this particular bug; although it crashes later at > > mkfs.btrfs: volumes.c:796: btrfs_alloc_chunk: Assertion `!(ret)'' failed > > but this is a separate issue and you''ve sent patches for that IIRC. > >> --- a/utils.c >> +++ b/utils.c >> @@ -557,6 +557,12 @@ int btrfs_prepare_device(int fd, char *file, int >> zero_end, u64 *block_count_ret, >> } >> if (max_block_count) >> block_count = min(block_count, max_block_count); >> + >> + if (block_count < 2 * 1024 * 1024) { >> + fprintf(stderr, "size of %s is too small(less than >> 2Mb)\n", file); > > line wrapped, please check your mailer (easy to fix but additional > unnecessary work) > >> + exit(1); >> + } >> + > > Otherwise ack from me. > > david-- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html