export.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  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 (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 vfsmount * ex_mnt;
  75. struct dentry * ex_dentry;
  76. char * ex_path;
  77. uid_t ex_anon_uid;
  78. gid_t ex_anon_gid;
  79. int ex_fsid;
  80. unsigned char * ex_uuid; /* 16 byte fsid */
  81. struct nfsd4_fs_locations ex_fslocs;
  82. int ex_nflavors;
  83. struct exp_flavor_info ex_flavors[MAX_SECINFO_LIST];
  84. };
  85. /* an "export key" (expkey) maps a filehandlefragement to an
  86. * svc_export for a given client. There can be several per export,
  87. * for the different fsid types.
  88. */
  89. struct svc_expkey {
  90. struct cache_head h;
  91. struct auth_domain * ek_client;
  92. int ek_fsidtype;
  93. u32 ek_fsid[6];
  94. struct vfsmount * ek_mnt;
  95. struct dentry * ek_dentry;
  96. };
  97. #define EX_SECURE(exp) (!((exp)->ex_flags & NFSEXP_INSECURE_PORT))
  98. #define EX_ISSYNC(exp) (!((exp)->ex_flags & NFSEXP_ASYNC))
  99. #define EX_NOHIDE(exp) ((exp)->ex_flags & NFSEXP_NOHIDE)
  100. #define EX_WGATHER(exp) ((exp)->ex_flags & NFSEXP_GATHERED_WRITES)
  101. int nfsexp_flags(struct svc_rqst *rqstp, struct svc_export *exp);
  102. __be32 check_nfsd_access(struct svc_export *exp, struct svc_rqst *rqstp);
  103. /*
  104. * Function declarations
  105. */
  106. int nfsd_export_init(void);
  107. void nfsd_export_shutdown(void);
  108. void nfsd_export_flush(void);
  109. void exp_readlock(void);
  110. void exp_readunlock(void);
  111. struct svc_export * rqst_exp_get_by_name(struct svc_rqst *,
  112. struct vfsmount *,
  113. struct dentry *);
  114. struct svc_export * rqst_exp_parent(struct svc_rqst *,
  115. struct vfsmount *mnt,
  116. struct dentry *dentry);
  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. struct svc_export * rqst_exp_find(struct svc_rqst *, int, u32 *);
  131. #endif /* __KERNEL__ */
  132. #endif /* NFSD_EXPORT_H */