From a2ccbb0b97c1eac3a68f01b7786822a66aaaefa2 Mon Sep 17 00:00:00 2001 From: Martin Mares Date: Sun, 24 May 1998 14:40:29 +0000 Subject: Implemented timers. Using bird_clock_t for absolute time from now... --- sysdep/config.h | 5 +++++ sysdep/unix/Modules | 2 ++ sysdep/unix/timer.h | 22 +++++++++++++++------- 3 files changed, 22 insertions(+), 7 deletions(-) (limited to 'sysdep') diff --git a/sysdep/config.h b/sysdep/config.h index c9c1393..65a0110 100644 --- a/sysdep/config.h +++ b/sysdep/config.h @@ -40,6 +40,11 @@ typedef u16 word; #define CPU_STRUCT_ALIGN 4 +/* Timers */ + +#undef TIME_T_IS_64BIT +#define TIME_T_IS_SIGNED + /* Protocol options */ #define CONFIG_STATIC diff --git a/sysdep/unix/Modules b/sysdep/unix/Modules index 450f579..95b80b3 100644 --- a/sysdep/unix/Modules +++ b/sysdep/unix/Modules @@ -1,3 +1,5 @@ log.c main.c timer.h +io.c +unix.h diff --git a/sysdep/unix/timer.h b/sysdep/unix/timer.h index 506e3c9..0589ec0 100644 --- a/sysdep/unix/timer.h +++ b/sysdep/unix/timer.h @@ -1,5 +1,5 @@ /* - * BIRD Timers + * BIRD -- Unix Timers * * (c) 1998 Martin Mares * @@ -9,18 +9,26 @@ #ifndef _BIRD_TIMER_H_ #define _BIRD_TIMER_H_ +#include + #include "lib/resource.h" +typedef time_t bird_clock_t; /* Use instead of time_t */ + typedef struct timer { - resource r; - void (*hook)(struct timer *); - void *data; - /* internal fields should be here */ + resource r; + void (*hook)(struct timer *); + void *data; + unsigned randomize; /* Amount of randomization */ + node n; /* Internal link */ + clock_t expires; /* 0=inactive */ } timer; -timer *tm_new(pool *, void (*hook)(timer *), void *data); +timer *tm_new(pool *); void tm_start(timer *, unsigned after); void tm_stop(timer *); -void tm_trigger(timer *); +void tm_dump_all(void); + +extern clock_t now; #endif -- cgit v1.2.3