blob: 3ab89feba8254ed7455eecfae31fee11966bb7bc [file] [log] [blame]
Willy Tarreaubaaee002006-06-26 02:48:02 +02001/*
Willy Tarreaue3ba5f02006-06-29 18:54:54 +02002 include/types/fd.h
Willy Tarreaubaaee002006-06-26 02:48:02 +02003 File descriptors states.
4
Willy Tarreau0c303ee2008-07-07 00:09:58 +02005 Copyright (C) 2000-2008 Willy Tarreau - w@1wt.eu
Willy Tarreaub5654f62008-12-07 16:45:10 +01006
Willy Tarreaubaaee002006-06-26 02:48:02 +02007 This library is free software; you can redistribute it and/or
8 modify it under the terms of the GNU Lesser General Public
9 License as published by the Free Software Foundation, version 2.1
10 exclusively.
11
12 This library is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 Lesser General Public License for more details.
16
17 You should have received a copy of the GNU Lesser General Public
18 License along with this library; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20*/
21
22#ifndef _TYPES_FD_H
23#define _TYPES_FD_H
24
Willy Tarreaue94ebd02007-10-09 17:14:37 +020025#include <sys/socket.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020026#include <sys/time.h>
27#include <sys/types.h>
28#include <unistd.h>
29
Willy Tarreau2dd0d472006-06-29 17:53:05 +020030#include <common/config.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020031#include <types/task.h>
Willy Tarreaudd815982007-10-16 12:25:14 +020032#include <types/protocols.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020033
34/* different possible states for the fd */
35#define FD_STCLOSE 0
36#define FD_STLISTEN 1
37#define FD_STCONN 2
38#define FD_STREADY 3
39#define FD_STERROR 4
40
Willy Tarreau54469402006-07-29 16:59:06 +020041enum {
42 DIR_RD=0,
43 DIR_WR=1,
44 DIR_SIZE
45};
Willy Tarreaubaaee002006-06-26 02:48:02 +020046
Willy Tarreaud6f087e2008-01-18 17:20:13 +010047/*
48 * FD_POLL_IN remains set as long as some data is pending for read.
49 * FD_POLL_OUT remains set as long as the fd accepts to write data.
50 * FD_POLL_ERR and FD_POLL_ERR remain set forever (until processed).
51 */
Willy Tarreau3d32d3a2007-04-15 11:31:05 +020052#define FD_POLL_IN 0x01
53#define FD_POLL_PRI 0x02
54#define FD_POLL_OUT 0x04
55#define FD_POLL_ERR 0x08
56#define FD_POLL_HUP 0x10
Willy Tarreau3d32d3a2007-04-15 11:31:05 +020057
Willy Tarreaud6f087e2008-01-18 17:20:13 +010058#define FD_POLL_DATA (FD_POLL_IN | FD_POLL_OUT)
59#define FD_POLL_STICKY (FD_POLL_ERR | FD_POLL_HUP)
Willy Tarreau3d32d3a2007-04-15 11:31:05 +020060
Willy Tarreaufb14edc2009-06-14 15:24:37 +020061/* bit values for fdtab[fd]->flags. Most of them are used to hold a value
62 * consecutive to a behaviour change.
63 */
64#define FD_FL_TCP 0x0001 /* socket is TCP */
65#define FD_FL_TCP_NODELAY 0x0002
Willy Tarreau6db06d32009-08-19 11:14:11 +020066#define FD_FL_TCP_NOLING 0x0004 /* lingering disabled */
Willy Tarreaufb14edc2009-06-14 15:24:37 +020067
Willy Tarreaubaaee002006-06-26 02:48:02 +020068/* info about one given fd */
69struct fdtab {
Willy Tarreau54469402006-07-29 16:59:06 +020070 struct {
71 int (*f)(int fd); /* read/write function */
72 struct buffer *b; /* read/write buffer */
73 } cb[DIR_SIZE];
Willy Tarreaueabf3132008-08-29 23:36:51 +020074 void *owner; /* the session (or proxy) associated with this fd */
Willy Tarreaufb14edc2009-06-14 15:24:37 +020075 unsigned short flags; /* various flags precising the exact status of this fd */
Willy Tarreau3d32d3a2007-04-15 11:31:05 +020076 unsigned char state; /* the state of this fd */
77 unsigned char ev; /* event seen in return of poll() : FD_POLL_* */
Willy Tarreaue94ebd02007-10-09 17:14:37 +020078 struct sockaddr *peeraddr; /* pointer to peer's network address, or NULL if unset */
79 socklen_t peerlen; /* peer's address length, or 0 if unset */
Willy Tarreauc6f4ce82009-06-10 11:09:37 +020080 int local_port; /* optional local port */
81 struct port_range *port_range; /* optional port range to bind to */
Willy Tarreaubaaee002006-06-26 02:48:02 +020082};
83
Willy Tarreau4f60f162007-04-08 16:39:58 +020084/*
85 * Poller descriptors.
86 * - <name> is initialized by the poller's register() function, and should not
87 * be allocated, just linked to.
88 * - <pref> is initialized by the poller's register() function. It is set to 0
89 * by default, meaning the poller is disabled. init() should set it to 0 in
90 * case of failure. term() must set it to 0. A generic unoptimized select()
91 * poller should set it to 100.
92 * - <private> is initialized by the poller's init() function, and cleaned by
93 * the term() function.
Willy Tarreau97129b52007-04-09 00:54:46 +020094 * - cond_s() checks if fd was not set then sets it and returns 1. Otherwise
95 * it returns 0. It may be the same as set().
96 * - cond_c() checks if fd was set then clears it and returns 1. Otherwise
97 * it returns 0. It may be the same as clr().
Willy Tarreau4f60f162007-04-08 16:39:58 +020098 * - clo() should be used to do indicate the poller that fd will be closed. It
99 * may be the same as rem() on some pollers.
Willy Tarreaud825eef2007-05-12 22:35:00 +0200100 * - poll() calls the poller, expiring at <exp>
Willy Tarreau4f60f162007-04-08 16:39:58 +0200101 */
102struct poller {
103 void *private; /* any private data for the poller */
Willy Tarreau5b702422007-04-16 01:33:26 +0200104 int REGPRM2 (*is_set)(const int fd, int dir); /* check if <fd> is being polled for dir <dir> */
105 int REGPRM2 (*set)(const int fd, int dir); /* set polling on <fd> for <dir> */
106 int REGPRM2 (*clr)(const int fd, int dir); /* clear polling on <fd> for <dir> */
107 int REGPRM2 (*cond_s)(const int fd, int dir); /* set polling on <fd> for <dir> if unset */
108 int REGPRM2 (*cond_c)(const int fd, int dir); /* clear polling on <fd> for <dir> if set */
109 void REGPRM1 (*rem)(const int fd); /* remove any polling on <fd> */
110 void REGPRM1 (*clo)(const int fd); /* mark <fd> as closed */
Willy Tarreau0c303ee2008-07-07 00:09:58 +0200111 void REGPRM2 (*poll)(struct poller *p, int exp); /* the poller itself */
Willy Tarreau5b702422007-04-16 01:33:26 +0200112 int REGPRM1 (*init)(struct poller *p); /* poller initialization */
113 void REGPRM1 (*term)(struct poller *p); /* termination of this poller */
114 int REGPRM1 (*test)(struct poller *p); /* pre-init check of the poller */
115 int REGPRM1 (*fork)(struct poller *p); /* post-fork re-opening */
Willy Tarreau4f60f162007-04-08 16:39:58 +0200116 const char *name; /* poller name */
117 int pref; /* try pollers with higher preference first */
118};
119
120extern struct poller cur_poller; /* the current poller */
121extern int nbpollers;
122#define MAX_POLLERS 10
123extern struct poller pollers[MAX_POLLERS]; /* all registered pollers */
124
Willy Tarreaubaaee002006-06-26 02:48:02 +0200125extern struct fdtab *fdtab; /* array of all the file descriptors */
126extern int maxfd; /* # of the highest fd + 1 */
127extern int totalconn; /* total # of terminated sessions */
128extern int actconn; /* # of active sessions */
129
130#endif /* _TYPES_FD_H */
131
132/*
133 * Local variables:
134 * c-indent-level: 8
135 * c-basic-offset: 8
136 * End:
137 */