clnt.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /*
  2. * linux/include/linux/sunrpc/clnt.h
  3. *
  4. * Declarations for the high-level RPC client interface
  5. *
  6. * Copyright (C) 1995, 1996, Olaf Kirch <okir@monad.swb.de>
  7. */
  8. #ifndef _LINUX_SUNRPC_CLNT_H
  9. #define _LINUX_SUNRPC_CLNT_H
  10. #include <linux/sunrpc/msg_prot.h>
  11. #include <linux/sunrpc/sched.h>
  12. #include <linux/sunrpc/xprt.h>
  13. #include <linux/sunrpc/auth.h>
  14. #include <linux/sunrpc/stats.h>
  15. #include <linux/sunrpc/xdr.h>
  16. #include <linux/sunrpc/timer.h>
  17. #include <asm/signal.h>
  18. /*
  19. * This defines an RPC port mapping
  20. */
  21. struct rpc_portmap {
  22. __u32 pm_prog;
  23. __u32 pm_vers;
  24. __u32 pm_prot;
  25. __u16 pm_port;
  26. unsigned char pm_binding : 1; /* doing a getport() */
  27. struct rpc_wait_queue pm_bindwait; /* waiting on getport() */
  28. };
  29. struct rpc_inode;
  30. /*
  31. * The high-level client handle
  32. */
  33. struct rpc_clnt {
  34. atomic_t cl_count; /* Number of clones */
  35. atomic_t cl_users; /* number of references */
  36. struct rpc_xprt * cl_xprt; /* transport */
  37. struct rpc_procinfo * cl_procinfo; /* procedure info */
  38. u32 cl_maxproc; /* max procedure number */
  39. char * cl_server; /* server machine name */
  40. char * cl_protname; /* protocol name */
  41. struct rpc_auth * cl_auth; /* authenticator */
  42. struct rpc_stat * cl_stats; /* per-program statistics */
  43. struct rpc_iostats * cl_metrics; /* per-client statistics */
  44. unsigned int cl_softrtry : 1,/* soft timeouts */
  45. cl_intr : 1,/* interruptible */
  46. cl_autobind : 1,/* use getport() */
  47. cl_oneshot : 1,/* dispose after use */
  48. cl_dead : 1;/* abandoned */
  49. struct rpc_rtt * cl_rtt; /* RTO estimator data */
  50. struct rpc_portmap * cl_pmap; /* port mapping */
  51. int cl_nodelen; /* nodename length */
  52. char cl_nodename[UNX_MAXNODENAME];
  53. char cl_pathname[30];/* Path in rpc_pipe_fs */
  54. struct vfsmount * cl_vfsmnt;
  55. struct dentry * cl_dentry; /* inode */
  56. struct rpc_clnt * cl_parent; /* Points to parent of clones */
  57. struct rpc_rtt cl_rtt_default;
  58. struct rpc_portmap cl_pmap_default;
  59. char cl_inline_name[32];
  60. };
  61. #define cl_timeout cl_xprt->timeout
  62. #define cl_prog cl_pmap->pm_prog
  63. #define cl_vers cl_pmap->pm_vers
  64. #define cl_port cl_pmap->pm_port
  65. #define cl_prot cl_pmap->pm_prot
  66. /*
  67. * General RPC program info
  68. */
  69. #define RPC_MAXVERSION 4
  70. struct rpc_program {
  71. char * name; /* protocol name */
  72. u32 number; /* program number */
  73. unsigned int nrvers; /* number of versions */
  74. struct rpc_version ** version; /* version array */
  75. struct rpc_stat * stats; /* statistics */
  76. char * pipe_dir_name; /* path to rpc_pipefs dir */
  77. };
  78. struct rpc_version {
  79. u32 number; /* version number */
  80. unsigned int nrprocs; /* number of procs */
  81. struct rpc_procinfo * procs; /* procedure array */
  82. };
  83. /*
  84. * Procedure information
  85. */
  86. struct rpc_procinfo {
  87. u32 p_proc; /* RPC procedure number */
  88. kxdrproc_t p_encode; /* XDR encode function */
  89. kxdrproc_t p_decode; /* XDR decode function */
  90. unsigned int p_bufsiz; /* req. buffer size */
  91. unsigned int p_count; /* call count */
  92. unsigned int p_timer; /* Which RTT timer to use */
  93. u32 p_statidx; /* Which procedure to account */
  94. char * p_name; /* name of procedure */
  95. };
  96. #define RPC_CONGESTED(clnt) (RPCXPRT_CONGESTED((clnt)->cl_xprt))
  97. #define RPC_PEERADDR(clnt) (&(clnt)->cl_xprt->addr)
  98. #ifdef __KERNEL__
  99. struct rpc_clnt *rpc_create_client(struct rpc_xprt *xprt, char *servname,
  100. struct rpc_program *info,
  101. u32 version, rpc_authflavor_t authflavor);
  102. struct rpc_clnt *rpc_new_client(struct rpc_xprt *xprt, char *servname,
  103. struct rpc_program *info,
  104. u32 version, rpc_authflavor_t authflavor);
  105. struct rpc_clnt *rpc_bind_new_program(struct rpc_clnt *,
  106. struct rpc_program *, int);
  107. struct rpc_clnt *rpc_clone_client(struct rpc_clnt *);
  108. int rpc_shutdown_client(struct rpc_clnt *);
  109. int rpc_destroy_client(struct rpc_clnt *);
  110. void rpc_release_client(struct rpc_clnt *);
  111. void rpc_getport(struct rpc_task *, struct rpc_clnt *);
  112. int rpc_register(u32, u32, int, unsigned short, int *);
  113. void rpc_call_setup(struct rpc_task *, struct rpc_message *, int);
  114. int rpc_call_async(struct rpc_clnt *clnt, struct rpc_message *msg,
  115. int flags, const struct rpc_call_ops *tk_ops,
  116. void *calldata);
  117. int rpc_call_sync(struct rpc_clnt *clnt, struct rpc_message *msg,
  118. int flags);
  119. void rpc_restart_call(struct rpc_task *);
  120. void rpc_clnt_sigmask(struct rpc_clnt *clnt, sigset_t *oldset);
  121. void rpc_clnt_sigunmask(struct rpc_clnt *clnt, sigset_t *oldset);
  122. void rpc_setbufsize(struct rpc_clnt *, unsigned int, unsigned int);
  123. size_t rpc_max_payload(struct rpc_clnt *);
  124. void rpc_force_rebind(struct rpc_clnt *);
  125. int rpc_ping(struct rpc_clnt *clnt, int flags);
  126. /*
  127. * Helper function for NFSroot support
  128. */
  129. int rpc_getport_external(struct sockaddr_in *, __u32, __u32, int);
  130. #endif /* __KERNEL__ */
  131. #endif /* _LINUX_SUNRPC_CLNT_H */