blob: 163afc4ba4b2e2225485b128bb0e3647d4d69e63 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * QNX4 file system, Linux implementation.
4 *
5 * Version : 0.2.1
6 *
7 * Using parts of the xiafs filesystem.
8 *
9 * History :
10 *
11 * 28-05-1998 by Richard Frowijn : first release.
12 * 20-06-1998 by Frank Denis : basic optimisations.
13 * 25-06-1998 by Frank Denis : qnx4_is_free, qnx4_set_bitmap, qnx4_bmap .
14 * 28-06-1998 by Frank Denis : qnx4_free_inode (to be fixed) .
15 */
16
Linus Torvalds1da177e2005-04-16 15:20:36 -070017#include <linux/buffer_head.h>
18#include <linux/bitops.h>
Al Viro964f5362009-06-07 09:47:13 -040019#include "qnx4.h"
Linus Torvalds1da177e2005-04-16 15:20:36 -070020
Linus Torvalds1da177e2005-04-16 15:20:36 -070021unsigned long qnx4_count_free_blocks(struct super_block *sb)
22{
23 int start = le32_to_cpu(qnx4_sb(sb)->BitMap->di_first_xtnt.xtnt_blk) - 1;
24 int total = 0;
25 int total_free = 0;
26 int offset = 0;
27 int size = le32_to_cpu(qnx4_sb(sb)->BitMap->di_size);
28 struct buffer_head *bh;
29
30 while (total < size) {
Akinobu Mita9b58f6d2012-07-30 14:40:57 -070031 int bytes = min(size - total, QNX4_BLOCK_SIZE);
32
Linus Torvalds1da177e2005-04-16 15:20:36 -070033 if ((bh = sb_bread(sb, start + offset)) == NULL) {
Anders Larsen891ddb92009-09-26 20:15:09 +020034 printk(KERN_ERR "qnx4: I/O error in counting free blocks\n");
Linus Torvalds1da177e2005-04-16 15:20:36 -070035 break;
36 }
Akinobu Mita9b58f6d2012-07-30 14:40:57 -070037 total_free += bytes * BITS_PER_BYTE -
38 memweight(bh->b_data, bytes);
Linus Torvalds1da177e2005-04-16 15:20:36 -070039 brelse(bh);
Akinobu Mita9b58f6d2012-07-30 14:40:57 -070040 total += bytes;
Linus Torvalds1da177e2005-04-16 15:20:36 -070041 offset++;
42 }
43
44 return total_free;
45}