Received: by 2002:a05:6358:1087:b0:cb:c9d3:cd90 with SMTP id j7csp5784729rwi; Sun, 23 Oct 2022 11:53:39 -0700 (PDT) X-Google-Smtp-Source: AMsMyM74shflAIptD0xdFLX2UWlba3HfrWS5QY0J699JemNA1TYplR4vUzSEL5W85rq8j5nHWUCM X-Received: by 2002:a17:907:2c4f:b0:78d:eebe:f413 with SMTP id hf15-20020a1709072c4f00b0078deebef413mr24725193ejc.221.1666551219356; Sun, 23 Oct 2022 11:53:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666551219; cv=none; d=google.com; s=arc-20160816; b=LxvUEjXf4VyoO2P+e8Tc5OZq24cSQ39WTiElBkIs+790nzeUeTVKAIKC7n3ILDvHvW J2qZWjEkExTA4eCgaJMZFwpeexM+6S6dmehSsNTj+VGZ5y5gLxaEAVcsVDpUKgAcnG5W JPQmZCCY42R/QLOQXY+uwd4Z9sxfy9MxWyHuoCpyPutrFwgT3qg3xC6bxDeLRGik0zWN fIN53juMOmuSa+YEG3VAxt8hBDFOz4kcCmRK2PPvsv8wzQcOPgiM6MWyZCVncPTpmjFr Qo5V46slK0N2VtfFi7NL50K8mMXAo3OkvFj42ZwJmJUwIs9h8cQKtlcKvpGjOvLF/4Fj AM8A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=odAWkN4gFACvQCgtlD8vBRY9RqfQUlfFahgLNQiMtQo=; b=Xp90RYc4DUVHPiwM+FcM9Kf0c8CBf38D+/U7Ox6t98bducwOPaf8eaalPKGieDapTN fnJ5nlreUcdVxsWaHTQE7UrGmxrQMe5RoyCbAvJwSPFweuMw4U4AtM1S5gqGyac+3YmM DviTdAwxjQdKrPA0YsyP/rL3Abq7fjSirRbLqURQCnh1MYXBex4tCz5K+LFXwwe8tcNW 26cc9T68Df3XV0aVPeWuQalVkLXfSTxXBF5wQhaZ/xmtxKn463UjTZm5jYd4mNCHgGul HtRD9He82yMMs8t22Vtcvq2dyeBgGXchedRg9iEGABGHFrTPAgMQlNESSbtO4zCETxki toRA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=s+ISBcXl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id di22-20020a170906731600b007813594dc31si17177017ejc.523.2022.10.23.11.53.14; Sun, 23 Oct 2022 11:53:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=s+ISBcXl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230370AbiJWSgH (ORCPT + 99 others); Sun, 23 Oct 2022 14:36:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51460 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230166AbiJWSgF (ORCPT ); Sun, 23 Oct 2022 14:36:05 -0400 Received: from sin.source.kernel.org (sin.source.kernel.org [IPv6:2604:1380:40e1:4800::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3BDCC70E52 for ; Sun, 23 Oct 2022 11:36:00 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sin.source.kernel.org (Postfix) with ESMTPS id DA680CE0F2C for ; Sun, 23 Oct 2022 18:35:58 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 89BDCC433D6; Sun, 23 Oct 2022 18:35:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1666550156; bh=iCifHuat/D34dOyB7ohhjRHHVpFQPLMF05srQJ2flKE=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=s+ISBcXlS3A2uvsXyivddy0mKrJ4B1fZh/VELjzCbpzK4LIMa8dGXa5g+HFYEF8Nn iuzEt7V7l92kdATjRozhWEPw+if/MJSX/o3zaUxSrNIg1vUCYfU4BB3TlxSnw7thB9 e27zOU5aYY/exqm7kd9d6JDjnolr8cA/v4kPwTEwk//mPtAf4Go5ShJav4RceJ8BuU EMhd8bHu8Ub2ASZyITwvCIu3l9q4K0VQ0qpwzYeYfzERilV3CxnIqzcwOm2E7IokYJ 6Mnc44x3bCO5IpZAqr9/+Gjh2NElyyEXf8Uycw1oVFQPstzxkEhWiW+xySLBr7iBts gW7iVY6X2Ja5A== Date: Sun, 23 Oct 2022 19:35:51 +0100 From: Conor Dooley To: binglei wang Cc: Conor Dooley , paul.walmsley@sifive.com, palmer@dabbelt.com, aou@eecs.berkeley.edu, naveen.n.rao@linux.ibm.com, anil.s.keshavamurthy@intel.com, davem@davemloft.net, mhiramat@kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v8] rethook: add riscv rethook implementation Message-ID: References: <20220930081357.651914-1-l3b2w1@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Spam-Status: No, score=-7.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Oct 23, 2022 at 01:14:15AM +0800, binglei wang wrote: > Hi Conor, > I would appreciate if you can send the patch for me this time ! > As keen as mustard i am to see the patch applied and merged if there > is no something unsuitable. I was in the process of doing a resend on your behalf but I noticed some issues with the patch. Firstly, there's a whitespace error: Applying: rethook: add riscv rethook implementation /stuff/linux/.git/rebase-apply/patch:121: new blank line at EOF. + warning: 1 line adds whitespace errors. And there are a bunch of errors from checkpatch too: ./scripts/checkpatch.pl --strict -g HEAD CHECK: Please use a blank line after function/struct/union/enum declarations #107: FILE: arch/riscv/kernel/probes/rethook.c:15: +} +NOKPROBE_SYMBOL(arch_rethook_trampoline_callback); CHECK: Please don't use multiple blank lines #109: FILE: arch/riscv/kernel/probes/rethook.c:17: + + CHECK: Please use a blank line after function/struct/union/enum declarations #118: FILE: arch/riscv/kernel/probes/rethook.c:26: +} +NOKPROBE_SYMBOL(arch_rethook_prepare); WARNING: Improper SPDX comment style for 'arch/riscv/kernel/probes/rethook.h', please use '/*' instead #126: FILE: arch/riscv/kernel/probes/rethook.h:1: +// SPDX-License-Identifier: GPL-2.0-only WARNING: Missing or malformed SPDX-License-Identifier tag in line 1 #126: FILE: arch/riscv/kernel/probes/rethook.h:1: +// SPDX-License-Identifier: GPL-2.0-only total: 0 errors, 3 warnings, 3 checks, 96 lines checked I'm still happy to resend it on your behalf once these issues are fixed. Thanks, Conor. > > > > 2022-10-18 22:22 GMT+08:00, Conor Dooley : > > On Tue, Oct 18, 2022 at 10:08:55PM +0800, binglei wang wrote: > >> Hi Conor: > >> Thank you for your help to check the merging process for this patch. > >> > >> > Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed) > >> > -- links below jump to the message on this page -- > >> > [not found] <20220930081357.651914-1-l3b2w1@gmail.com> > >> I have no idea what this means, I guess maybe the way i sended the > >> patch was not right. > >> > >> I found the patch on the lore in this url, is this helpful ? > >> https://lore.kernel.org/lkml/20221002181035.490ad0155d741e39faa29716@kernel.org/ > > > > Hmm, looks like your patch made it to lkml itself but got rejected by > > linux-riscv which is hosted by infradead. It's missing here: > > https://lore.kernel.org/linux-riscv/CAJ3C4Kwj0yYS5JCPw=g0X9qiQhw04iKy_cTjc0x8iWdy0ay7bg@mail.gmail.com/T/#t > > > >> > >> > I'm not really sure what's happened there.. I can only see your v1 and > >> > your v4 on lore/patchwork. > >> I find all my commits from v1 to v8 in this addr > >> https://lore.kernel.org/lkml/?q=l3b2w1 > >> > >> Should I resend the patch as a last resort ? > > > > Eh, I guess you could try (and CC patches@lists.linux.dev). I'm not sure > > if that'll help at all though.. At worst, if that doesn't work I could > > possibly send the patches for you. Or if you think you may end up doing > > more upstream work you could always apply for an @linux.dev account? > > See https://korg.docs.kernel.org/linuxdev.html for more information on > > that. > > > >> > >> Binglei Wang > >> Best wishes. > >> > >> Conor Dooley 于2022年10月17日周一 22:58写道: > >> > > >> > On Mon, Oct 17, 2022 at 10:31:28PM +0800, binglei wang wrote: > >> > > Hi Conor, > >> > > could you please help me to push forward merging process of this > >> > > patch > >> > > into the 6.1 ? Thank you! > >> > > >> > Hey Binglei, > >> > Unfortunately it is too late for v6.1 (the merge window closed on > >> > Sunday, Palmer sent his second PR on Friday) but I don't see why this > >> > should not be picked for v6.2. I tried last week & again just now to > >> > check the status of this patch on patchwork but I cannot find it there. > >> > Similarly, the patch does not appear on lore: > >> > https://lore.kernel.org/linux-riscv/CAJ3C4KzyAR7dKYFBKHzFEXr-dzr-JMGRFVx+dybMhRPy0uHUgA@mail.gmail.com/T/#t > >> > Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed) > >> > -- links below jump to the message on this page -- > >> > [not found] <20220930081357.651914-1-l3b2w1@gmail.com> > >> > 2022-10-02 9:10 ` [PATCH v8] rethook: add riscv rethook implementation > >> > Masami Hiramatsu > >> > 2022-10-02 16:39 ` Conor Dooley > >> > 2022-10-17 14:31 ` binglei wang > >> > > >> > I'm not really sure what's happened there.. I can only see your v1 and > >> > your v4 on lore/patchwork. Maybe take a look if you changed anything > >> > between versions & try resending as v9? > >> > > >> > HTH, > >> > Conor. > >> > > >> > > > >> > > Binglei Wang > >> > > Best wishes. > >> > > > >> > > > >> > > On 2022-10-03 00:39, Conor Dooley wrote: > >> > > > Hey Binglei, > >> > > > I am not qualified to give you an actual R-b on this patch, but I > >> > > > see > >> > > > you did get one from Masami who very much is! > >> > > > > >> > > > That said, the patch looks a lot better (and much simpler!) now. > >> > > > Thanks > >> > > > for sticking with it despite the initial issues with your email > >> > > > setup > >> > > > and the submission process. > >> > > > > >> > > > Thanks, > >> > > > Conor. > >> > > > > >> > > > On Fri, Sep 30, 2022 at 04:13:57PM +0800, Binglei Wang wrote: > >> > > >> From: Binglei Wang > >> > > >> > >> > > >> Implement the kretprobes on riscv arch by using rethook machenism > >> > > >> which abstracts general kretprobe info into a struct rethook_node > >> > > >> to be embedded in the struct kretprobe_instance. > >> > > >> > >> > > >> Signed-off-by: Binglei Wang > >> > > >> --- > >> > > >> > >> > > >> Notes: > >> > > >> v8: Add the omitted rethook.h > >> > > >> v7: Add the changelog. > >> > > >> v6: Remove the kretprobes trampoline. > >> > > >> v5: Trt to fix robot compiling error and warnings. > >> > > >> v4: Add patch version number. > >> > > >> v3: Trt to fix robot compiling error and warnings. > >> > > >> v2: Add comit log to explain reasons behind changes. > >> > > >> Use my personal email instead of work email > >> > > >> to avoid the attachments of company informaton. > >> > > >> Make the kprobes_trampoline.S code to be shared. > >> > > >> v1: Add riscv rethook implementation. > >> > > >> > >> > > >> arch/riscv/Kconfig | 1 + > >> > > >> arch/riscv/include/asm/kprobes.h | 2 -- > >> > > >> arch/riscv/kernel/probes/Makefile | 2 +- > >> > > >> arch/riscv/kernel/probes/kprobes.c | 13 --------- > >> > > >> arch/riscv/kernel/probes/rethook.c | 27 > >> > > >> +++++++++++++++++++ > >> > > >> arch/riscv/kernel/probes/rethook.h | 8 ++++++ > >> > > >> ...obes_trampoline.S => rethook_trampoline.S} | 6 ++--- > >> > > >> 7 files changed, 40 insertions(+), 19 deletions(-) > >> > > >> create mode 100644 arch/riscv/kernel/probes/rethook.c > >> > > >> create mode 100644 arch/riscv/kernel/probes/rethook.h > >> > > >> rename arch/riscv/kernel/probes/{kprobes_trampoline.S => > >> > > >> rethook_trampoline.S} (94%) > >> > > >> > >> > > >> diff --git a/arch/riscv/Kconfig b/arch/riscv/Kconfig > >> > > >> index 59d18881f..bfb66cdc5 100644 > >> > > >> --- a/arch/riscv/Kconfig > >> > > >> +++ b/arch/riscv/Kconfig > >> > > >> @@ -97,6 +97,7 @@ config RISCV > >> > > >> select HAVE_KPROBES if !XIP_KERNEL > >> > > >> select HAVE_KPROBES_ON_FTRACE if !XIP_KERNEL > >> > > >> select HAVE_KRETPROBES if !XIP_KERNEL > >> > > >> + select HAVE_RETHOOK if !XIP_KERNEL > >> > > >> select HAVE_MOVE_PMD > >> > > >> select HAVE_MOVE_PUD > >> > > >> select HAVE_PCI > >> > > >> diff --git a/arch/riscv/include/asm/kprobes.h > >> > > >> b/arch/riscv/include/asm/kprobes.h > >> > > >> index 217ef89f2..e7882ccb0 100644 > >> > > >> --- a/arch/riscv/include/asm/kprobes.h > >> > > >> +++ b/arch/riscv/include/asm/kprobes.h > >> > > >> @@ -40,8 +40,6 @@ void arch_remove_kprobe(struct kprobe *p); > >> > > >> int kprobe_fault_handler(struct pt_regs *regs, unsigned int > >> > > >> trapnr); > >> > > >> bool kprobe_breakpoint_handler(struct pt_regs *regs); > >> > > >> bool kprobe_single_step_handler(struct pt_regs *regs); > >> > > >> -void __kretprobe_trampoline(void); > >> > > >> -void __kprobes *trampoline_probe_handler(struct pt_regs *regs); > >> > > >> > >> > > >> #endif /* CONFIG_KPROBES */ > >> > > >> #endif /* _ASM_RISCV_KPROBES_H */ > >> > > >> diff --git a/arch/riscv/kernel/probes/Makefile > >> > > >> b/arch/riscv/kernel/probes/Makefile > >> > > >> index 7f0840dcc..c40139e9c 100644 > >> > > >> --- a/arch/riscv/kernel/probes/Makefile > >> > > >> +++ b/arch/riscv/kernel/probes/Makefile > >> > > >> @@ -1,6 +1,6 @@ > >> > > >> # SPDX-License-Identifier: GPL-2.0 > >> > > >> obj-$(CONFIG_KPROBES) += kprobes.o decode-insn.o > >> > > >> simulate-insn.o > >> > > >> -obj-$(CONFIG_KPROBES) += kprobes_trampoline.o > >> > > >> +obj-$(CONFIG_RETHOOK) += rethook.o > >> > > >> rethook_trampoline.o > >> > > >> obj-$(CONFIG_KPROBES_ON_FTRACE) += ftrace.o > >> > > >> obj-$(CONFIG_UPROBES) += uprobes.o decode-insn.o > >> > > >> simulate-insn.o > >> > > >> CFLAGS_REMOVE_simulate-insn.o = $(CC_FLAGS_FTRACE) > >> > > >> diff --git a/arch/riscv/kernel/probes/kprobes.c > >> > > >> b/arch/riscv/kernel/probes/kprobes.c > >> > > >> index e6e950b7c..f21592d20 100644 > >> > > >> --- a/arch/riscv/kernel/probes/kprobes.c > >> > > >> +++ b/arch/riscv/kernel/probes/kprobes.c > >> > > >> @@ -345,19 +345,6 @@ int __init > >> > > >> arch_populate_kprobe_blacklist(void) > >> > > >> return ret; > >> > > >> } > >> > > >> > >> > > >> -void __kprobes __used *trampoline_probe_handler(struct pt_regs > >> > > >> *regs) > >> > > >> -{ > >> > > >> - return (void *)kretprobe_trampoline_handler(regs, NULL); > >> > > >> -} > >> > > >> - > >> > > >> -void __kprobes arch_prepare_kretprobe(struct kretprobe_instance > >> > > >> *ri, > >> > > >> - struct pt_regs *regs) > >> > > >> -{ > >> > > >> - ri->ret_addr = (kprobe_opcode_t *)regs->ra; > >> > > >> - ri->fp = NULL; > >> > > >> - regs->ra = (unsigned long) &__kretprobe_trampoline; > >> > > >> -} > >> > > >> - > >> > > >> int __kprobes arch_trampoline_kprobe(struct kprobe *p) > >> > > >> { > >> > > >> return 0; > >> > > >> diff --git a/arch/riscv/kernel/probes/rethook.c > >> > > >> b/arch/riscv/kernel/probes/rethook.c > >> > > >> new file mode 100644 > >> > > >> index 000000000..cbd0da059 > >> > > >> --- /dev/null > >> > > >> +++ b/arch/riscv/kernel/probes/rethook.c > >> > > >> @@ -0,0 +1,27 @@ > >> > > >> +// SPDX-License-Identifier: GPL-2.0-only > >> > > >> +/* > >> > > >> + * Generic return hook for riscv. > >> > > >> + */ > >> > > >> + > >> > > >> +#include > >> > > >> +#include > >> > > >> +#include "rethook.h" > >> > > >> + > >> > > >> +/* This is called from arch_rethook_trampoline() */ > >> > > >> +unsigned long __used arch_rethook_trampoline_callback(struct > >> > > >> pt_regs *regs) > >> > > >> +{ > >> > > >> + return rethook_trampoline_handler(regs, regs->s0); > >> > > >> +} > >> > > >> +NOKPROBE_SYMBOL(arch_rethook_trampoline_callback); > >> > > >> + > >> > > >> + > >> > > >> +void arch_rethook_prepare(struct rethook_node *rhn, struct pt_regs > >> > > >> *regs, bool mcount) > >> > > >> +{ > >> > > >> + rhn->ret_addr = regs->ra; > >> > > >> + rhn->frame = regs->s0; > >> > > >> + > >> > > >> + /* replace return addr with trampoline */ > >> > > >> + regs->ra = (unsigned long)arch_rethook_trampoline; > >> > > >> +} > >> > > >> +NOKPROBE_SYMBOL(arch_rethook_prepare); > >> > > >> + > >> > > >> diff --git a/arch/riscv/kernel/probes/rethook.h > >> > > >> b/arch/riscv/kernel/probes/rethook.h > >> > > >> new file mode 100644 > >> > > >> index 000000000..cc573d701 > >> > > >> --- /dev/null > >> > > >> +++ b/arch/riscv/kernel/probes/rethook.h > >> > > >> @@ -0,0 +1,8 @@ > >> > > >> +// SPDX-License-Identifier: GPL-2.0-only > >> > > >> +#ifndef __RISCV_RETHOOK_H > >> > > >> +#define __RISCV_RETHOOK_H > >> > > >> + > >> > > >> +unsigned long arch_rethook_trampoline_callback(struct pt_regs > >> > > >> *regs); > >> > > >> +void arch_rethook_prepare(struct rethook_node *rhn, struct pt_regs > >> > > >> *regs, bool mcount); > >> > > >> + > >> > > >> +#endif > >> > > >> diff --git a/arch/riscv/kernel/probes/kprobes_trampoline.S > >> > > >> b/arch/riscv/kernel/probes/rethook_trampoline.S > >> > > >> similarity index 94% > >> > > >> rename from arch/riscv/kernel/probes/kprobes_trampoline.S > >> > > >> rename to arch/riscv/kernel/probes/rethook_trampoline.S > >> > > >> index 7bdb09ded..21bac92a1 100644 > >> > > >> --- a/arch/riscv/kernel/probes/kprobes_trampoline.S > >> > > >> +++ b/arch/riscv/kernel/probes/rethook_trampoline.S > >> > > >> @@ -75,13 +75,13 @@ > >> > > >> REG_L x31, PT_T6(sp) > >> > > >> .endm > >> > > >> > >> > > >> -ENTRY(__kretprobe_trampoline) > >> > > >> +ENTRY(arch_rethook_trampoline) > >> > > >> addi sp, sp, -(PT_SIZE_ON_STACK) > >> > > >> save_all_base_regs > >> > > >> > >> > > >> move a0, sp /* pt_regs */ > >> > > >> > >> > > >> - call trampoline_probe_handler > >> > > >> + call arch_rethook_trampoline_callback > >> > > >> > >> > > >> /* use the result as the return-address */ > >> > > >> move ra, a0 > >> > > >> @@ -90,4 +90,4 @@ ENTRY(__kretprobe_trampoline) > >> > > >> addi sp, sp, PT_SIZE_ON_STACK > >> > > >> > >> > > >> ret > >> > > >> -ENDPROC(__kretprobe_trampoline) > >> > > >> +ENDPROC(arch_rethook_trampoline) > >> > > >> -- > >> > > >> 2.27.0 > >> > > >> > >> > > > >> > > _______________________________________________ > >> > > linux-riscv mailing list > >> > > linux-riscv@lists.infradead.org > >> > > http://lists.infradead.org/mailman/listinfo/linux-riscv > >> > > > > > > _______________________________________________ > linux-riscv mailing list > linux-riscv@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-riscv