fscache.h 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  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_cookie(struct inode *);
  67. extern void nfs_fscache_release_inode_cookie(struct inode *);
  68. extern void nfs_fscache_zap_inode_cookie(struct inode *);
  69. extern void nfs_fscache_set_inode_cookie(struct inode *, struct file *);
  70. extern void nfs_fscache_reset_inode_cookie(struct inode *);
  71. extern void __nfs_fscache_invalidate_page(struct page *, struct inode *);
  72. extern int nfs_fscache_release_page(struct page *, gfp_t);
  73. extern int __nfs_readpage_from_fscache(struct nfs_open_context *,
  74. struct inode *, struct page *);
  75. extern int __nfs_readpages_from_fscache(struct nfs_open_context *,
  76. struct inode *, struct address_space *,
  77. struct list_head *, unsigned *);
  78. extern void __nfs_readpage_to_fscache(struct inode *, struct page *, int);
  79. /*
  80. * wait for a page to complete writing to the cache
  81. */
  82. static inline void nfs_fscache_wait_on_page_write(struct nfs_inode *nfsi,
  83. struct page *page)
  84. {
  85. if (PageFsCache(page))
  86. fscache_wait_on_page_write(nfsi->fscache, page);
  87. }
  88. /*
  89. * release the caching state associated with a page if undergoing complete page
  90. * invalidation
  91. */
  92. static inline void nfs_fscache_invalidate_page(struct page *page,
  93. struct inode *inode)
  94. {
  95. if (PageFsCache(page))
  96. __nfs_fscache_invalidate_page(page, inode);
  97. }
  98. /*
  99. * Retrieve a page from an inode data storage object.
  100. */
  101. static inline int nfs_readpage_from_fscache(struct nfs_open_context *ctx,
  102. struct inode *inode,
  103. struct page *page)
  104. {
  105. if (NFS_I(inode)->fscache)
  106. return __nfs_readpage_from_fscache(ctx, inode, page);
  107. return -ENOBUFS;
  108. }
  109. /*
  110. * Retrieve a set of pages from an inode data storage object.
  111. */
  112. static inline int nfs_readpages_from_fscache(struct nfs_open_context *ctx,
  113. struct inode *inode,
  114. struct address_space *mapping,
  115. struct list_head *pages,
  116. unsigned *nr_pages)
  117. {
  118. if (NFS_I(inode)->fscache)
  119. return __nfs_readpages_from_fscache(ctx, inode, mapping, pages,
  120. nr_pages);
  121. return -ENOBUFS;
  122. }
  123. /*
  124. * Store a page newly fetched from the server in an inode data storage object
  125. * in the cache.
  126. */
  127. static inline void nfs_readpage_to_fscache(struct inode *inode,
  128. struct page *page,
  129. int sync)
  130. {
  131. if (PageFsCache(page))
  132. __nfs_readpage_to_fscache(inode, page, sync);
  133. }
  134. /*
  135. * indicate the client caching state as readable text
  136. */
  137. static inline const char *nfs_server_fscache_state(struct nfs_server *server)
  138. {
  139. if (server->fscache && (server->options & NFS_OPTION_FSCACHE))
  140. return "yes";
  141. return "no ";
  142. }
  143. #else /* CONFIG_NFS_FSCACHE */
  144. static inline int nfs_fscache_register(void) { return 0; }
  145. static inline void nfs_fscache_unregister(void) {}
  146. static inline void nfs_fscache_get_client_cookie(struct nfs_client *clp) {}
  147. static inline void nfs_fscache_release_client_cookie(struct nfs_client *clp) {}
  148. static inline void nfs_fscache_release_super_cookie(struct super_block *sb) {}
  149. static inline void nfs_fscache_init_inode_cookie(struct inode *inode) {}
  150. static inline void nfs_fscache_release_inode_cookie(struct inode *inode) {}
  151. static inline void nfs_fscache_zap_inode_cookie(struct inode *inode) {}
  152. static inline void nfs_fscache_set_inode_cookie(struct inode *inode,
  153. struct file *filp) {}
  154. static inline void nfs_fscache_reset_inode_cookie(struct inode *inode) {}
  155. static inline int nfs_fscache_release_page(struct page *page, gfp_t gfp)
  156. {
  157. return 1; /* True: may release page */
  158. }
  159. static inline void nfs_fscache_invalidate_page(struct page *page,
  160. struct inode *inode) {}
  161. static inline void nfs_fscache_wait_on_page_write(struct nfs_inode *nfsi,
  162. struct page *page) {}
  163. static inline int nfs_readpage_from_fscache(struct nfs_open_context *ctx,
  164. struct inode *inode,
  165. struct page *page)
  166. {
  167. return -ENOBUFS;
  168. }
  169. static inline int nfs_readpages_from_fscache(struct nfs_open_context *ctx,
  170. struct inode *inode,
  171. struct address_space *mapping,
  172. struct list_head *pages,
  173. unsigned *nr_pages)
  174. {
  175. return -ENOBUFS;
  176. }
  177. static inline void nfs_readpage_to_fscache(struct inode *inode,
  178. struct page *page, int sync) {}
  179. static inline const char *nfs_server_fscache_state(struct nfs_server *server)
  180. {
  181. return "no ";
  182. }
  183. #endif /* CONFIG_NFS_FSCACHE */
  184. #endif /* _NFS_FSCACHE_H */