inode.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /*
  2. * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved.
  3. * Copyright (C) 2004-2006 Red Hat, Inc. All rights reserved.
  4. *
  5. * This copyrighted material is made available to anyone wishing to use,
  6. * modify, copy, or redistribute it subject to the terms and conditions
  7. * of the GNU General Public License version 2.
  8. */
  9. #ifndef __INODE_DOT_H__
  10. #define __INODE_DOT_H__
  11. #include <linux/fs.h>
  12. #include <linux/buffer_head.h>
  13. #include <linux/mm.h>
  14. #include "util.h"
  15. extern int gfs2_releasepage(struct page *page, gfp_t gfp_mask);
  16. extern int gfs2_internal_read(struct gfs2_inode *ip,
  17. struct file_ra_state *ra_state,
  18. char *buf, loff_t *pos, unsigned size);
  19. extern void gfs2_page_add_databufs(struct gfs2_inode *ip, struct page *page,
  20. unsigned int from, unsigned int to);
  21. extern void gfs2_set_aops(struct inode *inode);
  22. static inline int gfs2_is_stuffed(const struct gfs2_inode *ip)
  23. {
  24. return !ip->i_height;
  25. }
  26. static inline int gfs2_is_jdata(const struct gfs2_inode *ip)
  27. {
  28. return ip->i_diskflags & GFS2_DIF_JDATA;
  29. }
  30. static inline int gfs2_is_writeback(const struct gfs2_inode *ip)
  31. {
  32. const struct gfs2_sbd *sdp = GFS2_SB(&ip->i_inode);
  33. return (sdp->sd_args.ar_data == GFS2_DATA_WRITEBACK) && !gfs2_is_jdata(ip);
  34. }
  35. static inline int gfs2_is_ordered(const struct gfs2_inode *ip)
  36. {
  37. const struct gfs2_sbd *sdp = GFS2_SB(&ip->i_inode);
  38. return (sdp->sd_args.ar_data == GFS2_DATA_ORDERED) && !gfs2_is_jdata(ip);
  39. }
  40. static inline int gfs2_is_dir(const struct gfs2_inode *ip)
  41. {
  42. return S_ISDIR(ip->i_inode.i_mode);
  43. }
  44. static inline void gfs2_set_inode_blocks(struct inode *inode, u64 blocks)
  45. {
  46. inode->i_blocks = blocks <<
  47. (GFS2_SB(inode)->sd_sb.sb_bsize_shift - GFS2_BASIC_BLOCK_SHIFT);
  48. }
  49. static inline u64 gfs2_get_inode_blocks(const struct inode *inode)
  50. {
  51. return inode->i_blocks >>
  52. (GFS2_SB(inode)->sd_sb.sb_bsize_shift - GFS2_BASIC_BLOCK_SHIFT);
  53. }
  54. static inline void gfs2_add_inode_blocks(struct inode *inode, s64 change)
  55. {
  56. gfs2_assert(GFS2_SB(inode), (change >= 0 || inode->i_blocks > -change));
  57. change *= (GFS2_SB(inode)->sd_sb.sb_bsize/GFS2_BASIC_BLOCK);
  58. inode->i_blocks += change;
  59. }
  60. static inline int gfs2_check_inum(const struct gfs2_inode *ip, u64 no_addr,
  61. u64 no_formal_ino)
  62. {
  63. return ip->i_no_addr == no_addr && ip->i_no_formal_ino == no_formal_ino;
  64. }
  65. static inline void gfs2_inum_out(const struct gfs2_inode *ip,
  66. struct gfs2_dirent *dent)
  67. {
  68. dent->de_inum.no_formal_ino = cpu_to_be64(ip->i_no_formal_ino);
  69. dent->de_inum.no_addr = cpu_to_be64(ip->i_no_addr);
  70. }
  71. static inline int gfs2_check_internal_file_size(struct inode *inode,
  72. u64 minsize, u64 maxsize)
  73. {
  74. u64 size = i_size_read(inode);
  75. if (size < minsize || size > maxsize)
  76. goto err;
  77. if (size & ((1 << inode->i_blkbits) - 1))
  78. goto err;
  79. return 0;
  80. err:
  81. gfs2_consist_inode(GFS2_I(inode));
  82. return -EIO;
  83. }
  84. extern struct inode *gfs2_inode_lookup(struct super_block *sb, unsigned type,
  85. u64 no_addr, u64 no_formal_ino,
  86. int non_block);
  87. extern struct inode *gfs2_lookup_by_inum(struct gfs2_sbd *sdp, u64 no_addr,
  88. u64 *no_formal_ino,
  89. unsigned int blktype);
  90. extern struct inode *gfs2_ilookup(struct super_block *sb, u64 no_addr, int nonblock);
  91. extern int gfs2_inode_refresh(struct gfs2_inode *ip);
  92. extern struct inode *gfs2_lookupi(struct inode *dir, const struct qstr *name,
  93. int is_root);
  94. extern int gfs2_permission(struct inode *inode, int mask);
  95. extern int gfs2_setattr_simple(struct inode *inode, struct iattr *attr);
  96. extern struct inode *gfs2_lookup_simple(struct inode *dip, const char *name);
  97. extern void gfs2_dinode_out(const struct gfs2_inode *ip, void *buf);
  98. extern const struct inode_operations gfs2_file_iops;
  99. extern const struct inode_operations gfs2_dir_iops;
  100. extern const struct inode_operations gfs2_symlink_iops;
  101. extern const struct file_operations gfs2_file_fops_nolock;
  102. extern const struct file_operations gfs2_dir_fops_nolock;
  103. extern void gfs2_set_inode_flags(struct inode *inode);
  104. #ifdef CONFIG_GFS2_FS_LOCKING_DLM
  105. extern const struct file_operations gfs2_file_fops;
  106. extern const struct file_operations gfs2_dir_fops;
  107. static inline int gfs2_localflocks(const struct gfs2_sbd *sdp)
  108. {
  109. return sdp->sd_args.ar_localflocks;
  110. }
  111. #else /* Single node only */
  112. #define gfs2_file_fops gfs2_file_fops_nolock
  113. #define gfs2_dir_fops gfs2_dir_fops_nolock
  114. static inline int gfs2_localflocks(const struct gfs2_sbd *sdp)
  115. {
  116. return 1;
  117. }
  118. #endif /* CONFIG_GFS2_FS_LOCKING_DLM */
  119. #endif /* __INODE_DOT_H__ */