riscv: add compile-time test into is_compat_task()
authorLeonardo Bras <leobras@redhat.com>
Wed, 3 Jan 2024 16:00:21 +0000 (13:00 -0300)
committerPalmer Dabbelt <palmer@rivosinc.com>
Tue, 19 Mar 2024 23:39:38 +0000 (16:39 -0700)
commit4c0b5a451675e9a95be98a16ddb889bb0486d2ad
tree09c9bf4c104c7bd2cfb5d09162e8c895c178dc01
parent9dc30419248f78dfebea7a554ec212dd1d82f8d7
riscv: add compile-time test into is_compat_task()

Currently several places will test for CONFIG_COMPAT before testing
is_compat_task(), probably in order to avoid a run-time test into the task
structure.

Since is_compat_task() is an inlined function, it would be helpful to add a
compile-time test of CONFIG_COMPAT, making sure it always returns zero when
the option is not enabled during the kernel build.

With this, the compiler is able to understand in build-time that
is_compat_task() will always return 0, and optimize-out some of the extra
code introduced by the option.

This will also allow removing a lot #ifdefs that were introduced, and make
the code more clean.

Signed-off-by: Leonardo Bras <leobras@redhat.com>
Reviewed-by: Guo Ren <guoren@kernel.org>
Reviewed-by: Andy Chiu <andy.chiu@sifive.com>
Link: https://lore.kernel.org/r/20240103160024.70305-5-leobras@redhat.com
Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
arch/riscv/include/asm/compat.h
arch/riscv/include/asm/elf.h
arch/riscv/include/asm/pgtable.h
arch/riscv/include/asm/processor.h