Merge pull request #56 from tkelman/ldexp

Export ldexp aliases on Windows
This commit is contained in:
Jeff Bezanson 2014-05-11 19:07:38 -04:00
commit 1f3925b3c1
4 changed files with 22 additions and 10 deletions

View file

@ -41,10 +41,14 @@ ENTRY(scalbn)
fstpl -8(%rsp) fstpl -8(%rsp)
movsd -8(%rsp),%xmm0 movsd -8(%rsp),%xmm0
ret ret
#ifndef _WIN64
END(scalbn) END(scalbn)
.globl CNAME(ldexp) .globl CNAME(ldexp)
#else
.globl CNAME(ldexp); .section .drectve; .ascii " -export:ldexp"
#endif
.set CNAME(ldexp),CNAME(scalbn) .set CNAME(ldexp),CNAME(scalbn)
/* Enable stack protection */ /* Enable stack protection */
#if defined(__linux__) && defined(__ELF__) #if defined(__linux__) && defined(__ELF__)
.section .note.GNU-stack,"",%progbits .section .note.GNU-stack,"",%progbits

View file

@ -41,12 +41,14 @@ ENTRY(scalbnf)
fstps -8(%rsp) fstps -8(%rsp)
movss -8(%rsp),%xmm0 movss -8(%rsp),%xmm0
ret ret
#ifndef _WIN64
END(scalbnf) END(scalbnf)
.globl CNAME(ldexpf) .globl CNAME(ldexpf)
#else
.globl CNAME(ldexpf); .section .drectve; .ascii " -export:ldexpf"
#endif
.set CNAME(ldexpf),CNAME(scalbnf) .set CNAME(ldexpf),CNAME(scalbnf)
/* Enable stack protection */ /* Enable stack protection */
#if defined(__linux__) && defined(__ELF__) #if defined(__linux__) && defined(__ELF__)
.section .note.GNU-stack,"",%progbits .section .note.GNU-stack,"",%progbits

View file

@ -26,12 +26,14 @@ ENTRY(scalbnl)
fstpt (%rcx) fstpt (%rcx)
#endif #endif
ret ret
#ifndef _WIN64
END(scalbnl) END(scalbnl)
.globl CNAME(ldexpl) .globl CNAME(ldexpl)
#else
.globl CNAME(ldexpl); .section .drectve; .ascii " -export:ldexpl"
#endif
.set CNAME(ldexpl),CNAME(scalbnl) .set CNAME(ldexpl),CNAME(scalbnl)
/* Enable stack protection */ /* Enable stack protection */
#if defined(__linux__) && defined(__ELF__) #if defined(__linux__) && defined(__ELF__)
.section .note.GNU-stack,"",%progbits .section .note.GNU-stack,"",%progbits

View file

@ -22,8 +22,12 @@
#ifdef __GNUC__ #ifdef __GNUC__
#ifndef __strong_reference #ifndef __strong_reference
#define __strong_reference(sym,aliassym) #ifdef __APPLE__
//extern __typeof (sym) aliassym __attribute__ ((__alias__ (#sym))); #define __strong_reference(sym,aliassym) __weak_reference(sym,aliassym)
#else
#define __strong_reference(sym,aliassym) \
DLLEXPORT extern __typeof (sym) aliassym __attribute__ ((__alias__ (#sym)));
#endif /* __APPLE__ */
#endif /* __strong_reference */ #endif /* __strong_reference */
#ifndef __weak_reference #ifndef __weak_reference