fscache.h 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  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. * Definition of the auxiliary data attached to NFS inode storage objects
  52. * within the cache.
  53. *
  54. * The contents of this struct are recorded in the on-disk local cache in the
  55. * auxiliary data attached to the data storage object backing an inode. This
  56. * permits coherency to be managed when a new inode binds to an already extant
  57. * cache object.
  58. */
  59. struct nfs_fscache_inode_auxdata {
  60. struct timespec mtime;
  61. struct timespec ctime;
  62. u64 change_attr;
  63. };
  64. /*
  65. * fscache-index.c
  66. */
  67. extern struct fscache_netfs nfs_fscache_netfs;
  68. extern const struct fscache_cookie_def nfs_fscache_server_index_def;
  69. extern const struct fscache_cookie_def nfs_fscache_super_index_def;
  70. extern const struct fscache_cookie_def nfs_fscache_inode_object_def;
  71. extern int nfs_fscache_register(void);
  72. extern void nfs_fscache_unregister(void);
  73. /*
  74. * fscache.c
  75. */
  76. extern void nfs_fscache_get_client_cookie(struct nfs_client *);
  77. extern void nfs_fscache_release_client_cookie(struct nfs_client *);
  78. extern void nfs_fscache_get_super_cookie(struct super_block *, const char *, int);
  79. extern void nfs_fscache_release_super_cookie(struct super_block *);
  80. extern void nfs_fscache_init_inode(struct inode *);
  81. extern void nfs_fscache_clear_inode(struct inode *);
  82. extern void nfs_fscache_open_file(struct inode *, struct file *);
  83. extern void __nfs_fscache_invalidate_page(struct page *, struct inode *);
  84. extern int nfs_fscache_release_page(struct page *, gfp_t);
  85. extern int __nfs_readpage_from_fscache(struct nfs_open_context *,
  86. struct inode *, struct page *);
  87. extern int __nfs_readpages_from_fscache(struct nfs_open_context *,
  88. struct inode *, struct address_space *,
  89. struct list_head *, unsigned *);
  90. extern void __nfs_readpage_to_fscache(struct inode *, struct page *, int);
  91. /*
  92. * wait for a page to complete writing to the cache
  93. */
  94. static inline void nfs_fscache_wait_on_page_write(struct nfs_inode *nfsi,
  95. struct page *page)
  96. {
  97. if (PageFsCache(page))
  98. fscache_wait_on_page_write(nfsi->fscache, page);
  99. }
  100. /*
  101. * release the caching state associated with a page if undergoing complete page
  102. * invalidation
  103. */
  104. static inline void nfs_fscache_invalidate_page(struct page *page,
  105. struct inode *inode)
  106. {
  107. if (PageFsCache(page))
  108. __nfs_fscache_invalidate_page(page, inode);
  109. }
  110. /*
  111. * Retrieve a page from an inode data storage object.
  112. */
  113. static inline int nfs_readpage_from_fscache(struct nfs_open_context *ctx,
  114. struct inode *inode,
  115. struct page *page)
  116. {
  117. if (NFS_I(inode)->fscache)
  118. return __nfs_readpage_from_fscache(ctx, inode, page);
  119. return -ENOBUFS;
  120. }
  121. /*
  122. * Retrieve a set of pages from an inode data storage object.
  123. */
  124. static inline int nfs_readpages_from_fscache(struct nfs_open_context *ctx,
  125. struct inode *inode,
  126. struct address_space *mapping,
  127. struct list_head *pages,
  128. unsigned *nr_pages)
  129. {
  130. if (NFS_I(inode)->fscache)
  131. return __nfs_readpages_from_fscache(ctx, inode, mapping, pages,
  132. nr_pages);
  133. return -ENOBUFS;
  134. }
  135. /*
  136. * Store a page newly fetched from the server in an inode data storage object
  137. * in the cache.
  138. */
  139. static inline void nfs_readpage_to_fscache(struct inode *inode,
  140. struct page *page,
  141. int sync)
  142. {
  143. if (PageFsCache(page))
  144. __nfs_readpage_to_fscache(inode, page, sync);
  145. }
  146. /*
  147. * Invalidate the contents of fscache for this inode. This will not sleep.
  148. */
  149. static inline void nfs_fscache_invalidate(struct inode *inode)
  150. {
  151. fscache_invalidate(NFS_I(inode)->fscache);
  152. }
  153. /*
  154. * Wait for an object to finish being invalidated.
  155. */
  156. static inline void nfs_fscache_wait_on_invalidate(struct inode *inode)
  157. {
  158. fscache_wait_on_invalidate(NFS_I(inode)->fscache);
  159. }
  160. /*
  161. * indicate the client caching state as readable text
  162. */
  163. static inline const char *nfs_server_fscache_state(struct nfs_server *server)
  164. {
  165. if (server->fscache)
  166. return "yes";
  167. return "no ";
  168. }
  169. #else /* CONFIG_NFS_FSCACHE */
  170. static inline int nfs_fscache_register(void) { return 0; }
  171. static inline void nfs_fscache_unregister(void) {}
  172. static inline void nfs_fscache_get_client_cookie(struct nfs_client *clp) {}
  173. static inline void nfs_fscache_release_client_cookie(struct nfs_client *clp) {}
  174. static inline void nfs_fscache_release_super_cookie(struct super_block *sb) {}
  175. static inline void nfs_fscache_init_inode(struct inode *inode) {}
  176. static inline void nfs_fscache_clear_inode(struct inode *inode) {}
  177. static inline void nfs_fscache_open_file(struct inode *inode,
  178. struct file *filp) {}
  179. static inline int nfs_fscache_release_page(struct page *page, gfp_t gfp)
  180. {
  181. return 1; /* True: may release page */
  182. }
  183. static inline void nfs_fscache_invalidate_page(struct page *page,
  184. struct inode *inode) {}
  185. static inline void nfs_fscache_wait_on_page_write(struct nfs_inode *nfsi,
  186. struct page *page) {}
  187. static inline int nfs_readpage_from_fscache(struct nfs_open_context *ctx,
  188. struct inode *inode,
  189. struct page *page)
  190. {
  191. return -ENOBUFS;
  192. }
  193. static inline int nfs_readpages_from_fscache(struct nfs_open_context *ctx,
  194. struct inode *inode,
  195. struct address_space *mapping,
  196. struct list_head *pages,
  197. unsigned *nr_pages)
  198. {
  199. return -ENOBUFS;
  200. }
  201. static inline void nfs_readpage_to_fscache(struct inode *inode,
  202. struct page *page, int sync) {}
  203. static inline void nfs_fscache_invalidate(struct inode *inode) {}
  204. static inline void nfs_fscache_wait_on_invalidate(struct inode *inode) {}
  205. static inline const char *nfs_server_fscache_state(struct nfs_server *server)
  206. {
  207. return "no ";
  208. }
  209. #endif /* CONFIG_NFS_FSCACHE */
  210. #endif /* _NFS_FSCACHE_H */