Re: Re: [PATCH v3 1/7] riscv: ftrace: support fastcc in Clang for WITH_ARGS

From: Evgenii Shatokhin
Date: Tue Dec 03 2024 - 10:26:02 EST


Hi,

On 03.12.2024 15:05, Björn Töpel wrote:

Andy Chiu <andybnac@xxxxxxxxx> writes:

From: Andy Chiu <andy.chiu@xxxxxxxxxx>

Some caller-saved registers which are not defined as function arguments
in the ABI can still be passed as arguments when the kernel is compiled
with Clang. As a result, we must save and restore those registers to
prevent ftrace from clobbering them.

- [1]: https://reviews.llvm.org/D68559

Reported-by: Evgenii Shatokhin <e.shatokhin@xxxxxxxxx>
Closes: https://lore.kernel.org/linux-riscv/7e7c7914-445d-426d-89a0-59a9199c45b1@xxxxxxxxx/
Acked-by: Nathan Chancellor <nathan@xxxxxxxxxx>
Signed-off-by: Andy Chiu <andy.chiu@xxxxxxxxxx>

Fixes tag?

As far as I understand it, Ftrace for RISC-V has had this problem since support for FTRACE_WITH_REGS was added. FTRACE_WITH_ARGS inherited it.

So, it should probably be as follows:

Fixes: aea4c671fb98 ("riscv/ftrace: Add DYNAMIC_FTRACE_WITH_REGS support")

It is more of a workaround rather than a fix though, because it is still undecided where the problem is, in the kernel or in LLVM/clang. That discussion went nowhere, unfortunately, so it is better to use a workaround and move on, IMO.


Reviewed-by: Björn Töpel <bjorn@xxxxxxxxxxxx>


Regards,
Evgenii