Commit b16b1b6c authored by NeilBrown's avatar NeilBrown

md/bitmap: fix calculation of 'chunks' - missing shift.

commit 61a0d80c "md/bitmap: discard CHUNK_BLOCK_SHIFT macro"
replaced CHUNK_BLOCK_RATIO() by the same text that was
replacing CHUNK_BLOCK_SHIFT() - which is clearly wrong.

The result is that 'chunks' is often too small by 1,
which can sometimes result in a crash (not sure how).

So use the correct replacement, and get rid of CHUNK_BLOCK_RATIO
which is no longe used.
Reported-by: default avatarKarl Newman <siliconfiend@gmail.com>
Tested-by: default avatarKarl Newman <siliconfiend@gmail.com>
Signed-off-by: default avatarNeilBrown <neilb@suse.de>
parent 69964ea4
...@@ -1727,8 +1727,7 @@ int bitmap_create(struct mddev *mddev) ...@@ -1727,8 +1727,7 @@ int bitmap_create(struct mddev *mddev)
bitmap->chunkshift = (ffz(~mddev->bitmap_info.chunksize) bitmap->chunkshift = (ffz(~mddev->bitmap_info.chunksize)
- BITMAP_BLOCK_SHIFT); - BITMAP_BLOCK_SHIFT);
/* now that chunksize and chunkshift are set, we can use these macros */ chunks = (blocks + (1 << bitmap->chunkshift) - 1) >>
chunks = (blocks + bitmap->chunkshift - 1) >>
bitmap->chunkshift; bitmap->chunkshift;
pages = (chunks + PAGE_COUNTER_RATIO - 1) / PAGE_COUNTER_RATIO; pages = (chunks + PAGE_COUNTER_RATIO - 1) / PAGE_COUNTER_RATIO;
......
...@@ -101,9 +101,6 @@ typedef __u16 bitmap_counter_t; ...@@ -101,9 +101,6 @@ typedef __u16 bitmap_counter_t;
#define BITMAP_BLOCK_SHIFT 9 #define BITMAP_BLOCK_SHIFT 9
/* how many blocks per chunk? (this is variable) */
#define CHUNK_BLOCK_RATIO(bitmap) ((bitmap)->mddev->bitmap_info.chunksize >> BITMAP_BLOCK_SHIFT)
#endif #endif
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment