X-Git-Url: https://git.distorted.org.uk/~mdw/fwd/blobdiff_plain/0d3d364b48292a4bd349b2dd096f060b1db21212..096c89c34505cadba1fc6e7a5367273d5c5bea47:/blast.c diff --git a/blast.c b/blast.c index c273a41..cda5346 100644 --- a/blast.c +++ b/blast.c @@ -1,6 +1,7 @@ #include #include #include +#include #include #include #include @@ -15,6 +16,7 @@ #include #include +#include #include #include #include @@ -26,13 +28,14 @@ typedef struct blast { sel_timer t; } blast; +#define sin saddrin static struct sockaddr_in sin; static sel_state sel; static struct timeval ctv = { 0, 500000 }; static sel_timer sec; static unsigned count = 0; -static void timers(void); +static void IGNORABLE timers(void); static void stats(struct timeval *tv, void *p) { @@ -94,14 +97,14 @@ static void timers(void) sel_timer *t = sel.timers; while (t) { struct tab *q; for (q = tab; q->func != t->func; q++) ; - assert(t->prev->next == t); - printf("%i.%06i %p %s\n", t->tv.tv_sec, t->tv.tv_usec, t->p, q->name); +/* assert(t->prev->next == t); */ + printf("%lu.%06lu %p %s\n", t->tv.tv_sec, t->tv.tv_usec, t->p, q->name); assert(t != t->next); t = t->next; } puts(""); } - + static void newconn(blast *b) { int fd = socket(PF_INET, SOCK_STREAM, 0); @@ -110,13 +113,14 @@ static void newconn(blast *b) goto fail; gettimeofday(&tv, 0); TV_ADD(&tv, &tv, &ctv); + sel_addtimer(&sel, &b->t, &tv, timeout, b); if (conn_init(&b->c, &sel, fd, (struct sockaddr *)&sin, sizeof(sin), connected, b)) goto fail; - sel_addtimer(&sel, &b->t, &tv, timeout, b); return; fail: + sel_rmtimer(&b->t); backoff(b); } @@ -149,7 +153,7 @@ int main(int argc, char *argv[]) argv += optind; argc -= optind; if (argc != 2) { - pquis(stderr, "Usage: $ [-t time] [-n count] host port\n"); + pquis(stderr, "Usage: $ [-t TIME] [-n COUNT] HOST PORT\n"); exit(1); }