Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp4778490rwb; Tue, 17 Jan 2023 05:31:13 -0800 (PST) X-Google-Smtp-Source: AMrXdXsOcnqNcS1Mtcu49jjSlwumdicMaA07J7n9Dw5w4p4PB/Hp9QrgUReBCF32lRVW0nklesGK X-Received: by 2002:a17:902:cccb:b0:192:b927:39d1 with SMTP id z11-20020a170902cccb00b00192b92739d1mr3676834ple.3.1673962272959; Tue, 17 Jan 2023 05:31:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673962272; cv=none; d=google.com; s=arc-20160816; b=SJvqDBLTgPOMH0x5ktuP0VW24pUKnbATGZTvSk3TOEHkI/eLuvMw4vt3eX+N3YH/zU omuo4CZgU0Fd0JnUNwkmhNNzJTX2i7e4a89U/cmbJgHal4WQ3jcHHCFpF6iGGHu/xsyF fr33cKE+RqQQGWGLP2NCBzeXC712cdVvP678+wfkfzGs44198muBxPdSDmXTZy7utB5K Y2nY/JDBQLpQgtQB2rPu51FXJTbz5Wmj9yXV9Fi8YAVWYiMcKWf2kpD+QEmYdZLECn9t v9DgognSapec31w+wg1Xcn/ZF2JwQTUPqPWXow7+9O78CSIdmtUOxK8Lzs6z71zWXNrj +t0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=HWxnzh6UTvudLwf3K4PlegtuzcCCHkSoFSTSPm922Nw=; b=YPLW7KwAYQIPs3ar7vbjjytzlRseNKHTR4JCBXajXI5RzQVSH2SvVBPto3Xp0oaunE U9yzYEWhUjBds+32gLRhb7m8UEGi6vh5bJepWh+0IxgB34AquQEcTbIHZDCHfW60dAky 36gJZtrfXMdSYPaQeLXI2/0E4ZPKGg63gIQB7aj73rYZlQmYCZHz+sfcNU3ol/E50Jmn JHus5hz27AMpJX7L+TKDcIDGC85m1W0ULnRDm+vVa+CQv/UajSbDxErvlmuqOxpF7P3k Njz2tUjIeWMbc2fKyVaQJZrz3kjBT3Y+o37IU5wRkyfWacMA9C2au4uVWlEuYKP5h022 h4kw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@yadro.com header.s=mta-01 header.b="sF/xKMLF"; 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=yadro.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id d17-20020a170902aa9100b00189b92d9921si1531944plr.313.2023.01.17.05.31.06; Tue, 17 Jan 2023 05:31:12 -0800 (PST) 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=@yadro.com header.s=mta-01 header.b="sF/xKMLF"; 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=yadro.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237081AbjAQNRG (ORCPT + 50 others); Tue, 17 Jan 2023 08:17:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53840 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236861AbjAQNQ7 (ORCPT ); Tue, 17 Jan 2023 08:16:59 -0500 Received: from mta-01.yadro.com (mta-02.yadro.com [89.207.88.252]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id ECA641CAD8 for ; Tue, 17 Jan 2023 05:16:57 -0800 (PST) Received: from mta-01.yadro.com (localhost.localdomain [127.0.0.1]) by mta-01.yadro.com (Proxmox) with ESMTP id 048FE341A7F; Tue, 17 Jan 2023 16:16:56 +0300 (MSK) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yadro.com; h=cc :cc:content-transfer-encoding:content-type:content-type:date :from:from:in-reply-to:message-id:mime-version:references :reply-to:subject:subject:to:to; s=mta-01; bh=HWxnzh6UTvudLwf3K4 PlegtuzcCCHkSoFSTSPm922Nw=; b=sF/xKMLFxuot8BC3xynDoykpef70d60pPA 31EkkMWPYyiwWKZuAP+oASDsvKtRMYHhIxdGa+KxYh2Imy7+VkSjbPNiMUBfqeNh /EDFLIYw9ZxppAblkdwF2UaMcK73kFF2crPfC2Rb0jxE6TMkozYL5oaLzBcMNenR bIdC5rlao= Received: from T-EXCH-08.corp.yadro.com (unknown [172.17.10.14]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mta-01.yadro.com (Proxmox) with ESMTPS id EEBBC341A78; Tue, 17 Jan 2023 16:16:55 +0300 (MSK) Received: from [10.199.21.212] (10.199.21.212) by T-EXCH-08.corp.yadro.com (172.17.11.58) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.2.1118.9; Tue, 17 Jan 2023 16:16:55 +0300 Message-ID: <1514c929-5a98-0e58-e038-9bb4537d5189@yadro.com> Date: Tue, 17 Jan 2023 16:16:54 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.4.2 Subject: Re: [PATCH -next V7 6/7] samples: ftrace: Add riscv support for SAMPLE_FTRACE_DIRECT[_MULTI] Content-Language: en-US To: Song Shuai CC: , , , , , , , , , , , , , , References: <20230112090603.1295340-1-guoren@kernel.org> <20230112090603.1295340-7-guoren@kernel.org> From: Evgenii Shatokhin In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-Originating-IP: [10.199.21.212] X-ClientProxiedBy: T-EXCH-01.corp.yadro.com (172.17.10.101) To T-EXCH-08.corp.yadro.com (172.17.11.58) X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,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 Hi, Song, On 17.01.2023 12:32, Song Shuai wrote: > > Hi, Evgenii: > > Evgenii Shatokhin 于2023年1月16日周一 14:30写道: > >> >> Hi, >> >> On 12.01.2023 12:06, guoren@kernel.org wrote: >>> From: Song Shuai >>> >>> select HAVE_SAMPLE_FTRACE_DIRECT and HAVE_SAMPLE_FTRACE_DIRECT_MULTI >>> for ARCH_RV64I in arch/riscv/Kconfig. And add riscv asm code for >>> the ftrace-direct*.c files in samples/ftrace/. >>> >>> Signed-off-by: Song Shuai >>> Tested-by: Guo Ren >>> Signed-off-by: Guo Ren >>> --- >>> arch/riscv/Kconfig | 2 ++ >>> samples/ftrace/ftrace-direct-modify.c | 33 ++++++++++++++++++ >>> samples/ftrace/ftrace-direct-multi-modify.c | 37 +++++++++++++++++++++ >>> samples/ftrace/ftrace-direct-multi.c | 22 ++++++++++++ >>> samples/ftrace/ftrace-direct-too.c | 26 +++++++++++++++ >>> samples/ftrace/ftrace-direct.c | 22 ++++++++++++ >>> 6 files changed, 142 insertions(+) >> >> The samples were built OK now, but ftrace-direct-multi and >> ftrace-direct-multi-modify report incorrect values of ip/pc it seems. >> >> I ran 'insmod ftrace-direct-multi.ko', waited a little and then checked >> the messages in the trace: >> >> # TASK-PID CPU# ||||| TIMESTAMP FUNCTION >> # | | | ||||| | | >> migration/1-19 [001] ..... 3858.532131: my_direct_func1: my >> direct func1 ip 0 >> migration/0-15 [000] d.s2. 3858.532136: my_direct_func1: my >> direct func1 ip ff60000001ba9600 >> migration/0-15 [000] d..2. 3858.532204: my_direct_func1: my >> direct func1 ip ff60000003334d00 >> migration/0-15 [000] ..... 3858.532232: my_direct_func1: my >> direct func1 ip 0 >> rcu_sched-14 [001] ..... 3858.532257: my_direct_func1: my >> direct func1 ip 0 >> insmod-415 [000] ..... 3858.532270: my_direct_func1: my >> direct func1 ip 7fffffffffffffff >> -0 [001] ..s1. 3858.539051: my_direct_func1: my >> direct func1 ip ff60000001ba9600 >> -0 [001] dns2. 3858.539124: my_direct_func1: my >> direct func1 ip ff60000001ba9600 >> rcu_sched-14 [001] ..... 3858.539208: my_direct_func1: my >> direct func1 ip 0 >> [...] >> >> If I understand it right, my_direct_func1() should print the address of >> some location in the code, probably - at the beginning of the traced >> functions. >> >> The printed values (0x0, 0x7fffffffffffffff, ...) are not valid code >> addresses. >> > The invalid code address is only printed by accessing the schedule() > function's first argument whose address stores in a0 register. > While schedule() actually has no parameter declared, so my_direct_func > just prints the a0 in the context of the schedule()'s caller and > the address maybe varies depending on the caller. > > I can't really understand why tracing the first argument of the > schedule() function, but it seems nonsense at this point. The question is, what should be passed as the argument(s) of my_direct_func() in this particular sample module. The kernel docs and commit logs seem to contain no info on that. With direct functions, I suppose, the trampoline can pass anything it wants to my_direct_func(), not just the arguments of the traced function. I'd check what these sample modules do on x86 and would try to match that behaviour on RISC-V. > > As for this patch, it just impls a simple mcount (direct_caller) to > trace kernel functions, and basically saves the necessary ABI, > call the tracing function, and restores the ABI, just like other arches do. > so It shouldn't be blamed. > > I started an independent patch to replace schedule with kick_process > to make these samples more reasonable. And It has no conflict with the > current patch, so we can go on. > > Link: https://lore.kernel.org/linux-kernel/20230117091101.3669996-1-suagrfillet@gmail.com/T/#u > >> The same issue is with ftrace-direct-multi-modify.ko. >> >> Is anything missing here? >> >>> >>> diff --git a/arch/riscv/Kconfig b/arch/riscv/Kconfig >>> index 307a9f413edd..e944af44f681 100644 >>> --- a/arch/riscv/Kconfig >>> +++ b/arch/riscv/Kconfig >>> @@ -112,6 +112,8 @@ config RISCV >>> select HAVE_POSIX_CPU_TIMERS_TASK_WORK >>> select HAVE_REGS_AND_STACK_ACCESS_API >>> select HAVE_FUNCTION_ARG_ACCESS_API >>> + select HAVE_SAMPLE_FTRACE_DIRECT >>> + select HAVE_SAMPLE_FTRACE_DIRECT_MULTI >>> select HAVE_STACKPROTECTOR >>> select HAVE_SYSCALL_TRACEPOINTS >>> select HAVE_RSEQ >>> diff --git a/samples/ftrace/ftrace-direct-modify.c b/samples/ftrace/ftrace-direct-modify.c >>> index de5a0f67f320..be7bf472c3c7 100644 >>> --- a/samples/ftrace/ftrace-direct-modify.c >>> +++ b/samples/ftrace/ftrace-direct-modify.c >>> @@ -23,6 +23,39 @@ extern void my_tramp2(void *); >>> >>> static unsigned long my_ip = (unsigned long)schedule; >>> >>> +#ifdef CONFIG_RISCV >>> + >>> +asm (" .pushsection .text, \"ax\", @progbits\n" >>> +" .type my_tramp1, @function\n" >>> +" .globl my_tramp1\n" >>> +" my_tramp1:\n" >>> +" addi sp,sp,-16\n" >>> +" sd t0,0(sp)\n" >>> +" sd ra,8(sp)\n" >>> +" call my_direct_func1\n" >>> +" ld t0,0(sp)\n" >>> +" ld ra,8(sp)\n" >>> +" addi sp,sp,16\n" >>> +" jr t0\n" >>> +" .size my_tramp1, .-my_tramp1\n" >>> + >>> +" .type my_tramp2, @function\n" >>> +" .globl my_tramp2\n" >>> +" my_tramp2:\n" >>> +" addi sp,sp,-16\n" >>> +" sd t0,0(sp)\n" >>> +" sd ra,8(sp)\n" >>> +" call my_direct_func2\n" >>> +" ld t0,0(sp)\n" >>> +" ld ra,8(sp)\n" >>> +" addi sp,sp,16\n" >>> +" jr t0\n" >>> +" .size my_tramp2, .-my_tramp2\n" >>> +" .popsection\n" >>> +); >>> + >>> +#endif /* CONFIG_RISCV */ >>> + >>> #ifdef CONFIG_X86_64 >>> >>> #include >>> diff --git a/samples/ftrace/ftrace-direct-multi-modify.c b/samples/ftrace/ftrace-direct-multi-modify.c >>> index d52370cad0b6..10884bf418f7 100644 >>> --- a/samples/ftrace/ftrace-direct-multi-modify.c >>> +++ b/samples/ftrace/ftrace-direct-multi-modify.c >>> @@ -21,6 +21,43 @@ void my_direct_func2(unsigned long ip) >>> extern void my_tramp1(void *); >>> extern void my_tramp2(void *); >>> >>> +#ifdef CONFIG_RISCV >>> + >>> +asm (" .pushsection .text, \"ax\", @progbits\n" >>> +" .type my_tramp1, @function\n" >>> +" .globl my_tramp1\n" >>> +" my_tramp1:\n" >>> +" addi sp,sp,-24\n" >>> +" sd a0,0(sp)\n" >>> +" sd t0,8(sp)\n" >>> +" sd ra,16(sp)\n" >>> +" call my_direct_func1\n" >>> +" ld a0,0(sp)\n" >>> +" ld t0,8(sp)\n" >>> +" ld ra,16(sp)\n" >>> +" addi sp,sp,24\n" >>> +" jr t0\n" >>> +" .size my_tramp1, .-my_tramp1\n" >>> + >>> +" .type my_tramp2, @function\n" >>> +" .globl my_tramp2\n" >>> +" my_tramp2:\n" >>> +" addi sp,sp,-24\n" >>> +" sd a0,0(sp)\n" >>> +" sd t0,8(sp)\n" >>> +" sd ra,16(sp)\n" >>> +" call my_direct_func2\n" >>> +" ld a0,0(sp)\n" >>> +" ld t0,8(sp)\n" >>> +" ld ra,16(sp)\n" >>> +" addi sp,sp,24\n" >>> +" jr t0\n" >>> +" .size my_tramp2, .-my_tramp2\n" >>> +" .popsection\n" >>> +); >>> + >>> +#endif /* CONFIG_RISCV */ >>> + >>> #ifdef CONFIG_X86_64 >>> >>> #include >>> diff --git a/samples/ftrace/ftrace-direct-multi.c b/samples/ftrace/ftrace-direct-multi.c >>> index ec1088922517..a35bf43bf6d7 100644 >>> --- a/samples/ftrace/ftrace-direct-multi.c >>> +++ b/samples/ftrace/ftrace-direct-multi.c >>> @@ -16,6 +16,28 @@ void my_direct_func(unsigned long ip) >>> >>> extern void my_tramp(void *); >>> >>> +#ifdef CONFIG_RISCV >>> + >>> +asm (" .pushsection .text, \"ax\", @progbits\n" >>> +" .type my_tramp, @function\n" >>> +" .globl my_tramp\n" >>> +" my_tramp:\n" >>> +" addi sp,sp,-24\n" >>> +" sd a0,0(sp)\n" >>> +" sd t0,8(sp)\n" >>> +" sd ra,16(sp)\n" >>> +" call my_direct_func\n" >>> +" ld a0,0(sp)\n" >>> +" ld t0,8(sp)\n" >>> +" ld ra,16(sp)\n" >>> +" addi sp,sp,24\n" >>> +" jr t0\n" >>> +" .size my_tramp, .-my_tramp\n" >>> +" .popsection\n" >>> +); >>> + >>> +#endif /* CONFIG_RISCV */ >>> + >>> #ifdef CONFIG_X86_64 >>> >>> #include >>> diff --git a/samples/ftrace/ftrace-direct-too.c b/samples/ftrace/ftrace-direct-too.c >>> index e13fb59a2b47..3b62e33c2e6d 100644 >>> --- a/samples/ftrace/ftrace-direct-too.c >>> +++ b/samples/ftrace/ftrace-direct-too.c >>> @@ -18,6 +18,32 @@ void my_direct_func(struct vm_area_struct *vma, >>> >>> extern void my_tramp(void *); >>> >>> +#ifdef CONFIG_RISCV >>> + >>> +asm (" .pushsection .text, \"ax\", @progbits\n" >>> +" .type my_tramp, @function\n" >>> +" .globl my_tramp\n" >>> +" my_tramp:\n" >>> +" addi sp,sp,-40\n" >>> +" sd a0,0(sp)\n" >>> +" sd a1,8(sp)\n" >>> +" sd a2,16(sp)\n" >>> +" sd t0,24(sp)\n" >>> +" sd ra,32(sp)\n" >>> +" call my_direct_func\n" >>> +" ld a0,0(sp)\n" >>> +" ld a1,8(sp)\n" >>> +" ld a2,16(sp)\n" >>> +" ld t0,24(sp)\n" >>> +" ld ra,32(sp)\n" >>> +" addi sp,sp,40\n" >>> +" jr t0\n" >>> +" .size my_tramp, .-my_tramp\n" >>> +" .popsection\n" >>> +); >>> + >>> +#endif /* CONFIG_RISCV */ >>> + >>> #ifdef CONFIG_X86_64 >>> >>> #include >>> diff --git a/samples/ftrace/ftrace-direct.c b/samples/ftrace/ftrace-direct.c >>> index 1f769d0db20f..2cfe5a7d2d70 100644 >>> --- a/samples/ftrace/ftrace-direct.c >>> +++ b/samples/ftrace/ftrace-direct.c >>> @@ -15,6 +15,28 @@ void my_direct_func(struct task_struct *p) >>> >>> extern void my_tramp(void *); >>> >>> +#ifdef CONFIG_RISCV >>> + >>> +asm (" .pushsection .text, \"ax\", @progbits\n" >>> +" .type my_tramp, @function\n" >>> +" .globl my_tramp\n" >>> +" my_tramp:\n" >>> +" addi sp,sp,-24\n" >>> +" sd a0,0(sp)\n" >>> +" sd t0,8(sp)\n" >>> +" sd ra,16(sp)\n" >>> +" call my_direct_func\n" >>> +" ld a0,0(sp)\n" >>> +" ld t0,8(sp)\n" >>> +" ld ra,16(sp)\n" >>> +" addi sp,sp,24\n" >>> +" jr t0\n" >>> +" .size my_tramp, .-my_tramp\n" >>> +" .popsection\n" >>> +); >>> + >>> +#endif /* CONFIG_RISCV */ >>> + >>> #ifdef CONFIG_X86_64 >>> >>> #include >>> -- >>> 2.36.1 > > -- > Thanks, > Song > Regards, Evgenii