blob: 7b12e0edd258c998d8cd8842efc4b60fce3feb14 [file] [log] [blame]
Denis Vlasenko844ff092007-01-14 12:34:48 +00001/* vi: set sw=4 ts=4: */
2/*
3 * Generic non-forking server infrastructure.
4 * Intended to make writing telnetd-type servers easier.
5 *
Denis Vlasenkod18f52b2008-03-02 12:53:15 +00006 * Copyright (C) 2007 Denys Vlasenko
Denis Vlasenko844ff092007-01-14 12:34:48 +00007 *
Denys Vlasenko0ef64bd2010-08-16 20:14:46 +02008 * Licensed under GPLv2, see file LICENSE in this source tree.
Denis Vlasenko844ff092007-01-14 12:34:48 +00009 */
10
Denis Vlasenkof81e8db2009-04-09 12:35:13 +000011PUSH_AND_SET_FUNCTION_VISIBILITY_TO_HIDDEN
Denis Vlasenko98636eb2008-05-09 17:59:34 +000012
Denis Vlasenkofdf7aec2007-01-14 12:32:30 +000013/* opaque structure */
14struct isrv_state_t;
15typedef struct isrv_state_t isrv_state_t;
16
17/* callbacks */
18void isrv_want_rd(isrv_state_t *state, int fd);
19void isrv_want_wr(isrv_state_t *state, int fd);
20void isrv_dont_want_rd(isrv_state_t *state, int fd);
21void isrv_dont_want_wr(isrv_state_t *state, int fd);
22int isrv_register_fd(isrv_state_t *state, int peer, int fd);
23void isrv_close_fd(isrv_state_t *state, int fd);
24int isrv_register_peer(isrv_state_t *state, void *param);
25
Denys Vlasenko3ea93e82014-01-09 19:58:19 +010026/* Driver:
27 *
28 * Select on listen_fd for <linger_timeout> (or forever if 0).
29 *
30 * If we time out and we have no peers, exit.
31 * If we have peers, call do_timeout(peer_param),
32 * if it returns !0, peer is removed.
33 *
34 * If listen_fd is active, accept new connection ("peer"),
Denys Vlasenkoabaf9102014-01-09 20:05:47 +010035 * call new_peer() on it, and if it returns 0,
Denys Vlasenko3deabea2014-01-09 20:09:43 +010036 * add it to fds to select on.
Denys Vlasenko3ea93e82014-01-09 19:58:19 +010037 * Now, select will wait for <timeout>, not <linger_timeout>
Denys Vlasenko3deabea2014-01-09 20:09:43 +010038 * (as long as we have more than zero peers).
Denys Vlasenko3ea93e82014-01-09 19:58:19 +010039 *
40 * If a peer's fd is active, we call do_rd() on it if read
Denys Vlasenko3deabea2014-01-09 20:09:43 +010041 * bit was set, and then do_wr() if write bit was also set.
Denys Vlasenko3ea93e82014-01-09 19:58:19 +010042 * If either returns !0, peer is removed.
43 * Reaching this place also resets timeout counter for this peer.
44 *
45 * Note that peer must indicate that he wants to be selected
46 * for read and/or write using isrv_want_rd()/isrv_want_wr()
47 * [can be called in new_peer() or in do_rd()/do_wr()].
48 * If it never wants to be selected for write, do_wr()
49 * will never be called (can be NULL).
50 */
Denis Vlasenkofdf7aec2007-01-14 12:32:30 +000051void isrv_run(
52 int listen_fd,
53 int (*new_peer)(isrv_state_t *state, int fd),
54 int (*do_rd)(int fd, void **),
55 int (*do_wr)(int fd, void **),
56 int (*do_timeout)(void **),
57 int timeout,
58 int linger_timeout
59);
Denis Vlasenko98636eb2008-05-09 17:59:34 +000060
Denis Vlasenkof81e8db2009-04-09 12:35:13 +000061POP_SAVED_FUNCTION_VISIBILITY