mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-02-07 15:03:34 +00:00
This change greatly reduces the number of modules that need to be compiled. The only issue right now is that sometimes when viewing symbol table entries, the aliased symbol is chosen.
57 lines
2.5 KiB
C
57 lines
2.5 KiB
C
#ifndef COSMOPOLITAN_LIBC_BITS_PUSHPOP_H_
|
|
#define COSMOPOLITAN_LIBC_BITS_PUSHPOP_H_
|
|
#include "libc/macros.internal.h"
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
#ifdef COSMO
|
|
|
|
#if !defined(__GNUC__) || defined(__STRICT_ANSI__) || !defined(__x86_64__)
|
|
#define pushpop(x) (x)
|
|
#else
|
|
/**
|
|
* PushPop
|
|
* An elegant weapon for a more civilized age.
|
|
*/
|
|
#define pushpop(x) \
|
|
({ \
|
|
typeof(x) Popped; \
|
|
if (__builtin_constant_p(x) && \
|
|
(TYPE_SIGNED(typeof(x)) ? (intptr_t)(x) + 128 < 256 \
|
|
: (intptr_t)(x) < 128)) { \
|
|
if (x) { \
|
|
asm("push\t%1\n\t" \
|
|
"pop\t%q0" \
|
|
: "=r"(Popped) \
|
|
: "ir"(x)); \
|
|
} else { \
|
|
asm("xor\t%k0,%k0" : "=r"(Popped)); \
|
|
} \
|
|
} else { \
|
|
asm("" : "=r"(Popped) : "0"(x)); \
|
|
} \
|
|
Popped; \
|
|
})
|
|
#endif
|
|
|
|
#if !defined(__GNUC__) || defined(__STRICT_ANSI__) || !defined(__x86_64__)
|
|
#define pushmov(d, x) (*(d) = (x))
|
|
#else
|
|
#define pushmov(d, x) \
|
|
({ \
|
|
typeof(*(d)) Popped = (x); \
|
|
if (__builtin_constant_p(x) && \
|
|
(TYPE_SIGNED(typeof(x)) ? (intptr_t)(x) + 128 < 256 \
|
|
: (intptr_t)(x) < 128)) { \
|
|
asm("pushq\t%1\n\t" \
|
|
"popq\t%0" \
|
|
: "=m"(*(d)) \
|
|
: "ir"(Popped)); \
|
|
} else { \
|
|
*(d) = Popped; \
|
|
} \
|
|
Popped; \
|
|
})
|
|
#endif
|
|
|
|
#endif /* COSMO */
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
#endif /* COSMOPOLITAN_LIBC_BITS_PUSHPOP_H_ */
|