1 // SPDX-License-Identifier: GPL-2.0
2 #include <linux/buffer_head.h>
5 enum {DIRECT
= 7, DEPTH
= 4}; /* Have triple indirect */
7 typedef u32 block_t
; /* 32 bit, host order */
9 static inline unsigned long block_to_cpu(block_t n
)
14 static inline block_t
cpu_to_block(unsigned long n
)
19 static inline block_t
*i_data(struct inode
*inode
)
21 return (block_t
*)minix_i(inode
)->u
.i2_data
;
25 #define INDIRCOUNT(sb) (1 << ((sb)->s_blocksize_bits - 2))
27 static int block_to_path(struct inode
* inode
, long block
, int offsets
[DEPTH
])
30 struct super_block
*sb
= inode
->i_sb
;
33 printk("MINIX-fs: block_to_path: block %ld < 0 on dev %pg\n",
35 } else if ((u64
)block
* (u64
)sb
->s_blocksize
>=
36 minix_sb(sb
)->s_max_size
) {
37 if (printk_ratelimit())
38 printk("MINIX-fs: block_to_path: "
39 "block %ld too big on dev %pg\n",
41 } else if (block
< DIRCOUNT
) {
43 } else if ((block
-= DIRCOUNT
) < INDIRCOUNT(sb
)) {
44 offsets
[n
++] = DIRCOUNT
;
46 } else if ((block
-= INDIRCOUNT(sb
)) < INDIRCOUNT(sb
) * INDIRCOUNT(sb
)) {
47 offsets
[n
++] = DIRCOUNT
+ 1;
48 offsets
[n
++] = block
/ INDIRCOUNT(sb
);
49 offsets
[n
++] = block
% INDIRCOUNT(sb
);
51 block
-= INDIRCOUNT(sb
) * INDIRCOUNT(sb
);
52 offsets
[n
++] = DIRCOUNT
+ 2;
53 offsets
[n
++] = (block
/ INDIRCOUNT(sb
)) / INDIRCOUNT(sb
);
54 offsets
[n
++] = (block
/ INDIRCOUNT(sb
)) % INDIRCOUNT(sb
);
55 offsets
[n
++] = block
% INDIRCOUNT(sb
);
60 #include "itree_common.c"
62 int V2_minix_get_block(struct inode
* inode
, long block
,
63 struct buffer_head
*bh_result
, int create
)
65 return get_block(inode
, block
, bh_result
, create
);
68 void V2_minix_truncate(struct inode
* inode
)
73 unsigned V2_minix_blocks(loff_t size
, struct super_block
*sb
)
75 return nblocks(size
, sb
);