[PATCH] knfsd: use new lock for svc_sock deferred list
[linux-2.6.git] / include / linux / sunrpc / svcsock.h
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
23         struct svc_serv *       sk_server;      /* service for this socket */
24         atomic_t                sk_inuse;       /* use count */
25         unsigned long           sk_flags;
26 #define SK_BUSY         0                       /* enqueued/receiving */
27 #define SK_CONN         1                       /* conn pending */
28 #define SK_CLOSE        2                       /* dead or dying */
29 #define SK_DATA         3                       /* data pending */
30 #define SK_TEMP         4                       /* temp (TCP) socket */
31 #define SK_DEAD         6                       /* socket closed */
32 #define SK_CHNGBUF      7                       /* need to change snd/rcv buffer sizes */
33 #define SK_DEFERRED     8                       /* request on sk_deferred */
34 #define SK_OLD          9                       /* used for temp socket aging mark+sweep */
35 #define SK_DETACHED     10                      /* detached from tempsocks list */
36
37         int                     sk_reserved;    /* space on outq that is reserved */
38
39         spinlock_t              sk_defer_lock;  /* protects sk_deferred */
40         struct list_head        sk_deferred;    /* deferred requests that need to
41                                                  * be revisted */
42         struct mutex            sk_mutex;       /* to serialize sending data */
43
44         int                     (*sk_recvfrom)(struct svc_rqst *rqstp);
45         int                     (*sk_sendto)(struct svc_rqst *rqstp);
46
47         /* We keep the old state_change and data_ready CB's here */
48         void                    (*sk_ostate)(struct sock *);
49         void                    (*sk_odata)(struct sock *, int bytes);
50         void                    (*sk_owspace)(struct sock *);
51
52         /* private TCP part */
53         int                     sk_reclen;      /* length of record */
54         int                     sk_tcplen;      /* current read length */
55         time_t                  sk_lastrecv;    /* time of last received request */
56 };
57
58 /*
59  * Function prototypes.
60  */
61 int             svc_makesock(struct svc_serv *, int, unsigned short);
62 void            svc_delete_socket(struct svc_sock *);
63 int             svc_recv(struct svc_rqst *, long);
64 int             svc_send(struct svc_rqst *);
65 void            svc_drop(struct svc_rqst *);
66 void            svc_sock_update_bufs(struct svc_serv *serv);
67 int             svc_sock_names(char *buf, struct svc_serv *serv, char *toclose);
68 int             svc_addsock(struct svc_serv *serv,
69                             int fd,
70                             char *name_return,
71                             int *proto);
72
73 #endif /* SUNRPC_SVCSOCK_H */