From: Siddhesh Poyarekar Date: Sun, 8 Jan 2023 00:30:32 +0000 (-0500) Subject: alloc-util: Disallow inlining of expand_to_usable X-Git-Tag: v253-rc1~156 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=4f79f545b3c46c358666c9f5f2b384fe50aac4b4;p=thirdparty%2Fsystemd.git alloc-util: Disallow inlining of expand_to_usable Explicitly set __attribute__ ((noinline)) so that the compiler does not attempt to inline expand_to_usable, even with LTO. --- diff --git a/src/basic/alloc-util.h b/src/basic/alloc-util.h index eb53aae6f3e..bf783b15a22 100644 --- a/src/basic/alloc-util.h +++ b/src/basic/alloc-util.h @@ -186,10 +186,11 @@ void* greedy_realloc0(void **p, size_t need, size_t size); #endif /* Dummy allocator to tell the compiler that the new size of p is newsize. The implementation returns the - * pointer as is; the only reason for its existence is as a conduit for the _alloc_ attribute. This cannot be - * a static inline because gcc then loses the attributes on the function. + * pointer as is; the only reason for its existence is as a conduit for the _alloc_ attribute. This must not + * be inlined (hence a non-static function with _noinline_ because LTO otherwise tries to inline it) because + * gcc then loses the attributes on the function. * See: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96503 */ -void *expand_to_usable(void *p, size_t newsize) _alloc_(2) _returns_nonnull_; +void *expand_to_usable(void *p, size_t newsize) _alloc_(2) _returns_nonnull_ _noinline_; static inline size_t malloc_sizeof_safe(void **xp) { if (_unlikely_(!xp || !*xp)) diff --git a/src/fundamental/macro-fundamental.h b/src/fundamental/macro-fundamental.h index 9400c389ca9..10ee46b9c1c 100644 --- a/src/fundamental/macro-fundamental.h +++ b/src/fundamental/macro-fundamental.h @@ -20,6 +20,7 @@ #define _hidden_ __attribute__((__visibility__("hidden"))) #define _likely_(x) (__builtin_expect(!!(x), 1)) #define _malloc_ __attribute__((__malloc__)) +#define _noinline_ __attribute__((noinline)) #define _noreturn_ _Noreturn #define _packed_ __attribute__((__packed__)) #define _printf_(a, b) __attribute__((__format__(printf, a, b)))