X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fgeekos%2Ftimer.h;h=f6add166f87e8d41d080fd15e331686b387d252c;hb=7617d3cee4bd93b90558206b1bb1681c07f0396a;hp=7fb783d7db368ee2af9d4196e2246db012054b85;hpb=d1eb5efb0a6b8b3a1dfd5d1eb944bbe2a20cf95a;p=palacios.git diff --git a/palacios/include/geekos/timer.h b/palacios/include/geekos/timer.h index 7fb783d..f6add16 100644 --- a/palacios/include/geekos/timer.h +++ b/palacios/include/geekos/timer.h @@ -16,7 +16,7 @@ extern volatile ulong_t g_numTicks; -typedef void (*timerCallback)(int); +typedef void (*timerCallback)(int, void*); void Init_Timer(void); @@ -24,22 +24,24 @@ void Micro_Delay(int us); typedef struct { - int ticks; /* timer code decrements this */ - int id; /* unqiue id for this timer even */ - timerCallback callBack; /* Queue to wakeup on timer expire */ - int origTicks; + int ticks; /* timer code decrements this */ + int id; /* unqiue id for this timer even */ + timerCallback callBack; /* Queue to wakeup on timer expire */ + void * cb_arg; /* Argument to add to callback */ + int origTicks; + } timerEvent; -int Start_Timer_Secs(int seconds, timerCallback cb); -int Start_Timer_MSecs(int msecs, timerCallback cb); -int Start_Timer(int ticks, timerCallback); +int Start_Timer_Secs(int seconds, timerCallback cb, void * arg); +int Start_Timer_MSecs(int msecs, timerCallback cb, void * arg); +int Start_Timer(int ticks, timerCallback, void * arg); + double Get_Remaining_Timer_Secs(int id); int Get_Remaining_Timer_MSecs(int id); int Get_Remaining_Timer_Ticks(int id); int Cancel_Timer(int id); - void Micro_Delay(int us); #endif /* GEEKOS_TIMER_H */