GMP patch: MinGW/win64 port

Wesley W. Terpstra wesley at terpstra.ca
Tue Mar 4 16:04:49 CET 2008


On Sat, 2008-01-03 at 02:03 -0800, Myria wrote:
> http://msdn2.microsoft.com/en-us/library/ms794533.aspx
> 
> The ABI for Win64 is much more complicated than just the register allocation 
> scheme.

Yes; this is why I made no attempt to fix this. My interest was only in
getting gmp to a working state. It's performance was a very distant
secondary concern to me.

> Brian Gladman ported the x86-64 assembly code to Windows for Visual Studio, 
> but I don't remember whether he added the function markup.

I know nothing about any other ports of gmp to win64.

>   It is necessary to use 'malloc-reentrant' to forbid use of alloca,
>   which appears to be broken under win64.
> Is this something particular to GMP, or does alloca fail to work
> properly also for other programs?

alloca was broken under mingw/win64 in general. There have been posts to
the mingw-w64 mailing list purporting that this is fixed, but I have not
had time to check this.

>   make check succeeds except for the tests t-locale and t-printf.
>   t-locale fails to compile because it tries to replace an imported
>   function with a local copy of localeconv. Probably GMP shouldn't do
>   this.
> 
> Perhaps not.  I din't write that code, and will wait for contributions
> about how to handle this.
> 
>   t-printf fails because the win64 printf ignores the high 32 bits of
>   %llu.
> 
> Can the dos64 printf print 'long long' arguments at all?

It does support 64 bit pointers in printf. At the time I wrote that
patch the relevant headers were broken. They have since been fixed. To
printf a value that is possibly 64 bit, the following will work:

long long x = 34324;
printf("blah: %"PRIdMAX"\n", (uintmax_t)x);

AFAIK, this should be portable to all systems (including mingw/win64).

> I am troubled by your tests/amd64check.c change, since it
> unconditionally changes the constants to 'long long'.  Not all
> compilers might have that type.  Could you please try using the
> CNST_LIMB mechanism instead?

amd64check is only for amd64. What amd64 compiler does not have long
long? AFAIK, none. I doubt such a compiler will ever exist.




More information about the gmp-bugs mailing list