diff options
author | Stephen Hines <srhines@google.com> | 2014-04-25 15:48:06 -0700 |
---|---|---|
committer | Stephen Hines <srhines@google.com> | 2014-04-25 15:48:06 -0700 |
commit | 9bb490cbb1b3919481ff8e76dd66a02e8117e2ea (patch) | |
tree | 50f1811094d38d078cd5cbb8887a3316a34f2d6d /renderscript/clang-include | |
parent | 176c9825198c5ad76ac25cdf631db567cf13dde9 (diff) | |
parent | f303208f4d911bfa5c6825569a1747a63be467a0 (diff) | |
download | prebuilts_sdk-9bb490cbb1b3919481ff8e76dd66a02e8117e2ea.zip prebuilts_sdk-9bb490cbb1b3919481ff8e76dd66a02e8117e2ea.tar.gz prebuilts_sdk-9bb490cbb1b3919481ff8e76dd66a02e8117e2ea.tar.bz2 |
resolved conflicts for merge of f303208f to master
Diffstat (limited to 'renderscript/clang-include')
-rw-r--r-- | renderscript/clang-include/Intrin.h | 267 | ||||
-rw-r--r-- | renderscript/clang-include/cpuid.h | 1 | ||||
-rw-r--r-- | renderscript/clang-include/float.h | 2 | ||||
-rw-r--r-- | renderscript/clang-include/ia32intrin.h | 92 | ||||
-rw-r--r-- | renderscript/clang-include/immintrin.h | 2 | ||||
-rw-r--r-- | renderscript/clang-include/limits.h | 5 | ||||
-rw-r--r-- | renderscript/clang-include/stdarg.h | 2 | ||||
-rw-r--r-- | renderscript/clang-include/stddef.h | 14 | ||||
-rw-r--r-- | renderscript/clang-include/stdint.h | 3 | ||||
-rw-r--r-- | renderscript/clang-include/x86intrin.h | 2 | ||||
-rw-r--r-- | renderscript/clang-include/xmmintrin.h | 2 |
11 files changed, 353 insertions, 39 deletions
diff --git a/renderscript/clang-include/Intrin.h b/renderscript/clang-include/Intrin.h index 4376464..e365abe 100644 --- a/renderscript/clang-include/Intrin.h +++ b/renderscript/clang-include/Intrin.h @@ -32,6 +32,9 @@ /* First include the standard intrinsics. */ #include <x86intrin.h> +/* For the definition of jmp_buf. */ +#include <setjmp.h> + #ifdef __cplusplus extern "C" { #endif @@ -48,13 +51,16 @@ void __addfsbyte(unsigned long, unsigned char); void __addfsdword(unsigned long, unsigned long); void __addfsword(unsigned long, unsigned short); void __code_seg(const char *); +static __inline__ void __cpuid(int[4], int); +static __inline__ void __cpuidex(int[4], int, int); void __debugbreak(void); __int64 __emul(int, int); unsigned __int64 __emulu(unsigned int, unsigned int); void __cdecl __fastfail(unsigned int); unsigned int __getcallerseflags(void); +static __inline__ void __halt(void); unsigned char __inbyte(unsigned short); void __inbytestring(unsigned short, unsigned char *, unsigned long); @@ -75,8 +81,11 @@ unsigned char __lwpins32(unsigned int, unsigned int, unsigned int); void __lwpval32(unsigned int, unsigned int, unsigned int); unsigned int __lzcnt(unsigned int); unsigned short __lzcnt16(unsigned short); +static __inline__ void __movsb(unsigned char *, unsigned char const *, size_t); +static __inline__ void __movsd(unsigned long *, unsigned long const *, size_t); +static __inline__ void __movsw(unsigned short *, unsigned short const *, size_t); void __nop(void); void __nvreg_restore_fence(void); @@ -91,26 +100,35 @@ static __inline__ unsigned int __popcnt(unsigned int); static __inline__ unsigned short __popcnt16(unsigned short); +static __inline__ unsigned __int64 __rdtsc(void); unsigned __int64 __rdtscp(unsigned int *); unsigned long __readcr0(void); unsigned long __readcr2(void); unsigned long __readcr3(void); -unsigned long __readcr5(void); +unsigned long __readcr4(void); unsigned long __readcr8(void); unsigned int __readdr(unsigned int); -unsigned int __readeflags(void); +#ifdef __i386__ +static __inline__ unsigned char __readfsbyte(unsigned long); +static __inline__ unsigned long __readfsdword(unsigned long); +static __inline__ unsigned __int64 __readfsqword(unsigned long); +static __inline__ unsigned short __readfsword(unsigned long); +#endif unsigned __int64 __readmsr(unsigned long); unsigned __int64 __readpmc(unsigned long); unsigned long __segmentlimit(unsigned long); void __sidt(void *); void *__slwpcb(void); +static __inline__ void __stosb(unsigned char *, unsigned char, size_t); +static __inline__ void __stosd(unsigned long *, unsigned long, size_t); +static __inline__ void __stosw(unsigned short *, unsigned short, size_t); void __svm_clgi(void); void __svm_invlpga(void *, int); @@ -129,7 +147,6 @@ void __writecr3(unsigned int); void __writecr4(unsigned int); void __writecr8(unsigned int); void __writedr(unsigned int, unsigned int); -void __writeeflags(unsigned int); void __writefsbyte(unsigned long, unsigned char); void __writefsdword(unsigned long, unsigned long); void __writefsqword(unsigned long, unsigned __int64); @@ -139,7 +156,6 @@ static __inline__ void *_AddressOfReturnAddress(void); unsigned int _andn_u32(unsigned int, unsigned int); unsigned int _bextr_u32(unsigned int, unsigned int, unsigned int); -unsigned int _bextr_u32(unsigned int, unsigned int, unsigned int); unsigned int _bextri_u32(unsigned int, unsigned int); static __inline__ unsigned char _BitScanForward(unsigned long *_Index, unsigned long _Mask); @@ -162,8 +178,6 @@ unsigned int _blsfill_u32(unsigned int); unsigned int _blsi_u32(unsigned int); unsigned int _blsic_u32(unsigned int); unsigned int _blsmsk_u32(unsigned int); -unsigned int _blsmsk_u32(unsigned int); -unsigned int _blsr_u32(unsigned int); unsigned int _blsr_u32(unsigned int); unsigned __int64 __cdecl _byteswap_uint64(unsigned __int64); unsigned long __cdecl _byteswap_ulong(unsigned long); @@ -181,6 +195,7 @@ short _InterlockedAnd16(short volatile *_Value, short _Mask); static __inline__ char _InterlockedAnd8(char volatile *_Value, char _Mask); unsigned char _interlockedbittestandreset(long volatile *, long); +static __inline__ unsigned char _interlockedbittestandset(long volatile *, long); static __inline__ long __cdecl _InterlockedCompareExchange(long volatile *_Destination, @@ -219,6 +234,10 @@ long __cdecl _InterlockedExchangeAdd(long volatile *_Addend, long _Value); long _InterlockedExchangeAdd_HLEAcquire(long volatile *, long); long _InterlockedExchangeAdd_HLERelease(long volatile *, long); static __inline__ +short _InterlockedExchangeAdd16(short volatile *_Addend, short _Value); +__int64 _InterlockedExchangeAdd64_HLEAcquire(__int64 volatile *, __int64); +__int64 _InterlockedExchangeAdd64_HLERelease(__int64 volatile *, __int64); +static __inline__ char _InterlockedExchangeAdd8(char volatile *_Addend, char _Value); static __inline__ long __cdecl _InterlockedIncrement(long volatile *_Addend); @@ -269,10 +288,7 @@ unsigned __int64 __cdecl _rotr64(unsigned __int64 _Value, int _Shift); static __inline__ unsigned char _rotr8(unsigned char _Value, unsigned char _Shift); int _sarx_i32(int, unsigned int); - -/* FIXME: Need definition for jmp_buf. - int __cdecl _setjmp(jmp_buf); */ - +int __cdecl _setjmp(jmp_buf); unsigned int _shlx_u32(unsigned int, unsigned int); unsigned int _shrx_u32(unsigned int, unsigned int); void _Store_HLERelease(long volatile *, long); @@ -280,13 +296,13 @@ void _Store64_HLERelease(__int64 volatile *, __int64); void _StorePointer_HLERelease(void *volatile *, void *); unsigned int _t1mskc_u32(unsigned int); unsigned int _tzcnt_u32(unsigned int); -unsigned int _tzcnt_u32(unsigned int); unsigned int _tzmsk_u32(unsigned int); static __inline__ void _WriteBarrier(void); void _xabort(const unsigned int imm); unsigned __int32 xbegin(void); void _xend(void); +static __inline__ unsigned __int64 __cdecl _xgetbv(unsigned int); void __cdecl _xrstor(void const *, unsigned __int64); void __cdecl _xsave(void *, unsigned __int64); @@ -300,19 +316,47 @@ void __addgsbyte(unsigned long, unsigned char); void __addgsdword(unsigned long, unsigned long); void __addgsqword(unsigned long, unsigned __int64); void __addgsword(unsigned long, unsigned short); +static __inline__ void __faststorefence(void); void __incgsbyte(unsigned long); void __incgsdword(unsigned long); void __incgsqword(unsigned long); void __incgsword(unsigned long); +unsigned char __lwpins64(unsigned __int64, unsigned int, unsigned int); +void __lwpval64(unsigned __int64, unsigned int, unsigned int); +unsigned __int64 __lzcnt64(unsigned __int64); +static __inline__ +void __movsq(unsigned long long *, unsigned long long const *, size_t); +__int64 __mulh(__int64, __int64); +static __inline__ unsigned __int64 __popcnt64(unsigned __int64); +static __inline__ +unsigned char __readgsbyte(unsigned long); +static __inline__ +unsigned long __readgsdword(unsigned long); +static __inline__ +unsigned __int64 __readgsqword(unsigned long); +unsigned short __readgsword(unsigned long); unsigned __int64 __shiftleft128(unsigned __int64 _LowPart, unsigned __int64 _HighPart, unsigned char _Shift); unsigned __int64 __shiftright128(unsigned __int64 _LowPart, unsigned __int64 _HighPart, unsigned char _Shift); +static __inline__ void __stosq(unsigned __int64 *, unsigned __int64, size_t); +unsigned __int64 __umulh(unsigned __int64, unsigned __int64); +unsigned char __vmx_on(unsigned __int64 *); +unsigned char __vmx_vmclear(unsigned __int64 *); +unsigned char __vmx_vmlaunch(void); +unsigned char __vmx_vmptrld(unsigned __int64 *); +unsigned char __vmx_vmread(size_t, size_t *); +unsigned char __vmx_vmresume(void); +unsigned char __vmx_vmwrite(size_t, size_t); +void __writegsbyte(unsigned long, unsigned char); +void __writegsdword(unsigned long, unsigned long); +void __writegsqword(unsigned long, unsigned __int64); +void __writegsword(unsigned long, unsigned short); unsigned __int64 _andn_u64(unsigned __int64, unsigned __int64); unsigned __int64 _bextr_u64(unsigned __int64, unsigned int, unsigned int); unsigned __int64 _bextri_u64(unsigned __int64, unsigned int); @@ -336,7 +380,7 @@ unsigned __int64 _blcs_u64(unsigned __int64); unsigned __int64 _blsfill_u64(unsigned __int64); unsigned __int64 _blsi_u64(unsigned __int64); unsigned __int64 _blsic_u64(unsigned __int64); -unsigned __int64 _blmsk_u64(unsigned __int64); +unsigned __int64 _blsmsk_u64(unsigned __int64); unsigned __int64 _blsr_u64(unsigned __int64); unsigned __int64 __cdecl _byteswap_uint64(unsigned __int64); unsigned __int64 _bzhi_u64(unsigned __int64, unsigned int); @@ -347,6 +391,7 @@ short _InterlockedAnd16_np(short volatile *_Value, short _Mask); __int64 _InterlockedAnd64_np(__int64 volatile *_Value, __int64 _Mask); char _InterlockedAnd8_np(char volatile *_Value, char _Mask); unsigned char _interlockedbittestandreset64(__int64 volatile *, __int64); +static __inline__ unsigned char _interlockedbittestandset64(__int64 volatile *, __int64); long _InterlockedCompareExchange_np(long volatile *_Destination, long _Exchange, long _Comparand); @@ -360,18 +405,40 @@ unsigned char _InterlockedCompareExchange128_np(__int64 volatile *_Destination, __int64 *_ComparandResult); short _InterlockedCompareExchange16_np(short volatile *_Destination, short _Exchange, short _Comparand); +__int64 _InterlockedCompareExchange64_HLEAcquire(__int64 volatile *, __int64, + __int64); +__int64 _InterlockedCompareExchange64_HLERelease(__int64 volatile *, __int64, + __int64); __int64 _InterlockedCompareExchange64_np(__int64 volatile *_Destination, __int64 _Exchange, __int64 _Comparand); +static __inline__ +void *_InterlockedCompareExchangePointer(void *volatile *_Destination, + void *_Exchange, void *_Comparand); void *_InterlockedCompareExchangePointer_np(void *volatile *_Destination, void *_Exchange, void *_Comparand); +static __inline__ +__int64 _InterlockedDecrement64(__int64 volatile *_Addend); +static __inline__ +__int64 _InterlockedExchange64(__int64 volatile *_Target, __int64 _Value); +static __inline__ +__int64 _InterlockedExchangeAdd64(__int64 volatile *_Addend, __int64 _Value); +static __inline__ +void *_InterlockedExchangePointer(void *volatile *_Target, void *_Value); +static __inline__ +__int64 _InterlockedIncrement64(__int64 volatile *_Addend); long _InterlockedOr_np(long volatile *_Value, long _Mask); short _InterlockedOr16_np(short volatile *_Value, short _Mask); +static __inline__ +__int64 _InterlockedOr64(__int64 volatile *_Value, __int64 _Mask); __int64 _InterlockedOr64_np(__int64 volatile *_Value, __int64 _Mask); char _InterlockedOr8_np(char volatile *_Value, char _Mask); long _InterlockedXor_np(long volatile *_Value, long _Mask); short _InterlockedXor16_np(short volatile *_Value, short _Mask); +static __inline__ +__int64 _InterlockedXor64(__int64 volatile *_Value, __int64 _Mask); __int64 _InterlockedXor64_np(__int64 volatile *_Value, __int64 _Mask); char _InterlockedXor8_np(char volatile *_Value, char _Mask); +static __inline__ unsigned __int64 _lzcnt_u64(unsigned __int64); __int64 _mul128(__int64 _Multiplier, __int64 _Multiplicand, __int64 *_HighProduct); @@ -380,6 +447,11 @@ unsigned __int64 __cdecl _readfsbase_u64(void); unsigned int __cdecl _readgsbase_u32(void); unsigned __int64 __cdecl _readgsbase_u64(void); unsigned __int64 _rorx_u64(unsigned __int64, const unsigned int); +__int64 _sarx_i64(__int64, unsigned int); +/* FIXME: Need definition for jmp_buf. + int __cdecl _setjmpex(jmp_buf); */ +unsigned __int64 _shlx_u64(unsigned __int64, unsigned int); +unsigned __int64 shrx_u64(unsigned __int64, unsigned int); unsigned __int64 _tzcnt_u64(unsigned __int64); unsigned __int64 _tzmsk_u64(unsigned __int64); unsigned __int64 _umul128(unsigned __int64 _Multiplier, @@ -503,6 +575,16 @@ _bittestandset(long *a, long b) { *a = *a | (1 << b); return x; } +static __inline__ unsigned char __attribute__((__always_inline__, __nodebug__)) +_interlockedbittestandset(long volatile *__BitBase, long __BitPos) { + unsigned char __Res; + __asm__ ("xor %0, %0\n" + "lock bts %2, %1\n" + "setc %0\n" + : "=r" (__Res), "+m"(*__BitBase) + : "Ir"(__BitPos)); + return __Res; +} #ifdef __x86_64__ static __inline__ unsigned char __attribute__((__always_inline__, __nodebug__)) _BitScanForward64(unsigned long *_Index, unsigned __int64 _Mask) { @@ -552,6 +634,16 @@ _bittestandset64(__int64 *a, __int64 b) { *a = *a | (1ll << b); return x; } +static __inline__ unsigned char __attribute__((__always_inline__, __nodebug__)) +_interlockedbittestandset64(__int64 volatile *__BitBase, __int64 __BitPos) { + unsigned char __Res; + __asm__ ("xor %0, %0\n" + "lock bts %2, %1\n" + "setc %0\n" + : "=r" (__Res), "+m"(*__BitBase) + : "Ir"(__BitPos)); + return __Res; +} #endif /*----------------------------------------------------------------------------*\ |* Interlocked Exchange Add @@ -564,10 +656,6 @@ static __inline__ short __attribute__((__always_inline__, __nodebug__)) _InterlockedExchangeAdd16(short volatile *_Addend, short _Value) { return __atomic_add_fetch(_Addend, _Value, 0) - _Value; } -static __inline__ long __attribute__((__always_inline__, __nodebug__)) -_InterlockedExchangeAdd(long volatile *_Addend, long _Value) { - return __atomic_add_fetch(_Addend, _Value, 0) - _Value; -} #ifdef __x86_64__ static __inline__ __int64 __attribute__((__always_inline__, __nodebug__)) _InterlockedExchangeAdd64(__int64 volatile *_Addend, __int64 _Value) { @@ -598,12 +686,8 @@ _InterlockedExchangeSub64(__int64 volatile *_Subend, __int64 _Value) { /*----------------------------------------------------------------------------*\ |* Interlocked Increment \*----------------------------------------------------------------------------*/ -static __inline__ char __attribute__((__always_inline__, __nodebug__)) -_InterlockedIncrement16(char volatile *_Value) { - return __atomic_add_fetch(_Value, 1, 0); -} -static __inline__ long __attribute__((__always_inline__, __nodebug__)) -_InterlockedIncrement(long volatile *_Value) { +static __inline__ short __attribute__((__always_inline__, __nodebug__)) +_InterlockedIncrement16(short volatile *_Value) { return __atomic_add_fetch(_Value, 1, 0); } #ifdef __x86_64__ @@ -615,12 +699,8 @@ _InterlockedIncrement64(__int64 volatile *_Value) { /*----------------------------------------------------------------------------*\ |* Interlocked Decrement \*----------------------------------------------------------------------------*/ -static __inline__ char __attribute__((__always_inline__, __nodebug__)) -_InterlockedDecrement16(char volatile *_Value) { - return __atomic_sub_fetch(_Value, 1, 0); -} -static __inline__ long __attribute__((__always_inline__, __nodebug__)) -_InterlockedDecrement(long volatile *_Value) { +static __inline__ short __attribute__((__always_inline__, __nodebug__)) +_InterlockedDecrement16(short volatile *_Value) { return __atomic_sub_fetch(_Value, 1, 0); } #ifdef __x86_64__ @@ -716,6 +796,11 @@ _InterlockedExchange64(__int64 volatile *_Target, __int64 _Value) { __atomic_exchange(_Target, &_Value, &_Value, 0); return _Value; } +static __inline__ void *__attribute__((__always_inline__, __nodebug__)) +_InterlockedExchangePointer(void *volatile *_Target, void *_Value) { + __atomic_exchange(_Target, &_Value, &_Value, 0); + return _Value; +} #endif /*----------------------------------------------------------------------------*\ |* Interlocked Compare Exchange @@ -732,12 +817,14 @@ _InterlockedCompareExchange16(short volatile *_Destination, __atomic_compare_exchange(_Destination, &_Comparand, &_Exchange, 0, 0, 0); return _Comparand; } -static __inline__ long __attribute__((__always_inline__, __nodebug__)) -_InterlockedCompareExchange(long volatile *_Destination, - long _Exchange, long _Comparand) { +#ifdef __x86_64__ +static __inline__ void *__attribute__((__always_inline__, __nodebug__)) +_InterlockedCompareExchangePointer(void *volatile *_Destination, + void *_Exchange, void *_Comparand) { __atomic_compare_exchange(_Destination, &_Comparand, &_Exchange, 0, 0, 0); return _Comparand; } +#endif #ifdef __x86_64__ static __inline__ __int64 __attribute__((__always_inline__, __nodebug__)) _InterlockedCompareExchange64(__int64 volatile *_Destination, @@ -764,6 +851,104 @@ __attribute__((deprecated("use other intrinsics or C++11 atomics instead"))) _WriteBarrier(void) { __asm__ volatile ("" : : : "memory"); } +#ifdef __x86_64__ +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__faststorefence(void) { + __asm__ volatile("lock orq $0, (%%rsp)" : : : "memory"); +} +#endif +/*----------------------------------------------------------------------------*\ +|* readfs, readgs +|* (Pointers in address space #256 and #257 are relative to the GS and FS +|* segment registers, respectively.) +\*----------------------------------------------------------------------------*/ +#define __ptr_to_addr_space(__addr_space_nbr, __type, __offset) \ + ((volatile __type __attribute__((__address_space__(__addr_space_nbr)))*) \ + (__offset)) + +#ifdef __i386__ +static __inline__ unsigned char __attribute__((__always_inline__, __nodebug__)) +__readfsbyte(unsigned long __offset) { + return *__ptr_to_addr_space(257, unsigned char, __offset); +} +static __inline__ unsigned long __attribute__((__always_inline__, __nodebug__)) +__readfsdword(unsigned long __offset) { + return *__ptr_to_addr_space(257, unsigned long, __offset); +} +static __inline__ unsigned __int64 __attribute__((__always_inline__, __nodebug__)) +__readfsqword(unsigned long __offset) { + return *__ptr_to_addr_space(257, unsigned __int64, __offset); +} +static __inline__ unsigned short __attribute__((__always_inline__, __nodebug__)) +__readfsword(unsigned long __offset) { + return *__ptr_to_addr_space(257, unsigned short, __offset); +} +#endif +#ifdef __x86_64__ +static __inline__ unsigned char __attribute__((__always_inline__, __nodebug__)) +__readgsbyte(unsigned long __offset) { + return *__ptr_to_addr_space(256, unsigned char, __offset); +} +static __inline__ unsigned long __attribute__((__always_inline__, __nodebug__)) +__readgsdword(unsigned long __offset) { + return *__ptr_to_addr_space(256, unsigned long, __offset); +} +static __inline__ unsigned __int64 __attribute__((__always_inline__, __nodebug__)) +__readgsqword(unsigned long __offset) { + return *__ptr_to_addr_space(256, unsigned __int64, __offset); +} +static __inline__ unsigned short __attribute__((__always_inline__, __nodebug__)) +__readgsword(unsigned long __offset) { + return *__ptr_to_addr_space(256, unsigned short, __offset); +} +#endif +#undef __ptr_to_addr_space +/*----------------------------------------------------------------------------*\ +|* movs, stos +\*----------------------------------------------------------------------------*/ +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__movsb(unsigned char *__dst, unsigned char const *__src, size_t __n) { + __asm__("rep movsb" : : "D"(__dst), "S"(__src), "c"(__n) + : "%edi", "%esi", "%ecx"); +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__movsd(unsigned long *__dst, unsigned long const *__src, size_t __n) { + __asm__("rep movsl" : : "D"(__dst), "S"(__src), "c"(__n) + : "%edi", "%esi", "%ecx"); +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__movsw(unsigned short *__dst, unsigned short const *__src, size_t __n) { + __asm__("rep movsh" : : "D"(__dst), "S"(__src), "c"(__n) + : "%edi", "%esi", "%ecx"); +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__stosb(unsigned char *__dst, unsigned char __x, size_t __n) { + __asm__("rep stosb" : : "D"(__dst), "a"(__x), "c"(__n) + : "%edi", "%ecx"); +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__stosd(unsigned long *__dst, unsigned long __x, size_t __n) { + __asm__("rep stosl" : : "D"(__dst), "a"(__x), "c"(__n) + : "%edi", "%ecx"); +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__stosw(unsigned short *__dst, unsigned short __x, size_t __n) { + __asm__("rep stosh" : : "D"(__dst), "a"(__x), "c"(__n) + : "%edi", "%ecx"); +} +#ifdef __x86_64__ +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__movsq(unsigned long long *__dst, unsigned long long const *__src, size_t __n) { + __asm__("rep movsq" : : "D"(__dst), "S"(__src), "c"(__n) + : "%edi", "%esi", "%ecx"); +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__stosq(unsigned __int64 *__dst, unsigned __int64 __x, size_t __n) { + __asm__("rep stosq" : : "D"(__dst), "a"(__x), "c"(__n) + : "%edi", "%ecx"); +} +#endif + /*----------------------------------------------------------------------------*\ |* Misc \*----------------------------------------------------------------------------*/ @@ -775,6 +960,26 @@ static __inline__ void * __attribute__((__always_inline__, __nodebug__)) _ReturnAddress(void) { return __builtin_return_address(0); } +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__cpuid(int __info[4], int __level) { + __asm__ ("cpuid" : "=a"(__info[0]), "=b" (__info[1]), "=c"(__info[2]), "=d"(__info[3]) + : "a"(__level)); +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__cpuidex(int __info[4], int __level, int __ecx) { + __asm__ ("cpuid" : "=a"(__info[0]), "=b" (__info[1]), "=c"(__info[2]), "=d"(__info[3]) + : "a"(__level), "c"(__ecx)); +} +static __inline__ unsigned __int64 __cdecl __attribute__((__always_inline__, __nodebug__)) +_xgetbv(unsigned int __xcr_no) { + unsigned int __eax, __edx; + __asm__ ("xgetbv" : "=a" (__eax), "=d" (__edx) : "c" (__xcr_no)); + return ((unsigned __int64)__edx << 32) | __eax; +} +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__halt(void) { + __asm__ volatile ("hlt"); +} #ifdef __cplusplus } diff --git a/renderscript/clang-include/cpuid.h b/renderscript/clang-include/cpuid.h index 8f12cae..f9254e9 100644 --- a/renderscript/clang-include/cpuid.h +++ b/renderscript/clang-include/cpuid.h @@ -79,6 +79,7 @@ #define bit_ACPI 0x00400000 #define bit_MMX 0x00800000 #define bit_FXSR 0x01000000 +#define bit_FXSAVE bit_FXSR /* for gcc compat */ #define bit_SSE 0x02000000 #define bit_SSE2 0x04000000 #define bit_SS 0x08000000 diff --git a/renderscript/clang-include/float.h b/renderscript/clang-include/float.h index 2cb13d3..02ef6bf 100644 --- a/renderscript/clang-include/float.h +++ b/renderscript/clang-include/float.h @@ -29,7 +29,7 @@ * For more details see http://msdn.microsoft.com/en-us/library/y0ybw9fy.aspx */ #if (defined(__MINGW32__) || defined(_MSC_VER)) && \ - defined(__has_include_next) && __has_include_next(<float.h>) + __has_include_next(<float.h>) # include_next <float.h> /* Undefine anything that we'll be redefining below. */ diff --git a/renderscript/clang-include/ia32intrin.h b/renderscript/clang-include/ia32intrin.h new file mode 100644 index 0000000..a5985f6 --- /dev/null +++ b/renderscript/clang-include/ia32intrin.h @@ -0,0 +1,92 @@ +/* ===-------- ia32intrin.h ---------------------------------------------------=== + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + * + *===-----------------------------------------------------------------------=== + */ + +#ifndef __X86INTRIN_H +#error "Never use <ia32intrin.h> directly; include <x86intrin.h> instead." +#endif + +#ifndef __IA32INTRIN_H +#define __IA32INTRIN_H + +#ifdef __x86_64__ +static __inline__ unsigned long long __attribute__((__always_inline__, __nodebug__)) +__readeflags(void) +{ + unsigned long long __res = 0; + __asm__ __volatile__ ("pushf\n\t" + "popq %0\n" + :"=r"(__res) + : + : + ); + return __res; +} + +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__writeeflags(unsigned long long __f) +{ + __asm__ __volatile__ ("pushq %0\n\t" + "popf\n" + : + :"r"(__f) + :"flags" + ); +} + +#else /* !__x86_64__ */ +static __inline__ unsigned int __attribute__((__always_inline__, __nodebug__)) +__readeflags(void) +{ + unsigned int __res = 0; + __asm__ __volatile__ ("pushf\n\t" + "popl %0\n" + :"=r"(__res) + : + : + ); + return __res; +} + +static __inline__ void __attribute__((__always_inline__, __nodebug__)) +__writeeflags(unsigned int __f) +{ + __asm__ __volatile__ ("pushl %0\n\t" + "popf\n" + : + :"r"(__f) + :"flags" + ); +} +#endif /* !__x86_64__ */ + +/* __rdtsc */ +static __inline__ unsigned long long __attribute__((__always_inline__, __nodebug__)) +__rdtsc(void) { + unsigned int __eax, __edx; + __asm__ ("rdtsc" : "=a" (__eax), "=d" (__edx)); + return ((unsigned long long)__edx << 32) | __eax; +} + +#define _rdtsc() __rdtsc() + +#endif /* __IA32INTRIN_H */ diff --git a/renderscript/clang-include/immintrin.h b/renderscript/clang-include/immintrin.h index 15d6e05..df4bea8 100644 --- a/renderscript/clang-include/immintrin.h +++ b/renderscript/clang-include/immintrin.h @@ -48,7 +48,7 @@ #include <smmintrin.h> #endif -#if defined (__AES__) +#if defined (__AES__) || defined (__PCLMUL__) #include <wmmintrin.h> #endif diff --git a/renderscript/clang-include/limits.h b/renderscript/clang-include/limits.h index 91bd404..f04187c 100644 --- a/renderscript/clang-include/limits.h +++ b/renderscript/clang-include/limits.h @@ -33,8 +33,7 @@ /* System headers include a number of constants from POSIX in <limits.h>. Include it if we're hosted. */ -#if __STDC_HOSTED__ && \ - defined(__has_include_next) && __has_include_next(<limits.h>) +#if __STDC_HOSTED__ && __has_include_next(<limits.h>) #include_next <limits.h> #endif @@ -90,7 +89,7 @@ /* C99 5.2.4.2.1: Added long long. C++11 18.3.3.2: same contents as the Standard C Library header <limits.h>. */ -#if __STDC_VERSION__ >= 199901 || __cplusplus >= 201103L +#if __STDC_VERSION__ >= 199901L || __cplusplus >= 201103L #undef LLONG_MIN #undef LLONG_MAX diff --git a/renderscript/clang-include/stdarg.h b/renderscript/clang-include/stdarg.h index 2957bf0..6110a06 100644 --- a/renderscript/clang-include/stdarg.h +++ b/renderscript/clang-include/stdarg.h @@ -39,7 +39,7 @@ typedef __builtin_va_list va_list; */ #define __va_copy(d,s) __builtin_va_copy(d,s) -#if __STDC_VERSION__ >= 199900L || __cplusplus >= 201103L || !defined(__STRICT_ANSI__) +#if __STDC_VERSION__ >= 199901L || __cplusplus >= 201103L || !defined(__STRICT_ANSI__) #define va_copy(dest, src) __builtin_va_copy(dest, src) #endif diff --git a/renderscript/clang-include/stddef.h b/renderscript/clang-include/stddef.h index 6a64d6d..97126ed 100644 --- a/renderscript/clang-include/stddef.h +++ b/renderscript/clang-include/stddef.h @@ -84,6 +84,20 @@ using ::std::nullptr_t; #endif #endif +#if __STDC_VERSION__ >= 201112L || __cplusplus >= 201103L +#ifndef _MSC_VER +typedef struct { + long long __clang_max_align_nonce1 + __attribute__((__aligned__(__alignof__(long long)))); + long double __clang_max_align_nonce2 + __attribute__((__aligned__(__alignof__(long double)))); +} max_align_t; +#else +typedef double max_align_t; +#endif +#define __CLANG_MAX_ALIGN_T_DEFINED +#endif + #define offsetof(t, d) __builtin_offsetof(t, d) #endif /* __STDDEF_H */ diff --git a/renderscript/clang-include/stdint.h b/renderscript/clang-include/stdint.h index 11529c0..2b1bc09 100644 --- a/renderscript/clang-include/stdint.h +++ b/renderscript/clang-include/stdint.h @@ -28,8 +28,7 @@ /* If we're hosted, fall back to the system's stdint.h, which might have * additional definitions. */ -#if __STDC_HOSTED__ && \ - defined(__has_include_next) && __has_include_next(<stdint.h>) +#if __STDC_HOSTED__ && __has_include_next(<stdint.h>) // C99 7.18.3 Limits of other integer types // diff --git a/renderscript/clang-include/x86intrin.h b/renderscript/clang-include/x86intrin.h index 399016f..be9e71d 100644 --- a/renderscript/clang-include/x86intrin.h +++ b/renderscript/clang-include/x86intrin.h @@ -24,6 +24,8 @@ #ifndef __X86INTRIN_H #define __X86INTRIN_H +#include <ia32intrin.h> + #include <immintrin.h> #ifdef __3dNOW__ diff --git a/renderscript/clang-include/xmmintrin.h b/renderscript/clang-include/xmmintrin.h index c68d3ed..c8765a7 100644 --- a/renderscript/clang-include/xmmintrin.h +++ b/renderscript/clang-include/xmmintrin.h @@ -672,10 +672,12 @@ _mm_storer_ps(float *__p, __m128 __a) #define _MM_HINT_T2 1 #define _MM_HINT_NTA 0 +#ifndef _MSC_VER /* FIXME: We have to #define this because "sel" must be a constant integer, and Sema doesn't do any form of constant propagation yet. */ #define _mm_prefetch(a, sel) (__builtin_prefetch((void *)(a), 0, (sel))) +#endif static __inline__ void __attribute__((__always_inline__, __nodebug__)) _mm_stream_pi(__m64 *__p, __m64 __a) |