1*2b15cb3dSCy Schubert /* 2*2b15cb3dSCy Schubert * Copyright (c) 2002-2007 Niels Provos <provos@citi.umich.edu> 3*2b15cb3dSCy Schubert * Copyright (c) 2007-2012 Niels Provos and Nick Mathewson 4*2b15cb3dSCy Schubert * 5*2b15cb3dSCy Schubert * Redistribution and use in source and binary forms, with or without 6*2b15cb3dSCy Schubert * modification, are permitted provided that the following conditions 7*2b15cb3dSCy Schubert * are met: 8*2b15cb3dSCy Schubert * 1. Redistributions of source code must retain the above copyright 9*2b15cb3dSCy Schubert * notice, this list of conditions and the following disclaimer. 10*2b15cb3dSCy Schubert * 2. Redistributions in binary form must reproduce the above copyright 11*2b15cb3dSCy Schubert * notice, this list of conditions and the following disclaimer in the 12*2b15cb3dSCy Schubert * documentation and/or other materials provided with the distribution. 13*2b15cb3dSCy Schubert * 3. The name of the author may not be used to endorse or promote products 14*2b15cb3dSCy Schubert * derived from this software without specific prior written permission. 15*2b15cb3dSCy Schubert * 16*2b15cb3dSCy Schubert * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 17*2b15cb3dSCy Schubert * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 18*2b15cb3dSCy Schubert * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 19*2b15cb3dSCy Schubert * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 20*2b15cb3dSCy Schubert * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 21*2b15cb3dSCy Schubert * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 22*2b15cb3dSCy Schubert * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 23*2b15cb3dSCy Schubert * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24*2b15cb3dSCy Schubert * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 25*2b15cb3dSCy Schubert * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26*2b15cb3dSCy Schubert */ 27*2b15cb3dSCy Schubert #include "event2/event-config.h" 28*2b15cb3dSCy Schubert 29*2b15cb3dSCy Schubert #include <sys/types.h> 30*2b15cb3dSCy Schubert #include <sys/stat.h> 31*2b15cb3dSCy Schubert #include <fcntl.h> 32*2b15cb3dSCy Schubert #include <stdlib.h> 33*2b15cb3dSCy Schubert #include <stdio.h> 34*2b15cb3dSCy Schubert #include <string.h> 35*2b15cb3dSCy Schubert #ifndef _WIN32 36*2b15cb3dSCy Schubert #include <unistd.h> 37*2b15cb3dSCy Schubert #include <sys/time.h> 38*2b15cb3dSCy Schubert #endif 39*2b15cb3dSCy Schubert #include <errno.h> 40*2b15cb3dSCy Schubert 41*2b15cb3dSCy Schubert #include "event2/event.h" 42*2b15cb3dSCy Schubert #include "event2/event_compat.h" 43*2b15cb3dSCy Schubert #include "event2/event_struct.h" 44*2b15cb3dSCy Schubert 45*2b15cb3dSCy Schubert int called = 0; 46*2b15cb3dSCy Schubert 47*2b15cb3dSCy Schubert #define NEVENT 20000 48*2b15cb3dSCy Schubert 49*2b15cb3dSCy Schubert struct event *ev[NEVENT]; 50*2b15cb3dSCy Schubert 51*2b15cb3dSCy Schubert static int 52*2b15cb3dSCy Schubert rand_int(int n) 53*2b15cb3dSCy Schubert { 54*2b15cb3dSCy Schubert #ifdef _WIN32 55*2b15cb3dSCy Schubert return (int)(rand() % n); 56*2b15cb3dSCy Schubert #else 57*2b15cb3dSCy Schubert return (int)(random() % n); 58*2b15cb3dSCy Schubert #endif 59*2b15cb3dSCy Schubert } 60*2b15cb3dSCy Schubert 61*2b15cb3dSCy Schubert static void 62*2b15cb3dSCy Schubert time_cb(evutil_socket_t fd, short event, void *arg) 63*2b15cb3dSCy Schubert { 64*2b15cb3dSCy Schubert struct timeval tv; 65*2b15cb3dSCy Schubert int i, j; 66*2b15cb3dSCy Schubert 67*2b15cb3dSCy Schubert called++; 68*2b15cb3dSCy Schubert 69*2b15cb3dSCy Schubert if (called < 10*NEVENT) { 70*2b15cb3dSCy Schubert for (i = 0; i < 10; i++) { 71*2b15cb3dSCy Schubert j = rand_int(NEVENT); 72*2b15cb3dSCy Schubert tv.tv_sec = 0; 73*2b15cb3dSCy Schubert tv.tv_usec = rand_int(50000); 74*2b15cb3dSCy Schubert if (tv.tv_usec % 2) 75*2b15cb3dSCy Schubert evtimer_add(ev[j], &tv); 76*2b15cb3dSCy Schubert else 77*2b15cb3dSCy Schubert evtimer_del(ev[j]); 78*2b15cb3dSCy Schubert } 79*2b15cb3dSCy Schubert } 80*2b15cb3dSCy Schubert } 81*2b15cb3dSCy Schubert 82*2b15cb3dSCy Schubert int 83*2b15cb3dSCy Schubert main(int argc, char **argv) 84*2b15cb3dSCy Schubert { 85*2b15cb3dSCy Schubert struct timeval tv; 86*2b15cb3dSCy Schubert int i; 87*2b15cb3dSCy Schubert #ifdef _WIN32 88*2b15cb3dSCy Schubert WORD wVersionRequested; 89*2b15cb3dSCy Schubert WSADATA wsaData; 90*2b15cb3dSCy Schubert 91*2b15cb3dSCy Schubert wVersionRequested = MAKEWORD(2, 2); 92*2b15cb3dSCy Schubert 93*2b15cb3dSCy Schubert (void) WSAStartup(wVersionRequested, &wsaData); 94*2b15cb3dSCy Schubert #endif 95*2b15cb3dSCy Schubert 96*2b15cb3dSCy Schubert /* Initalize the event library */ 97*2b15cb3dSCy Schubert event_init(); 98*2b15cb3dSCy Schubert 99*2b15cb3dSCy Schubert for (i = 0; i < NEVENT; i++) { 100*2b15cb3dSCy Schubert ev[i] = malloc(sizeof(struct event)); 101*2b15cb3dSCy Schubert 102*2b15cb3dSCy Schubert /* Initalize one event */ 103*2b15cb3dSCy Schubert evtimer_set(ev[i], time_cb, ev[i]); 104*2b15cb3dSCy Schubert tv.tv_sec = 0; 105*2b15cb3dSCy Schubert tv.tv_usec = rand_int(50000); 106*2b15cb3dSCy Schubert evtimer_add(ev[i], &tv); 107*2b15cb3dSCy Schubert } 108*2b15cb3dSCy Schubert 109*2b15cb3dSCy Schubert event_dispatch(); 110*2b15cb3dSCy Schubert 111*2b15cb3dSCy Schubert return (called < NEVENT); 112*2b15cb3dSCy Schubert } 113*2b15cb3dSCy Schubert 114