summaryrefslogtreecommitdiffstats
path: root/super1.c
diff options
context:
space:
mode:
authorNeil Brown <neilb@suse.de>2007-05-21 14:25:30 +1000
committerNeil Brown <neilb@suse.de>2007-05-21 14:25:30 +1000
commit68754bd17c81377091e509367e8d0cf9c80369a5 (patch)
treef7eb6e6672f794a636bb1eb6bf8941e33b800bbe /super1.c
parentb80da6616192d1bbfc65cba14c105ee68e71b517 (diff)
downloadmdadm-68754bd17c81377091e509367e8d0cf9c80369a5.tar.gz
mdadm-68754bd17c81377091e509367e8d0cf9c80369a5.tar.xz
mdadm-68754bd17c81377091e509367e8d0cf9c80369a5.zip
Fix handling of negative bitmap offsets on 64bit hosts.
The bitmap offset is a signed 32bit number, so casting to (long) isn't sufficient. We must cast to (int32_t).
Diffstat (limited to 'super1.c')
-rw-r--r--super1.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/super1.c b/super1.c
index efe8a46..5995bb6 100644
--- a/super1.c
+++ b/super1.c
@@ -215,7 +215,7 @@ static void examine_super1(void *sbv, char *homehost)
printf("\n");
if (sb->feature_map & __cpu_to_le32(MD_FEATURE_BITMAP_OFFSET)) {
printf("Internal Bitmap : %ld sectors from superblock\n",
- (long)__le32_to_cpu(sb->bitmap_offset));
+ (long)(int32_t)__le32_to_cpu(sb->bitmap_offset));
}
if (sb->feature_map & __le32_to_cpu(MD_FEATURE_RESHAPE_ACTIVE)) {
printf(" Reshape pos'n : %llu%s\n", (unsigned long long)__le64_to_cpu(sb->reshape_position)/2,
@@ -1276,7 +1276,7 @@ static void locate_bitmap1(struct supertype *st, int fd, void *sbv)
sb = sbv;
offset = __le64_to_cpu(sb->super_offset);
- offset += (long) __le32_to_cpu(sb->bitmap_offset);
+ offset += (int32_t) __le32_to_cpu(sb->bitmap_offset);
if (mustfree)
free(sb);
lseek64(fd, offset<<9, 0);