* hires.h: Fix copyright.
* times.cc: Ditto. localtime, gmtime). (FACTOR): Add comment. (NSPERSEC): Ditto. (JITTER): New definition. Comment. (systime_ns): Avoid gratuitous copying of the value returned by GetSystemTimeAsFileTime. (corelocaltime, localtime, gmtime): Remove very old, unused code block. (cygwin_tzset): Remove. (hires_ms::timeGetTime_ns): Add missing semicolon in comment. (hires_ms::nsecs): Redefine check for difference between internal timer value and system time.
This commit is contained in:
parent
af23d12d33
commit
d22bbac76c
@ -1,3 +1,19 @@
|
|||||||
|
2011-03-30 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
|
* hires.h: Fix copyright.
|
||||||
|
* times.cc: Ditto.
|
||||||
|
localtime, gmtime).
|
||||||
|
(FACTOR): Add comment.
|
||||||
|
(NSPERSEC): Ditto.
|
||||||
|
(JITTER): New definition. Comment.
|
||||||
|
(systime_ns): Avoid gratuitous copying of the value returned by
|
||||||
|
GetSystemTimeAsFileTime.
|
||||||
|
(corelocaltime, localtime, gmtime): Remove very old, unused code block.
|
||||||
|
(cygwin_tzset): Remove.
|
||||||
|
(hires_ms::timeGetTime_ns): Add missing semicolon in comment.
|
||||||
|
(hires_ms::nsecs): Redefine check for difference between internal
|
||||||
|
timer value and system time.
|
||||||
|
|
||||||
2011-03-30 Corinna Vinschen <corinna@vinschen.de>
|
2011-03-30 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
* times.cc (hires_ms::resolution): Make sure resolution is never 0.
|
* times.cc (hires_ms::resolution): Make sure resolution is never 0.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/* hires.h: Definitions for hires clock calculations
|
/* hires.h: Definitions for hires clock calculations
|
||||||
|
|
||||||
Copyright 2002, 2003, 2004, 2005, 2009, 2010 Red Hat, Inc.
|
Copyright 2002, 2003, 2004, 2005, 2009, 2010, 2011 Red Hat, Inc.
|
||||||
|
|
||||||
This file is part of Cygwin.
|
This file is part of Cygwin.
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/* times.cc
|
/* times.cc
|
||||||
|
|
||||||
Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
||||||
2005, 2006, 2007, 2008, 2009, 2010 Red Hat, Inc.
|
2005, 2006, 2007, 2008, 2009, 2010, 2011 Red Hat, Inc.
|
||||||
|
|
||||||
This file is part of Cygwin.
|
This file is part of Cygwin.
|
||||||
|
|
||||||
@ -25,8 +25,13 @@ details. */
|
|||||||
#include "cygtls.h"
|
#include "cygtls.h"
|
||||||
#include "ntdll.h"
|
#include "ntdll.h"
|
||||||
|
|
||||||
|
/* 100ns difference between WIndows and UNIX timebase. */
|
||||||
#define FACTOR (0x19db1ded53e8000LL)
|
#define FACTOR (0x19db1ded53e8000LL)
|
||||||
|
/* # of 100ns intervals per second. */
|
||||||
#define NSPERSEC 10000000LL
|
#define NSPERSEC 10000000LL
|
||||||
|
/* Max allowed diversion in 100ns of internal timer from system time. If
|
||||||
|
this difference is exceeded, the internal timer gets re-primed. */
|
||||||
|
#define JITTER (40 * 10000LL)
|
||||||
|
|
||||||
/* TODO: Putting this variable in the shared cygwin region partially solves
|
/* TODO: Putting this variable in the shared cygwin region partially solves
|
||||||
the problem of cygwin processes not recognizing date changes when other
|
the problem of cygwin processes not recognizing date changes when other
|
||||||
@ -42,10 +47,7 @@ static inline LONGLONG
|
|||||||
systime_ns ()
|
systime_ns ()
|
||||||
{
|
{
|
||||||
LARGE_INTEGER x;
|
LARGE_INTEGER x;
|
||||||
FILETIME ft;
|
GetSystemTimeAsFileTime ((LPFILETIME) &x);
|
||||||
GetSystemTimeAsFileTime (&ft);
|
|
||||||
x.HighPart = ft.dwHighDateTime;
|
|
||||||
x.LowPart = ft.dwLowDateTime;
|
|
||||||
x.QuadPart -= FACTOR; /* Add conversion factor for UNIX vs. Windows base time */
|
x.QuadPart -= FACTOR; /* Add conversion factor for UNIX vs. Windows base time */
|
||||||
return x.QuadPart;
|
return x.QuadPart;
|
||||||
}
|
}
|
||||||
@ -326,166 +328,6 @@ time (time_t * ptr)
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* localtime_r.c
|
|
||||||
* Original Author: Adapted from tzcode maintained by Arthur David Olson.
|
|
||||||
*
|
|
||||||
* Converts the calendar time pointed to by tim_p into a broken-down time
|
|
||||||
* expressed as local time. Returns a pointer to a structure containing the
|
|
||||||
* broken-down time.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define SECSPERMIN 60
|
|
||||||
#define MINSPERHOUR 60
|
|
||||||
#define HOURSPERDAY 24
|
|
||||||
#define SECSPERHOUR (SECSPERMIN * MINSPERHOUR)
|
|
||||||
#define SECSPERDAY (SECSPERHOUR * HOURSPERDAY)
|
|
||||||
#define DAYSPERWEEK 7
|
|
||||||
#define MONSPERYEAR 12
|
|
||||||
|
|
||||||
#define YEAR_BASE 1900
|
|
||||||
#define EPOCH_YEAR 1970
|
|
||||||
#define EPOCH_WDAY 4
|
|
||||||
|
|
||||||
#define isleap(y) ((((y) % 4) == 0 && ((y) % 100) != 0) || ((y) % 400) == 0)
|
|
||||||
|
|
||||||
#if 0 /* POSIX_LOCALTIME */
|
|
||||||
|
|
||||||
static _CONST int mon_lengths[2][MONSPERYEAR] = {
|
|
||||||
{31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},
|
|
||||||
{31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}
|
|
||||||
};
|
|
||||||
|
|
||||||
static _CONST int year_lengths[2] = {
|
|
||||||
365,
|
|
||||||
366
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Convert a time_t into a struct tm *.
|
|
||||||
* Does NO timezone conversion.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Cygwin internal */
|
|
||||||
static struct tm * __stdcall
|
|
||||||
corelocaltime (const time_t * tim_p)
|
|
||||||
{
|
|
||||||
long days, rem;
|
|
||||||
int y;
|
|
||||||
int yleap;
|
|
||||||
_CONST int *ip;
|
|
||||||
struct tm &localtime_buf=_my_tls.locals.localtime_buf;
|
|
||||||
|
|
||||||
time_t tim = *tim_p;
|
|
||||||
struct tm *res = &localtime_buf;
|
|
||||||
|
|
||||||
days = ((long) tim) / SECSPERDAY;
|
|
||||||
rem = ((long) tim) % SECSPERDAY;
|
|
||||||
|
|
||||||
while (rem < 0)
|
|
||||||
{
|
|
||||||
rem += SECSPERDAY;
|
|
||||||
--days;
|
|
||||||
}
|
|
||||||
while (rem >= SECSPERDAY)
|
|
||||||
{
|
|
||||||
rem -= SECSPERDAY;
|
|
||||||
++days;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* compute hour, min, and sec */
|
|
||||||
res->tm_hour = (int) (rem / SECSPERHOUR);
|
|
||||||
rem %= SECSPERHOUR;
|
|
||||||
res->tm_min = (int) (rem / SECSPERMIN);
|
|
||||||
res->tm_sec = (int) (rem % SECSPERMIN);
|
|
||||||
|
|
||||||
/* compute day of week */
|
|
||||||
if ((res->tm_wday = ((EPOCH_WDAY + days) % DAYSPERWEEK)) < 0)
|
|
||||||
res->tm_wday += DAYSPERWEEK;
|
|
||||||
|
|
||||||
/* compute year & day of year */
|
|
||||||
y = EPOCH_YEAR;
|
|
||||||
if (days >= 0)
|
|
||||||
{
|
|
||||||
for (;;)
|
|
||||||
{
|
|
||||||
yleap = isleap (y);
|
|
||||||
if (days < year_lengths[yleap])
|
|
||||||
break;
|
|
||||||
y++;
|
|
||||||
days -= year_lengths[yleap];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
do
|
|
||||||
{
|
|
||||||
--y;
|
|
||||||
yleap = isleap (y);
|
|
||||||
days += year_lengths[yleap];
|
|
||||||
} while (days < 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
res->tm_year = y - YEAR_BASE;
|
|
||||||
res->tm_yday = days;
|
|
||||||
ip = mon_lengths[yleap];
|
|
||||||
for (res->tm_mon = 0; days >= ip[res->tm_mon]; ++res->tm_mon)
|
|
||||||
days -= ip[res->tm_mon];
|
|
||||||
res->tm_mday = days + 1;
|
|
||||||
|
|
||||||
/* set daylight saving time flag */
|
|
||||||
res->tm_isdst = -1;
|
|
||||||
|
|
||||||
syscall_printf ("%d = corelocaltime (%x)", res, tim_p);
|
|
||||||
|
|
||||||
return (res);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* localtime: POSIX 8.1.1, C 4.12.3.4 */
|
|
||||||
/*
|
|
||||||
* localtime takes a time_t (which is in UTC)
|
|
||||||
* and formats it into a struct tm as a local time.
|
|
||||||
*/
|
|
||||||
extern "C" struct tm *
|
|
||||||
localtime (const time_t *tim_p)
|
|
||||||
{
|
|
||||||
time_t tim = *tim_p;
|
|
||||||
struct tm *rtm;
|
|
||||||
|
|
||||||
tzset ();
|
|
||||||
|
|
||||||
tim -= _timezone;
|
|
||||||
|
|
||||||
rtm = corelocaltime (&tim);
|
|
||||||
|
|
||||||
rtm->tm_isdst = _daylight;
|
|
||||||
|
|
||||||
syscall_printf ("%x = localtime (%x)", rtm, tim_p);
|
|
||||||
|
|
||||||
return rtm;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* gmtime: C 4.12.3.3 */
|
|
||||||
/*
|
|
||||||
* gmtime takes a time_t (which is already in UTC)
|
|
||||||
* and just puts it into a struct tm.
|
|
||||||
*/
|
|
||||||
extern "C" struct tm *
|
|
||||||
gmtime (const time_t *tim_p)
|
|
||||||
{
|
|
||||||
time_t tim = *tim_p;
|
|
||||||
|
|
||||||
struct tm *rtm = corelocaltime (&tim);
|
|
||||||
/* UTC has no daylight savings time */
|
|
||||||
rtm->tm_isdst = 0;
|
|
||||||
|
|
||||||
syscall_printf ("%x = gmtime (%x)", rtm, tim_p);
|
|
||||||
|
|
||||||
return rtm;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* POSIX_LOCALTIME */
|
|
||||||
|
|
||||||
int
|
int
|
||||||
utimens_worker (path_conv &win32, const struct timespec *tvp)
|
utimens_worker (path_conv &win32, const struct timespec *tvp)
|
||||||
{
|
{
|
||||||
@ -611,12 +453,6 @@ ftime (struct timeb *tp)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* obsolete, changed to cygwin_tzset when localtime.c was added - dj */
|
|
||||||
extern "C" void
|
|
||||||
cygwin_tzset ()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
#define stupid_printf if (cygwin_finished_initializing) debug_printf
|
#define stupid_printf if (cygwin_finished_initializing) debug_printf
|
||||||
void
|
void
|
||||||
hires_ns::prime ()
|
hires_ns::prime ()
|
||||||
@ -684,7 +520,7 @@ hires_ms::timeGetTime_ns ()
|
|||||||
LARGE_INTEGER int_time_start;
|
LARGE_INTEGER int_time_start;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
tick_count_start = GetTickCount ()
|
tick_count_start = GetTickCount ();
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
int_time_start.HighPart = SharedUserData.InterruptTime.High1Time;
|
int_time_start.HighPart = SharedUserData.InterruptTime.High1Time;
|
||||||
@ -735,7 +571,7 @@ hires_ms::nsecs ()
|
|||||||
|
|
||||||
LONGLONG t = systime_ns ();
|
LONGLONG t = systime_ns ();
|
||||||
LONGLONG res = initime_ns + timeGetTime_ns ();
|
LONGLONG res = initime_ns + timeGetTime_ns ();
|
||||||
if (res < (t - 40 * 10000LL))
|
if (llabs (res - t) > JITTER)
|
||||||
{
|
{
|
||||||
inited = false;
|
inited = false;
|
||||||
prime ();
|
prime ();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user