Hi Dmitry,

Thanks for the patch.

"Dmitry V. Levin" <l...@altlinux.org> writes:
> From: Elvira Khabirova <lineprin...@altlinux.org>
>
> Arch code should use tracehook_*() helpers as documented
> in include/linux/tracehook.h,
> ptrace_report_syscall() is not expected to be used outside that file.
>
> Co-authored-by: Dmitry V. Levin <l...@altlinux.org>
> Fixes: 5521eb4bca2d ("powerpc/ptrace: Add support for PTRACE_SYSEMU")
> Signed-off-by: Elvira Khabirova <lineprin...@altlinux.org>
> Signed-off-by: Dmitry V. Levin <l...@altlinux.org>
> ---
>
> v3: add a descriptive comment
> v2: explicitly ignore tracehook_report_syscall_entry() return code
>
>  arch/powerpc/kernel/ptrace.c | 7 ++++++-
>  1 file changed, 6 insertions(+), 1 deletion(-)
>
> diff --git a/arch/powerpc/kernel/ptrace.c b/arch/powerpc/kernel/ptrace.c
> index afb819f4ca68..e84220d91bbd 100644
> --- a/arch/powerpc/kernel/ptrace.c
> +++ b/arch/powerpc/kernel/ptrace.c
> @@ -3266,7 +3266,12 @@ long do_syscall_trace_enter(struct pt_regs *regs)
>       user_exit();
>  
>       if (test_thread_flag(TIF_SYSCALL_EMU)) {
> -             ptrace_report_syscall(regs);
> +             /*
> +              * A nonzero return code from tracehook_report_syscall_entry()
> +              * tells us to prevent the syscall execution, but we are not
> +              * going to execute it anyway.
> +              */
> +             (void) tracehook_report_syscall_entry(regs);

Unfortunately the (void) cast doesn't work to suppress the must check
warning.

  arch/powerpc/kernel/ptrace.c:3274:3: error: ignoring return value of 
'tracehook_report_syscall_entry', declared with attribute warn_unused_result 
[-Werror=unused-result]

AFAIK we don't have a way to suppress that.

I guess we should rewrite it to only call
tracehook_report_syscall_entry() once, like x86 does.

I'll try and get a patch for that done & tested.

cheers

Reply via email to