diff options
Diffstat (limited to 'fs/hfs/super.c')
| -rw-r--r-- | fs/hfs/super.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/fs/hfs/super.c b/fs/hfs/super.c index f7fcbe49da72..5ed7252b7b23 100644 --- a/fs/hfs/super.c +++ b/fs/hfs/super.c | |||
| @@ -409,8 +409,13 @@ static int hfs_fill_super(struct super_block *sb, void *data, int silent) | |||
| 409 | /* try to get the root inode */ | 409 | /* try to get the root inode */ |
| 410 | hfs_find_init(HFS_SB(sb)->cat_tree, &fd); | 410 | hfs_find_init(HFS_SB(sb)->cat_tree, &fd); |
| 411 | res = hfs_cat_find_brec(sb, HFS_ROOT_CNID, &fd); | 411 | res = hfs_cat_find_brec(sb, HFS_ROOT_CNID, &fd); |
| 412 | if (!res) | 412 | if (!res) { |
| 413 | if (fd.entrylength > sizeof(rec) || fd.entrylength < 0) { | ||
| 414 | res = -EIO; | ||
| 415 | goto bail; | ||
| 416 | } | ||
| 413 | hfs_bnode_read(fd.bnode, &rec, fd.entryoffset, fd.entrylength); | 417 | hfs_bnode_read(fd.bnode, &rec, fd.entryoffset, fd.entrylength); |
| 418 | } | ||
| 414 | if (res) { | 419 | if (res) { |
| 415 | hfs_find_exit(&fd); | 420 | hfs_find_exit(&fd); |
| 416 | goto bail_no_root; | 421 | goto bail_no_root; |
