From 9582dc2058e2f8a9d789c6184e5e32602758ed0d Mon Sep 17 00:00:00 2001 From: Eric Salo Date: Wed, 16 Nov 2022 19:02:32 -0800 Subject: [PATCH] fix UPB_LIKELY() for 32-bit Windows builds and update to latest protobuf commit https://github.com/protocolbuffers/protobuf/issues/10950 PiperOrigin-RevId: 489095346 --- upb/port/def.inc | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/upb/port/def.inc b/upb/port/def.inc index 99e1c1d6f8..86d16382df 100644 --- a/upb/port/def.inc +++ b/upb/port/def.inc @@ -106,16 +106,16 @@ #define UPB_ALIGN_MALLOC(size) UPB_ALIGN_UP(size, UPB_MALLOC_ALIGN) #define UPB_ALIGN_OF(type) offsetof (struct { char c; type member; }, member) -/* Hints to the compiler about likely/unlikely branches. */ +// Hints to the compiler about likely/unlikely branches. #if defined (__GNUC__) || defined(__clang__) -#define UPB_LIKELY(x) __builtin_expect((x),1) -#define UPB_UNLIKELY(x) __builtin_expect((x),0) +#define UPB_LIKELY(x) __builtin_expect((bool)(x), 1) +#define UPB_UNLIKELY(x) __builtin_expect((bool)(x), 0) #else #define UPB_LIKELY(x) (x) #define UPB_UNLIKELY(x) (x) #endif -/* Macros for function attributes on compilers that support them. */ +// Macros for function attributes on compilers that support them. #ifdef __GNUC__ #define UPB_FORCEINLINE __inline__ __attribute__((always_inline)) #define UPB_NOINLINE __attribute__((noinline)) @@ -138,8 +138,7 @@ #define UPB_UNUSED(var) (void)var -/* UPB_ASSUME(): in release mode, we tell the compiler to assume this is true. - */ +// UPB_ASSUME(): in release mode, we tell the compiler to assume this is true. #ifdef NDEBUG #ifdef __GNUC__ #define UPB_ASSUME(expr) if (!(expr)) __builtin_unreachable()