|
@@ -71,6 +71,11 @@ struct hfs_btree *hfs_btree_open(struct super_block *sb, u32 id)
|
|
tree->max_key_len);
|
|
tree->max_key_len);
|
|
goto fail_page;
|
|
goto fail_page;
|
|
}
|
|
}
|
|
|
|
+ if (tree->attributes & HFS_TREE_VARIDXKEYS) {
|
|
|
|
+ printk(KERN_ERR "hfs: invalid extent btree flag\n");
|
|
|
|
+ goto fail_page;
|
|
|
|
+ }
|
|
|
|
+
|
|
tree->keycmp = hfsplus_ext_cmp_key;
|
|
tree->keycmp = hfsplus_ext_cmp_key;
|
|
break;
|
|
break;
|
|
case HFSPLUS_CAT_CNID:
|
|
case HFSPLUS_CAT_CNID:
|
|
@@ -79,6 +84,10 @@ struct hfs_btree *hfs_btree_open(struct super_block *sb, u32 id)
|
|
tree->max_key_len);
|
|
tree->max_key_len);
|
|
goto fail_page;
|
|
goto fail_page;
|
|
}
|
|
}
|
|
|
|
+ if (!(tree->attributes & HFS_TREE_VARIDXKEYS)) {
|
|
|
|
+ printk(KERN_ERR "hfs: invalid catalog btree flag\n");
|
|
|
|
+ goto fail_page;
|
|
|
|
+ }
|
|
|
|
|
|
if (test_bit(HFSPLUS_SB_HFSX, &HFSPLUS_SB(sb)->flags) &&
|
|
if (test_bit(HFSPLUS_SB_HFSX, &HFSPLUS_SB(sb)->flags) &&
|
|
(head->key_type == HFSPLUS_KEY_BINARY))
|
|
(head->key_type == HFSPLUS_KEY_BINARY))
|
|
@@ -93,6 +102,11 @@ struct hfs_btree *hfs_btree_open(struct super_block *sb, u32 id)
|
|
goto fail_page;
|
|
goto fail_page;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ if (!(tree->attributes & HFS_TREE_BIGKEYS)) {
|
|
|
|
+ printk(KERN_ERR "hfs: invalid btree flag\n");
|
|
|
|
+ goto fail_page;
|
|
|
|
+ }
|
|
|
|
+
|
|
size = tree->node_size;
|
|
size = tree->node_size;
|
|
if (!is_power_of_2(size))
|
|
if (!is_power_of_2(size))
|
|
goto fail_page;
|
|
goto fail_page;
|