From 228417ab8c2980879853545163f6ec8d933ff01e Mon Sep 17 00:00:00 2001 From: YAMAMOTO Takashi Date: Thu, 27 Jul 2023 22:37:23 +0900 Subject: [PATCH] Move generic parts of wasm_suspend_flags.h to bh_atomic.h (#2393) --- core/iwasm/common/wasm_suspend_flags.h | 40 ++++--------------- core/shared/utils/bh_atomic.h | 53 ++++++++++++++++++++++++++ core/shared/utils/bh_platform.h | 1 - 3 files changed, 60 insertions(+), 34 deletions(-) create mode 100644 core/shared/utils/bh_atomic.h diff --git a/core/iwasm/common/wasm_suspend_flags.h b/core/iwasm/common/wasm_suspend_flags.h index 0558eaf6..b7ecbb0b 100644 --- a/core/iwasm/common/wasm_suspend_flags.h +++ b/core/iwasm/common/wasm_suspend_flags.h @@ -6,7 +6,7 @@ #ifndef _WASM_SUSPEND_FLAGS_H #define _WASM_SUSPEND_FLAGS_H -#include "bh_platform.h" +#include "bh_atomic.h" #ifdef __cplusplus extern "C" { @@ -22,42 +22,16 @@ extern "C" { #define WASM_SUSPEND_FLAG_EXIT 0x8 typedef union WASMSuspendFlags { - uint32 flags; + bh_atomic_32_t flags; uintptr_t __padding__; } WASMSuspendFlags; -#if defined(__GNUC_PREREQ) -#if __GNUC_PREREQ(4, 7) -#define CLANG_GCC_HAS_ATOMIC_BUILTIN -#endif -#elif defined(__clang__) -#if __clang_major__ > 3 || (__clang_major__ == 3 && __clang_minor__ >= 0) -#define CLANG_GCC_HAS_ATOMIC_BUILTIN -#endif -#endif - -#if defined(CLANG_GCC_HAS_ATOMIC_BUILTIN) -#define WASM_SUSPEND_FLAGS_IS_ATOMIC 1 -#define WASM_SUSPEND_FLAGS_GET(s_flags) \ - __atomic_load_n(&s_flags.flags, __ATOMIC_SEQ_CST) +#define WASM_SUSPEND_FLAGS_IS_ATOMIC BH_ATOMIC_32_IS_ATOMIC +#define WASM_SUSPEND_FLAGS_GET(s_flags) BH_ATOMIC_32_LOAD(s_flags.flags) #define WASM_SUSPEND_FLAGS_FETCH_OR(s_flags, val) \ - __atomic_fetch_or(&s_flags.flags, val, __ATOMIC_SEQ_CST) + BH_ATOMIC_32_FETCH_OR(s_flags.flags, val) #define WASM_SUSPEND_FLAGS_FETCH_AND(s_flags, val) \ - __atomic_fetch_and(&s_flags.flags, val, __ATOMIC_SEQ_CST) -#else /* else of defined(CLANG_GCC_HAS_ATOMIC_BUILTIN) */ -#define WASM_SUSPEND_FLAGS_GET(s_flags) (s_flags.flags) -#define WASM_SUSPEND_FLAGS_FETCH_OR(s_flags, val) (s_flags.flags |= val) -#define WASM_SUSPEND_FLAGS_FETCH_AND(s_flags, val) (s_flags.flags &= val) - -/* The flag can be defined by the user if the platform - supports atomic access to uint32 aligned memory. */ -#ifdef WASM_UINT32_IS_ATOMIC -#define WASM_SUSPEND_FLAGS_IS_ATOMIC 1 -#else /* else of WASM_UINT32_IS_ATOMIC */ -#define WASM_SUSPEND_FLAGS_IS_ATOMIC 0 -#endif /* WASM_UINT32_IS_ATOMIC */ - -#endif + BH_ATOMIC_32_FETCH_AND(s_flags.flags, val) #if WASM_SUSPEND_FLAGS_IS_ATOMIC != 0 #define WASM_SUSPEND_FLAGS_LOCK(lock) (void)0 @@ -71,4 +45,4 @@ typedef union WASMSuspendFlags { } #endif -#endif /* end of _WASM_SUSPEND_FLAGS_H */ \ No newline at end of file +#endif /* end of _WASM_SUSPEND_FLAGS_H */ diff --git a/core/shared/utils/bh_atomic.h b/core/shared/utils/bh_atomic.h new file mode 100644 index 00000000..4dfffa72 --- /dev/null +++ b/core/shared/utils/bh_atomic.h @@ -0,0 +1,53 @@ +/* + * Copyright (C) 2023 Amazon Inc. All rights reserved. + * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception + */ + +#ifndef _BH_ATOMIC_H +#define _BH_ATOMIC_H + +#include "gnuc.h" + +#ifdef __cplusplus +extern "C" { +#endif + +typedef uint32 bh_atomic_32_t; + +#if defined(__GNUC_PREREQ) +#if __GNUC_PREREQ(4, 7) +#define CLANG_GCC_HAS_ATOMIC_BUILTIN +#endif +#elif defined(__clang__) +#if __clang_major__ > 3 || (__clang_major__ == 3 && __clang_minor__ >= 0) +#define CLANG_GCC_HAS_ATOMIC_BUILTIN +#endif +#endif + +#if defined(CLANG_GCC_HAS_ATOMIC_BUILTIN) +#define BH_ATOMIC_32_IS_ATOMIC 1 +#define BH_ATOMIC_32_LOAD(v) __atomic_load_n(&(v), __ATOMIC_SEQ_CST) +#define BH_ATOMIC_32_FETCH_OR(v, val) \ + __atomic_fetch_or(&(v), (val), __ATOMIC_SEQ_CST) +#define BH_ATOMIC_32_FETCH_AND(v, val) \ + __atomic_fetch_and(&(v), (val), __ATOMIC_SEQ_CST) +#else /* else of defined(CLANG_GCC_HAS_ATOMIC_BUILTIN) */ +#define BH_ATOMIC_32_LOAD(v) (v) +#define BH_ATOMIC_32_FETCH_OR(v, val) ((v) |= (val)) +#define BH_ATOMIC_32_FETCH_AND(v, val) ((v) &= (val)) + +/* The flag can be defined by the user if the platform + supports atomic access to uint32 aligned memory. */ +#ifdef WASM_UINT32_IS_ATOMIC +#define BH_ATOMIC_32_IS_ATOMIC 1 +#else /* else of WASM_UINT32_IS_ATOMIC */ +#define BH_ATOMIC_32_IS_ATOMIC 0 +#endif /* WASM_UINT32_IS_ATOMIC */ + +#endif + +#ifdef __cplusplus +} +#endif + +#endif /* end of _BH_ATOMIC_H */ diff --git a/core/shared/utils/bh_platform.h b/core/shared/utils/bh_platform.h index 9821d710..86aef839 100644 --- a/core/shared/utils/bh_platform.h +++ b/core/shared/utils/bh_platform.h @@ -16,7 +16,6 @@ #include "bh_log.h" #include "bh_queue.h" #include "bh_vector.h" -#include "gnuc.h" #include "runtime_timer.h" /**