diff options
author | Akinobu Mita <akinobu.mita@gmail.com> | 2012-07-30 17:40:57 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-07-30 20:25:16 -0400 |
commit | 9b58f6d4aaef070bf6e0744713b6d2b6fc1b3578 (patch) | |
tree | 67b220d36ae96abb0a4551d0ead65e3c0c599704 | |
parent | 639b9e34f15e4b2c30068a4e4485586af0cdf709 (diff) |
qnx4fs: use memweight()
Use memweight() to count the total number of bits clear in memory area.
Note that this memweight() call can't be replaced with a single
bitmap_weight() call, although the pointer to the memory area is aligned
to long-word boundary. Because the size of the memory area may not be a
multiple of BITS_PER_LONG, then it returns wrong value on big-endian
architecture.
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Acked-by: Anders Larsen <al@alarsen.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | fs/qnx4/bitmap.c | 24 |
1 files changed, 5 insertions, 19 deletions
diff --git a/fs/qnx4/bitmap.c b/fs/qnx4/bitmap.c index 22e0d60e53ef..76a7a697b778 100644 --- a/fs/qnx4/bitmap.c +++ b/fs/qnx4/bitmap.c | |||
@@ -17,23 +17,6 @@ | |||
17 | #include <linux/bitops.h> | 17 | #include <linux/bitops.h> |
18 | #include "qnx4.h" | 18 | #include "qnx4.h" |
19 | 19 | ||
20 | static void count_bits(register const char *bmPart, register int size, | ||
21 | int *const tf) | ||
22 | { | ||
23 | char b; | ||
24 | int tot = *tf; | ||
25 | |||
26 | if (size > QNX4_BLOCK_SIZE) { | ||
27 | size = QNX4_BLOCK_SIZE; | ||
28 | } | ||
29 | do { | ||
30 | b = *bmPart++; | ||
31 | tot += 8 - hweight8(b); | ||
32 | size--; | ||
33 | } while (size != 0); | ||
34 | *tf = tot; | ||
35 | } | ||
36 | |||
37 | unsigned long qnx4_count_free_blocks(struct super_block *sb) | 20 | unsigned long qnx4_count_free_blocks(struct super_block *sb) |
38 | { | 21 | { |
39 | int start = le32_to_cpu(qnx4_sb(sb)->BitMap->di_first_xtnt.xtnt_blk) - 1; | 22 | int start = le32_to_cpu(qnx4_sb(sb)->BitMap->di_first_xtnt.xtnt_blk) - 1; |
@@ -44,13 +27,16 @@ unsigned long qnx4_count_free_blocks(struct super_block *sb) | |||
44 | struct buffer_head *bh; | 27 | struct buffer_head *bh; |
45 | 28 | ||
46 | while (total < size) { | 29 | while (total < size) { |
30 | int bytes = min(size - total, QNX4_BLOCK_SIZE); | ||
31 | |||
47 | if ((bh = sb_bread(sb, start + offset)) == NULL) { | 32 | if ((bh = sb_bread(sb, start + offset)) == NULL) { |
48 | printk(KERN_ERR "qnx4: I/O error in counting free blocks\n"); | 33 | printk(KERN_ERR "qnx4: I/O error in counting free blocks\n"); |
49 | break; | 34 | break; |
50 | } | 35 | } |
51 | count_bits(bh->b_data, size - total, &total_free); | 36 | total_free += bytes * BITS_PER_BYTE - |
37 | memweight(bh->b_data, bytes); | ||
52 | brelse(bh); | 38 | brelse(bh); |
53 | total += QNX4_BLOCK_SIZE; | 39 | total += bytes; |
54 | offset++; | 40 | offset++; |
55 | } | 41 | } |
56 | 42 | ||