export.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  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 <linux/types.h>
  12. #ifdef __KERNEL__
  13. # include <linux/nfsd/nfsfh.h>
  14. #endif
  15. /*
  16. * Important limits for the exports stuff.
  17. */
  18. #define NFSCLNT_IDMAX 1024
  19. #define NFSCLNT_ADDRMAX 16
  20. #define NFSCLNT_KEYMAX 32
  21. /*
  22. * Export flags.
  23. */
  24. #define NFSEXP_READONLY 0x0001
  25. #define NFSEXP_INSECURE_PORT 0x0002
  26. #define NFSEXP_ROOTSQUASH 0x0004
  27. #define NFSEXP_ALLSQUASH 0x0008
  28. #define NFSEXP_ASYNC 0x0010
  29. #define NFSEXP_GATHERED_WRITES 0x0020
  30. /* 40 80 100 currently unused */
  31. #define NFSEXP_NOHIDE 0x0200
  32. #define NFSEXP_NOSUBTREECHECK 0x0400
  33. #define NFSEXP_NOAUTHNLM 0x0800 /* Don't authenticate NLM requests - just trust */
  34. #define NFSEXP_MSNFS 0x1000 /* do silly things that MS clients expect */
  35. #define NFSEXP_FSID 0x2000
  36. #define NFSEXP_CROSSMOUNT 0x4000
  37. #define NFSEXP_NOACL 0x8000 /* reserved for possible ACL related use */
  38. /* All flags that we claim to support. (Note we don't support NOACL.) */
  39. #define NFSEXP_ALLFLAGS 0x7E3F
  40. /* The flags that may vary depending on security flavor: */
  41. #define NFSEXP_SECINFO_FLAGS (NFSEXP_READONLY | NFSEXP_ROOTSQUASH \
  42. | NFSEXP_ALLSQUASH)
  43. #ifdef __KERNEL__
  44. /*
  45. * FS Locations
  46. */
  47. #define MAX_FS_LOCATIONS 128
  48. struct nfsd4_fs_location {
  49. char *hosts; /* colon separated list of hosts */
  50. char *path; /* slash separated list of path components */
  51. };
  52. struct nfsd4_fs_locations {
  53. uint32_t locations_count;
  54. struct nfsd4_fs_location *locations;
  55. /* If we're not actually serving this data ourselves (only providing a
  56. * list of replicas that do serve it) then we set "migrated": */
  57. int migrated;
  58. };
  59. /*
  60. * We keep an array of pseudoflavors with the export, in order from most
  61. * to least preferred. For the forseeable future, we don't expect more
  62. * than the eight pseudoflavors null, unix, krb5, krb5i, krb5p, skpm3,
  63. * spkm3i, and spkm3p (and using all 8 at once should be rare).
  64. */
  65. #define MAX_SECINFO_LIST 8
  66. struct exp_flavor_info {
  67. u32 pseudoflavor;
  68. u32 flags;
  69. };
  70. struct svc_export {
  71. struct cache_head h;
  72. struct auth_domain * ex_client;
  73. int ex_flags;
  74. struct path ex_path;
  75. char *ex_pathname;
  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 path ek_path;
  94. };
  95. #define EX_SECURE(exp) (!((exp)->ex_flags & NFSEXP_INSECURE_PORT))
  96. #define EX_ISSYNC(exp) (!((exp)->ex_flags & NFSEXP_ASYNC))
  97. #define EX_NOHIDE(exp) ((exp)->ex_flags & NFSEXP_NOHIDE)
  98. #define EX_WGATHER(exp) ((exp)->ex_flags & NFSEXP_GATHERED_WRITES)
  99. int nfsexp_flags(struct svc_rqst *rqstp, struct svc_export *exp);
  100. __be32 check_nfsd_access(struct svc_export *exp, struct svc_rqst *rqstp);
  101. /*
  102. * Function declarations
  103. */
  104. int 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 * rqst_exp_get_by_name(struct svc_rqst *,
  110. struct path *);
  111. struct svc_export * rqst_exp_parent(struct svc_rqst *,
  112. struct path *);
  113. int exp_rootfh(struct auth_domain *,
  114. char *path, struct knfsd_fh *, int maxsize);
  115. __be32 exp_pseudoroot(struct svc_rqst *, struct svc_fh *);
  116. __be32 nfserrno(int errno);
  117. extern struct cache_detail svc_export_cache;
  118. static inline void exp_put(struct svc_export *exp)
  119. {
  120. cache_put(&exp->h, &svc_export_cache);
  121. }
  122. static inline void exp_get(struct svc_export *exp)
  123. {
  124. cache_get(&exp->h);
  125. }
  126. struct svc_export * rqst_exp_find(struct svc_rqst *, int, u32 *);
  127. #endif /* __KERNEL__ */
  128. #endif /* NFSD_EXPORT_H */