diff options
Diffstat (limited to 'fs/qnx4')
-rw-r--r-- | fs/qnx4/bitmap.c | 24 | ||||
-rw-r--r-- | fs/qnx4/namei.c | 2 | ||||
-rw-r--r-- | fs/qnx4/qnx4.h | 2 |
3 files changed, 7 insertions, 21 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 | ||
diff --git a/fs/qnx4/namei.c b/fs/qnx4/namei.c index a512c0b30e8e..d024505ba007 100644 --- a/fs/qnx4/namei.c +++ b/fs/qnx4/namei.c | |||
@@ -95,7 +95,7 @@ static struct buffer_head *qnx4_find_entry(int len, struct inode *dir, | |||
95 | return NULL; | 95 | return NULL; |
96 | } | 96 | } |
97 | 97 | ||
98 | struct dentry * qnx4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd) | 98 | struct dentry * qnx4_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags) |
99 | { | 99 | { |
100 | int ino; | 100 | int ino; |
101 | struct qnx4_inode_entry *de; | 101 | struct qnx4_inode_entry *de; |
diff --git a/fs/qnx4/qnx4.h b/fs/qnx4/qnx4.h index 244d4620189b..34e2d329c97e 100644 --- a/fs/qnx4/qnx4.h +++ b/fs/qnx4/qnx4.h | |||
@@ -23,7 +23,7 @@ struct qnx4_inode_info { | |||
23 | }; | 23 | }; |
24 | 24 | ||
25 | extern struct inode *qnx4_iget(struct super_block *, unsigned long); | 25 | extern struct inode *qnx4_iget(struct super_block *, unsigned long); |
26 | extern struct dentry *qnx4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd); | 26 | extern struct dentry *qnx4_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags); |
27 | extern unsigned long qnx4_count_free_blocks(struct super_block *sb); | 27 | extern unsigned long qnx4_count_free_blocks(struct super_block *sb); |
28 | extern unsigned long qnx4_block_map(struct inode *inode, long iblock); | 28 | extern unsigned long qnx4_block_map(struct inode *inode, long iblock); |
29 | 29 | ||