export.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  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/in.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. #define NFSEXP_ALLFLAGS 0xFE3F
  39. /* The flags that may vary depending on security flavor: */
  40. #define NFSEXP_SECINFO_FLAGS (NFSEXP_READONLY | NFSEXP_ROOTSQUASH \
  41. | NFSEXP_ALLSQUASH)
  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 path ex_path;
  74. char *ex_pathname;
  75. uid_t ex_anon_uid;
  76. gid_t ex_anon_gid;
  77. int ex_fsid;
  78. unsigned char * ex_uuid; /* 16 byte fsid */
  79. struct nfsd4_fs_locations ex_fslocs;
  80. int ex_nflavors;
  81. struct exp_flavor_info ex_flavors[MAX_SECINFO_LIST];
  82. };
  83. /* an "export key" (expkey) maps a filehandlefragement to an
  84. * svc_export for a given client. There can be several per export,
  85. * for the different fsid types.
  86. */
  87. struct svc_expkey {
  88. struct cache_head h;
  89. struct auth_domain * ek_client;
  90. int ek_fsidtype;
  91. u32 ek_fsid[6];
  92. struct path ek_path;
  93. };
  94. #define EX_SECURE(exp) (!((exp)->ex_flags & NFSEXP_INSECURE_PORT))
  95. #define EX_ISSYNC(exp) (!((exp)->ex_flags & NFSEXP_ASYNC))
  96. #define EX_NOHIDE(exp) ((exp)->ex_flags & NFSEXP_NOHIDE)
  97. #define EX_WGATHER(exp) ((exp)->ex_flags & NFSEXP_GATHERED_WRITES)
  98. int nfsexp_flags(struct svc_rqst *rqstp, struct svc_export *exp);
  99. __be32 check_nfsd_access(struct svc_export *exp, struct svc_rqst *rqstp);
  100. /*
  101. * Function declarations
  102. */
  103. int nfsd_export_init(void);
  104. void nfsd_export_shutdown(void);
  105. void nfsd_export_flush(void);
  106. void exp_readlock(void);
  107. void exp_readunlock(void);
  108. struct svc_export * rqst_exp_get_by_name(struct svc_rqst *,
  109. struct vfsmount *,
  110. struct dentry *);
  111. struct svc_export * rqst_exp_parent(struct svc_rqst *,
  112. struct vfsmount *mnt,
  113. struct dentry *dentry);
  114. int exp_rootfh(struct auth_domain *,
  115. char *path, struct knfsd_fh *, int maxsize);
  116. __be32 exp_pseudoroot(struct svc_rqst *, struct svc_fh *);
  117. __be32 nfserrno(int errno);
  118. extern struct cache_detail svc_export_cache;
  119. static inline void exp_put(struct svc_export *exp)
  120. {
  121. cache_put(&exp->h, &svc_export_cache);
  122. }
  123. static inline void exp_get(struct svc_export *exp)
  124. {
  125. cache_get(&exp->h);
  126. }
  127. struct svc_export * rqst_exp_find(struct svc_rqst *, int, u32 *);
  128. #endif /* __KERNEL__ */
  129. #endif /* NFSD_EXPORT_H */