Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp6643167rwb; Wed, 18 Jan 2023 07:41:18 -0800 (PST) X-Google-Smtp-Source: AMrXdXt3+M2gDCEZNG1cHzMO4xjfw3Znwcz2HWYDN50O66W7WQoFtE4L77k4qdzv3DuPwr5a5qqU X-Received: by 2002:a17:906:3b01:b0:84d:4767:734 with SMTP id g1-20020a1709063b0100b0084d47670734mr21019293ejf.6.1674056478736; Wed, 18 Jan 2023 07:41:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1674056478; cv=none; d=google.com; s=arc-20160816; b=BbsJht5SzBqBYq5sKJrnVNO2863Q7xFaebZQ0eeap6K2MFb95nfsxb2e4L8otDIt+2 71y6m6dp9fnpbQRvwYVbGGIemJws9cLPE0ef1RwCcvByImbl0NfGpBrhmHFp44iUdhOO Qg/lRfQReTot0LmmGjbLNKCcDCm6383rFOk1igSuCl6LFaCeoKzfnM5EEW7dEMshFbxc CIQB0YWiBr3tlr4gSqHmqLz4601WPpX3YDSp+QKeDKTe1aPqFKpecvias+NcLA9N+T6Q wQEuB+AZfv8PAPPpj6zPvqLxoLMrHX0Nff8UTSu6l5JPiZRsEJ193Hr9APRHWArJaMR5 uL6A== 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=eHluV91WrSVHSKJ6scS7krCLC3zPBscZhDyMj0nLg/U=; b=exIG91fD5YceslnJuR9Yxpkrt7A+UvFZQRJKhMBMTvtI5pl2rYroHcPdibg0Qvsqdg ujp9cmMVkXEjYcayqAbdQ+KnLpWYUCHfTgT+qlheV+HdRdMkEPcLN+f7ETXaRJcHwwXE +UwDtY//pXmSNLiBgvxz/jBMivYPGOrKISZkzED2sCJjiclMcX2tT60KrbUKCw3LgJbz 9plxJ0D/i+sOPSLz8pPwLbHPHGBzxfJ+SxA6SKIxsqJEfyZpY758m4H3QkylXlp7DP4c MOclYi40+W1HMk2srWqLdcEDMagScAnYzE+UyOYah/yhQ0v0rw9t+mpi4Ayj3WosJU4k i/4Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@yadro.com header.s=mta-01 header.b=Rr0trLoU; 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 ne21-20020a1709077b9500b007bdd38a5d5asi15208168ejc.636.2023.01.18.07.41.07; Wed, 18 Jan 2023 07:41:18 -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=Rr0trLoU; 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 S231392AbjARPW4 (ORCPT + 45 others); Wed, 18 Jan 2023 10:22:56 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52320 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231365AbjARPWd (ORCPT ); Wed, 18 Jan 2023 10:22:33 -0500 Received: from mta-01.yadro.com (mta-02.yadro.com [89.207.88.252]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AAA29402F6 for ; Wed, 18 Jan 2023 07:19:24 -0800 (PST) Received: from mta-01.yadro.com (localhost.localdomain [127.0.0.1]) by mta-01.yadro.com (Proxmox) with ESMTP id AED0B341B61; Wed, 18 Jan 2023 18:19:22 +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=eHluV91WrSVHSKJ6sc S7krCLC3zPBscZhDyMj0nLg/U=; b=Rr0trLoUZJWgrFgZJWEl8n9YeaWmAz6Ptb LspUO+WJwYFawfr7f14ReuV9K0F24kNXPRmdx6Xgk7plrJ50dUFW6W8hAOintUGb to5CNMd91ze8/F1VPWtpXKe6ZTqcxOwsTDUx/hetREbIhm49iQNbaybPkQBvr0/x yKO7TPoCc= 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 A4066341B5D; Wed, 18 Jan 2023 18:19:22 +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; Wed, 18 Jan 2023 18:19:22 +0300 Message-ID: <926b0971-5c0c-2d12-5366-8a0e2aa7ae0f@yadro.com> Date: Wed, 18 Jan 2023 18:19:21 +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> <1514c929-5a98-0e58-e038-9bb4537d5189@yadro.com> <7c85f9d8-458d-6881-ffbe-4f5c6384e35e@yadro.com> 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 On 18.01.2023 05:37, Song Shuai wrote: > Evgenii Shatokhin 于2023年1月17日周二 16:22写道: >> >> On 17.01.2023 16:16, Evgenii Shatokhin wrote: >>> 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. >> >> I have checked ftrace-direct-multi.ko and ftrace-direct-multi-modify.ko >> on 6.2-rc4 built for x86-64 - yes, ip/pc in the traced function should >> be passed to my_direct_func(). >> >> ftrace-direct-multi.ko: >> # TASK-PID CPU# ||||| TIMESTAMP FUNCTION >> # | | | ||||| | | >> insmod-10829 [000] d.h1. 1719.518535: my_direct_func: ip >> ffffffff87332f45 // wake_up_process+0x5 >> rcu_tasks_kthre-11 [000] ..... 1719.518696: my_direct_func: ip >> ffffffff8828d935 // schedule+0x5 >> insmod-10829 [000] ..... 1719.518708: my_direct_func: ip >> ffffffff8828d935 >> systemd-journal-293 [001] ..... 1719.518823: my_direct_func: ip >> ffffffff8828d935 >> systemd-1 [000] ..... 1719.519141: my_direct_func: ip >> ffffffff8828d935 >> -0 [001] ..s1. 1719.521889: my_direct_func: ip >> ffffffff87332f45 >> -0 [000] d.s2. 1719.521901: my_direct_func: ip >> ffffffff87332f45 >> rcu_preempt-15 [001] ..... 1719.521917: my_direct_func: ip >> ffffffff8828d935 >> [...] >> >> The ip values are wake_up_process+0x5 and schedule+0x5, the locations >> where the execution of the traced functions resumes after the Ftrace >> trampoline has finished. >> >> The results with ftrace-direct-multi-modify.ko are similar to that. >> >> The samples look like a demonstration, that one can pass anything >> necessary to the handler in case of "direct" functions. >> >> I suppose, the RISC-V-specific asm code in these two sample modules >> could be updated to pass the saved pc value to my_direct_func() in a0. > > Yes, you're right. > > I added 'mv a0,t0' in front of `call my_direct_func` to pass the address of > traced function with mcount offset. > > Here is the updated patch for your reference. > https://github.com/sugarfillet/linux/commit/95b174fb104dd970b982ee6fa19879393e229318 Thank you for the quick fix. This one looks good to me. ftrace-direct-multi*.ko now report the ip values corresponding to schedule+0x8 and wake_up_process+0x8, which is what was expected here. One more thing: please change my "Co-developed-by:" into "Tested-by:" in your patch, becase this is what I actually did: tested it and reported the results. I cannot take your credit for development of this patch ;-) Looking forward for v8 of the series. > > >> >>> >>>> >>>> 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 >> >> > > > -- > Thanks, > Song >