* grub-core/fs/bfs.c (mount): Improve filesystem detection reliability.

* grub-core/fs/ext2.c (grub_ext2_mount): Likewise.
	* grub-core/fs/hfs.c (grub_hfs_mount): Likewise.
	* grub-core/fs/hfsplus.c (grub_hfsplus_mount): Likewise.
	* grub-core/fs/jfs.c (grub_jfs_mount): Likewise.
	* grub-core/fs/minix.c (grub_minix_mount): Likewise.
	* grub-core/fs/ntfs.c (grub_ntfs_mount): Likewise.
	* grub-core/fs/romfs.c (grub_romfs_mount): Likewise.
	* grub-core/fs/xfs.c (grub_xfs_mount): Likewise.
This commit is contained in:
Vladimir 'phcoder' Serbinenko 2012-05-12 13:31:05 +02:00
parent fe8c2f1117
commit 2e57f28fc7
10 changed files with 63 additions and 18 deletions

View file

@ -1,3 +1,15 @@
2012-05-12 Vladimir Serbinenko <phcoder@gmail.com>
* grub-core/fs/bfs.c (mount): Improve filesystem detection reliability.
* grub-core/fs/ext2.c (grub_ext2_mount): Likewise.
* grub-core/fs/hfs.c (grub_hfs_mount): Likewise.
* grub-core/fs/hfsplus.c (grub_hfsplus_mount): Likewise.
* grub-core/fs/jfs.c (grub_jfs_mount): Likewise.
* grub-core/fs/minix.c (grub_minix_mount): Likewise.
* grub-core/fs/ntfs.c (grub_ntfs_mount): Likewise.
* grub-core/fs/romfs.c (grub_romfs_mount): Likewise.
* grub-core/fs/xfs.c (grub_xfs_mount): Likewise.
2012-05-11 Vladimir Serbinenko <phcoder@gmail.com> 2012-05-11 Vladimir Serbinenko <phcoder@gmail.com>
Use grub-probe and not cmp to check that disk is empty. Use grub-probe and not cmp to check that disk is empty.

View file

@ -43,6 +43,7 @@ GRUB_MOD_LICENSE ("GPLv3+");
#define grub_bfs_to_cpu16 grub_le_to_cpu16 #define grub_bfs_to_cpu16 grub_le_to_cpu16
#define grub_bfs_to_cpu32 grub_le_to_cpu32 #define grub_bfs_to_cpu32 grub_le_to_cpu32
#define grub_bfs_to_cpu64 grub_le_to_cpu64 #define grub_bfs_to_cpu64 grub_le_to_cpu64
#define grub_cpu_to_bfs32_compile_time grub_cpu_to_le32_compile_time
#ifdef MODE_AFS #ifdef MODE_AFS
#define grub_bfs_to_cpu_treehead grub_bfs_to_cpu32 #define grub_bfs_to_cpu_treehead grub_bfs_to_cpu32
@ -818,11 +819,13 @@ mount (grub_disk_t disk, struct grub_bfs_superblock *sb)
); );
if (err) if (err)
return err; return err;
if (grub_bfs_to_cpu32 (sb->magic1) != SUPER_BLOCK_MAGIC1 if (sb->magic1 != grub_cpu_to_bfs32_compile_time (SUPER_BLOCK_MAGIC1)
|| grub_bfs_to_cpu32 (sb->magic2) != SUPER_BLOCK_MAGIC2 || sb->magic2 != grub_cpu_to_bfs32_compile_time (SUPER_BLOCK_MAGIC2)
|| grub_bfs_to_cpu32 (sb->magic3) != SUPER_BLOCK_MAGIC3 || sb->magic3 != grub_cpu_to_bfs32_compile_time (SUPER_BLOCK_MAGIC3)
|| sb->bsize == 0
|| (grub_bfs_to_cpu32 (sb->bsize) || (grub_bfs_to_cpu32 (sb->bsize)
!= (1U << grub_bfs_to_cpu32 (sb->log2_bsize)))) != (1U << grub_bfs_to_cpu32 (sb->log2_bsize)))
|| grub_bfs_to_cpu32 (sb->log2_bsize) < GRUB_DISK_SECTOR_BITS)
return grub_error (GRUB_ERR_BAD_FS, return grub_error (GRUB_ERR_BAD_FS,
#ifdef MODE_AFS #ifdef MODE_AFS
"not an AFS filesystem" "not an AFS filesystem"

View file

@ -578,7 +578,8 @@ grub_ext2_mount (grub_disk_t disk)
goto fail; goto fail;
/* Make sure this is an ext2 filesystem. */ /* Make sure this is an ext2 filesystem. */
if (grub_le_to_cpu16 (data->sblock.magic) != EXT2_MAGIC) if (grub_le_to_cpu16 (data->sblock.magic) != EXT2_MAGIC
|| grub_le_to_cpu32 (data->sblock.log2_block_size) >= 16)
{ {
grub_error (GRUB_ERR_BAD_FS, "not an ext2 filesystem"); grub_error (GRUB_ERR_BAD_FS, "not an ext2 filesystem");
goto fail; goto fail;

View file

@ -328,7 +328,8 @@ grub_hfs_mount (grub_disk_t disk)
goto fail; goto fail;
/* Check if this is a HFS filesystem. */ /* Check if this is a HFS filesystem. */
if (grub_be_to_cpu16 (data->sblock.magic) != GRUB_HFS_MAGIC) if (grub_be_to_cpu16 (data->sblock.magic) != GRUB_HFS_MAGIC
|| (data->sblock.blksz & grub_cpu_to_be32_compile_time (0xc00001ff)))
{ {
grub_error (GRUB_ERR_BAD_FS, "not an HFS filesystem"); grub_error (GRUB_ERR_BAD_FS, "not an HFS filesystem");
goto fail; goto fail;

View file

@ -439,7 +439,10 @@ grub_hfsplus_mount (grub_disk_t disk)
/* Make sure this is an HFS+ filesystem. XXX: Do we really support /* Make sure this is an HFS+ filesystem. XXX: Do we really support
HFX? */ HFX? */
magic = grub_be_to_cpu16 (volheader.hfsplus.magic); magic = grub_be_to_cpu16 (volheader.hfsplus.magic);
if ((magic != GRUB_HFSPLUS_MAGIC) && (magic != GRUB_HFSPLUSX_MAGIC)) if (((magic != GRUB_HFSPLUS_MAGIC) && (magic != GRUB_HFSPLUSX_MAGIC))
|| volheader.hfsplus.blksize == 0
|| ((volheader.hfsplus.blksize & (volheader.hfsplus.blksize - 1)) != 0)
|| grub_be_to_cpu32 (volheader.hfsplus.blksize) < GRUB_DISK_SECTOR_SIZE)
{ {
grub_error (GRUB_ERR_BAD_FS, "not a HFS+ filesystem"); grub_error (GRUB_ERR_BAD_FS, "not a HFS+ filesystem");
goto fail; goto fail;
@ -448,9 +451,9 @@ grub_hfsplus_mount (grub_disk_t disk)
grub_memcpy (&data->volheader, &volheader.hfsplus, grub_memcpy (&data->volheader, &volheader.hfsplus,
sizeof (volheader.hfsplus)); sizeof (volheader.hfsplus));
if (grub_fshelp_log2blksize (grub_be_to_cpu32 (data->volheader.blksize), for (data->log2blksize = 0;
&data->log2blksize)) (1U << data->log2blksize) < grub_be_to_cpu32 (data->volheader.blksize);
goto fail; data->log2blksize++);
/* Make a new node for the catalog tree. */ /* Make a new node for the catalog tree. */
data->catalog_tree.file.data = data; data->catalog_tree.file.data = data;

View file

@ -366,8 +366,10 @@ grub_jfs_mount (grub_disk_t disk)
goto fail; goto fail;
} }
if (grub_le_to_cpu32 (data->sblock.blksz) if (data->sblock.blksz == 0
!= (1U << grub_le_to_cpu16 (data->sblock.log2_blksz))) || grub_le_to_cpu32 (data->sblock.blksz)
!= (1U << grub_le_to_cpu16 (data->sblock.log2_blksz))
|| grub_le_to_cpu16 (data->sblock.log2_blksz) < GRUB_DISK_SECTOR_BITS)
{ {
grub_error (GRUB_ERR_BAD_FS, "not a JFS filesystem"); grub_error (GRUB_ERR_BAD_FS, "not a JFS filesystem");
goto fail; goto fail;

View file

@ -496,6 +496,11 @@ grub_minix_mount (grub_disk_t disk)
else else
goto fail; goto fail;
/* 20 means 1G zones. We could support up to 31 but already 1G isn't
supported by anything else. */
if (grub_minix_to_cpu16 (data->sblock.log2_zone_size) >= 20)
goto fail;
data->disk = disk; data->disk = disk;
data->linknest = 0; data->linknest = 0;
#ifdef MODE_MINIX3 #ifdef MODE_MINIX3

View file

@ -945,12 +945,18 @@ grub_ntfs_mount (grub_disk_t disk)
if (grub_disk_read (disk, 0, 0, sizeof (bpb), &bpb)) if (grub_disk_read (disk, 0, 0, sizeof (bpb), &bpb))
goto fail; goto fail;
if (grub_memcmp ((char *) &bpb.oem_name, "NTFS", 4)) if (grub_memcmp ((char *) &bpb.oem_name, "NTFS", 4) != 0
|| bpb.sectors_per_cluster == 0
|| (bpb.sectors_per_cluster & (bpb.sectors_per_cluster - 1)) != 0
|| bpb.bytes_per_sector == 0
|| (bpb.bytes_per_sector & (bpb.bytes_per_sector - 1)) != 0)
goto fail; goto fail;
data->spc = (((grub_uint32_t) bpb.sectors_per_cluster data->spc = (((grub_uint32_t) bpb.sectors_per_cluster
* (grub_uint32_t) grub_le_to_cpu16 (bpb.bytes_per_sector)) * (grub_uint32_t) grub_le_to_cpu16 (bpb.bytes_per_sector))
>> GRUB_NTFS_BLK_SHR); >> GRUB_NTFS_BLK_SHR);
if (!data->spc)
goto fail;
if (bpb.clusters_per_mft > 0) if (bpb.clusters_per_mft > 0)
data->mft_size = data->spc * bpb.clusters_per_mft; data->mft_size = data->spc * bpb.clusters_per_mft;

View file

@ -107,10 +107,19 @@ grub_romfs_mount (grub_device_t dev)
grub_error (GRUB_ERR_BAD_FS, "too short filesystem"); grub_error (GRUB_ERR_BAD_FS, "too short filesystem");
return NULL; return NULL;
} }
if (grub_memcmp (sb.sb.magic, GRUB_ROMFS_MAGIC,
sizeof (sb.sb.magic)) != 0)
{
grub_error (GRUB_ERR_BAD_FS, "not romfs");
return NULL;
}
err = do_checksum (&sb, sizeof (sb) < grub_be_to_cpu32 (sb.sb.total_size) ? err = do_checksum (&sb, sizeof (sb) < grub_be_to_cpu32 (sb.sb.total_size) ?
sizeof (sb) : grub_be_to_cpu32 (sb.sb.total_size)); sizeof (sb) : grub_be_to_cpu32 (sb.sb.total_size));
if (err) if (err)
{
grub_error (GRUB_ERR_BAD_FS, "checksum incorrect");
return NULL; return NULL;
}
for (ptr = sb.sb.label; (void *) ptr < (void *) (&sb + 1) for (ptr = sb.sb.label; (void *) ptr < (void *) (&sb + 1)
&& ptr - sb.d < (grub_ssize_t) grub_be_to_cpu32 (sb.sb.total_size); ptr++) && ptr - sb.d < (grub_ssize_t) grub_be_to_cpu32 (sb.sb.total_size); ptr++)
if (!*ptr) if (!*ptr)

View file

@ -663,7 +663,10 @@ grub_xfs_mount (grub_disk_t disk)
sizeof (struct grub_xfs_sblock), &data->sblock)) sizeof (struct grub_xfs_sblock), &data->sblock))
goto fail; goto fail;
if (grub_strncmp ((char *) (data->sblock.magic), "XFSB", 4)) if (grub_strncmp ((char *) (data->sblock.magic), "XFSB", 4)
|| data->sblock.log2_bsize < GRUB_DISK_SECTOR_BITS
|| ((int) data->sblock.log2_bsize
+ (int) data->sblock.log2_dirblk) >= 27)
{ {
grub_error (GRUB_ERR_BAD_FS, "not a XFS filesystem"); grub_error (GRUB_ERR_BAD_FS, "not a XFS filesystem");
goto fail; goto fail;