2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
* linux/include/linux/sunrpc/svcsock.h
|
|
|
|
*
|
|
|
|
* RPC server socket I/O.
|
|
|
|
*
|
|
|
|
* Copyright (C) 1995, 1996 Olaf Kirch <okir@monad.swb.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SUNRPC_SVCSOCK_H
|
|
|
|
#define SUNRPC_SVCSOCK_H
|
|
|
|
|
|
|
|
#include <linux/sunrpc/svc.h>
|
2007-12-31 11:07:17 +08:00
|
|
|
#include <linux/sunrpc/svc_xprt.h>
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* RPC server socket.
|
|
|
|
*/
|
|
|
|
struct svc_sock {
|
2007-12-31 11:07:17 +08:00
|
|
|
struct svc_xprt sk_xprt;
|
2005-04-17 06:20:36 +08:00
|
|
|
struct list_head sk_ready; /* list of ready sockets */
|
|
|
|
struct list_head sk_list; /* list of all sockets */
|
|
|
|
struct socket * sk_sock; /* berkeley socket layer */
|
|
|
|
struct sock * sk_sk; /* INET layer */
|
|
|
|
|
2006-10-02 17:17:56 +08:00
|
|
|
atomic_t sk_reserved; /* space on outq that is reserved */
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2007-05-09 17:34:48 +08:00
|
|
|
spinlock_t sk_lock; /* protects sk_deferred and
|
|
|
|
* sk_info_authunix */
|
2005-04-17 06:20:36 +08:00
|
|
|
struct list_head sk_deferred; /* deferred requests that need to
|
|
|
|
* be revisted */
|
2006-03-21 14:35:41 +08:00
|
|
|
struct mutex sk_mutex; /* to serialize sending data */
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/* We keep the old state_change and data_ready CB's here */
|
|
|
|
void (*sk_ostate)(struct sock *);
|
|
|
|
void (*sk_odata)(struct sock *, int bytes);
|
|
|
|
void (*sk_owspace)(struct sock *);
|
|
|
|
|
|
|
|
/* private TCP part */
|
|
|
|
int sk_reclen; /* length of record */
|
|
|
|
int sk_tcplen; /* current read length */
|
|
|
|
time_t sk_lastrecv; /* time of last received request */
|
2006-10-04 17:15:50 +08:00
|
|
|
|
|
|
|
/* cache of various info for TCP sockets */
|
|
|
|
void *sk_info_authunix;
|
2007-02-12 16:53:30 +08:00
|
|
|
|
2007-07-10 04:21:39 +08:00
|
|
|
struct sockaddr_storage sk_local; /* local address */
|
2007-02-12 16:53:30 +08:00
|
|
|
struct sockaddr_storage sk_remote; /* remote peer's address */
|
|
|
|
int sk_remotelen; /* length of address */
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Function prototypes.
|
|
|
|
*/
|
2007-03-06 17:42:22 +08:00
|
|
|
void svc_force_close_socket(struct svc_sock *);
|
2006-10-02 17:17:50 +08:00
|
|
|
int svc_recv(struct svc_rqst *, long);
|
2005-04-17 06:20:36 +08:00
|
|
|
int svc_send(struct svc_rqst *);
|
|
|
|
void svc_drop(struct svc_rqst *);
|
|
|
|
void svc_sock_update_bufs(struct svc_serv *serv);
|
2006-10-02 17:17:48 +08:00
|
|
|
int svc_sock_names(char *buf, struct svc_serv *serv, char *toclose);
|
|
|
|
int svc_addsock(struct svc_serv *serv,
|
|
|
|
int fd,
|
|
|
|
char *name_return,
|
|
|
|
int *proto);
|
2007-12-31 11:07:17 +08:00
|
|
|
void svc_init_xprt_sock(void);
|
|
|
|
void svc_cleanup_xprt_sock(void);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2007-02-12 16:53:28 +08:00
|
|
|
/*
|
|
|
|
* svc_makesock socket characteristics
|
|
|
|
*/
|
|
|
|
#define SVC_SOCK_DEFAULTS (0U)
|
|
|
|
#define SVC_SOCK_ANONYMOUS (1U << 0) /* don't register with pmap */
|
|
|
|
#define SVC_SOCK_TEMPORARY (1U << 1) /* flag socket as temporary */
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
#endif /* SUNRPC_SVCSOCK_H */
|