mirror of
https://github.com/radareorg/radare2.git
synced 2025-02-23 07:42:38 +00:00
Add cwisstable headers + support headers ##util
This commit is contained in:
parent
0fdc819c1c
commit
41a6006c37
3293
libr/include/cwisstable.h
Normal file
3293
libr/include/cwisstable.h
Normal file
File diff suppressed because it is too large
Load Diff
70
libr/include/gcc_stdatomic.h
Normal file
70
libr/include/gcc_stdatomic.h
Normal file
@ -0,0 +1,70 @@
|
||||
/*
|
||||
* Copyright © 2018, VideoLAN and dav1d authors
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||
* list of conditions and the following disclaimer.
|
||||
*
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#ifndef GCCVER_STDATOMIC_H_
|
||||
#define GCCVER_STDATOMIC_H_
|
||||
|
||||
#if !defined(__cplusplus)
|
||||
|
||||
typedef int atomic_int;
|
||||
typedef unsigned int atomic_uint;
|
||||
|
||||
#ifndef __ATOMIC_RELAXED
|
||||
#define __ATOMIC_RELAXED 0
|
||||
#endif
|
||||
#ifndef __ATOMIC_CONSUME
|
||||
#define __ATOMIC_CONSUME 1
|
||||
#endif
|
||||
#ifndef __ATOMIC_ACQUIRE
|
||||
#define __ATOMIC_ACQUIRE 2
|
||||
#endif
|
||||
#ifndef __ATOMIC_RELEASE
|
||||
#define __ATOMIC_RELEASE 3
|
||||
#endif
|
||||
#ifndef __ATOMIC_ACQ_REL
|
||||
#define __ATOMIC_ACQ_REL 4
|
||||
#endif
|
||||
#ifndef __ATOMIC_SEQ_CST
|
||||
#define __ATOMIC_SEQ_CST 5
|
||||
#endif
|
||||
|
||||
#define memory_order_relaxed __ATOMIC_RELAXED
|
||||
#define memory_order_acquire __ATOMIC_ACQUIRE
|
||||
|
||||
#define atomic_init(p_a, v) do { *(p_a) = (v); } while(0)
|
||||
#define atomic_store(p_a, v) __atomic_store_n(p_a, v, __ATOMIC_SEQ_CST)
|
||||
#define atomic_load(p_a) __atomic_load_n(p_a, __ATOMIC_SEQ_CST)
|
||||
#define atomic_load_explicit(p_a, mo) __atomic_load_n(p_a, mo)
|
||||
#define atomic_fetch_add(p_a, inc) __atomic_fetch_add(p_a, inc, __ATOMIC_SEQ_CST)
|
||||
#define atomic_fetch_add_explicit(p_a, inc, mo) __atomic_fetch_add(p_a, inc, mo)
|
||||
#define atomic_fetch_sub(p_a, dec) __atomic_fetch_sub(p_a, dec, __ATOMIC_SEQ_CST)
|
||||
#define atomic_exchange(p_a, v) __atomic_exchange_n(p_a, v, __ATOMIC_SEQ_CST)
|
||||
#define atomic_fetch_or(p_a, v) __atomic_fetch_or(p_a, v, __ATOMIC_SEQ_CST)
|
||||
#define atomic_compare_exchange_strong(p_a, expected, desired) __atomic_compare_exchange_n(p_a, expected, desired, 0, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST)
|
||||
|
||||
#endif /* !defined(__cplusplus) */
|
||||
|
||||
#endif /* GCCVER_STDATOMIC_H_ */
|
54
libr/include/msvc_stdatomic.h
Normal file
54
libr/include/msvc_stdatomic.h
Normal file
@ -0,0 +1,54 @@
|
||||
#ifndef MSCVER_STDATOMIC_H_
|
||||
#define MSCVER_STDATOMIC_H_
|
||||
|
||||
#if !defined(__cplusplus) && defined(_MSC_VER)
|
||||
|
||||
#pragma warning(push)
|
||||
#pragma warning(disable:4067) /* newline for __has_include_next */
|
||||
|
||||
#if defined(__clang__) && __has_include_next(<stdatomic.h>)
|
||||
/* use the clang stdatomic.h with clang-cl*/
|
||||
# include_next <stdatomic.h>
|
||||
#else /* ! stdatomic.h */
|
||||
|
||||
#include <windows.h>
|
||||
|
||||
typedef volatile LONG atomic_int;
|
||||
typedef volatile ULONG atomic_uint;
|
||||
|
||||
typedef enum {
|
||||
memory_order_relaxed,
|
||||
memory_order_acquire
|
||||
} msvc_atomic_memory_order;
|
||||
|
||||
#define atomic_init(p_a, v) do { *(p_a) = (v); } while(0)
|
||||
#define atomic_store(p_a, v) InterlockedExchange((LONG*)p_a, v)
|
||||
#define atomic_load(p_a) InterlockedCompareExchange((LONG*)p_a, 0, 0)
|
||||
#define atomic_exchange(p_a, v) InterlockedExchange(p_a, v)
|
||||
#define atomic_load_explicit(p_a, mo) atomic_load(p_a)
|
||||
|
||||
static inline int atomic_compare_exchange_strong_int(LONG *obj, LONG *expected,
|
||||
LONG desired)
|
||||
{
|
||||
LONG orig = *expected;
|
||||
*expected = InterlockedCompareExchange(obj, desired, orig);
|
||||
return *expected == orig;
|
||||
}
|
||||
#define atomic_compare_exchange_strong(p_a, expected, desired) atomic_compare_exchange_strong_int((LONG *)p_a, (LONG *)expected, (LONG)desired)
|
||||
|
||||
/*
|
||||
* TODO use a special call to increment/decrement
|
||||
* using InterlockedIncrement/InterlockedDecrement
|
||||
*/
|
||||
#define atomic_fetch_add(p_a, inc) InterlockedExchangeAdd(p_a, inc)
|
||||
#define atomic_fetch_sub(p_a, dec) InterlockedExchangeAdd(p_a, -(dec))
|
||||
#define atomic_fetch_or(p_a, v) InterlockedOr(p_a, v)
|
||||
#define atomic_fetch_add_explicit(p_a, inc, mo) atomic_fetch_add(p_a, inc)
|
||||
|
||||
#endif /* ! stdatomic.h */
|
||||
|
||||
#pragma warning(pop)
|
||||
|
||||
#endif /* !defined(__cplusplus) && defined(_MSC_VER) */
|
||||
|
||||
#endif /* MSCVER_STDATOMIC_H_ */
|
@ -420,6 +420,9 @@ include_files = [
|
||||
'include/rvc.h',
|
||||
'include/r_agraph.h',
|
||||
'include/r_anal.h',
|
||||
'include/gcc_stdatomic.h',
|
||||
'include/msvc_stdatomic.h',
|
||||
'include/cwisstable.h',
|
||||
'include/r_arch.h',
|
||||
'include/r_esil.h',
|
||||
'include/r_asm.h',
|
||||
|
Loading…
x
Reference in New Issue
Block a user