fscache.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. /* NFS filesystem cache interface definitions
  2. *
  3. * Copyright (C) 2008 Red Hat, Inc. All Rights Reserved.
  4. * Written by David Howells (dhowells@redhat.com)
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public Licence
  8. * as published by the Free Software Foundation; either version
  9. * 2 of the Licence, or (at your option) any later version.
  10. */
  11. #ifndef _NFS_FSCACHE_H
  12. #define _NFS_FSCACHE_H
  13. #include <linux/nfs_fs.h>
  14. #include <linux/nfs_mount.h>
  15. #include <linux/nfs4_mount.h>
  16. #include <linux/fscache.h>
  17. #ifdef CONFIG_NFS_FSCACHE
  18. /*
  19. * set of NFS FS-Cache objects that form a superblock key
  20. */
  21. struct nfs_fscache_key {
  22. struct rb_node node;
  23. struct nfs_client *nfs_client; /* the server */
  24. /* the elements of the unique key - as used by nfs_compare_super() and
  25. * nfs_compare_mount_options() to distinguish superblocks */
  26. struct {
  27. struct {
  28. unsigned long s_flags; /* various flags
  29. * (& NFS_MS_MASK) */
  30. } super;
  31. struct {
  32. struct nfs_fsid fsid;
  33. int flags;
  34. unsigned int rsize; /* read size */
  35. unsigned int wsize; /* write size */
  36. unsigned int acregmin; /* attr cache timeouts */
  37. unsigned int acregmax;
  38. unsigned int acdirmin;
  39. unsigned int acdirmax;
  40. } nfs_server;
  41. struct {
  42. rpc_authflavor_t au_flavor;
  43. } rpc_auth;
  44. /* uniquifier - can be used if nfs_server.flags includes
  45. * NFS_MOUNT_UNSHARED */
  46. u8 uniq_len;
  47. char uniquifier[0];
  48. } key;
  49. };
  50. /*
  51. * fscache-index.c
  52. */
  53. extern struct fscache_netfs nfs_fscache_netfs;
  54. extern const struct fscache_cookie_def nfs_fscache_server_index_def;
  55. extern const struct fscache_cookie_def nfs_fscache_super_index_def;
  56. extern const struct fscache_cookie_def nfs_fscache_inode_object_def;
  57. extern int nfs_fscache_register(void);
  58. extern void nfs_fscache_unregister(void);
  59. /*
  60. * fscache.c
  61. */
  62. extern void nfs_fscache_get_client_cookie(struct nfs_client *);
  63. extern void nfs_fscache_release_client_cookie(struct nfs_client *);
  64. extern void nfs_fscache_get_super_cookie(struct super_block *, const char *, int);
  65. extern void nfs_fscache_release_super_cookie(struct super_block *);
  66. extern void nfs_fscache_init_inode(struct inode *);
  67. extern void nfs_fscache_clear_inode(struct inode *);
  68. extern void nfs_fscache_open_file(struct inode *, struct file *);
  69. extern void __nfs_fscache_invalidate_page(struct page *, struct inode *);
  70. extern int nfs_fscache_release_page(struct page *, gfp_t);
  71. extern int __nfs_readpage_from_fscache(struct nfs_open_context *,
  72. struct inode *, struct page *);
  73. extern int __nfs_readpages_from_fscache(struct nfs_open_context *,
  74. struct inode *, struct address_space *,
  75. struct list_head *, unsigned *);
  76. extern void __nfs_readpage_to_fscache(struct inode *, struct page *, int);
  77. /*
  78. * wait for a page to complete writing to the cache
  79. */
  80. static inline void nfs_fscache_wait_on_page_write(struct nfs_inode *nfsi,
  81. struct page *page)
  82. {
  83. if (PageFsCache(page))
  84. fscache_wait_on_page_write(nfsi->fscache, page);
  85. }
  86. /*
  87. * release the caching state associated with a page if undergoing complete page
  88. * invalidation
  89. */
  90. static inline void nfs_fscache_invalidate_page(struct page *page,
  91. struct inode *inode)
  92. {
  93. if (PageFsCache(page))
  94. __nfs_fscache_invalidate_page(page, inode);
  95. }
  96. /*
  97. * Retrieve a page from an inode data storage object.
  98. */
  99. static inline int nfs_readpage_from_fscache(struct nfs_open_context *ctx,
  100. struct inode *inode,
  101. struct page *page)
  102. {
  103. if (NFS_I(inode)->fscache)
  104. return __nfs_readpage_from_fscache(ctx, inode, page);
  105. return -ENOBUFS;
  106. }
  107. /*
  108. * Retrieve a set of pages from an inode data storage object.
  109. */
  110. static inline int nfs_readpages_from_fscache(struct nfs_open_context *ctx,
  111. struct inode *inode,
  112. struct address_space *mapping,
  113. struct list_head *pages,
  114. unsigned *nr_pages)
  115. {
  116. if (NFS_I(inode)->fscache)
  117. return __nfs_readpages_from_fscache(ctx, inode, mapping, pages,
  118. nr_pages);
  119. return -ENOBUFS;
  120. }
  121. /*
  122. * Store a page newly fetched from the server in an inode data storage object
  123. * in the cache.
  124. */
  125. static inline void nfs_readpage_to_fscache(struct inode *inode,
  126. struct page *page,
  127. int sync)
  128. {
  129. if (PageFsCache(page))
  130. __nfs_readpage_to_fscache(inode, page, sync);
  131. }
  132. /*
  133. * Invalidate the contents of fscache for this inode. This will not sleep.
  134. */
  135. static inline void nfs_fscache_invalidate(struct inode *inode)
  136. {
  137. fscache_invalidate(NFS_I(inode)->fscache);
  138. }
  139. /*
  140. * Wait for an object to finish being invalidated.
  141. */
  142. static inline void nfs_fscache_wait_on_invalidate(struct inode *inode)
  143. {
  144. fscache_wait_on_invalidate(NFS_I(inode)->fscache);
  145. }
  146. /*
  147. * indicate the client caching state as readable text
  148. */
  149. static inline const char *nfs_server_fscache_state(struct nfs_server *server)
  150. {
  151. if (server->fscache && (server->options & NFS_OPTION_FSCACHE))
  152. return "yes";
  153. return "no ";
  154. }
  155. #else /* CONFIG_NFS_FSCACHE */
  156. static inline int nfs_fscache_register(void) { return 0; }
  157. static inline void nfs_fscache_unregister(void) {}
  158. static inline void nfs_fscache_get_client_cookie(struct nfs_client *clp) {}
  159. static inline void nfs_fscache_release_client_cookie(struct nfs_client *clp) {}
  160. static inline void nfs_fscache_release_super_cookie(struct super_block *sb) {}
  161. static inline void nfs_fscache_init_inode(struct inode *inode) {}
  162. static inline void nfs_fscache_clear_inode(struct inode *inode) {}
  163. static inline void nfs_fscache_open_file(struct inode *inode,
  164. struct file *filp) {}
  165. static inline int nfs_fscache_release_page(struct page *page, gfp_t gfp)
  166. {
  167. return 1; /* True: may release page */
  168. }
  169. static inline void nfs_fscache_invalidate_page(struct page *page,
  170. struct inode *inode) {}
  171. static inline void nfs_fscache_wait_on_page_write(struct nfs_inode *nfsi,
  172. struct page *page) {}
  173. static inline int nfs_readpage_from_fscache(struct nfs_open_context *ctx,
  174. struct inode *inode,
  175. struct page *page)
  176. {
  177. return -ENOBUFS;
  178. }
  179. static inline int nfs_readpages_from_fscache(struct nfs_open_context *ctx,
  180. struct inode *inode,
  181. struct address_space *mapping,
  182. struct list_head *pages,
  183. unsigned *nr_pages)
  184. {
  185. return -ENOBUFS;
  186. }
  187. static inline void nfs_readpage_to_fscache(struct inode *inode,
  188. struct page *page, int sync) {}
  189. static inline void nfs_fscache_invalidate(struct inode *inode) {}
  190. static inline void nfs_fscache_wait_on_invalidate(struct inode *inode) {}
  191. static inline const char *nfs_server_fscache_state(struct nfs_server *server)
  192. {
  193. return "no ";
  194. }
  195. #endif /* CONFIG_NFS_FSCACHE */
  196. #endif /* _NFS_FSCACHE_H */