| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 |  | 
 | 9 | #ifndef SUNRPC_SVCSOCK_H | 
 | 10 | #define SUNRPC_SVCSOCK_H | 
 | 11 |  | 
 | 12 | #include <linux/sunrpc/svc.h> | 
 | 13 |  | 
 | 14 | /* | 
 | 15 |  * RPC server socket. | 
 | 16 |  */ | 
 | 17 | struct svc_sock { | 
 | 18 | 	struct list_head	sk_ready;	/* list of ready sockets */ | 
 | 19 | 	struct list_head	sk_list;	/* list of all sockets */ | 
 | 20 | 	struct socket *		sk_sock;	/* berkeley socket layer */ | 
 | 21 | 	struct sock *		sk_sk;		/* INET layer */ | 
 | 22 |  | 
| Greg Banks | 3262c81 | 2006-10-02 02:17:58 -0700 | [diff] [blame] | 23 | 	struct svc_pool *	sk_pool;	/* current pool iff queued */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | 	struct svc_serv *	sk_server;	/* service for this socket */ | 
| Greg Banks | c45c357 | 2006-10-02 02:17:54 -0700 | [diff] [blame] | 25 | 	atomic_t		sk_inuse;	/* use count */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | 	unsigned long		sk_flags; | 
 | 27 | #define	SK_BUSY		0			/* enqueued/receiving */ | 
 | 28 | #define	SK_CONN		1			/* conn pending */ | 
 | 29 | #define	SK_CLOSE	2			/* dead or dying */ | 
 | 30 | #define	SK_DATA		3			/* data pending */ | 
 | 31 | #define	SK_TEMP		4			/* temp (TCP) socket */ | 
 | 32 | #define	SK_DEAD		6			/* socket closed */ | 
 | 33 | #define	SK_CHNGBUF	7			/* need to change snd/rcv buffer sizes */ | 
 | 34 | #define	SK_DEFERRED	8			/* request on sk_deferred */ | 
| Greg Banks | 36bdfc8 | 2006-10-02 02:17:54 -0700 | [diff] [blame] | 35 | #define	SK_OLD		9			/* used for temp socket aging mark+sweep */ | 
 | 36 | #define	SK_DETACHED	10			/* detached from tempsocks list */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 37 |  | 
| Greg Banks | 5685f0f | 2006-10-02 02:17:56 -0700 | [diff] [blame] | 38 | 	atomic_t    	    	sk_reserved;	/* space on outq that is reserved */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 39 |  | 
| NeilBrown | 7ac1bea | 2007-05-09 02:34:48 -0700 | [diff] [blame] | 40 | 	spinlock_t		sk_lock;	/* protects sk_deferred and | 
 | 41 | 						 * sk_info_authunix */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 42 | 	struct list_head	sk_deferred;	/* deferred requests that need to | 
 | 43 | 						 * be revisted */ | 
| Ingo Molnar | 57b47a5 | 2006-03-20 22:35:41 -0800 | [diff] [blame] | 44 | 	struct mutex		sk_mutex;	/* to serialize sending data */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 |  | 
 | 46 | 	int			(*sk_recvfrom)(struct svc_rqst *rqstp); | 
 | 47 | 	int			(*sk_sendto)(struct svc_rqst *rqstp); | 
 | 48 |  | 
 | 49 | 	/* We keep the old state_change and data_ready CB's here */ | 
 | 50 | 	void			(*sk_ostate)(struct sock *); | 
 | 51 | 	void			(*sk_odata)(struct sock *, int bytes); | 
 | 52 | 	void			(*sk_owspace)(struct sock *); | 
 | 53 |  | 
 | 54 | 	/* private TCP part */ | 
 | 55 | 	int			sk_reclen;	/* length of record */ | 
 | 56 | 	int			sk_tcplen;	/* current read length */ | 
 | 57 | 	time_t			sk_lastrecv;	/* time of last received request */ | 
| Greg Banks | 7b2b1fe | 2006-10-04 02:15:50 -0700 | [diff] [blame] | 58 |  | 
 | 59 | 	/* cache of various info for TCP sockets */ | 
 | 60 | 	void			*sk_info_authunix; | 
| Chuck Lever | 067d781 | 2007-02-12 00:53:30 -0800 | [diff] [blame] | 61 |  | 
| Frank van Maarseveen | a974769 | 2007-07-09 22:21:39 +0200 | [diff] [blame] | 62 | 	struct sockaddr_storage	sk_local;	/* local address */ | 
| Chuck Lever | 067d781 | 2007-02-12 00:53:30 -0800 | [diff] [blame] | 63 | 	struct sockaddr_storage	sk_remote;	/* remote peer's address */ | 
 | 64 | 	int			sk_remotelen;	/* length of address */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 65 | }; | 
 | 66 |  | 
 | 67 | /* | 
 | 68 |  * Function prototypes. | 
 | 69 |  */ | 
| Chuck Lever | 482fb94 | 2007-02-12 00:53:29 -0800 | [diff] [blame] | 70 | int		svc_makesock(struct svc_serv *, int, unsigned short, int flags); | 
| NeilBrown | cda1fd4 | 2007-03-06 01:42:22 -0800 | [diff] [blame] | 71 | void		svc_force_close_socket(struct svc_sock *); | 
| NeilBrown | 6fb2b47 | 2006-10-02 02:17:50 -0700 | [diff] [blame] | 72 | int		svc_recv(struct svc_rqst *, long); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 73 | int		svc_send(struct svc_rqst *); | 
 | 74 | void		svc_drop(struct svc_rqst *); | 
 | 75 | void		svc_sock_update_bufs(struct svc_serv *serv); | 
| NeilBrown | b41b66d | 2006-10-02 02:17:48 -0700 | [diff] [blame] | 76 | int		svc_sock_names(char *buf, struct svc_serv *serv, char *toclose); | 
 | 77 | int		svc_addsock(struct svc_serv *serv, | 
 | 78 | 			    int fd, | 
 | 79 | 			    char *name_return, | 
 | 80 | 			    int *proto); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 81 |  | 
| Chuck Lever | 6b17433 | 2007-02-12 00:53:28 -0800 | [diff] [blame] | 82 | /* | 
 | 83 |  * svc_makesock socket characteristics | 
 | 84 |  */ | 
 | 85 | #define SVC_SOCK_DEFAULTS	(0U) | 
 | 86 | #define SVC_SOCK_ANONYMOUS	(1U << 0)	/* don't register with pmap */ | 
 | 87 | #define SVC_SOCK_TEMPORARY	(1U << 1)	/* flag socket as temporary */ | 
 | 88 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 89 | #endif /* SUNRPC_SVCSOCK_H */ |