diff options
-rw-r--r-- | fs/udf/balloc.c | 4 | ||||
-rw-r--r-- | fs/udf/super.c | 16 | ||||
-rw-r--r-- | fs/udf/udf_sb.h | 2 |
3 files changed, 13 insertions, 9 deletions
diff --git a/fs/udf/balloc.c b/fs/udf/balloc.c index 8c0c27912278..3f67d9dc8631 100644 --- a/fs/udf/balloc.c +++ b/fs/udf/balloc.c | |||
@@ -231,9 +231,7 @@ static int udf_bitmap_prealloc_blocks(struct super_block *sb, | |||
231 | block_count = part_len - first_block; | 231 | block_count = part_len - first_block; |
232 | 232 | ||
233 | repeat: | 233 | repeat: |
234 | nr_groups = (sbi->s_partmaps[partition].s_partition_len + | 234 | nr_groups = udf_compute_nr_groups(sb, partition); |
235 | (sizeof(struct spaceBitmapDesc) << 3) + | ||
236 | (sb->s_blocksize * 8) - 1) / (sb->s_blocksize * 8); | ||
237 | block = first_block + (sizeof(struct spaceBitmapDesc) << 3); | 235 | block = first_block + (sizeof(struct spaceBitmapDesc) << 3); |
238 | block_group = block >> (sb->s_blocksize_bits + 3); | 236 | block_group = block >> (sb->s_blocksize_bits + 3); |
239 | group_start = block_group ? 0 : sizeof(struct spaceBitmapDesc); | 237 | group_start = block_group ? 0 : sizeof(struct spaceBitmapDesc); |
diff --git a/fs/udf/super.c b/fs/udf/super.c index 86aa2238bc7b..c19ee38e85b3 100644 --- a/fs/udf/super.c +++ b/fs/udf/super.c | |||
@@ -937,18 +937,22 @@ static void udf_load_fileset(struct super_block *sb, struct buffer_head *bh, | |||
937 | root->logicalBlockNum, root->partitionReferenceNum); | 937 | root->logicalBlockNum, root->partitionReferenceNum); |
938 | } | 938 | } |
939 | 939 | ||
940 | int udf_compute_nr_groups(struct super_block *sb, u32 partition) | ||
941 | { | ||
942 | struct udf_part_map *map = &UDF_SB(sb)->s_partmaps[partition]; | ||
943 | return (map->s_partition_len + | ||
944 | (sizeof(struct spaceBitmapDesc) << 3) + | ||
945 | (sb->s_blocksize * 8) - 1) / | ||
946 | (sb->s_blocksize * 8); | ||
947 | } | ||
948 | |||
940 | static struct udf_bitmap *udf_sb_alloc_bitmap(struct super_block *sb, u32 index) | 949 | static struct udf_bitmap *udf_sb_alloc_bitmap(struct super_block *sb, u32 index) |
941 | { | 950 | { |
942 | struct udf_part_map *map = &UDF_SB(sb)->s_partmaps[index]; | ||
943 | struct udf_bitmap *bitmap; | 951 | struct udf_bitmap *bitmap; |
944 | int nr_groups; | 952 | int nr_groups; |
945 | int size; | 953 | int size; |
946 | 954 | ||
947 | /* TODO: move calculating of nr_groups into helper function */ | 955 | nr_groups = udf_compute_nr_groups(sb, index); |
948 | nr_groups = (map->s_partition_len + | ||
949 | (sizeof(struct spaceBitmapDesc) << 3) + | ||
950 | (sb->s_blocksize * 8) - 1) / | ||
951 | (sb->s_blocksize * 8); | ||
952 | size = sizeof(struct udf_bitmap) + | 956 | size = sizeof(struct udf_bitmap) + |
953 | (sizeof(struct buffer_head *) * nr_groups); | 957 | (sizeof(struct buffer_head *) * nr_groups); |
954 | 958 | ||
diff --git a/fs/udf/udf_sb.h b/fs/udf/udf_sb.h index 2c05f8277fd8..d9adb0fff84c 100644 --- a/fs/udf/udf_sb.h +++ b/fs/udf/udf_sb.h | |||
@@ -43,6 +43,8 @@ static inline struct udf_sb_info *UDF_SB(struct super_block *sb) | |||
43 | 43 | ||
44 | struct logicalVolIntegrityDescImpUse *udf_sb_lvidiu(struct udf_sb_info *sbi); | 44 | struct logicalVolIntegrityDescImpUse *udf_sb_lvidiu(struct udf_sb_info *sbi); |
45 | 45 | ||
46 | int udf_compute_nr_groups(struct super_block *sb, u32 partition); | ||
47 | |||
46 | #define UDF_QUERY_FLAG(X,Y) ( UDF_SB(X)->s_flags & ( 1 << (Y) ) ) | 48 | #define UDF_QUERY_FLAG(X,Y) ( UDF_SB(X)->s_flags & ( 1 << (Y) ) ) |
47 | #define UDF_SET_FLAG(X,Y) ( UDF_SB(X)->s_flags |= ( 1 << (Y) ) ) | 49 | #define UDF_SET_FLAG(X,Y) ( UDF_SB(X)->s_flags |= ( 1 << (Y) ) ) |
48 | #define UDF_CLEAR_FLAG(X,Y) ( UDF_SB(X)->s_flags &= ~( 1 << (Y) ) ) | 50 | #define UDF_CLEAR_FLAG(X,Y) ( UDF_SB(X)->s_flags &= ~( 1 << (Y) ) ) |