mirror of
https://github.com/mirror/tinycc.git
synced 2025-02-06 06:40:07 +08:00
add MemoryBarrier marco define; tested gcc msvc
This commit is contained in:
parent
cd6ad857cf
commit
76d605192d
105
lib/stdatomic.c
105
lib/stdatomic.c
@ -15,55 +15,8 @@
|
|||||||
#define __ATOMIC_SEQ_CST 5
|
#define __ATOMIC_SEQ_CST 5
|
||||||
typedef __SIZE_TYPE__ size_t;
|
typedef __SIZE_TYPE__ size_t;
|
||||||
|
|
||||||
/* uses alias to allow building with gcc/clang */
|
void __atomic_thread_fence(int memorder);
|
||||||
#ifdef __TINYC__
|
#define MemoryBarrier(memorder) __atomic_thread_fence(memorder)
|
||||||
#define ATOMIC(x) __atomic_##x
|
|
||||||
#else
|
|
||||||
#define ATOMIC(x) __tcc_atomic_##x
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void ATOMIC(signal_fence) (int memorder)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void ATOMIC(thread_fence) (int memorder)
|
|
||||||
{
|
|
||||||
#if defined __i386__
|
|
||||||
__asm__ volatile("lock orl $0, (%esp)");
|
|
||||||
#elif defined __x86_64__
|
|
||||||
__asm__ volatile("lock orq $0, (%rsp)");
|
|
||||||
#elif defined __arm__
|
|
||||||
__asm__ volatile(".int 0xee070fba"); // mcr p15, 0, r0, c7, c10, 5
|
|
||||||
#elif defined __aarch64__
|
|
||||||
__asm__ volatile(".int 0xd5033bbf"); // dmb ish
|
|
||||||
#elif defined __riscv
|
|
||||||
__asm__ volatile(".int 0x0ff0000f"); // fence iorw,iorw
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ATOMIC(is_lock_free) (unsigned long size, const volatile void *ptr)
|
|
||||||
{
|
|
||||||
bool ret;
|
|
||||||
|
|
||||||
switch (size) {
|
|
||||||
case 1: ret = true; break;
|
|
||||||
case 2: ret = true; break;
|
|
||||||
case 4: ret = true; break;
|
|
||||||
#if defined __x86_64__ || defined __aarch64__ || defined __riscv
|
|
||||||
case 8: ret = true; break;
|
|
||||||
#else
|
|
||||||
case 8: ret = false; break;
|
|
||||||
#endif
|
|
||||||
default: ret = false; break;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef __TINYC__
|
|
||||||
void __atomic_signal_fence(int memorder) __attribute__((alias("__tcc_atomic_signal_fence")));
|
|
||||||
void __atomic_thread_fence(int memorder) __attribute__((alias("__tcc_atomic_thread_fence")));
|
|
||||||
bool __atomic_is_lock_free(unsigned long size, const volatile void *ptr) __attribute__((alias("__tcc_atomic_is_lock_free")));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined __i386__ || defined __x86_64__
|
#if defined __i386__ || defined __x86_64__
|
||||||
#define ATOMIC_COMPARE_EXCHANGE(TYPE, MODE, SUFFIX) \
|
#define ATOMIC_COMPARE_EXCHANGE(TYPE, MODE, SUFFIX) \
|
||||||
@ -92,7 +45,7 @@ bool __atomic_is_lock_free(unsigned long size, const volatile void *ptr) __attri
|
|||||||
#define ATOMIC_LOAD(TYPE, MODE) \
|
#define ATOMIC_LOAD(TYPE, MODE) \
|
||||||
TYPE __atomic_load_##MODE(const volatile void *atom, int memorder) \
|
TYPE __atomic_load_##MODE(const volatile void *atom, int memorder) \
|
||||||
{ \
|
{ \
|
||||||
__atomic_thread_fence(__ATOMIC_ACQUIRE); \
|
MemoryBarrier(__ATOMIC_ACQUIRE); \
|
||||||
return *(volatile TYPE *)atom; \
|
return *(volatile TYPE *)atom; \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -100,7 +53,7 @@ bool __atomic_is_lock_free(unsigned long size, const volatile void *ptr) __attri
|
|||||||
void __atomic_store_##MODE(volatile void *atom, TYPE value, int memorder) \
|
void __atomic_store_##MODE(volatile void *atom, TYPE value, int memorder) \
|
||||||
{ \
|
{ \
|
||||||
*(volatile TYPE *)atom = value; \
|
*(volatile TYPE *)atom = value; \
|
||||||
__atomic_thread_fence(__ATOMIC_RELEASE); \
|
MemoryBarrier(__ATOMIC_ACQ_REL); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define ATOMIC_GEN_OP(TYPE, MODE, NAME, OP, RET) \
|
#define ATOMIC_GEN_OP(TYPE, MODE, NAME, OP, RET) \
|
||||||
@ -166,3 +119,53 @@ ATOMIC_GEN(uint32_t, 4, "l")
|
|||||||
#if defined __x86_64__ || defined __aarch64__ || defined __riscv
|
#if defined __x86_64__ || defined __aarch64__ || defined __riscv
|
||||||
ATOMIC_GEN(uint64_t, 8, "q")
|
ATOMIC_GEN(uint64_t, 8, "q")
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* uses alias to allow building with gcc/clang */
|
||||||
|
#ifdef __TINYC__
|
||||||
|
#define ATOMIC(x) __atomic_##x
|
||||||
|
#else
|
||||||
|
#define ATOMIC(x) __tcc_atomic_##x
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void ATOMIC(signal_fence) (int memorder)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void ATOMIC(thread_fence) (int memorder)
|
||||||
|
{
|
||||||
|
#if defined __i386__
|
||||||
|
__asm__ volatile("lock orl $0, (%esp)");
|
||||||
|
#elif defined __x86_64__
|
||||||
|
__asm__ volatile("lock orq $0, (%rsp)");
|
||||||
|
#elif defined __arm__
|
||||||
|
__asm__ volatile(".int 0xee070fba"); // mcr p15, 0, r0, c7, c10, 5
|
||||||
|
#elif defined __aarch64__
|
||||||
|
__asm__ volatile(".int 0xd5033bbf"); // dmb ish
|
||||||
|
#elif defined __riscv
|
||||||
|
__asm__ volatile(".int 0x0ff0000f"); // fence iorw,iorw
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ATOMIC(is_lock_free) (unsigned long size, const volatile void *ptr)
|
||||||
|
{
|
||||||
|
bool ret;
|
||||||
|
|
||||||
|
switch (size) {
|
||||||
|
case 1: ret = true; break;
|
||||||
|
case 2: ret = true; break;
|
||||||
|
case 4: ret = true; break;
|
||||||
|
#if defined __x86_64__ || defined __aarch64__ || defined __riscv
|
||||||
|
case 8: ret = true; break;
|
||||||
|
#else
|
||||||
|
case 8: ret = false; break;
|
||||||
|
#endif
|
||||||
|
default: ret = false; break;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef __TINYC__
|
||||||
|
void __atomic_signal_fence(int memorder) __attribute__((alias("__tcc_atomic_signal_fence")));
|
||||||
|
void __atomic_thread_fence(int memorder) __attribute__((alias("__tcc_atomic_thread_fence")));
|
||||||
|
bool __atomic_is_lock_free(unsigned long size, const volatile void *ptr) __attribute__((alias("__tcc_atomic_is_lock_free")));
|
||||||
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user