mirror of
git://git.musl-libc.org/musl
synced 2024-12-20 22:01:16 +00:00
9f65796c35
clang does not presently support the "v" constraint we want to use to get the result from $3, and trying to use register...__asm__("$3") to do the same invokes serious compiler bugs. so for now, i'm working around the issue with an extra temp register and putting $3 in the clobber list instead of using it as output. when the bugs in clang are fixed, this issue should be revisited to generate smaller/faster code like what gcc gets.
13 lines
322 B
C
13 lines
322 B
C
static inline struct pthread *__pthread_self()
|
|
{
|
|
struct pthread *self;
|
|
#ifdef __clang__
|
|
__asm__ __volatile__ (".word 0x7c03e83b ; move %0, $3" : "=r" (self) : : "$3" );
|
|
#else
|
|
__asm__ __volatile__ (".word 0x7c03e83b" : "=v" (self) );
|
|
#endif
|
|
return self;
|
|
}
|
|
|
|
#define CANCEL_REG_IP (3-(union {int __i; char __b;}){1}.__b)
|