summaryrefslogtreecommitdiffstats
path: root/winsup/cygwin/hires.h
diff options
context:
space:
mode:
Diffstat (limited to 'winsup/cygwin/hires.h')
-rw-r--r--winsup/cygwin/hires.h18
1 files changed, 15 insertions, 3 deletions
diff --git a/winsup/cygwin/hires.h b/winsup/cygwin/hires.h
index b4599cb1b..df4c44c4a 100644
--- a/winsup/cygwin/hires.h
+++ b/winsup/cygwin/hires.h
@@ -13,11 +13,18 @@ details. */
#include <mmsystem.h>
+/* Largest delay in ms for sleep and alarm calls.
+ Allow actual delay to exceed requested delay by 10 s.
+ Express as multiple of 1000 (i.e. seconds) + max resolution
+ The tv_sec argument in timeval structures cannot exceed
+ HIRES_DELAY_MAX / 1000 - 1, so that adding fractional part
+ and rounding won't exceed HIRES_DELAY_MAX */
+#define HIRES_DELAY_MAX (((UINT_MAX - 10000) / 1000) * 1000) + 10
+
class hires_base
{
protected:
int inited;
- virtual void prime () {}
public:
virtual LONGLONG usecs (bool justdelta) {return 0LL;}
virtual ~hires_base () {}
@@ -37,9 +44,14 @@ class hires_ms : hires_base
{
DWORD initime_ms;
LARGE_INTEGER initime_us;
- UINT minperiod;
- void prime ();
+ static UINT minperiod;
+ UINT prime ();
public:
LONGLONG usecs (bool justdelta);
+ UINT dmsecs () { return timeGetTime (); }
+ UINT resolution () { return minperiod ?: prime (); }
+
};
+
+extern hires_ms gtod;
#endif /*__HIRES_H__*/