ufs.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef _UFS_UFS_H
  3. #define _UFS_UFS_H 1
  4. #ifdef pr_fmt
  5. #undef pr_fmt
  6. #endif
  7. #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
  8. #define UFS_MAX_GROUP_LOADED 8
  9. #define UFS_CGNO_EMPTY ((unsigned)-1)
  10. struct ufs_sb_private_info;
  11. struct ufs_cg_private_info;
  12. struct ufs_csum;
  13. struct ufs_sb_info {
  14. struct ufs_sb_private_info * s_uspi;
  15. struct ufs_csum * s_csp;
  16. unsigned s_bytesex;
  17. unsigned s_flags;
  18. struct buffer_head ** s_ucg;
  19. struct ufs_cg_private_info * s_ucpi[UFS_MAX_GROUP_LOADED];
  20. unsigned s_cgno[UFS_MAX_GROUP_LOADED];
  21. unsigned short s_cg_loaded;
  22. unsigned s_flavour;
  23. unsigned s_on_err;
  24. struct super_block *sb;
  25. int work_queued; /* non-zero if the delayed work is queued */
  26. struct delayed_work sync_work; /* FS sync delayed work */
  27. spinlock_t work_lock; /* protects sync_work and work_queued */
  28. struct mutex s_lock;
  29. };
  30. struct ufs_inode_info {
  31. union {
  32. __fs32 i_data[15];
  33. __u8 i_symlink[2 * 4 * 15];
  34. __fs64 u2_i_data[15];
  35. } i_u1;
  36. __u32 i_flags;
  37. __u32 i_shadow;
  38. __u32 i_unused1;
  39. __u32 i_unused2;
  40. __u32 i_oeftflag;
  41. __u16 i_osync;
  42. __u64 i_lastfrag;
  43. seqlock_t meta_lock;
  44. struct mutex truncate_mutex;
  45. __u32 i_dir_start_lookup;
  46. struct inode vfs_inode;
  47. };
  48. /* mount options */
  49. #define UFS_MOUNT_ONERROR_PANIC 0x00000001
  50. #define UFS_MOUNT_ONERROR_LOCK 0x00000002
  51. #define UFS_MOUNT_ONERROR_UMOUNT 0x00000004
  52. #define UFS_MOUNT_ONERROR_REPAIR 0x00000008
  53. #define UFS_MOUNT_UFSTYPE_OLD 0x00000010
  54. #define UFS_MOUNT_UFSTYPE_44BSD 0x00000020
  55. #define UFS_MOUNT_UFSTYPE_SUN 0x00000040
  56. #define UFS_MOUNT_UFSTYPE_NEXTSTEP 0x00000080
  57. #define UFS_MOUNT_UFSTYPE_NEXTSTEP_CD 0x00000100
  58. #define UFS_MOUNT_UFSTYPE_OPENSTEP 0x00000200
  59. #define UFS_MOUNT_UFSTYPE_SUNx86 0x00000400
  60. #define UFS_MOUNT_UFSTYPE_HP 0x00000800
  61. #define UFS_MOUNT_UFSTYPE_UFS2 0x00001000
  62. #define UFS_MOUNT_UFSTYPE_SUNOS 0x00002000
  63. /*
  64. * Debug code
  65. */
  66. #ifdef CONFIG_UFS_DEBUG
  67. # define UFSD(f, a...) { \
  68. pr_debug("UFSD (%s, %d): %s:", \
  69. __FILE__, __LINE__, __func__); \
  70. pr_debug(f, ## a); \
  71. }
  72. #else
  73. # define UFSD(f, a...) /**/
  74. #endif
  75. /* balloc.c */
  76. void ufs_free_fragments (struct inode *, u64 fragment, unsigned count);
  77. void ufs_free_blocks (struct inode *, u64 fragment, unsigned count);
  78. u64 ufs_new_fragments(struct inode *, void *, u64 fragment, u64 goal,
  79. unsigned count, int *err, struct folio *);
  80. /* cylinder.c */
  81. extern struct ufs_cg_private_info * ufs_load_cylinder (struct super_block *, unsigned);
  82. extern void ufs_put_cylinder (struct super_block *, unsigned);
  83. /* dir.c */
  84. extern const struct inode_operations ufs_dir_inode_operations;
  85. int ufs_add_link(struct dentry *, struct inode *);
  86. ino_t ufs_inode_by_name(struct inode *, const struct qstr *);
  87. int ufs_make_empty(struct inode *, struct inode *);
  88. struct ufs_dir_entry *ufs_find_entry(struct inode *, const struct qstr *,
  89. struct folio **);
  90. int ufs_delete_entry(struct inode *, struct ufs_dir_entry *, struct folio *);
  91. int ufs_empty_dir(struct inode *);
  92. struct ufs_dir_entry *ufs_dotdot(struct inode *, struct folio **);
  93. int ufs_set_link(struct inode *dir, struct ufs_dir_entry *de,
  94. struct folio *folio, struct inode *inode, bool update_times);
  95. /* file.c */
  96. extern const struct inode_operations ufs_file_inode_operations;
  97. extern const struct file_operations ufs_file_operations;
  98. extern const struct address_space_operations ufs_aops;
  99. /* ialloc.c */
  100. extern void ufs_free_inode (struct inode *inode);
  101. extern struct inode * ufs_new_inode (struct inode *, umode_t);
  102. /* inode.c */
  103. extern struct inode *ufs_iget(struct super_block *, unsigned long);
  104. extern int ufs_write_inode (struct inode *, struct writeback_control *);
  105. extern int ufs_sync_inode (struct inode *);
  106. extern void ufs_evict_inode (struct inode *);
  107. extern int ufs_setattr(struct mnt_idmap *idmap, struct dentry *dentry,
  108. struct iattr *attr);
  109. /* namei.c */
  110. extern const struct file_operations ufs_dir_operations;
  111. /* super.c */
  112. extern __printf(3, 4)
  113. void ufs_warning(struct super_block *, const char *, const char *, ...);
  114. extern __printf(3, 4)
  115. void ufs_error(struct super_block *, const char *, const char *, ...);
  116. extern __printf(3, 4)
  117. void ufs_panic(struct super_block *, const char *, const char *, ...);
  118. void ufs_mark_sb_dirty(struct super_block *sb);
  119. static inline struct ufs_sb_info *UFS_SB(struct super_block *sb)
  120. {
  121. return sb->s_fs_info;
  122. }
  123. static inline struct ufs_inode_info *UFS_I(struct inode *inode)
  124. {
  125. return container_of(inode, struct ufs_inode_info, vfs_inode);
  126. }
  127. /*
  128. * Give cylinder group number for a file system block.
  129. * Give cylinder group block number for a file system block.
  130. */
  131. /* #define ufs_dtog(d) ((d) / uspi->s_fpg) */
  132. static inline u64 ufs_dtog(struct ufs_sb_private_info * uspi, u64 b)
  133. {
  134. do_div(b, uspi->s_fpg);
  135. return b;
  136. }
  137. /* #define ufs_dtogd(d) ((d) % uspi->s_fpg) */
  138. static inline u32 ufs_dtogd(struct ufs_sb_private_info * uspi, u64 b)
  139. {
  140. return do_div(b, uspi->s_fpg);
  141. }
  142. #endif /* _UFS_UFS_H */