public inbox for pthreads-win32@sourceware.org
 help / color / mirror / Atom feed
* Win64 support, second take
@ 2007-01-26 13:47 Stefan Eilemann
  2007-01-27  1:45 ` Ross Johnson
  0 siblings, 1 reply; 5+ messages in thread
From: Stefan Eilemann @ 2007-01-26 13:47 UTC (permalink / raw)
  To: pthreads-win32; +Cc: kstreith

Keith, List,

I have seen your posting from March 2006 regarding Win64 support.
I am in the need of a Win64 port -- has anybody in the meantime
successfully build a libpthread on Win64, or is the code in more
or less the same state?


Cheers,

Stefan.
-- 
http://www.equalizergraphics.com
http://www.linkedin.com/in/eilemann



^ permalink raw reply	[flat|nested] 5+ messages in thread
* Re: Win64 support, second take
@ 2007-05-10  8:40 Romanchuk, Mike
  0 siblings, 0 replies; 5+ messages in thread
From: Romanchuk, Mike @ 2007-05-10  8:40 UTC (permalink / raw)
  To: pthreads-win32

> "2. Since you are using /WX, the tests fail as soon as Visual Studio
> outputs a warning, it currently outputs two different warnings, one is
> related to _ftime64 being deprecated, which I can suppress by
including
> /D_CRT_SECURE_NO_DEPRECATE in the CFLAGS variable. The other is more
> troublesome, there are about 20-30 places in the tests where you copy
a
> value of the _timeb structure into the timespec structure. The problem
> with that is in 64-bit mode, most of the values of the _timeb
structure
> are 64-bit integers (ie. __time64_t) and the timespec structure only
> holds 32-bit integers (ie. long) and Visual Studio issues a warning
> about truncating the numbers during the assignment. Any suggestions on
> what fix should be applied here?"
>
> The _timeb issue has not been properly resolved, although I'm guessing
> it is not a problem yet. AFAICS the structure elements still represent
> the same time components with the same epoch as the 32 bit version,
and
> no actual truncation is taking place. I'm assuming that 2038 is still
> the critical year for this. Please correct me if that understanding is
> wrong.

I think the way to solve this is by fixing the timespec to use a time_t
for the tv_sec member.  As far as I can tell, this is the correct way to
specify the timespec structure.  This should also solve the problem
because Microsoft has already made time_t 64-bit compatible.  The
following is from the MSDN Library:

"In Visual C++ 2005, time is a wrapper for _time64 and time_t is, by
default, equivalent to __time64_t. If you need to force the compiler to
interpret time_t as the old 32-bit time_t, you can define
_USE_32BIT_TIME_T. This is not recommended because your application may
fail after January 18, 2038; the use of this macro is not allowed on
64-bit platforms."

Mike.

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2007-04-26  4:23 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2007-01-26 13:47 Win64 support, second take Stefan Eilemann
2007-01-27  1:45 ` Ross Johnson
2007-01-29 13:49   ` Streithorst, Kip
2007-01-29 13:54   ` Stefan Eilemann
2007-05-10  8:40 Romanchuk, Mike

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).