X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Ftimeval.h;h=5a7b6e25c62aeabc09b3b1089913446a828a8576;hb=ea7655d9f9d38a3af7250de8ba0b89115b5f4a5e;hp=1384848a1cec8f9b19087ce3c83413dd64e651a9;hpb=8706009e555bb9fa04a5679e4be2c7c67506802b;p=sliver-openvswitch.git diff --git a/lib/timeval.h b/lib/timeval.h index 1384848a1..5a7b6e25c 100644 --- a/lib/timeval.h +++ b/lib/timeval.h @@ -25,6 +25,7 @@ extern "C" { #endif +struct ds; struct pollfd; struct timespec; struct timeval; @@ -36,21 +37,6 @@ BUILD_ASSERT_DECL(TYPE_IS_INTEGER(time_t)); * ever encounter such a platform. */ BUILD_ASSERT_DECL(TYPE_IS_SIGNED(time_t)); -/* On x86-64 systems, Linux avoids using syscalls for clock_gettime(). - * - * For systems which do invoke a system call we wait at least - * TIME_UPDATE_INTERVAL ms between clock_gettime() calls and cache the time for - * the interim. - * - * For systems which do not invoke a system call, we just call clock_gettime() - * whenever the time is requested. As a result we don't start the background - * SIGALRM timer unless explicitly needed by time_alarm() */ -#if defined __x86_64__ && defined __linux__ -#define CACHE_TIME 0 -#else -#define CACHE_TIME 1 -#endif - #define TIME_MAX TYPE_MAXIMUM(time_t) #define TIME_MIN TYPE_MINIMUM(time_t) @@ -59,6 +45,24 @@ BUILD_ASSERT_DECL(TYPE_IS_SIGNED(time_t)); * much time will be wasted in signal handlers and calls to clock_gettime(). */ #define TIME_UPDATE_INTERVAL 100 +/* True on systems (particularly x86-64 Linux) where clock_gettime() is + * inexpensive. On these systems, we don't bother caching the current time. + * Instead, we consult clock_gettime() directly when needed. + * + * False on systems where clock_gettime() is relatively expensive. On these + * systems, we cache the current time and set up a periodic SIGALRM to remind + * us to update it. + * + * Also false on systems (e.g. ESX) that don't support setting up timers based + * on a monotonically increasing clock. */ +#ifndef CACHE_TIME +#if defined ESX || (defined __x86_64__ && defined LINUX_DATAPATH) +#define CACHE_TIME 0 +#else +#define CACHE_TIME 1 +#endif +#endif /* ifndef CACHE_TIME */ + void time_disable_restart(void); void time_enable_restart(void); void time_postfork(void); @@ -72,6 +76,7 @@ void time_wall_timespec(struct timespec *); void time_alarm(unsigned int secs); int time_poll(struct pollfd *, int n_pollfds, long long int timeout_when, int *elapsed); +bool time_cached(void); long long int timespec_to_msec(const struct timespec *); long long int timeval_to_msec(const struct timeval *); @@ -79,6 +84,7 @@ long long int timeval_to_msec(const struct timeval *); void xgettimeofday(struct timeval *); int get_cpu_usage(void); +void format_backtraces(struct ds *, size_t min_count); long long int time_boot_msec(void);