X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;ds=inline;f=lib%2Ftimeval.h;h=eff28e2296c3ea0688edb7c86d1f583abc187673;hb=f80022d9df98d29ee41176a4bc6cb91025da84b8;hp=1384848a1cec8f9b19087ce3c83413dd64e651a9;hpb=49635519bae2c14e44744825c907ccee9216bf90;p=sliver-openvswitch.git diff --git a/lib/timeval.h b/lib/timeval.h index 1384848a1..eff28e229 100644 --- a/lib/timeval.h +++ b/lib/timeval.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2009, 2010, 2011, 2012 Nicira, Inc. + * Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -25,6 +25,7 @@ extern "C" { #endif +struct ds; struct pollfd; struct timespec; struct timeval; @@ -36,31 +37,26 @@ 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) /* Interval between updates to the reported time, in ms. This should not be * adjusted much below 10 ms or so with the current implementation, or too * much time will be wasted in signal handlers and calls to clock_gettime(). */ -#define TIME_UPDATE_INTERVAL 100 +#define TIME_UPDATE_INTERVAL 25 + +/* True on systems that support a monotonic clock. Compared to just getting + * the value of a variable, clock_gettime() is somewhat expensive, even on + * systems that try hard to optimize it (such as x86-64 Linux), so it's + * worthwhile to minimize calls via caching. */ +#ifndef CACHE_TIME +#if defined ESX +#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); void time_refresh(void); time_t time_now(void); @@ -79,6 +75,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);