inode.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * fs/bfs/inode.c
  4. * BFS superblock and inode operations.
  5. * Copyright (C) 1999-2018 Tigran Aivazian <aivazian.tigran@gmail.com>
  6. * From fs/minix, Copyright (C) 1991, 1992 Linus Torvalds.
  7. * Made endianness-clean by Andrew Stribblehill <ads@wompom.org>, 2005.
  8. */
  9. #include <linux/module.h>
  10. #include <linux/mm.h>
  11. #include <linux/slab.h>
  12. #include <linux/init.h>
  13. #include <linux/fs.h>
  14. #include <linux/buffer_head.h>
  15. #include <linux/vfs.h>
  16. #include <linux/writeback.h>
  17. #include <linux/uio.h>
  18. #include <linux/uaccess.h>
  19. #include <linux/fs_context.h>
  20. #include "bfs.h"
  21. MODULE_AUTHOR("Tigran Aivazian <aivazian.tigran@gmail.com>");
  22. MODULE_DESCRIPTION("SCO UnixWare BFS filesystem for Linux");
  23. MODULE_LICENSE("GPL");
  24. #undef DEBUG
  25. #ifdef DEBUG
  26. #define dprintf(x...) printf(x)
  27. #else
  28. #define dprintf(x...)
  29. #endif
  30. struct inode *bfs_iget(struct super_block *sb, unsigned long ino)
  31. {
  32. struct bfs_inode *di;
  33. struct inode *inode;
  34. struct buffer_head *bh;
  35. int block, off;
  36. inode = iget_locked(sb, ino);
  37. if (!inode)
  38. return ERR_PTR(-ENOMEM);
  39. if (!(inode_state_read_once(inode) & I_NEW))
  40. return inode;
  41. if ((ino < BFS_ROOT_INO) || (ino > BFS_SB(inode->i_sb)->si_lasti)) {
  42. printf("Bad inode number %s:%08lx\n", inode->i_sb->s_id, ino);
  43. goto error;
  44. }
  45. block = (ino - BFS_ROOT_INO) / BFS_INODES_PER_BLOCK + 1;
  46. bh = sb_bread(inode->i_sb, block);
  47. if (!bh) {
  48. printf("Unable to read inode %s:%08lx\n", inode->i_sb->s_id,
  49. ino);
  50. goto error;
  51. }
  52. off = (ino - BFS_ROOT_INO) % BFS_INODES_PER_BLOCK;
  53. di = (struct bfs_inode *)bh->b_data + off;
  54. /*
  55. * https://martin.hinner.info/fs/bfs/bfs-structure.html explains that
  56. * BFS in SCO UnixWare environment used only lower 9 bits of di->i_mode
  57. * value. This means that, although bfs_write_inode() saves whole
  58. * inode->i_mode bits (which include S_IFMT bits and S_IS{UID,GID,VTX}
  59. * bits), middle 7 bits of di->i_mode value can be garbage when these
  60. * bits were not saved by bfs_write_inode().
  61. * Since we can't tell whether middle 7 bits are garbage, use only
  62. * lower 12 bits (i.e. tolerate S_IS{UID,GID,VTX} bits possibly being
  63. * garbage) and reconstruct S_IFMT bits for Linux environment from
  64. * di->i_vtype value.
  65. */
  66. inode->i_mode = 0x00000FFF & le32_to_cpu(di->i_mode);
  67. if (le32_to_cpu(di->i_vtype) == BFS_VDIR) {
  68. inode->i_mode |= S_IFDIR;
  69. inode->i_op = &bfs_dir_inops;
  70. inode->i_fop = &bfs_dir_operations;
  71. } else if (le32_to_cpu(di->i_vtype) == BFS_VREG) {
  72. inode->i_mode |= S_IFREG;
  73. inode->i_op = &bfs_file_inops;
  74. inode->i_fop = &bfs_file_operations;
  75. inode->i_mapping->a_ops = &bfs_aops;
  76. } else {
  77. brelse(bh);
  78. printf("Unknown vtype=%u %s:%08lx\n",
  79. le32_to_cpu(di->i_vtype), inode->i_sb->s_id, ino);
  80. goto error;
  81. }
  82. BFS_I(inode)->i_sblock = le32_to_cpu(di->i_sblock);
  83. BFS_I(inode)->i_eblock = le32_to_cpu(di->i_eblock);
  84. BFS_I(inode)->i_dsk_ino = le16_to_cpu(di->i_ino);
  85. i_uid_write(inode, le32_to_cpu(di->i_uid));
  86. i_gid_write(inode, le32_to_cpu(di->i_gid));
  87. set_nlink(inode, le32_to_cpu(di->i_nlink));
  88. inode->i_size = BFS_FILESIZE(di);
  89. inode->i_blocks = BFS_FILEBLOCKS(di);
  90. inode_set_atime(inode, le32_to_cpu(di->i_atime), 0);
  91. inode_set_mtime(inode, le32_to_cpu(di->i_mtime), 0);
  92. inode_set_ctime(inode, le32_to_cpu(di->i_ctime), 0);
  93. brelse(bh);
  94. unlock_new_inode(inode);
  95. return inode;
  96. error:
  97. iget_failed(inode);
  98. return ERR_PTR(-EIO);
  99. }
  100. static struct bfs_inode *find_inode(struct super_block *sb, u16 ino, struct buffer_head **p)
  101. {
  102. if ((ino < BFS_ROOT_INO) || (ino > BFS_SB(sb)->si_lasti)) {
  103. printf("Bad inode number %s:%08x\n", sb->s_id, ino);
  104. return ERR_PTR(-EIO);
  105. }
  106. ino -= BFS_ROOT_INO;
  107. *p = sb_bread(sb, 1 + ino / BFS_INODES_PER_BLOCK);
  108. if (!*p) {
  109. printf("Unable to read inode %s:%08x\n", sb->s_id, ino);
  110. return ERR_PTR(-EIO);
  111. }
  112. return (struct bfs_inode *)(*p)->b_data + ino % BFS_INODES_PER_BLOCK;
  113. }
  114. static int bfs_write_inode(struct inode *inode, struct writeback_control *wbc)
  115. {
  116. struct bfs_sb_info *info = BFS_SB(inode->i_sb);
  117. unsigned int ino = (u16)inode->i_ino;
  118. unsigned long i_sblock;
  119. struct bfs_inode *di;
  120. struct buffer_head *bh;
  121. int err = 0;
  122. dprintf("ino=%08x\n", ino);
  123. di = find_inode(inode->i_sb, ino, &bh);
  124. if (IS_ERR(di))
  125. return PTR_ERR(di);
  126. mutex_lock(&info->bfs_lock);
  127. if (ino == BFS_ROOT_INO)
  128. di->i_vtype = cpu_to_le32(BFS_VDIR);
  129. else
  130. di->i_vtype = cpu_to_le32(BFS_VREG);
  131. di->i_ino = cpu_to_le16(ino);
  132. di->i_mode = cpu_to_le32(inode->i_mode);
  133. di->i_uid = cpu_to_le32(i_uid_read(inode));
  134. di->i_gid = cpu_to_le32(i_gid_read(inode));
  135. di->i_nlink = cpu_to_le32(inode->i_nlink);
  136. di->i_atime = cpu_to_le32(inode_get_atime_sec(inode));
  137. di->i_mtime = cpu_to_le32(inode_get_mtime_sec(inode));
  138. di->i_ctime = cpu_to_le32(inode_get_ctime_sec(inode));
  139. i_sblock = BFS_I(inode)->i_sblock;
  140. di->i_sblock = cpu_to_le32(i_sblock);
  141. di->i_eblock = cpu_to_le32(BFS_I(inode)->i_eblock);
  142. di->i_eoffset = cpu_to_le32(i_sblock * BFS_BSIZE + inode->i_size - 1);
  143. mark_buffer_dirty(bh);
  144. if (wbc->sync_mode == WB_SYNC_ALL) {
  145. sync_dirty_buffer(bh);
  146. if (buffer_req(bh) && !buffer_uptodate(bh))
  147. err = -EIO;
  148. }
  149. brelse(bh);
  150. mutex_unlock(&info->bfs_lock);
  151. return err;
  152. }
  153. static void bfs_evict_inode(struct inode *inode)
  154. {
  155. unsigned long ino = inode->i_ino;
  156. struct bfs_inode *di;
  157. struct buffer_head *bh;
  158. struct super_block *s = inode->i_sb;
  159. struct bfs_sb_info *info = BFS_SB(s);
  160. struct bfs_inode_info *bi = BFS_I(inode);
  161. dprintf("ino=%08lx\n", ino);
  162. truncate_inode_pages_final(&inode->i_data);
  163. invalidate_inode_buffers(inode);
  164. clear_inode(inode);
  165. if (inode->i_nlink)
  166. return;
  167. di = find_inode(s, inode->i_ino, &bh);
  168. if (IS_ERR(di))
  169. return;
  170. mutex_lock(&info->bfs_lock);
  171. /* clear on-disk inode */
  172. memset(di, 0, sizeof(struct bfs_inode));
  173. mark_buffer_dirty(bh);
  174. brelse(bh);
  175. if (bi->i_dsk_ino) {
  176. if (bi->i_sblock)
  177. info->si_freeb += bi->i_eblock + 1 - bi->i_sblock;
  178. info->si_freei++;
  179. clear_bit(ino, info->si_imap);
  180. bfs_dump_imap("evict_inode", s);
  181. }
  182. /*
  183. * If this was the last file, make the previous block
  184. * "last block of the last file" even if there is no
  185. * real file there, saves us 1 gap.
  186. */
  187. if (info->si_lf_eblk == bi->i_eblock)
  188. info->si_lf_eblk = bi->i_sblock - 1;
  189. mutex_unlock(&info->bfs_lock);
  190. }
  191. static void bfs_put_super(struct super_block *s)
  192. {
  193. struct bfs_sb_info *info = BFS_SB(s);
  194. if (!info)
  195. return;
  196. mutex_destroy(&info->bfs_lock);
  197. kfree(info);
  198. s->s_fs_info = NULL;
  199. }
  200. static int bfs_statfs(struct dentry *dentry, struct kstatfs *buf)
  201. {
  202. struct super_block *s = dentry->d_sb;
  203. struct bfs_sb_info *info = BFS_SB(s);
  204. u64 id = huge_encode_dev(s->s_bdev->bd_dev);
  205. buf->f_type = BFS_MAGIC;
  206. buf->f_bsize = s->s_blocksize;
  207. buf->f_blocks = info->si_blocks;
  208. buf->f_bfree = buf->f_bavail = info->si_freeb;
  209. buf->f_files = info->si_lasti + 1 - BFS_ROOT_INO;
  210. buf->f_ffree = info->si_freei;
  211. buf->f_fsid = u64_to_fsid(id);
  212. buf->f_namelen = BFS_NAMELEN;
  213. return 0;
  214. }
  215. static struct kmem_cache *bfs_inode_cachep;
  216. static struct inode *bfs_alloc_inode(struct super_block *sb)
  217. {
  218. struct bfs_inode_info *bi;
  219. bi = alloc_inode_sb(sb, bfs_inode_cachep, GFP_KERNEL);
  220. if (!bi)
  221. return NULL;
  222. return &bi->vfs_inode;
  223. }
  224. static void bfs_free_inode(struct inode *inode)
  225. {
  226. kmem_cache_free(bfs_inode_cachep, BFS_I(inode));
  227. }
  228. static void init_once(void *foo)
  229. {
  230. struct bfs_inode_info *bi = foo;
  231. inode_init_once(&bi->vfs_inode);
  232. }
  233. static int __init init_inodecache(void)
  234. {
  235. bfs_inode_cachep = kmem_cache_create("bfs_inode_cache",
  236. sizeof(struct bfs_inode_info),
  237. 0, (SLAB_RECLAIM_ACCOUNT|
  238. SLAB_ACCOUNT),
  239. init_once);
  240. if (bfs_inode_cachep == NULL)
  241. return -ENOMEM;
  242. return 0;
  243. }
  244. static void destroy_inodecache(void)
  245. {
  246. /*
  247. * Make sure all delayed rcu free inodes are flushed before we
  248. * destroy cache.
  249. */
  250. rcu_barrier();
  251. kmem_cache_destroy(bfs_inode_cachep);
  252. }
  253. static const struct super_operations bfs_sops = {
  254. .alloc_inode = bfs_alloc_inode,
  255. .free_inode = bfs_free_inode,
  256. .write_inode = bfs_write_inode,
  257. .evict_inode = bfs_evict_inode,
  258. .put_super = bfs_put_super,
  259. .statfs = bfs_statfs,
  260. };
  261. void bfs_dump_imap(const char *prefix, struct super_block *s)
  262. {
  263. #ifdef DEBUG
  264. int i;
  265. char *tmpbuf = (char *)get_zeroed_page(GFP_KERNEL);
  266. if (!tmpbuf)
  267. return;
  268. for (i = BFS_SB(s)->si_lasti; i >= 0; i--) {
  269. if (i > PAGE_SIZE - 100) break;
  270. if (test_bit(i, BFS_SB(s)->si_imap))
  271. strcat(tmpbuf, "1");
  272. else
  273. strcat(tmpbuf, "0");
  274. }
  275. printf("%s: lasti=%08lx <%s>\n", prefix, BFS_SB(s)->si_lasti, tmpbuf);
  276. free_page((unsigned long)tmpbuf);
  277. #endif
  278. }
  279. static int bfs_fill_super(struct super_block *s, struct fs_context *fc)
  280. {
  281. struct buffer_head *bh, *sbh;
  282. struct bfs_super_block *bfs_sb;
  283. struct inode *inode;
  284. unsigned i;
  285. struct bfs_sb_info *info;
  286. int ret = -EINVAL;
  287. unsigned long i_sblock, i_eblock, i_eoff, s_size;
  288. int silent = fc->sb_flags & SB_SILENT;
  289. info = kzalloc_obj(*info);
  290. if (!info)
  291. return -ENOMEM;
  292. mutex_init(&info->bfs_lock);
  293. s->s_fs_info = info;
  294. s->s_time_min = 0;
  295. s->s_time_max = U32_MAX;
  296. sb_set_blocksize(s, BFS_BSIZE);
  297. sbh = sb_bread(s, 0);
  298. if (!sbh)
  299. goto out;
  300. bfs_sb = (struct bfs_super_block *)sbh->b_data;
  301. if (le32_to_cpu(bfs_sb->s_magic) != BFS_MAGIC) {
  302. if (!silent)
  303. printf("No BFS filesystem on %s (magic=%08x)\n", s->s_id, le32_to_cpu(bfs_sb->s_magic));
  304. goto out1;
  305. }
  306. if (BFS_UNCLEAN(bfs_sb, s) && !silent)
  307. printf("%s is unclean, continuing\n", s->s_id);
  308. s->s_magic = BFS_MAGIC;
  309. if (le32_to_cpu(bfs_sb->s_start) > le32_to_cpu(bfs_sb->s_end) ||
  310. le32_to_cpu(bfs_sb->s_start) < sizeof(struct bfs_super_block) + sizeof(struct bfs_dirent)) {
  311. printf("Superblock is corrupted on %s\n", s->s_id);
  312. goto out1;
  313. }
  314. info->si_lasti = (le32_to_cpu(bfs_sb->s_start) - BFS_BSIZE) / sizeof(struct bfs_inode) + BFS_ROOT_INO - 1;
  315. if (info->si_lasti == BFS_MAX_LASTI)
  316. printf("NOTE: filesystem %s was created with 512 inodes, the real maximum is 511, mounting anyway\n", s->s_id);
  317. else if (info->si_lasti > BFS_MAX_LASTI) {
  318. printf("Impossible last inode number %lu > %d on %s\n", info->si_lasti, BFS_MAX_LASTI, s->s_id);
  319. goto out1;
  320. }
  321. for (i = 0; i < BFS_ROOT_INO; i++)
  322. set_bit(i, info->si_imap);
  323. s->s_op = &bfs_sops;
  324. inode = bfs_iget(s, BFS_ROOT_INO);
  325. if (IS_ERR(inode)) {
  326. ret = PTR_ERR(inode);
  327. goto out1;
  328. }
  329. s->s_root = d_make_root(inode);
  330. if (!s->s_root) {
  331. ret = -ENOMEM;
  332. goto out1;
  333. }
  334. info->si_blocks = (le32_to_cpu(bfs_sb->s_end) + 1) >> BFS_BSIZE_BITS;
  335. info->si_freeb = (le32_to_cpu(bfs_sb->s_end) + 1 - le32_to_cpu(bfs_sb->s_start)) >> BFS_BSIZE_BITS;
  336. info->si_freei = 0;
  337. info->si_lf_eblk = 0;
  338. /* can we read the last block? */
  339. bh = sb_bread(s, info->si_blocks - 1);
  340. if (!bh) {
  341. printf("Last block not available on %s: %lu\n", s->s_id, info->si_blocks - 1);
  342. ret = -EIO;
  343. goto out2;
  344. }
  345. brelse(bh);
  346. bh = NULL;
  347. for (i = BFS_ROOT_INO; i <= info->si_lasti; i++) {
  348. struct bfs_inode *di;
  349. int block = (i - BFS_ROOT_INO) / BFS_INODES_PER_BLOCK + 1;
  350. int off = (i - BFS_ROOT_INO) % BFS_INODES_PER_BLOCK;
  351. unsigned long eblock;
  352. if (!off) {
  353. brelse(bh);
  354. bh = sb_bread(s, block);
  355. }
  356. if (!bh)
  357. continue;
  358. di = (struct bfs_inode *)bh->b_data + off;
  359. /* test if filesystem is not corrupted */
  360. i_eoff = le32_to_cpu(di->i_eoffset);
  361. i_sblock = le32_to_cpu(di->i_sblock);
  362. i_eblock = le32_to_cpu(di->i_eblock);
  363. s_size = le32_to_cpu(bfs_sb->s_end);
  364. if (i_sblock > info->si_blocks ||
  365. i_eblock > info->si_blocks ||
  366. i_sblock > i_eblock ||
  367. (i_eoff != le32_to_cpu(-1) && i_eoff > s_size) ||
  368. i_sblock * BFS_BSIZE > i_eoff) {
  369. printf("Inode 0x%08x corrupted on %s\n", i, s->s_id);
  370. brelse(bh);
  371. ret = -EIO;
  372. goto out2;
  373. }
  374. if (!di->i_ino) {
  375. info->si_freei++;
  376. continue;
  377. }
  378. set_bit(i, info->si_imap);
  379. info->si_freeb -= BFS_FILEBLOCKS(di);
  380. eblock = le32_to_cpu(di->i_eblock);
  381. if (eblock > info->si_lf_eblk)
  382. info->si_lf_eblk = eblock;
  383. }
  384. brelse(bh);
  385. brelse(sbh);
  386. bfs_dump_imap("fill_super", s);
  387. return 0;
  388. out2:
  389. dput(s->s_root);
  390. s->s_root = NULL;
  391. out1:
  392. brelse(sbh);
  393. out:
  394. mutex_destroy(&info->bfs_lock);
  395. kfree(info);
  396. s->s_fs_info = NULL;
  397. return ret;
  398. }
  399. static int bfs_get_tree(struct fs_context *fc)
  400. {
  401. return get_tree_bdev(fc, bfs_fill_super);
  402. }
  403. static const struct fs_context_operations bfs_context_ops = {
  404. .get_tree = bfs_get_tree,
  405. };
  406. static int bfs_init_fs_context(struct fs_context *fc)
  407. {
  408. fc->ops = &bfs_context_ops;
  409. return 0;
  410. }
  411. static struct file_system_type bfs_fs_type = {
  412. .owner = THIS_MODULE,
  413. .name = "bfs",
  414. .init_fs_context = bfs_init_fs_context,
  415. .kill_sb = kill_block_super,
  416. .fs_flags = FS_REQUIRES_DEV,
  417. };
  418. MODULE_ALIAS_FS("bfs");
  419. static int __init init_bfs_fs(void)
  420. {
  421. int err = init_inodecache();
  422. if (err)
  423. goto out1;
  424. err = register_filesystem(&bfs_fs_type);
  425. if (err)
  426. goto out;
  427. return 0;
  428. out:
  429. destroy_inodecache();
  430. out1:
  431. return err;
  432. }
  433. static void __exit exit_bfs_fs(void)
  434. {
  435. unregister_filesystem(&bfs_fs_type);
  436. destroy_inodecache();
  437. }
  438. module_init(init_bfs_fs)
  439. module_exit(exit_bfs_fs)