[LTP] [PATCH] syscalls/mallinfo02: introduce LTP_VAR_USED to avoid optimization

Cyril Hrubis chrubis@suse.cz
Thu Feb 6 13:44:55 CET 2025


Hi!
> gcc 15 is a bit more clever and noticed that 'buf' isn't used
> for anything so it optimized it out, including call to malloc.
> So, there's also no mmap() call behind it and test fails,
> because nothing was allocated.

Huh, that sounds like the optimizations are getting more and more evil
over the time.

> Introduce LTP_VAR_USED macro, that makes compiler aware of the
> variable and doesn't optimize it out.
> 
> Signed-off-by: Jan Stancek <jstancek@redhat.com>
> ---
>  include/tst_common.h                               | 2 ++
>  testcases/kernel/syscalls/mallinfo2/mallinfo2_01.c | 2 +-
>  2 files changed, 3 insertions(+), 1 deletion(-)
> 
> diff --git a/include/tst_common.h b/include/tst_common.h
> index b14bbae04077..3de826acd0ec 100644
> --- a/include/tst_common.h
> +++ b/include/tst_common.h
> @@ -13,6 +13,8 @@
>  #define LTP_ATTRIBUTE_UNUSED		__attribute__((unused))
>  #define LTP_ATTRIBUTE_UNUSED_RESULT	__attribute__((warn_unused_result))
>  
> +#define LTP_VAR_USED(p) asm volatile("" :: "m"(p)); p

Shouldn't __attribute__((used)) suffice?

>  #ifndef ARRAY_SIZE
>  # define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
>  #endif
> diff --git a/testcases/kernel/syscalls/mallinfo2/mallinfo2_01.c b/testcases/kernel/syscalls/mallinfo2/mallinfo2_01.c
> index 90cf4fcb3b89..51783fc22b80 100644
> --- a/testcases/kernel/syscalls/mallinfo2/mallinfo2_01.c
> +++ b/testcases/kernel/syscalls/mallinfo2/mallinfo2_01.c
> @@ -26,7 +26,7 @@ void test_mallinfo2(void)
>  	char *buf;
>  	size_t size = 2UL * 1024UL * 1024UL * 1024UL;
>  
> -	buf = malloc(size);
> +	LTP_VAR_USED(buf) = malloc(size);
>  
>  	if (!buf)
>  		tst_brk(TCONF, "Current system can not malloc 2G space, skip it");
> -- 
> 2.43.0
> 
> 
> -- 
> Mailing list info: https://lists.linux.it/listinfo/ltp

-- 
Cyril Hrubis
chrubis@suse.cz


More information about the ltp mailing list