aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAkinobu Mita <akinobu.mita@gmail.com>2012-07-30 17:40:57 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2012-07-30 20:25:16 -0400
commit9b58f6d4aaef070bf6e0744713b6d2b6fc1b3578 (patch)
tree67b220d36ae96abb0a4551d0ead65e3c0c599704
parent639b9e34f15e4b2c30068a4e4485586af0cdf709 (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.c24
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
20static 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
37unsigned long qnx4_count_free_blocks(struct super_block *sb) 20unsigned 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