ext3, ext4: avoid divide by zero

As it turns out, the kernel divides by EXT3_INODES_PER_GROUP(s) when
mounting an ext3 filesystem. If that number is zero, a crash follows.
Below a patch.

This crash was reported by Joeri de Ruiter, Carst Tankink and Pim Vullers.

Cc: <linux-ext4@vger.kernel.org>
Acked-by: Alan Cox <alan@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>

authored by

Andries E. Brouwer and committed by
Linus Torvalds
b47b6f38 9e2de407

+2 -2
+1 -1
fs/ext3/super.c
··· 1676 1676 sbi->s_blocks_per_group = le32_to_cpu(es->s_blocks_per_group); 1677 1677 sbi->s_frags_per_group = le32_to_cpu(es->s_frags_per_group); 1678 1678 sbi->s_inodes_per_group = le32_to_cpu(es->s_inodes_per_group); 1679 - if (EXT3_INODE_SIZE(sb) == 0) 1679 + if (EXT3_INODE_SIZE(sb) == 0 || EXT3_INODES_PER_GROUP(sb) == 0) 1680 1680 goto cantfind_ext3; 1681 1681 sbi->s_inodes_per_block = blocksize / EXT3_INODE_SIZE(sb); 1682 1682 if (sbi->s_inodes_per_block == 0)
+1 -1
fs/ext4/super.c
··· 1797 1797 sbi->s_desc_size = EXT4_MIN_DESC_SIZE; 1798 1798 sbi->s_blocks_per_group = le32_to_cpu(es->s_blocks_per_group); 1799 1799 sbi->s_inodes_per_group = le32_to_cpu(es->s_inodes_per_group); 1800 - if (EXT4_INODE_SIZE(sb) == 0) 1800 + if (EXT4_INODE_SIZE(sb) == 0 || EXT4_INODES_PER_GROUP(sb) == 0) 1801 1801 goto cantfind_ext4; 1802 1802 sbi->s_inodes_per_block = blocksize / EXT4_INODE_SIZE(sb); 1803 1803 if (sbi->s_inodes_per_block == 0)