From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- Src/replicant/foundation/win-x86/atomics.h | 61 +++++++++++++++++++ Src/replicant/foundation/win-x86/types.h | 98 ++++++++++++++++++++++++++++++ 2 files changed, 159 insertions(+) create mode 100644 Src/replicant/foundation/win-x86/atomics.h create mode 100644 Src/replicant/foundation/win-x86/types.h (limited to 'Src/replicant/foundation/win-x86') diff --git a/Src/replicant/foundation/win-x86/atomics.h b/Src/replicant/foundation/win-x86/atomics.h new file mode 100644 index 00000000..f61f46d5 --- /dev/null +++ b/Src/replicant/foundation/win-x86/atomics.h @@ -0,0 +1,61 @@ +#pragma once +#include "../../foundation/types.h" +#include +#include + +#ifdef __cplusplus +#define NX_ATOMIC_INLINE inline +#else +#define NX_ATOMIC_INLINE +#endif + +NX_ATOMIC_INLINE static size_t nx_atomic_inc(volatile size_t *addr) +{ + return (size_t)_InterlockedIncrement((volatile LONG *)addr); +} + +NX_ATOMIC_INLINE static size_t nx_atomic_dec(volatile size_t *addr) +{ + return (size_t)_InterlockedDecrement((volatile LONG *)addr); +} + +NX_ATOMIC_INLINE static size_t nx_atomic_dec_release(volatile size_t *addr) +{ + return (size_t)_InterlockedDecrement((volatile LONG *)addr); +} + +NX_ATOMIC_INLINE static void nx_atomic_write(size_t value, volatile size_t *addr) +{ + InterlockedExchange((LONG *)addr, value); +} + +NX_ATOMIC_INLINE static void nx_atomic_write_pointer(void *value, void* volatile *addr) +{ + InterlockedExchangePointer(addr, value); +} + +NX_ATOMIC_INLINE static size_t nx_atomic_add(size_t value, volatile size_t* addr) +{ + return (size_t)InterlockedExchangeAdd((volatile LONG *)addr, (LONG)value); +} + +NX_ATOMIC_INLINE static size_t nx_atomic_sub(size_t value, volatile size_t* addr) +{ + return (size_t)InterlockedExchangeAdd((volatile LONG *)addr, -(LONG)value); +} + +NX_ATOMIC_INLINE static void *nx_atomic_swap_pointer(const void *value, void* volatile *addr) +{ + return InterlockedExchangePointer(addr, (PVOID)value); +} + +NX_ATOMIC_INLINE static int nx_atomic_cmpxchg_pointer(void *oldvalue, void *newvalue, void* volatile *addr) +{ + return InterlockedCompareExchangePointer(addr, newvalue, oldvalue) == oldvalue; +} + +#pragma intrinsic(_InterlockedCompareExchange64) +NX_ATOMIC_INLINE static int nx_atomic_cmpxchg2(int64_t oldvalue, int64_t newvalue, volatile int64_t *addr) +{ + return _InterlockedCompareExchange64(addr, newvalue, oldvalue) == oldvalue; +} diff --git a/Src/replicant/foundation/win-x86/types.h b/Src/replicant/foundation/win-x86/types.h new file mode 100644 index 00000000..156f009a --- /dev/null +++ b/Src/replicant/foundation/win-x86/types.h @@ -0,0 +1,98 @@ +#pragma once +#ifndef WIN32_LEAN_AND_MEAN +#define WIN32_LEAN_AND_MEAN +#endif +#include + +#include +// first, some standard int types +typedef unsigned int UINT; +typedef signed int SINT; + +typedef unsigned char UCHAR; +typedef signed char SCHAR; + +typedef unsigned long ARGB32; +typedef unsigned long RGB32; + +typedef unsigned long ARGB24; +typedef unsigned long RGB24; + +typedef unsigned short ARGB16; +typedef unsigned short RGB16; + +typedef unsigned long FOURCC; + +typedef wchar_t nsxml_char_t; +typedef wchar_t ns_char_t; +typedef wchar_t nsfilename_char_t; + +typedef int socklen_t; + +#if defined(_WIN32) && !defined(__GNUC__) +#include +#if _MSC_VER >= 1600 +#include +#else + // since windows doesn't have stdint.h + typedef unsigned __int64 uint64_t; + typedef unsigned __int32 uint32_t; + typedef unsigned __int16 uint16_t; + typedef unsigned __int8 uint8_t; + typedef signed __int64 int64_t; + typedef signed __int32 int32_t; + typedef signed __int16 int16_t; + typedef signed __int8 int8_t; +#ifdef _M_IX86 + typedef int64_t intptr2_t; +#else if defined(_M_IX64) + typedef unsigned __int128 uint128_t; + typedef __int128 int128_t; + typedef int128_t intptr2_t +#endif +#endif +#else +#include +#include +#include +#endif + +#ifndef GUID_DEFINED +#define GUID_DEFINED + + typedef struct _GUID + { + uint32_t Data1; + uint16_t Data2; + uint16_t Data3; + uint8_t Data4[8]; + } GUID; +/* +#ifndef _REFCLSID_DEFINED +#define REFGUID const GUID & +#define _REFCLSID_DEFINED +#endif +*/ +#endif + +// this is for GUID == and != +#include +#ifndef GUID_EQUALS_DEFINED + #define GUID_EQUALS_DEFINED +#endif + +#if defined(_MSC_VER) +#include + typedef SSIZE_T ssize_t; +#endif + +#ifdef NULL + #undef NULL +#endif +#ifndef NULL + #define NULL 0 +#endif + +#ifdef _WIN32_WCE +typedef int intptr_t; +#endif -- cgit