X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Kernel%2Ftime.c;h=dcc4f79eeb64523bde2ca237266a350463fca5c4;hb=86f49ede5038704ac4f12eab9794e9a8110a4985;hp=fcc13afbf71a3a07590caccd870499008fffa568;hpb=dea6bcf35a3f52396724d74e47f71cb3afade37c;p=tpg%2Facess2.git diff --git a/Kernel/time.c b/Kernel/time.c index fcc13afb..dcc4f79e 100644 --- a/Kernel/time.c +++ b/Kernel/time.c @@ -24,7 +24,7 @@ void Timer_CallTimers(void); Uint64 giTicks = 0; Sint64 giTimestamp = 0; Uint64 giPartMiliseconds = 0; -tTimer gTimers[NUM_TIMERS]; +tTimer gTimers[NUM_TIMERS]; // TODO: Replace by a ring-list timer // === CODE === /** @@ -43,23 +43,22 @@ void Timer_CallTimers() { int i; void (*callback)(void *); + void *arg; - for(i = 0; - i < NUM_TIMERS; - i ++) + for(i = 0; i < NUM_TIMERS; i ++) { if(gTimers[i].Callback == NULL) continue; if(giTimestamp < gTimers[i].FiresAfter) continue; - callback = gTimers[i].Callback; + callback = gTimers[i].Callback; arg = gTimers[i].Argument; gTimers[i].Callback = NULL; - callback(gTimers[i].Argument); + callback(arg); } } /** - * \fn int Time_CreateTimer(int Delta, void *Callback, void *Argument) + * \fn int Time_CreateTimer(int Delta, tTimerCallback *Callback, void *Argument) */ -int Time_CreateTimer(int Delta, void *Callback, void *Argument) +int Time_CreateTimer(int Delta, tTimerCallback *Callback, void *Argument) { int ret; @@ -96,7 +95,7 @@ void Time_RemoveTimer(int ID) void Time_Delay(int Delay) { Sint64 dest = giTimestamp + Delay; - while(dest < giTimestamp) Threads_Yield(); + while(dest > giTimestamp) Threads_Yield(); } // === EXPORTS ===