]> git.ipfire.org Git - thirdparty/mdadm.git/commitdiff
mdadm/bitmap: locate bitmap calcuate bitmap position wrongly
authorXiao Ni <xni@redhat.com>
Wed, 28 Oct 2020 06:04:24 +0000 (14:04 +0800)
committerJes Sorensen <jsorensen@fb.com>
Wed, 3 Mar 2021 14:29:13 +0000 (09:29 -0500)
Now it only adds bitmap offset based on cluster nodes. It's not right. It needs to
add per node bitmap space to find next node bitmap position.

Signed-off-by: Xiao Ni <xni@redhat.com>
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
super1.c

index 8b0d6ff3d8bc1ea2f97b55b3bae8fe2203d1278b..b5b379b3ae65012e5c30273a0436272ef1cc89d1 100644 (file)
--- a/super1.c
+++ b/super1.c
@@ -2582,8 +2582,9 @@ add_internal_bitmap1(struct supertype *st,
 
 static int locate_bitmap1(struct supertype *st, int fd, int node_num)
 {
-       unsigned long long offset;
+       unsigned long long offset, bm_sectors_per_node;
        struct mdp_superblock_1 *sb;
+       bitmap_super_t *bms;
        int mustfree = 0;
        int ret;
 
@@ -2598,8 +2599,13 @@ static int locate_bitmap1(struct supertype *st, int fd, int node_num)
                ret = 0;
        else
                ret = -1;
-       offset = __le64_to_cpu(sb->super_offset);
-       offset += (int32_t) __le32_to_cpu(sb->bitmap_offset) * (node_num + 1);
+
+       offset = __le64_to_cpu(sb->super_offset) + __le32_to_cpu(sb->bitmap_offset);
+       if (node_num) {
+               bms = (bitmap_super_t*)(((char*)sb)+MAX_SB_SIZE);
+               bm_sectors_per_node = calc_bitmap_size(bms, 4096) >> 9;
+               offset += bm_sectors_per_node * node_num;
+       }
        if (mustfree)
                free(sb);
        lseek64(fd, offset<<9, 0);