A clone of btpd with my configuration changes.
25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

340 lines
10 KiB

  1. /*
  2. * Copyright (c) 2000-2004 Niels Provos <provos@citi.umich.edu>
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. The name of the author may not be used to endorse or promote products
  14. * derived from this software without specific prior written permission.
  15. *
  16. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  17. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  18. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  19. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  20. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  21. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  22. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  23. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  24. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  25. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  26. */
  27. #ifndef _EVENT_H_
  28. #define _EVENT_H_
  29. #ifdef __cplusplus
  30. extern "C" {
  31. #endif
  32. #include <stdarg.h>
  33. #ifdef WIN32
  34. #define WIN32_LEAN_AND_MEAN
  35. #include <windows.h>
  36. #undef WIN32_LEAN_AND_MEAN
  37. typedef unsigned char u_char;
  38. #endif
  39. #define EVLIST_TIMEOUT 0x01
  40. #define EVLIST_INSERTED 0x02
  41. #define EVLIST_SIGNAL 0x04
  42. #define EVLIST_ACTIVE 0x08
  43. #define EVLIST_INTERNAL 0x10
  44. #define EVLIST_INIT 0x80
  45. /* EVLIST_X_ Private space: 0x1000-0xf000 */
  46. #define EVLIST_ALL (0xf000 | 0x9f)
  47. #define EV_TIMEOUT 0x01
  48. #define EV_READ 0x02
  49. #define EV_WRITE 0x04
  50. #define EV_SIGNAL 0x08
  51. #define EV_PERSIST 0x10 /* Persistant event */
  52. /* Fix so that ppl dont have to run with <sys/queue.h> */
  53. #ifndef TAILQ_ENTRY
  54. #define _EVENT_DEFINED_TQENTRY
  55. #define TAILQ_ENTRY(type) \
  56. struct { \
  57. struct type *tqe_next; /* next element */ \
  58. struct type **tqe_prev; /* address of previous next element */ \
  59. }
  60. #endif /* !TAILQ_ENTRY */
  61. #ifndef RB_ENTRY
  62. #define _EVENT_DEFINED_RBENTRY
  63. #define RB_ENTRY(type) \
  64. struct { \
  65. struct type *rbe_left; /* left element */ \
  66. struct type *rbe_right; /* right element */ \
  67. struct type *rbe_parent; /* parent element */ \
  68. int rbe_color; /* node color */ \
  69. }
  70. #endif /* !RB_ENTRY */
  71. struct event_base;
  72. struct event {
  73. TAILQ_ENTRY (event) ev_next;
  74. TAILQ_ENTRY (event) ev_active_next;
  75. TAILQ_ENTRY (event) ev_signal_next;
  76. RB_ENTRY (event) ev_timeout_node;
  77. struct event_base *ev_base;
  78. int ev_fd;
  79. short ev_events;
  80. short ev_ncalls;
  81. short *ev_pncalls; /* Allows deletes in callback */
  82. struct timeval ev_timeout;
  83. int ev_pri; /* smaller numbers are higher priority */
  84. void (*ev_callback)(int, short, void *arg);
  85. void *ev_arg;
  86. int ev_res; /* result passed to event callback */
  87. int ev_flags;
  88. };
  89. #define EVENT_SIGNAL(ev) (int)(ev)->ev_fd
  90. #define EVENT_FD(ev) (int)(ev)->ev_fd
  91. /*
  92. * Key-Value pairs. Can be used for HTTP headers but also for
  93. * query argument parsing.
  94. */
  95. struct evkeyval {
  96. TAILQ_ENTRY(evkeyval) next;
  97. char *key;
  98. char *value;
  99. };
  100. #ifdef _EVENT_DEFINED_TQENTRY
  101. #undef TAILQ_ENTRY
  102. struct event_list;
  103. struct evkeyvalq;
  104. #undef _EVENT_DEFINED_TQENTRY
  105. #else
  106. TAILQ_HEAD (event_list, event);
  107. TAILQ_HEAD (evkeyvalq, evkeyval);
  108. #endif /* _EVENT_DEFINED_TQENTRY */
  109. #ifdef _EVENT_DEFINED_RBENTRY
  110. #undef RB_ENTRY
  111. #undef _EVENT_DEFINED_RBENTRY
  112. #endif /* _EVENT_DEFINED_RBENTRY */
  113. struct eventop {
  114. char *name;
  115. void *(*init)(void);
  116. int (*add)(void *, struct event *);
  117. int (*del)(void *, struct event *);
  118. int (*recalc)(struct event_base *, void *, int);
  119. int (*dispatch)(struct event_base *, void *, struct timeval *);
  120. void (*dealloc)(void *);
  121. };
  122. #define TIMEOUT_DEFAULT {5, 0}
  123. void *event_init(void);
  124. int event_dispatch(void);
  125. int event_base_dispatch(struct event_base *);
  126. void event_base_free(struct event_base *);
  127. #define _EVENT_LOG_DEBUG 0
  128. #define _EVENT_LOG_MSG 1
  129. #define _EVENT_LOG_WARN 2
  130. #define _EVENT_LOG_ERR 3
  131. typedef void (*event_log_cb)(int severity, const char *msg);
  132. void event_set_log_callback(event_log_cb cb);
  133. /* Associate a different event base with an event */
  134. int event_base_set(struct event_base *, struct event *);
  135. #define EVLOOP_ONCE 0x01
  136. #define EVLOOP_NONBLOCK 0x02
  137. int event_loop(int);
  138. int event_base_loop(struct event_base *, int);
  139. int event_loopexit(struct timeval *); /* Causes the loop to exit */
  140. int event_base_loopexit(struct event_base *, struct timeval *);
  141. #define evtimer_add(ev, tv) event_add(ev, tv)
  142. #define evtimer_set(ev, cb, arg) event_set(ev, -1, 0, cb, arg)
  143. #define evtimer_del(ev) event_del(ev)
  144. #define evtimer_pending(ev, tv) event_pending(ev, EV_TIMEOUT, tv)
  145. #define evtimer_initialized(ev) ((ev)->ev_flags & EVLIST_INIT)
  146. #define timeout_add(ev, tv) event_add(ev, tv)
  147. #define timeout_set(ev, cb, arg) event_set(ev, -1, 0, cb, arg)
  148. #define timeout_del(ev) event_del(ev)
  149. #define timeout_pending(ev, tv) event_pending(ev, EV_TIMEOUT, tv)
  150. #define timeout_initialized(ev) ((ev)->ev_flags & EVLIST_INIT)
  151. #define signal_add(ev, tv) event_add(ev, tv)
  152. #define signal_set(ev, x, cb, arg) \
  153. event_set(ev, x, EV_SIGNAL|EV_PERSIST, cb, arg)
  154. #define signal_del(ev) event_del(ev)
  155. #define signal_pending(ev, tv) event_pending(ev, EV_SIGNAL, tv)
  156. #define signal_initialized(ev) ((ev)->ev_flags & EVLIST_INIT)
  157. void event_set(struct event *, int, short, void (*)(int, short, void *), void *);
  158. int event_once(int, short, void (*)(int, short, void *), void *, struct timeval *);
  159. int event_add(struct event *, struct timeval *);
  160. int event_del(struct event *);
  161. void event_active(struct event *, int, short);
  162. int event_pending(struct event *, short, struct timeval *);
  163. #ifdef WIN32
  164. #define event_initialized(ev) ((ev)->ev_flags & EVLIST_INIT && (ev)->ev_fd != INVALID_HANDLE_VALUE)
  165. #else
  166. #define event_initialized(ev) ((ev)->ev_flags & EVLIST_INIT)
  167. #endif
  168. /* Some simple debugging functions */
  169. const char *event_get_version(void);
  170. const char *event_get_method(void);
  171. /* These functions deal with event priorities */
  172. int event_priority_init(int);
  173. int event_base_priority_init(struct event_base *, int);
  174. int event_priority_set(struct event *, int);
  175. /* These functions deal with buffering input and output */
  176. struct evbuffer {
  177. u_char *buffer;
  178. u_char *orig_buffer;
  179. size_t misalign;
  180. size_t totallen;
  181. size_t off;
  182. void (*cb)(struct evbuffer *, size_t, size_t, void *);
  183. void *cbarg;
  184. };
  185. /* Just for error reporting - use other constants otherwise */
  186. #define EVBUFFER_READ 0x01
  187. #define EVBUFFER_WRITE 0x02
  188. #define EVBUFFER_EOF 0x10
  189. #define EVBUFFER_ERROR 0x20
  190. #define EVBUFFER_TIMEOUT 0x40
  191. struct bufferevent;
  192. typedef void (*evbuffercb)(struct bufferevent *, void *);
  193. typedef void (*everrorcb)(struct bufferevent *, short what, void *);
  194. struct event_watermark {
  195. size_t low;
  196. size_t high;
  197. };
  198. struct bufferevent {
  199. struct event ev_read;
  200. struct event ev_write;
  201. struct evbuffer *input;
  202. struct evbuffer *output;
  203. struct event_watermark wm_read;
  204. struct event_watermark wm_write;
  205. evbuffercb readcb;
  206. evbuffercb writecb;
  207. everrorcb errorcb;
  208. void *cbarg;
  209. int timeout_read; /* in seconds */
  210. int timeout_write; /* in seconds */
  211. short enabled; /* events that are currently enabled */
  212. };
  213. struct bufferevent *bufferevent_new(int fd,
  214. evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg);
  215. int bufferevent_priority_set(struct bufferevent *bufev, int pri);
  216. void bufferevent_free(struct bufferevent *bufev);
  217. int bufferevent_write(struct bufferevent *bufev, void *data, size_t size);
  218. int bufferevent_write_buffer(struct bufferevent *bufev, struct evbuffer *buf);
  219. size_t bufferevent_read(struct bufferevent *bufev, void *data, size_t size);
  220. int bufferevent_enable(struct bufferevent *bufev, short event);
  221. int bufferevent_disable(struct bufferevent *bufev, short event);
  222. void bufferevent_settimeout(struct bufferevent *bufev,
  223. int timeout_read, int timeout_write);
  224. #define EVBUFFER_LENGTH(x) (x)->off
  225. #define EVBUFFER_DATA(x) (x)->buffer
  226. #define EVBUFFER_INPUT(x) (x)->input
  227. #define EVBUFFER_OUTPUT(x) (x)->output
  228. struct evbuffer *evbuffer_new(void);
  229. void evbuffer_free(struct evbuffer *);
  230. int evbuffer_expand(struct evbuffer *, size_t);
  231. int evbuffer_add(struct evbuffer *, void *, size_t);
  232. int evbuffer_remove(struct evbuffer *, void *, size_t);
  233. char *evbuffer_readline(struct evbuffer *);
  234. int evbuffer_add_buffer(struct evbuffer *, struct evbuffer *);
  235. int evbuffer_add_printf(struct evbuffer *, const char *fmt, ...);
  236. int evbuffer_add_vprintf(struct evbuffer *, const char *fmt, va_list ap);
  237. void evbuffer_drain(struct evbuffer *, size_t);
  238. int evbuffer_write(struct evbuffer *, int);
  239. int evbuffer_read(struct evbuffer *, int, int);
  240. u_char *evbuffer_find(struct evbuffer *, const u_char *, size_t);
  241. void evbuffer_setcb(struct evbuffer *, void (*)(struct evbuffer *, size_t, size_t, void *), void *);
  242. /*
  243. * Marshaling tagged data - We assume that all tags are inserted in their
  244. * numeric order - so that unknown tags will always be higher than the
  245. * known ones - and we can just ignore the end of an event buffer.
  246. */
  247. void evtag_init(void);
  248. void evtag_marshal(struct evbuffer *evbuf, u_int8_t tag, const void *data,
  249. u_int16_t len);
  250. void encode_int(struct evbuffer *evbuf, u_int32_t number);
  251. void evtag_marshal_int(struct evbuffer *evbuf, u_int8_t tag,
  252. u_int32_t integer);
  253. void evtag_marshal_string(struct evbuffer *buf, u_int8_t tag,
  254. const char *string);
  255. void evtag_marshal_timeval(struct evbuffer *evbuf, u_int8_t tag,
  256. struct timeval *tv);
  257. void evtag_test(void);
  258. int evtag_unmarshal(struct evbuffer *src, u_int8_t *ptag,
  259. struct evbuffer *dst);
  260. int evtag_peek(struct evbuffer *evbuf, u_int8_t *ptag);
  261. int evtag_peek_length(struct evbuffer *evbuf, u_int32_t *plength);
  262. int evtag_payload_length(struct evbuffer *evbuf, u_int32_t *plength);
  263. int evtag_consume(struct evbuffer *evbuf);
  264. int evtag_unmarshal_int(struct evbuffer *evbuf, u_int8_t need_tag,
  265. u_int32_t *pinteger);
  266. int evtag_unmarshal_fixed(struct evbuffer *src, u_int8_t need_tag, void *data,
  267. size_t len);
  268. int evtag_unmarshal_string(struct evbuffer *evbuf, u_int8_t need_tag,
  269. char **pstring);
  270. int evtag_unmarshal_timeval(struct evbuffer *evbuf, u_int8_t need_tag,
  271. struct timeval *ptv);
  272. #ifdef __cplusplus
  273. }
  274. #endif
  275. #endif /* _EVENT_H_ */