Added platform detection macros and atomic/thread_local abstraction

This commit is contained in:
martinfouilleul 2022-12-22 15:29:07 +01:00
parent c57e16db5a
commit a696c2ba2b
6 changed files with 111 additions and 22 deletions

View File

@ -9,6 +9,7 @@
#include<stdlib.h> #include<stdlib.h>
#include<string.h> #include<string.h>
#include"platform.h"
#include"win32_app.c" #include"win32_app.c"
#include"debug_log.c" #include"debug_log.c"
#include"memory.c" #include"memory.c"

View File

@ -7,12 +7,6 @@
* *
*****************************************************************/ *****************************************************************/
#ifdef _WIN32
#include"win32_app.c"
#else
#include"osx_app.m" #include"osx_app.m"
#include"metal_surface.m" #include"metal_surface.m"
#include"metal_painter.m" #include"metal_painter.m"
@ -23,5 +17,3 @@
#pragma clang diagnostic pop #pragma clang diagnostic pop
#include"osx_surface_client.m" #include"osx_surface_client.m"
#endif

85
src/platform/platform.h Normal file
View File

@ -0,0 +1,85 @@
//*****************************************************************
//
// $file: platform.h $
// $author: Martin Fouilleul $
// $date: 22/12/2022 $
// $revision: $
// $note: (C) 2022 by Martin Fouilleul - all rights reserved $
//
//*****************************************************************
#ifndef __PLATFORM_H_
#define __PLATFORM_H_
//-----------------------------------------------------------------
// Compiler identification
//-----------------------------------------------------------------
#if defined(__clang__)
#define COMPILER_CLANG 1
#if defined(__apple_build_version__)
#define COMPILER_CLANG_APPLE 1
#elif defined(_MSC_VER)
#define COMPILER_CLANG_CL 1
#endif
#elif defined(_MSC_VER)
#define COMPILER_CL 1
#elif defined(__GNUC__)
#define COMPILER_GCC 1
#else
#error "Can't identify compiler"
#endif
//-----------------------------------------------------------------
// OS identification
//-----------------------------------------------------------------
#if defined(_WIN64)
#define OS_WIN64 1
#elif defined(_WIN32)
#error "Unsupported OS (32bit only version of Windows)"
#elif defined(__APPLE__) && defined(__MACH__)
#define OS_MACOS 1
#elif defined(__gnu_linux__)
#define OS_LINUX 1
#else
#error "Can't identify OS"
#endif
//-----------------------------------------------------------------
// Architecture identification
//-----------------------------------------------------------------
#if defined(COMPILER_CL)
#if defined(_M_AMD64)
#define ARCH_X64 1
#elif defined(_M_I86)
#define ARCH_X86 1
#elif defined(_M_ARM64)
#define ARCH_ARM64 1
#elif defined(_M_ARM)
#define ARCH_ARM32 1
#else
#error "Can't identify architecture"
#endif
#else
#if defined(__x86_64__)
#define ARCH_X64 1
#elif defined(__i386__)
#define ARCH_X86 1
#elif defined(__arm__)
#define ARCH_ARM32 1
#elif defined(__aarch64__)
#define ARCH_ARM64 1
#else
#error "Can't identify architecture"
#endif
#endif
//-----------------------------------------------------------------
// platform helper macros
//-----------------------------------------------------------------
#if defined(COMPILER_CL)
#define mp_thread_local __declspec(thread)
#elif defined(COMPILER_GCC) || defined(COMPILER_CLANG)
#define mp_thread_local __thread
#endif
#endif // __PLATFORM_H_

22
src/util/atomic.h Normal file
View File

@ -0,0 +1,22 @@
//*****************************************************************
//
// $file: atomic.h $
// $author: Martin Fouilleul $
// $date: 22/12/2022 $
// $revision: $
// $note: (C) 2022 by Martin Fouilleul - all rights reserved $
//
//*****************************************************************
#ifndef __ATOMIC_H_
#define __ATOMIC_H_
#include"platform.h"
#if (defined(COMPILER_CL) || defined(COMPILER_CLANG_CL)) && defined(__STDC_NO_ATOMICS__)
#define _Atomic(t) volatile t
//TODO
#else
#include<stdatomic.h>
#endif
#endif __ATOMIC_H_

View File

@ -8,6 +8,7 @@
*****************************************************************/ *****************************************************************/
#include<string.h> // memset #include<string.h> // memset
#include"platform.h"
#include"memory.h" #include"memory.h"
#include"platform_base_allocator.h" #include"platform_base_allocator.h"
#include"macro_helpers.h" #include"macro_helpers.h"
@ -112,13 +113,7 @@ void mem_pool_clear(mem_pool* pool)
//NOTE(martin): per-thread scratch arena //NOTE(martin): per-thread scratch arena
//-------------------------------------------------------------------------------- //--------------------------------------------------------------------------------
//TODO: move that somewhere in context cracking code mp_thread_local mem_arena __scratchArena = {0};
#ifdef _WIN32
#define __thread __declspec(thread)
#endif
__thread mem_arena __scratchArena = {0};
mem_arena* mem_scratch() mem_arena* mem_scratch()
{ {

View File

@ -10,13 +10,7 @@
#define __RINGBUFFER_H_ #define __RINGBUFFER_H_
#include"typedefs.h" #include"typedefs.h"
#include"atomic.h"
#if defined(_MSC_VER) && defined(__STDC_NO_ATOMICS__)
#define _Atomic(t) volatile t
#else
#include<stdatomic.h>
#endif
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {