Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp4165181pxt; Tue, 10 Aug 2021 22:34:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxLrOQyILndNf8kV/mnfaSL0MaEr5CPzCd/8oZYDP0RNTSINCxtG3X+HS4ORaSRWJ9y2khp X-Received: by 2002:a92:360e:: with SMTP id d14mr20978ila.171.1628660075528; Tue, 10 Aug 2021 22:34:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628660075; cv=none; d=google.com; s=arc-20160816; b=tNHPCN8HD36FiZow13OsXsvm7J2g6qs/2Lx9mQraV1D/eJwLTTZOtDEC/0Oq0Ni+ve Z70ApBQTjnYb21QJ3x95E/FgaiND2O9eXywlIBVKYDcQmXs0qd3hSXbeghSD+mabdjWj giwNFnz/2cf6hOAAmZh6f6T5Z8dfM2zfxcrqmK+f2VZgBaypxDTbWxgD0gZ+UHM29I+m u+J99g8tVF4WwJSH2i+Wq/4EkOaE1vEEkiqpiU0nkwZeX5btMxWDDmCaLf7x/IognZ4N aqSLiHQArXcXzUm1fmrrBv0QcjHCum7Ryb7Hnq2sOs4hQ/w3phbbZMEC7bjhYqnYaVXP xMlA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=vT7MmsdlHy283Go5wJW6RUoXc50zJ8BAShI96ufhZ28=; b=ym0WPJHlCWBQscE96iIp03BR4yhwbpuDy8AiHb1dUfHyePiq+jcYiTOINBqAJBjj0I e8Sav9ZbYO+d/BjiPUAIXHQn1aJ6/Xm36OdZ6GhyvfXNdXSq0if+i7srmTnfpK9dx5bS +l3KpBIbsV4jZG3JSSRlKbM21auP5I6oCVEgZTJybQPluceY0VWSIQN4QSAd7IGIhshe lkZ/B39/ODWqS16M33hC7A70EvvnqK1jKaXy3jKXuRPaL+xQ6tZTrpmYgM5RONJt1JLn oTM7mu9+KgDru66DhNo9WTMGZYPErSh4OfNzSi3V/fcF4dGsRLpEia7HUPJCXGh1C0FQ mzqw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n16si23186810jap.23.2021.08.10.22.34.21; Tue, 10 Aug 2021 22:34:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234153AbhHKFcD (ORCPT + 99 others); Wed, 11 Aug 2021 01:32:03 -0400 Received: from pegase2.c-s.fr ([93.17.235.10]:57893 "EHLO pegase2.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229730AbhHKFcD (ORCPT ); Wed, 11 Aug 2021 01:32:03 -0400 Received: from localhost (mailhub3.si.c-s.fr [172.26.127.67]) by localhost (Postfix) with ESMTP id 4Gkz2f3tsQz9sW4; Wed, 11 Aug 2021 07:31:38 +0200 (CEST) X-Virus-Scanned: amavisd-new at c-s.fr Received: from pegase2.c-s.fr ([172.26.127.65]) by localhost (pegase2.c-s.fr [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id ZhuviGjr4pbP; Wed, 11 Aug 2021 07:31:38 +0200 (CEST) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase2.c-s.fr (Postfix) with ESMTP id 4Gkz2f2nbHz9sVx; Wed, 11 Aug 2021 07:31:38 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 43FCB8B7C3; Wed, 11 Aug 2021 07:31:38 +0200 (CEST) X-Virus-Scanned: amavisd-new at c-s.fr Received: from messagerie.si.c-s.fr ([127.0.0.1]) by localhost (messagerie.si.c-s.fr [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id PtipKJ7MVT60; Wed, 11 Aug 2021 07:31:38 +0200 (CEST) Received: from [192.168.4.90] (unknown [192.168.4.90]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 8904E8B765; Wed, 11 Aug 2021 07:31:37 +0200 (CEST) Subject: Re: [PATCH v2] powerpc/kprobes: Fix kprobe Oops happens in booke To: Pu Lehui , mpe@ellerman.id.au, benh@kernel.crashing.org, paulus@samba.org, naveen.n.rao@linux.vnet.ibm.com, mhiramat@kernel.org, peterz@infradead.org, npiggin@gmail.com, ruscur@russell.cc Cc: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org, zhangjinhao2@huawei.com References: <20210809023658.218915-1-pulehui@huawei.com> From: Christophe Leroy Message-ID: <9c6cdb3f-37ac-9a8c-2c75-3a939ed76ab4@csgroup.eu> Date: Wed, 11 Aug 2021 07:31:37 +0200 User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.12.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: fr Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 11/08/2021 à 04:53, Pu Lehui a écrit : > Ping, serious problem here. All booke ppc will trigger Oops when > perform kprobes related operations. As far as I can see it is in the fixes branch: https://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux.git/log/?h=fixes > > On 2021/8/9 10:36, Pu Lehui wrote: >> When using kprobe on powerpc booke series processor, Oops happens >> as show bellow: >> >> / # echo "p:myprobe do_nanosleep" > /sys/kernel/debug/tracing/kprobe_events >> / # echo 1 > /sys/kernel/debug/tracing/events/kprobes/myprobe/enable >> / # sleep 1 >> [   50.076730] Oops: Exception in kernel mode, sig: 5 [#1] >> [   50.077017] BE PAGE_SIZE=4K SMP NR_CPUS=24 QEMU e500 >> [   50.077221] Modules linked in: >> [   50.077462] CPU: 0 PID: 77 Comm: sleep Not tainted 5.14.0-rc4-00022-g251a1524293d #21 >> [   50.077887] NIP:  c0b9c4e0 LR: c00ebecc CTR: 00000000 >> [   50.078067] REGS: c3883de0 TRAP: 0700   Not tainted (5.14.0-rc4-00022-g251a1524293d) >> [   50.078349] MSR:  00029000   CR: 24000228  XER: 20000000 >> [   50.078675] >> [   50.078675] GPR00: c00ebdf0 c3883e90 c313e300 c3883ea0 00000001 00000000 c3883ecc 00000001 >> [   50.078675] GPR08: c100598c c00ea250 00000004 00000000 24000222 102490c2 bff4180c 101e60d4 >> [   50.078675] GPR16: 00000000 102454ac 00000040 10240000 10241100 102410f8 10240000 00500000 >> [   50.078675] GPR24: 00000002 00000000 c3883ea0 00000001 00000000 0000c350 3b9b8d50 00000000 >> [   50.080151] NIP [c0b9c4e0] do_nanosleep+0x0/0x190 >> [   50.080352] LR [c00ebecc] hrtimer_nanosleep+0x14c/0x1e0 >> [   50.080638] Call Trace: >> [   50.080801] [c3883e90] [c00ebdf0] hrtimer_nanosleep+0x70/0x1e0 (unreliable) >> [   50.081110] [c3883f00] [c00ec004] sys_nanosleep_time32+0xa4/0x110 >> [   50.081336] [c3883f40] [c001509c] ret_from_syscall+0x0/0x28 >> [   50.081541] --- interrupt: c00 at 0x100a4d08 >> [   50.081749] NIP:  100a4d08 LR: 101b5234 CTR: 00000003 >> [   50.081931] REGS: c3883f50 TRAP: 0c00   Not tainted (5.14.0-rc4-00022-g251a1524293d) >> [   50.082183] MSR:  0002f902   CR: 24000222  XER: 00000000 >> [   50.082457] >> [   50.082457] GPR00: 000000a2 bf980040 1024b4d0 bf980084 bf980084 64000000 00555345 fefefeff >> [   50.082457] GPR08: 7f7f7f7f 101e0000 00000069 00000003 28000422 102490c2 bff4180c 101e60d4 >> [   50.082457] GPR16: 00000000 102454ac 00000040 10240000 10241100 102410f8 10240000 00500000 >> [   50.082457] GPR24: 00000002 bf9803f4 10240000 00000000 00000000 100039e0 00000000 102444e8 >> [   50.083789] NIP [100a4d08] 0x100a4d08 >> [   50.083917] LR [101b5234] 0x101b5234 >> [   50.084042] --- interrupt: c00 >> [   50.084238] Instruction dump: >> [   50.084483] 4bfffc40 60000000 60000000 60000000 9421fff0 39400402 914200c0 38210010 >> [   50.084841] 4bfffc20 00000000 00000000 00000000 <7fe00008> 7c0802a6 7c892378 93c10048 >> [   50.085487] ---[ end trace f6fffe98e2fa8f3e ]--- >> [   50.085678] >> Trace/breakpoint trap >> >> There is no real mode for booke arch and the MMU translation is >> always on. The corresponding MSR_IS/MSR_DS bit in booke is used >> to switch the address space, but not for real mode judgment. >> >> Fixes: 21f8b2fa3ca5 ("powerpc/kprobes: Ignore traps that happened in real mode") >> Signed-off-by: Pu Lehui >> --- >> v1->v2: >> - use IS_ENABLED(CONFIG_BOOKE) as suggested by Michael Ellerman and >>    Christophe Leroy >> - update Oops log to make problem clear >> >>   arch/powerpc/kernel/kprobes.c | 3 ++- >>   1 file changed, 2 insertions(+), 1 deletion(-) >> >> diff --git a/arch/powerpc/kernel/kprobes.c b/arch/powerpc/kernel/kprobes.c >> index cbc28d1a2e1b..7a7cd6bda53e 100644 >> --- a/arch/powerpc/kernel/kprobes.c >> +++ b/arch/powerpc/kernel/kprobes.c >> @@ -292,7 +292,8 @@ int kprobe_handler(struct pt_regs *regs) >>       if (user_mode(regs)) >>           return 0; >> -    if (!(regs->msr & MSR_IR) || !(regs->msr & MSR_DR)) >> +    if (!IS_ENABLED(CONFIG_BOOKE) && >> +        (!(regs->msr & MSR_IR) || !(regs->msr & MSR_DR))) >>           return 0; >>       /* >>