From 76941a3636f34e1bb21bbf3a323383d837adea0f Mon Sep 17 00:00:00 2001 From: Leonardo Alminana Date: Wed, 21 Aug 2024 16:16:10 +0200 Subject: [PATCH 1/2] build: added cpu byte order detection (same as msgpack-c) Signed-off-by: Leonardo Alminana --- CMakeLists.txt | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/CMakeLists.txt b/CMakeLists.txt index 2018e4f52c9..e2e9fbf3b04 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -88,6 +88,7 @@ elseif(FLB_SYSTEM_FREEBSD) set(WAMR_DISABLE_STACK_HW_BOUND_CHECK 1) endif() +INCLUDE(TestBigEndian) include(GNUInstallDirs) include(ExternalProject) include(cmake/FindJournald.cmake) @@ -772,6 +773,15 @@ if(FLB_HAVE_UNIX_SOCKET) FLB_DEFINITION(FLB_HAVE_UNIX_SOCKET) endif() +# byte order detection +test_big_endian(BIG_ENDIAN_SYSTEM_DETECTED) + +if (BIG_ENDIAN_SYSTEM_DETECTED) + FLB_DEFINITION(FLB_HAVE_BIG_ENDIAN_SYSTEM) +else() + FLB_DEFINITION(FLB_HAVE_LITTLE_ENDIAN_SYSTEM) +endif () + # Configuration file YAML format support if(FLB_CONFIG_YAML) find_package(PkgConfig) From e5eccbd472ec0be5803c51636749636e2cd4f730 Mon Sep 17 00:00:00 2001 From: Leonardo Alminana Date: Wed, 21 Aug 2024 16:16:49 +0200 Subject: [PATCH 2/2] core: replaced buggy cpu byte order detection with a reliable mechanism Signed-off-by: Leonardo Alminana --- include/fluent-bit/flb_endian.h | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/include/fluent-bit/flb_endian.h b/include/fluent-bit/flb_endian.h index b376ea84235..da21aef2b6e 100644 --- a/include/fluent-bit/flb_endian.h +++ b/include/fluent-bit/flb_endian.h @@ -55,9 +55,7 @@ #define FLB_BIG_ENDIAN 1 #ifndef FLB_BYTE_ORDER - #if defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__ - #define FLB_BYTE_ORDER FLB_BIG_ENDIAN - #elif defined(__BIG_ENDIAN__) || defined(__BIG_ENDIAN) || defined(_BIG_ENDIAN) + #ifdef FLB_HAVE_BIG_ENDIAN_SYSTEM #define FLB_BYTE_ORDER FLB_BIG_ENDIAN #else #define FLB_BYTE_ORDER FLB_LITTLE_ENDIAN