diff options
Diffstat (limited to 'erts/emulator/beam/erl_time.h')
| -rw-r--r-- | erts/emulator/beam/erl_time.h | 64 | 
1 files changed, 63 insertions, 1 deletions
| diff --git a/erts/emulator/beam/erl_time.h b/erts/emulator/beam/erl_time.h index 6f6b971d34..93d8ea4cb4 100644 --- a/erts/emulator/beam/erl_time.h +++ b/erts/emulator/beam/erl_time.h @@ -20,11 +20,15 @@  #ifndef ERL_TIME_H__  #define ERL_TIME_H__ +extern erts_smp_atomic_t do_time;	/* set at clock interrupt */ +extern SysTimeval erts_first_emu_time; +  /*  ** Timer entry:  */  typedef struct erl_timer {      struct erl_timer* next;	/* next entry tiw slot or chain */ +    struct erl_timer* prev;	/* prev entry tiw slot or chain */      Uint slot;			/* slot in timer wheel */      Uint count;			/* number of loops remaining */      int    active;		/* 1=activated, 0=deactivated */ @@ -39,7 +43,6 @@ typedef void (*ErlTimeoutProc)(void*);  typedef void (*ErlCancelProc)(void*);  #ifdef ERTS_SMP -  /*   * Process and port timer   */ @@ -61,7 +64,66 @@ void erts_create_smp_ptimer(ErtsSmpPTimer **timer_ref,  			    ErlTimeoutProc timeout_func,  			    Uint timeout);  void erts_cancel_smp_ptimer(ErtsSmpPTimer *ptimer); +#endif + +/* timer-wheel api */ +void erts_init_time(void); +void erts_set_timer(ErlTimer*, ErlTimeoutProc, ErlCancelProc, void*, Uint); +void erts_cancel_timer(ErlTimer*); +void erts_bump_timer(erts_aint_t); +Uint erts_timer_wheel_memory_size(void); +Uint erts_time_left(ErlTimer *); +erts_aint_t erts_next_time(void); + +#ifdef DEBUG +void erts_p_slpq(void);  #endif +ERTS_GLB_INLINE erts_aint_t erts_do_time_read_and_reset(void); +ERTS_GLB_INLINE void erts_do_time_add(long); + +#if ERTS_GLB_INLINE_INCL_FUNC_DEF + +ERTS_GLB_INLINE erts_aint_t erts_do_time_read_and_reset(void) { return erts_smp_atomic_xchg(&do_time, 0L); } +ERTS_GLB_INLINE void erts_do_time_add(long elapsed) { erts_smp_atomic_add(&do_time, elapsed); } + +#endif /* #if ERTS_GLB_INLINE_INCL_FUNC_DEF */ + + +/* time_sup */ + +#if (defined(HAVE_GETHRVTIME) || defined(HAVE_CLOCK_GETTIME)) +#  ifndef HAVE_ERTS_NOW_CPU +#    define HAVE_ERTS_NOW_CPU +#    ifdef HAVE_GETHRVTIME +#      define erts_start_now_cpu() sys_start_hrvtime() +#      define erts_stop_now_cpu()  sys_stop_hrvtime() +#    endif +#  endif +void erts_get_now_cpu(Uint* megasec, Uint* sec, Uint* microsec);  #endif + +void erts_get_timeval(SysTimeval *tv); +long erts_get_time(void); +void erts_get_emu_time(SysTimeval *); + +ERTS_GLB_INLINE int erts_cmp_timeval(SysTimeval *t1p, SysTimeval *t2p); + +#if ERTS_GLB_INLINE_INCL_FUNC_DEF + +ERTS_GLB_INLINE int +erts_cmp_timeval(SysTimeval *t1p, SysTimeval *t2p) +{ +    if (t1p->tv_sec == t2p->tv_sec) { +	if (t1p->tv_usec < t2p->tv_usec) +	    return -1; +	else if (t1p->tv_usec > t2p->tv_usec) +	    return 1; +	return 0; +    } +    return t1p->tv_sec < t2p->tv_sec ? -1 : 1; +} + +#endif /* #if ERTS_GLB_INLINE_INCL_FUNC_DEF */ +#endif /* ERL_TIME_H__ */ | 
