export.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /*
  2. * include/linux/nfsd/export.h
  3. *
  4. * Public declarations for NFS exports. The definitions for the
  5. * syscall interface are in nfsctl.h
  6. *
  7. * Copyright (C) 1995-1997 Olaf Kirch <okir@monad.swb.de>
  8. */
  9. #ifndef NFSD_EXPORT_H
  10. #define NFSD_EXPORT_H
  11. #include <asm/types.h>
  12. #ifdef __KERNEL__
  13. # include <linux/types.h>
  14. # include <linux/in.h>
  15. #endif
  16. /*
  17. * Important limits for the exports stuff.
  18. */
  19. #define NFSCLNT_IDMAX 1024
  20. #define NFSCLNT_ADDRMAX 16
  21. #define NFSCLNT_KEYMAX 32
  22. /*
  23. * Export flags.
  24. */
  25. #define NFSEXP_READONLY 0x0001
  26. #define NFSEXP_INSECURE_PORT 0x0002
  27. #define NFSEXP_ROOTSQUASH 0x0004
  28. #define NFSEXP_ALLSQUASH 0x0008
  29. #define NFSEXP_ASYNC 0x0010
  30. #define NFSEXP_GATHERED_WRITES 0x0020
  31. /* 40 80 100 currently unused */
  32. #define NFSEXP_NOHIDE 0x0200
  33. #define NFSEXP_NOSUBTREECHECK 0x0400
  34. #define NFSEXP_NOAUTHNLM 0x0800 /* Don't authenticate NLM requests - just trust */
  35. #define NFSEXP_MSNFS 0x1000 /* do silly things that MS clients expect */
  36. #define NFSEXP_FSID 0x2000
  37. #define NFSEXP_CROSSMOUNT 0x4000
  38. #define NFSEXP_NOACL 0x8000 /* reserved for possible ACL related use */
  39. #define NFSEXP_ALLFLAGS 0xFE3F
  40. /* The flags that may vary depending on security flavor: */
  41. #define NFSEXP_SECINFO_FLAGS 0
  42. #ifdef __KERNEL__
  43. /*
  44. * FS Locations
  45. */
  46. #define MAX_FS_LOCATIONS 128
  47. struct nfsd4_fs_location {
  48. char *hosts; /* colon separated list of hosts */
  49. char *path; /* slash separated list of path components */
  50. };
  51. struct nfsd4_fs_locations {
  52. uint32_t locations_count;
  53. struct nfsd4_fs_location *locations;
  54. /* If we're not actually serving this data ourselves (only providing a
  55. * list of replicas that do serve it) then we set "migrated": */
  56. int migrated;
  57. };
  58. /*
  59. * We keep an array of pseudoflavors with the export, in order from most
  60. * to least preferred. For the forseeable future, we don't expect more
  61. * than the eight pseudoflavors null, unix, krb5, krb5i, krb5p, skpm3,
  62. * spkm3i, and spkm3p (and using all 8 at once should be rare).
  63. */
  64. #define MAX_SECINFO_LIST 8
  65. struct exp_flavor_info {
  66. u32 pseudoflavor;
  67. u32 flags;
  68. };
  69. struct svc_export {
  70. struct cache_head h;
  71. struct auth_domain * ex_client;
  72. int ex_flags;
  73. struct vfsmount * ex_mnt;
  74. struct dentry * ex_dentry;
  75. char * ex_path;
  76. uid_t ex_anon_uid;
  77. gid_t ex_anon_gid;
  78. int ex_fsid;
  79. unsigned char * ex_uuid; /* 16 byte fsid */
  80. struct nfsd4_fs_locations ex_fslocs;
  81. int ex_nflavors;
  82. struct exp_flavor_info ex_flavors[MAX_SECINFO_LIST];
  83. };
  84. /* an "export key" (expkey) maps a filehandlefragement to an
  85. * svc_export for a given client. There can be several per export,
  86. * for the different fsid types.
  87. */
  88. struct svc_expkey {
  89. struct cache_head h;
  90. struct auth_domain * ek_client;
  91. int ek_fsidtype;
  92. u32 ek_fsid[6];
  93. struct vfsmount * ek_mnt;
  94. struct dentry * ek_dentry;
  95. };
  96. #define EX_SECURE(exp) (!((exp)->ex_flags & NFSEXP_INSECURE_PORT))
  97. #define EX_ISSYNC(exp) (!((exp)->ex_flags & NFSEXP_ASYNC))
  98. #define EX_RDONLY(exp) ((exp)->ex_flags & NFSEXP_READONLY)
  99. #define EX_NOHIDE(exp) ((exp)->ex_flags & NFSEXP_NOHIDE)
  100. #define EX_WGATHER(exp) ((exp)->ex_flags & NFSEXP_GATHERED_WRITES)
  101. /*
  102. * Function declarations
  103. */
  104. void nfsd_export_init(void);
  105. void nfsd_export_shutdown(void);
  106. void nfsd_export_flush(void);
  107. void exp_readlock(void);
  108. void exp_readunlock(void);
  109. struct svc_export * exp_get_by_name(struct auth_domain *clp,
  110. struct vfsmount *mnt,
  111. struct dentry *dentry,
  112. struct cache_req *reqp);
  113. struct svc_export * exp_parent(struct auth_domain *clp,
  114. struct vfsmount *mnt,
  115. struct dentry *dentry,
  116. struct cache_req *reqp);
  117. int exp_rootfh(struct auth_domain *,
  118. char *path, struct knfsd_fh *, int maxsize);
  119. __be32 exp_pseudoroot(struct svc_rqst *, struct svc_fh *);
  120. __be32 nfserrno(int errno);
  121. extern struct cache_detail svc_export_cache;
  122. static inline void exp_put(struct svc_export *exp)
  123. {
  124. cache_put(&exp->h, &svc_export_cache);
  125. }
  126. static inline void exp_get(struct svc_export *exp)
  127. {
  128. cache_get(&exp->h);
  129. }
  130. extern struct svc_export *
  131. exp_find(struct auth_domain *clp, int fsid_type, u32 *fsidv,
  132. struct cache_req *reqp);
  133. #endif /* __KERNEL__ */
  134. #endif /* NFSD_EXPORT_H */