svc: Make deferral processing xprt independent
[deliverable/linux.git] / include / linux / sunrpc / svcsock.h
CommitLineData
1da177e4
LT
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>
360d8738 13#include <linux/sunrpc/svc_xprt.h>
1da177e4
LT
14
15/*
16 * RPC server socket.
17 */
18struct svc_sock {
360d8738 19 struct svc_xprt sk_xprt;
1da177e4
LT
20 struct socket * sk_sock; /* berkeley socket layer */
21 struct sock * sk_sk; /* INET layer */
22
1da177e4
LT
23 /* We keep the old state_change and data_ready CB's here */
24 void (*sk_ostate)(struct sock *);
25 void (*sk_odata)(struct sock *, int bytes);
26 void (*sk_owspace)(struct sock *);
27
28 /* private TCP part */
29 int sk_reclen; /* length of record */
30 int sk_tcplen; /* current read length */
7b2b1fee 31
a9747692 32 struct sockaddr_storage sk_local; /* local address */
067d7817
CL
33 struct sockaddr_storage sk_remote; /* remote peer's address */
34 int sk_remotelen; /* length of address */
1da177e4
LT
35};
36
37/*
38 * Function prototypes.
39 */
7a182083 40void svc_close_all(struct list_head *);
6fb2b47f 41int svc_recv(struct svc_rqst *, long);
1da177e4
LT
42int svc_send(struct svc_rqst *);
43void svc_drop(struct svc_rqst *);
44void svc_sock_update_bufs(struct svc_serv *serv);
b41b66d6
N
45int svc_sock_names(char *buf, struct svc_serv *serv, char *toclose);
46int svc_addsock(struct svc_serv *serv,
47 int fd,
48 char *name_return,
49 int *proto);
360d8738
TT
50void svc_init_xprt_sock(void);
51void svc_cleanup_xprt_sock(void);
1da177e4 52
6b174337
CL
53/*
54 * svc_makesock socket characteristics
55 */
56#define SVC_SOCK_DEFAULTS (0U)
57#define SVC_SOCK_ANONYMOUS (1U << 0) /* don't register with pmap */
58#define SVC_SOCK_TEMPORARY (1U << 1) /* flag socket as temporary */
59
1da177e4 60#endif /* SUNRPC_SVCSOCK_H */
This page took 0.454191 seconds and 5 git commands to generate.