msg_prot.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * linux/include/net/sunrpc/msg_prot.h
  3. *
  4. * Copyright (C) 1996, Olaf Kirch <okir@monad.swb.de>
  5. */
  6. #ifndef _LINUX_SUNRPC_MSGPROT_H_
  7. #define _LINUX_SUNRPC_MSGPROT_H_
  8. #ifdef __KERNEL__ /* user programs should get these from the rpc header files */
  9. #define RPC_VERSION 2
  10. /* spec defines authentication flavor as an unsigned 32 bit integer */
  11. typedef u32 rpc_authflavor_t;
  12. enum rpc_auth_flavors {
  13. RPC_AUTH_NULL = 0,
  14. RPC_AUTH_UNIX = 1,
  15. RPC_AUTH_SHORT = 2,
  16. RPC_AUTH_DES = 3,
  17. RPC_AUTH_KRB = 4,
  18. RPC_AUTH_GSS = 6,
  19. RPC_AUTH_MAXFLAVOR = 8,
  20. /* pseudoflavors: */
  21. RPC_AUTH_GSS_KRB5 = 390003,
  22. RPC_AUTH_GSS_KRB5I = 390004,
  23. RPC_AUTH_GSS_KRB5P = 390005,
  24. RPC_AUTH_GSS_LKEY = 390006,
  25. RPC_AUTH_GSS_LKEYI = 390007,
  26. RPC_AUTH_GSS_LKEYP = 390008,
  27. RPC_AUTH_GSS_SPKM = 390009,
  28. RPC_AUTH_GSS_SPKMI = 390010,
  29. RPC_AUTH_GSS_SPKMP = 390011,
  30. };
  31. enum rpc_msg_type {
  32. RPC_CALL = 0,
  33. RPC_REPLY = 1
  34. };
  35. enum rpc_reply_stat {
  36. RPC_MSG_ACCEPTED = 0,
  37. RPC_MSG_DENIED = 1
  38. };
  39. enum rpc_accept_stat {
  40. RPC_SUCCESS = 0,
  41. RPC_PROG_UNAVAIL = 1,
  42. RPC_PROG_MISMATCH = 2,
  43. RPC_PROC_UNAVAIL = 3,
  44. RPC_GARBAGE_ARGS = 4,
  45. RPC_SYSTEM_ERR = 5
  46. };
  47. enum rpc_reject_stat {
  48. RPC_MISMATCH = 0,
  49. RPC_AUTH_ERROR = 1
  50. };
  51. enum rpc_auth_stat {
  52. RPC_AUTH_OK = 0,
  53. RPC_AUTH_BADCRED = 1,
  54. RPC_AUTH_REJECTEDCRED = 2,
  55. RPC_AUTH_BADVERF = 3,
  56. RPC_AUTH_REJECTEDVERF = 4,
  57. RPC_AUTH_TOOWEAK = 5,
  58. /* RPCSEC_GSS errors */
  59. RPCSEC_GSS_CREDPROBLEM = 13,
  60. RPCSEC_GSS_CTXPROBLEM = 14
  61. };
  62. #define RPC_PMAP_PROGRAM 100000
  63. #define RPC_PMAP_VERSION 2
  64. #define RPC_PMAP_PORT 111
  65. #define RPC_MAXNETNAMELEN 256
  66. /*
  67. * From RFC 1831:
  68. *
  69. * "A record is composed of one or more record fragments. A record
  70. * fragment is a four-byte header followed by 0 to (2**31) - 1 bytes of
  71. * fragment data. The bytes encode an unsigned binary number; as with
  72. * XDR integers, the byte order is from highest to lowest. The number
  73. * encodes two values -- a boolean which indicates whether the fragment
  74. * is the last fragment of the record (bit value 1 implies the fragment
  75. * is the last fragment) and a 31-bit unsigned binary value which is the
  76. * length in bytes of the fragment's data. The boolean value is the
  77. * highest-order bit of the header; the length is the 31 low-order bits.
  78. * (Note that this record specification is NOT in XDR standard form!)"
  79. *
  80. * The Linux RPC client always sends its requests in a single record
  81. * fragment, limiting the maximum payload size for stream transports to
  82. * 2GB.
  83. */
  84. typedef u32 rpc_fraghdr;
  85. #define RPC_LAST_STREAM_FRAGMENT (1U << 31)
  86. #define RPC_FRAGMENT_SIZE_MASK (~RPC_LAST_STREAM_FRAGMENT)
  87. #define RPC_MAX_FRAGMENT_SIZE ((1U << 31) - 1)
  88. #endif /* __KERNEL__ */
  89. #endif /* _LINUX_SUNRPC_MSGPROT_H_ */