mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-10 15:19:51 +00:00
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: Karl Newman <siliconfiend@gmail.com> Tested-by: Karl Newman <siliconfiend@gmail.com> Signed-off-by: NeilBrown <neilb@suse.de>
This commit is contained in:
parent
69964ea4c7
commit
b16b1b6cd0
@ -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;
|
|||||||
|
|
||||||
#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
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user