svcsock.h 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * linux/include/linux/sunrpc/svcsock.h
  3. *
  4. * RPC server socket I/O.
  5. *
  6. * Copyright (C) 1995, 1996 Olaf Kirch <okir@monad.swb.de>
  7. */
  8. #ifndef SUNRPC_SVCSOCK_H
  9. #define SUNRPC_SVCSOCK_H
  10. #include <linux/sunrpc/svc.h>
  11. /*
  12. * RPC server socket.
  13. */
  14. struct svc_sock {
  15. struct list_head sk_ready; /* list of ready sockets */
  16. struct list_head sk_list; /* list of all sockets */
  17. struct socket * sk_sock; /* berkeley socket layer */
  18. struct sock * sk_sk; /* INET layer */
  19. struct svc_pool * sk_pool; /* current pool iff queued */
  20. struct svc_serv * sk_server; /* service for this socket */
  21. atomic_t sk_inuse; /* use count */
  22. unsigned long sk_flags;
  23. #define SK_BUSY 0 /* enqueued/receiving */
  24. #define SK_CONN 1 /* conn pending */
  25. #define SK_CLOSE 2 /* dead or dying */
  26. #define SK_DATA 3 /* data pending */
  27. #define SK_TEMP 4 /* temp (TCP) socket */
  28. #define SK_DEAD 6 /* socket closed */
  29. #define SK_CHNGBUF 7 /* need to change snd/rcv buffer sizes */
  30. #define SK_DEFERRED 8 /* request on sk_deferred */
  31. #define SK_OLD 9 /* used for temp socket aging mark+sweep */
  32. #define SK_DETACHED 10 /* detached from tempsocks list */
  33. atomic_t sk_reserved; /* space on outq that is reserved */
  34. spinlock_t sk_lock; /* protects sk_deferred and
  35. * sk_info_authunix */
  36. struct list_head sk_deferred; /* deferred requests that need to
  37. * be revisted */
  38. struct mutex sk_mutex; /* to serialize sending data */
  39. int (*sk_recvfrom)(struct svc_rqst *rqstp);
  40. int (*sk_sendto)(struct svc_rqst *rqstp);
  41. /* We keep the old state_change and data_ready CB's here */
  42. void (*sk_ostate)(struct sock *);
  43. void (*sk_odata)(struct sock *, int bytes);
  44. void (*sk_owspace)(struct sock *);
  45. /* private TCP part */
  46. int sk_reclen; /* length of record */
  47. int sk_tcplen; /* current read length */
  48. time_t sk_lastrecv; /* time of last received request */
  49. /* cache of various info for TCP sockets */
  50. void *sk_info_authunix;
  51. struct sockaddr_storage sk_local; /* local address */
  52. struct sockaddr_storage sk_remote; /* remote peer's address */
  53. int sk_remotelen; /* length of address */
  54. };
  55. /*
  56. * Function prototypes.
  57. */
  58. int svc_makesock(struct svc_serv *, int, unsigned short, int flags);
  59. void svc_force_close_socket(struct svc_sock *);
  60. int svc_recv(struct svc_rqst *, long);
  61. int svc_send(struct svc_rqst *);
  62. void svc_drop(struct svc_rqst *);
  63. void svc_sock_update_bufs(struct svc_serv *serv);
  64. int svc_sock_names(char *buf, struct svc_serv *serv, char *toclose);
  65. int svc_addsock(struct svc_serv *serv,
  66. int fd,
  67. char *name_return,
  68. int *proto);
  69. /*
  70. * svc_makesock socket characteristics
  71. */
  72. #define SVC_SOCK_DEFAULTS (0U)
  73. #define SVC_SOCK_ANONYMOUS (1U << 0) /* don't register with pmap */
  74. #define SVC_SOCK_TEMPORARY (1U << 1) /* flag socket as temporary */
  75. #endif /* SUNRPC_SVCSOCK_H */