compat_libevent.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735
  1. /* Copyright (c) 2009-2013, The Tor Project, Inc. */
  2. /* See LICENSE for licensing information */
  3. /**
  4. * \file compat_libevent.c
  5. * \brief Wrappers to handle porting between different versions of libevent.
  6. *
  7. * In an ideal world, we'd just use Libevent 2.0 from now on. But as of June
  8. * 2012, Libevent 1.4 is still all over, and some poor souls are stuck on
  9. * Libevent 1.3e. */
  10. #include "orconfig.h"
  11. #include "compat.h"
  12. #include "compat_libevent.h"
  13. #include "crypto.h"
  14. #include "util.h"
  15. #include "torlog.h"
  16. #ifdef HAVE_EVENT2_EVENT_H
  17. #include <event2/event.h>
  18. #include <event2/thread.h>
  19. #ifdef USE_BUFFEREVENTS
  20. #include <event2/bufferevent.h>
  21. #endif
  22. #else
  23. #include <event.h>
  24. #endif
  25. /** A number representing a version of Libevent.
  26. This is a 4-byte number, with the first three bytes representing the
  27. major, minor, and patchlevel respectively of the library. The fourth
  28. byte is unused.
  29. This is equivalent to the format of LIBEVENT_VERSION_NUMBER on Libevent
  30. 2.0.1 or later. For versions of Libevent before 1.4.0, which followed the
  31. format of "1.0, 1.0a, 1.0b", we define 1.0 to be equivalent to 1.0.0, 1.0a
  32. to be equivalent to 1.0.1, and so on.
  33. */
  34. typedef uint32_t le_version_t;
  35. /** @{ */
  36. /** Macros: returns the number of a libevent version as a le_version_t */
  37. #define V(major, minor, patch) \
  38. (((major) << 24) | ((minor) << 16) | ((patch) << 8))
  39. #define V_OLD(major, minor, patch) \
  40. V((major), (minor), (patch)-'a'+1)
  41. /** @} */
  42. /** Represetns a version of libevent so old we can't figure out what version
  43. * it is. */
  44. #define LE_OLD V(0,0,0)
  45. /** Represents a version of libevent so weird we can't figure out what version
  46. * it is. */
  47. #define LE_OTHER V(0,0,99)
  48. #if 0
  49. static le_version_t tor_get_libevent_version(const char **v_out);
  50. #endif
  51. #if defined(HAVE_EVENT_SET_LOG_CALLBACK) || defined(RUNNING_DOXYGEN)
  52. /** A string which, if it appears in a libevent log, should be ignored. */
  53. static const char *suppress_msg = NULL;
  54. /** Callback function passed to event_set_log() so we can intercept
  55. * log messages from libevent. */
  56. static void
  57. libevent_logging_callback(int severity, const char *msg)
  58. {
  59. char buf[1024];
  60. size_t n;
  61. if (suppress_msg && strstr(msg, suppress_msg))
  62. return;
  63. n = strlcpy(buf, msg, sizeof(buf));
  64. if (n && n < sizeof(buf) && buf[n-1] == '\n') {
  65. buf[n-1] = '\0';
  66. }
  67. switch (severity) {
  68. case _EVENT_LOG_DEBUG:
  69. log_debug(LD_NOCB|LD_NET, "Message from libevent: %s", buf);
  70. break;
  71. case _EVENT_LOG_MSG:
  72. log_info(LD_NOCB|LD_NET, "Message from libevent: %s", buf);
  73. break;
  74. case _EVENT_LOG_WARN:
  75. log_warn(LD_NOCB|LD_GENERAL, "Warning from libevent: %s", buf);
  76. break;
  77. case _EVENT_LOG_ERR:
  78. log_err(LD_NOCB|LD_GENERAL, "Error from libevent: %s", buf);
  79. break;
  80. default:
  81. log_warn(LD_NOCB|LD_GENERAL, "Message [%d] from libevent: %s",
  82. severity, buf);
  83. break;
  84. }
  85. }
  86. /** Set hook to intercept log messages from libevent. */
  87. void
  88. configure_libevent_logging(void)
  89. {
  90. event_set_log_callback(libevent_logging_callback);
  91. }
  92. /** Ignore any libevent log message that contains <b>msg</b>. */
  93. void
  94. suppress_libevent_log_msg(const char *msg)
  95. {
  96. suppress_msg = msg;
  97. }
  98. #else
  99. void
  100. configure_libevent_logging(void)
  101. {
  102. }
  103. void
  104. suppress_libevent_log_msg(const char *msg)
  105. {
  106. (void)msg;
  107. }
  108. #endif
  109. #ifndef HAVE_EVENT2_EVENT_H
  110. /** Work-alike replacement for event_new() on pre-Libevent-2.0 systems. */
  111. struct event *
  112. tor_event_new(struct event_base *base, int sock, short what,
  113. void (*cb)(int, short, void *), void *arg)
  114. {
  115. struct event *e = tor_malloc_zero(sizeof(struct event));
  116. event_set(e, sock, what, cb, arg);
  117. if (! base)
  118. base = tor_libevent_get_base();
  119. event_base_set(base, e);
  120. return e;
  121. }
  122. /** Work-alike replacement for evtimer_new() on pre-Libevent-2.0 systems. */
  123. struct event *
  124. tor_evtimer_new(struct event_base *base,
  125. void (*cb)(int, short, void *), void *arg)
  126. {
  127. return tor_event_new(base, -1, 0, cb, arg);
  128. }
  129. /** Work-alike replacement for evsignal_new() on pre-Libevent-2.0 systems. */
  130. struct event *
  131. tor_evsignal_new(struct event_base * base, int sig,
  132. void (*cb)(int, short, void *), void *arg)
  133. {
  134. return tor_event_new(base, sig, EV_SIGNAL|EV_PERSIST, cb, arg);
  135. }
  136. /** Work-alike replacement for event_free() on pre-Libevent-2.0 systems,
  137. * except tolerate tor_event_free(NULL). */
  138. void
  139. tor_event_free(struct event *ev)
  140. {
  141. if (ev == NULL)
  142. return;
  143. event_del(ev);
  144. tor_free(ev);
  145. }
  146. #else
  147. /* Wrapper for event_free() that tolerates tor_event_free(NULL) */
  148. void
  149. tor_event_free(struct event *ev)
  150. {
  151. if (ev == NULL)
  152. return;
  153. event_free(ev);
  154. }
  155. #endif
  156. /** Global event base for use by the main thread. */
  157. struct event_base *the_event_base = NULL;
  158. /* This is what passes for version detection on OSX. We set
  159. * MACOSX_KQUEUE_IS_BROKEN to true iff we're on a version of OSX before
  160. * 10.4.0 (aka 1040). */
  161. #ifdef __APPLE__
  162. #ifdef __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__
  163. #define MACOSX_KQUEUE_IS_BROKEN \
  164. (__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ < 1040)
  165. #else
  166. #define MACOSX_KQUEUE_IS_BROKEN 0
  167. #endif
  168. #endif
  169. #ifdef USE_BUFFEREVENTS
  170. static int using_iocp_bufferevents = 0;
  171. static void tor_libevent_set_tick_timeout(int msec_per_tick);
  172. int
  173. tor_libevent_using_iocp_bufferevents(void)
  174. {
  175. return using_iocp_bufferevents;
  176. }
  177. #endif
  178. /** Initialize the Libevent library and set up the event base. */
  179. void
  180. tor_libevent_initialize(tor_libevent_cfg *torcfg)
  181. {
  182. tor_assert(the_event_base == NULL);
  183. /* some paths below don't use torcfg, so avoid unused variable warnings */
  184. (void)torcfg;
  185. #ifdef HAVE_EVENT2_EVENT_H
  186. {
  187. int attempts = 0;
  188. int using_threads;
  189. struct event_config *cfg;
  190. retry:
  191. ++attempts;
  192. using_threads = 0;
  193. cfg = event_config_new();
  194. tor_assert(cfg);
  195. #if defined(_WIN32) && defined(USE_BUFFEREVENTS)
  196. if (! torcfg->disable_iocp) {
  197. evthread_use_windows_threads();
  198. event_config_set_flag(cfg, EVENT_BASE_FLAG_STARTUP_IOCP);
  199. using_iocp_bufferevents = 1;
  200. using_threads = 1;
  201. } else {
  202. using_iocp_bufferevents = 0;
  203. }
  204. #endif
  205. if (!using_threads) {
  206. /* Telling Libevent not to try to turn locking on can avoid a needless
  207. * socketpair() attempt. */
  208. event_config_set_flag(cfg, EVENT_BASE_FLAG_NOLOCK);
  209. }
  210. #if defined(LIBEVENT_VERSION_NUMBER) && LIBEVENT_VERSION_NUMBER >= V(2,0,7)
  211. if (torcfg->num_cpus > 0)
  212. event_config_set_num_cpus_hint(cfg, torcfg->num_cpus);
  213. #endif
  214. #if LIBEVENT_VERSION_NUMBER >= V(2,0,9)
  215. /* We can enable changelist support with epoll, since we don't give
  216. * Libevent any dup'd fds. This lets us avoid some syscalls. */
  217. event_config_set_flag(cfg, EVENT_BASE_FLAG_EPOLL_USE_CHANGELIST);
  218. #endif
  219. the_event_base = event_base_new_with_config(cfg);
  220. event_config_free(cfg);
  221. if (using_threads && the_event_base == NULL && attempts < 2) {
  222. /* This could be a socketpair() failure, which can happen sometimes on
  223. * windows boxes with obnoxious firewall rules. Downgrade and try
  224. * again. */
  225. #if defined(_WIN32) && defined(USE_BUFFEREVENTS)
  226. if (torcfg->disable_iocp == 0) {
  227. log_warn(LD_GENERAL, "Unable to initialize Libevent. Trying again "
  228. "with IOCP disabled.");
  229. } else
  230. #endif
  231. {
  232. log_warn(LD_GENERAL, "Unable to initialize Libevent. Trying again.");
  233. }
  234. torcfg->disable_iocp = 1;
  235. goto retry;
  236. }
  237. }
  238. #else
  239. the_event_base = event_init();
  240. #endif
  241. if (!the_event_base) {
  242. log_err(LD_GENERAL, "Unable to initialize Libevent: cannot continue.");
  243. exit(1);
  244. }
  245. #if defined(HAVE_EVENT_GET_VERSION) && defined(HAVE_EVENT_GET_METHOD)
  246. /* Making this a NOTICE for now so we can link bugs to a libevent versions
  247. * or methods better. */
  248. log_info(LD_GENERAL,
  249. "Initialized libevent version %s using method %s. Good.",
  250. event_get_version(), tor_libevent_get_method());
  251. #else
  252. log_notice(LD_GENERAL,
  253. "Initialized old libevent (version 1.0b or earlier).");
  254. log_warn(LD_GENERAL,
  255. "You have a *VERY* old version of libevent. It is likely to be buggy; "
  256. "please build Tor with a more recent version.");
  257. #endif
  258. #ifdef USE_BUFFEREVENTS
  259. tor_libevent_set_tick_timeout(torcfg->msec_per_tick);
  260. #endif
  261. }
  262. /** Return the current Libevent event base that we're set up to use. */
  263. struct event_base *
  264. tor_libevent_get_base(void)
  265. {
  266. return the_event_base;
  267. }
  268. #ifndef HAVE_EVENT_BASE_LOOPEXIT
  269. /** Replacement for event_base_loopexit on some very old versions of Libevent
  270. * that we are not yet brave enough to deprecate. */
  271. int
  272. tor_event_base_loopexit(struct event_base *base, struct timeval *tv)
  273. {
  274. tor_assert(base == the_event_base);
  275. return event_loopexit(tv);
  276. }
  277. #endif
  278. /** Return the name of the Libevent backend we're using. */
  279. const char *
  280. tor_libevent_get_method(void)
  281. {
  282. #ifdef HAVE_EVENT2_EVENT_H
  283. return event_base_get_method(the_event_base);
  284. #elif defined(HAVE_EVENT_GET_METHOD)
  285. return event_get_method();
  286. #else
  287. return "<unknown>";
  288. #endif
  289. }
  290. /** Return the le_version_t for the version of libevent specified in the
  291. * string <b>v</b>. If the version is very new or uses an unrecognized
  292. * version, format, return LE_OTHER. */
  293. static le_version_t
  294. tor_decode_libevent_version(const char *v)
  295. {
  296. unsigned major, minor, patchlevel;
  297. char c, e, extra;
  298. int fields;
  299. /* Try the new preferred "1.4.11-stable" format.
  300. * Also accept "1.4.14b-stable". */
  301. fields = tor_sscanf(v, "%u.%u.%u%c%c", &major, &minor, &patchlevel, &c, &e);
  302. if (fields == 3 ||
  303. ((fields == 4 || fields == 5 ) && (c == '-' || c == '_')) ||
  304. (fields == 5 && TOR_ISALPHA(c) && (e == '-' || e == '_'))) {
  305. return V(major,minor,patchlevel);
  306. }
  307. /* Try the old "1.3e" format. */
  308. fields = tor_sscanf(v, "%u.%u%c%c", &major, &minor, &c, &extra);
  309. if (fields == 3 && TOR_ISALPHA(c)) {
  310. return V_OLD(major, minor, c);
  311. } else if (fields == 2) {
  312. return V(major, minor, 0);
  313. }
  314. return LE_OTHER;
  315. }
  316. /** Return an integer representing the binary interface of a Libevent library.
  317. * Two different versions with different numbers are sure not to be binary
  318. * compatible. Two different versions with the same numbers have a decent
  319. * chance of binary compatibility.*/
  320. static int
  321. le_versions_compatibility(le_version_t v)
  322. {
  323. if (v == LE_OTHER)
  324. return 0;
  325. if (v < V_OLD(1,0,'c'))
  326. return 1;
  327. else if (v < V(1,4,0))
  328. return 2;
  329. else if (v < V(1,4,99))
  330. return 3;
  331. else if (v < V(2,0,1))
  332. return 4;
  333. else /* Everything 2.0 and later should be compatible. */
  334. return 5;
  335. }
  336. #if 0
  337. /** Return the version number of the currently running version of Libevent.
  338. * See le_version_t for info on the format.
  339. */
  340. static le_version_t
  341. tor_get_libevent_version(const char **v_out)
  342. {
  343. const char *v;
  344. le_version_t r;
  345. #if defined(HAVE_EVENT_GET_VERSION_NUMBER)
  346. v = event_get_version();
  347. r = event_get_version_number();
  348. #elif defined (HAVE_EVENT_GET_VERSION)
  349. v = event_get_version();
  350. r = tor_decode_libevent_version(v);
  351. #else
  352. v = "pre-1.0c";
  353. r = LE_OLD;
  354. #endif
  355. if (v_out)
  356. *v_out = v;
  357. return r;
  358. }
  359. #endif
  360. /** Return a string representation of the version of the currently running
  361. * version of Libevent. */
  362. const char *
  363. tor_libevent_get_version_str(void)
  364. {
  365. #ifdef HAVE_EVENT_GET_VERSION
  366. return event_get_version();
  367. #else
  368. return "pre-1.0c";
  369. #endif
  370. }
  371. /**
  372. * Compare the current Libevent method and version to a list of versions
  373. * which are known not to work. Warn the user as appropriate.
  374. */
  375. void
  376. tor_check_libevent_version(const char *m, int server,
  377. const char **badness_out)
  378. {
  379. (void) m;
  380. (void) server;
  381. *badness_out = NULL;
  382. }
  383. #if defined(LIBEVENT_VERSION)
  384. #define HEADER_VERSION LIBEVENT_VERSION
  385. #elif defined(_EVENT_VERSION)
  386. #define HEADER_VERSION _EVENT_VERSION
  387. #endif
  388. /** Return a string representation of the version of Libevent that was used
  389. * at compilation time. */
  390. const char *
  391. tor_libevent_get_header_version_str(void)
  392. {
  393. return HEADER_VERSION;
  394. }
  395. /** See whether the headers we were built against differ from the library we
  396. * linked against so much that we're likely to crash. If so, warn the
  397. * user. */
  398. void
  399. tor_check_libevent_header_compatibility(void)
  400. {
  401. (void) le_versions_compatibility;
  402. (void) tor_decode_libevent_version;
  403. /* In libevent versions before 2.0, it's hard to keep binary compatibility
  404. * between upgrades, and unpleasant to detect when the version we compiled
  405. * against is unlike the version we have linked against. Here's how. */
  406. #if defined(HEADER_VERSION) && defined(HAVE_EVENT_GET_VERSION)
  407. /* We have a header-file version and a function-call version. Easy. */
  408. if (strcmp(HEADER_VERSION, event_get_version())) {
  409. le_version_t v1, v2;
  410. int compat1 = -1, compat2 = -1;
  411. int verybad;
  412. v1 = tor_decode_libevent_version(HEADER_VERSION);
  413. v2 = tor_decode_libevent_version(event_get_version());
  414. compat1 = le_versions_compatibility(v1);
  415. compat2 = le_versions_compatibility(v2);
  416. verybad = compat1 != compat2;
  417. tor_log(verybad ? LOG_WARN : LOG_NOTICE,
  418. LD_GENERAL, "We were compiled with headers from version %s "
  419. "of Libevent, but we're using a Libevent library that says it's "
  420. "version %s.", HEADER_VERSION, event_get_version());
  421. if (verybad)
  422. log_warn(LD_GENERAL, "This will almost certainly make Tor crash.");
  423. else
  424. log_info(LD_GENERAL, "I think these versions are binary-compatible.");
  425. }
  426. #elif defined(HAVE_EVENT_GET_VERSION)
  427. /* event_get_version but no _EVENT_VERSION. We might be in 1.4.0-beta or
  428. earlier, where that's normal. To see whether we were compiled with an
  429. earlier version, let's see whether the struct event defines MIN_HEAP_IDX.
  430. */
  431. #ifdef HAVE_STRUCT_EVENT_MIN_HEAP_IDX
  432. /* The header files are 1.4.0-beta or later. If the version is not
  433. * 1.4.0-beta, we are incompatible. */
  434. {
  435. if (strcmp(event_get_version(), "1.4.0-beta")) {
  436. log_warn(LD_GENERAL, "It's a little hard to tell, but you seem to have "
  437. "Libevent 1.4.0-beta header files, whereas you have linked "
  438. "against Libevent %s. This will probably make Tor crash.",
  439. event_get_version());
  440. }
  441. }
  442. #else
  443. /* Our headers are 1.3e or earlier. If the library version is not 1.4.x or
  444. later, we're probably fine. */
  445. {
  446. const char *v = event_get_version();
  447. if ((v[0] == '1' && v[2] == '.' && v[3] > '3') || v[0] > '1') {
  448. log_warn(LD_GENERAL, "It's a little hard to tell, but you seem to have "
  449. "Libevent header file from 1.3e or earlier, whereas you have "
  450. "linked against Libevent %s. This will probably make Tor "
  451. "crash.", event_get_version());
  452. }
  453. }
  454. #endif
  455. #elif defined(HEADER_VERSION)
  456. #warn "_EVENT_VERSION is defined but not get_event_version(): Libevent is odd."
  457. #else
  458. /* Your libevent is ancient. */
  459. #endif
  460. }
  461. /*
  462. If possible, we're going to try to use Libevent's periodic timer support,
  463. since it does a pretty good job of making sure that periodic events get
  464. called exactly M seconds apart, rather than starting each one exactly M
  465. seconds after the time that the last one was run.
  466. */
  467. #ifdef HAVE_EVENT2_EVENT_H
  468. #define HAVE_PERIODIC
  469. #define PERIODIC_FLAGS EV_PERSIST
  470. #else
  471. #define PERIODIC_FLAGS 0
  472. #endif
  473. /** Represents a timer that's run every N microseconds by Libevent. */
  474. struct periodic_timer_t {
  475. /** Underlying event used to implement this periodic event. */
  476. struct event *ev;
  477. /** The callback we'll be invoking whenever the event triggers */
  478. void (*cb)(struct periodic_timer_t *, void *);
  479. /** User-supplied data for the callback */
  480. void *data;
  481. #ifndef HAVE_PERIODIC
  482. /** If Libevent doesn't know how to invoke events every N microseconds,
  483. * we'll need to remember the timeout interval here. */
  484. struct timeval tv;
  485. #endif
  486. };
  487. /** Libevent callback to implement a periodic event. */
  488. static void
  489. periodic_timer_cb(evutil_socket_t fd, short what, void *arg)
  490. {
  491. periodic_timer_t *timer = arg;
  492. (void) what;
  493. (void) fd;
  494. #ifndef HAVE_PERIODIC
  495. /** reschedule the event as needed. */
  496. event_add(timer->ev, &timer->tv);
  497. #endif
  498. timer->cb(timer, timer->data);
  499. }
  500. /** Create and schedule a new timer that will run every <b>tv</b> in
  501. * the event loop of <b>base</b>. When the timer fires, it will
  502. * run the timer in <b>cb</b> with the user-supplied data in <b>data</b>. */
  503. periodic_timer_t *
  504. periodic_timer_new(struct event_base *base,
  505. const struct timeval *tv,
  506. void (*cb)(periodic_timer_t *timer, void *data),
  507. void *data)
  508. {
  509. periodic_timer_t *timer;
  510. tor_assert(base);
  511. tor_assert(tv);
  512. tor_assert(cb);
  513. timer = tor_malloc_zero(sizeof(periodic_timer_t));
  514. if (!(timer->ev = tor_event_new(base, -1, PERIODIC_FLAGS,
  515. periodic_timer_cb, timer))) {
  516. tor_free(timer);
  517. return NULL;
  518. }
  519. timer->cb = cb;
  520. timer->data = data;
  521. #ifndef HAVE_PERIODIC
  522. memcpy(&timer->tv, tv, sizeof(struct timeval));
  523. #endif
  524. event_add(timer->ev, (struct timeval *)tv); /*drop const for old libevent*/
  525. return timer;
  526. }
  527. /** Stop and free a periodic timer */
  528. void
  529. periodic_timer_free(periodic_timer_t *timer)
  530. {
  531. if (!timer)
  532. return;
  533. tor_event_free(timer->ev);
  534. tor_free(timer);
  535. }
  536. #ifdef USE_BUFFEREVENTS
  537. static const struct timeval *one_tick = NULL;
  538. /**
  539. * Return a special timeout to be passed whenever libevent's O(1) timeout
  540. * implementation should be used. Only use this when the timer is supposed
  541. * to fire after msec_per_tick ticks have elapsed.
  542. */
  543. const struct timeval *
  544. tor_libevent_get_one_tick_timeout(void)
  545. {
  546. tor_assert(one_tick);
  547. return one_tick;
  548. }
  549. /** Initialize the common timeout that we'll use to refill the buckets every
  550. * time a tick elapses. */
  551. static void
  552. tor_libevent_set_tick_timeout(int msec_per_tick)
  553. {
  554. struct event_base *base = tor_libevent_get_base();
  555. struct timeval tv;
  556. tor_assert(! one_tick);
  557. tv.tv_sec = msec_per_tick / 1000;
  558. tv.tv_usec = (msec_per_tick % 1000) * 1000;
  559. one_tick = event_base_init_common_timeout(base, &tv);
  560. }
  561. static struct bufferevent *
  562. tor_get_root_bufferevent(struct bufferevent *bev)
  563. {
  564. struct bufferevent *u;
  565. while ((u = bufferevent_get_underlying(bev)) != NULL)
  566. bev = u;
  567. return bev;
  568. }
  569. int
  570. tor_set_bufferevent_rate_limit(struct bufferevent *bev,
  571. struct ev_token_bucket_cfg *cfg)
  572. {
  573. return bufferevent_set_rate_limit(tor_get_root_bufferevent(bev), cfg);
  574. }
  575. int
  576. tor_add_bufferevent_to_rate_limit_group(struct bufferevent *bev,
  577. struct bufferevent_rate_limit_group *g)
  578. {
  579. return bufferevent_add_to_rate_limit_group(tor_get_root_bufferevent(bev), g);
  580. }
  581. #endif
  582. int
  583. tor_init_libevent_rng(void)
  584. {
  585. int rv = 0;
  586. #ifdef HAVE_EVUTIL_SECURE_RNG_INIT
  587. char buf[256];
  588. if (evutil_secure_rng_init() < 0) {
  589. rv = -1;
  590. }
  591. /* Older libevent -- manually initialize the RNG */
  592. crypto_rand(buf, 32);
  593. evutil_secure_rng_add_bytes(buf, 32);
  594. evutil_secure_rng_get_bytes(buf, sizeof(buf));
  595. #endif
  596. return rv;
  597. }
  598. #if defined(LIBEVENT_VERSION_NUMBER) && LIBEVENT_VERSION_NUMBER >= V(2,1,1) \
  599. && !defined(TOR_UNIT_TESTS)
  600. void
  601. tor_gettimeofday_cached(struct timeval *tv)
  602. {
  603. event_base_gettimeofday_cached(the_event_base, tv);
  604. }
  605. void
  606. tor_gettimeofday_cache_clear(void)
  607. {
  608. event_base_update_cache_time(the_event_base);
  609. }
  610. #else
  611. /** Cache the current hi-res time; the cache gets reset when libevent
  612. * calls us. */
  613. static struct timeval cached_time_hires = {0, 0};
  614. /** Return a fairly recent view of the current time. */
  615. void
  616. tor_gettimeofday_cached(struct timeval *tv)
  617. {
  618. if (cached_time_hires.tv_sec == 0) {
  619. tor_gettimeofday(&cached_time_hires);
  620. }
  621. *tv = cached_time_hires;
  622. }
  623. /** Reset the cached view of the current time, so that the next time we try
  624. * to learn it, we will get an up-to-date value. */
  625. void
  626. tor_gettimeofday_cache_clear(void)
  627. {
  628. cached_time_hires.tv_sec = 0;
  629. }
  630. #ifdef TOR_UNIT_TESTS
  631. /** For testing: force-update the cached time to a given value. */
  632. void
  633. tor_gettimeofday_cache_set(const struct timeval *tv)
  634. {
  635. tor_assert(tv);
  636. memcpy(&cached_time_hires, tv, sizeof(*tv));
  637. }
  638. #endif
  639. #endif
  640. /**
  641. * As tor_gettimeofday_cached, but can never move backwards in time.
  642. *
  643. * The returned value may diverge from wall-clock time, since wall-clock time
  644. * can trivially be adjusted backwards, and this can't. Don't mix wall-clock
  645. * time with these values in the same calculation.
  646. *
  647. * Depending on implementation, this function may or may not "smooth out" huge
  648. * jumps forward in wall-clock time. It may or may not keep its results
  649. * advancing forward (as opposed to stalling) if the wall-clock time goes
  650. * backwards. The current implementation does neither of of these.
  651. *
  652. * This function is not thread-safe; do not call it outside the main thread.
  653. *
  654. * In future versions of Tor, this may return a time does not have its
  655. * origin at the Unix epoch.
  656. */
  657. void
  658. tor_gettimeofday_cached_monotonic(struct timeval *tv)
  659. {
  660. struct timeval last_tv = { 0, 0 };
  661. tor_gettimeofday_cached(tv);
  662. if (timercmp(tv, &last_tv, <)) {
  663. memcpy(tv, &last_tv, sizeof(struct timeval));
  664. } else {
  665. memcpy(&last_tv, tv, sizeof(struct timeval));
  666. }
  667. }