Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp8706574ybi; Thu, 6 Jun 2019 18:05:59 -0700 (PDT) X-Google-Smtp-Source: APXvYqwbl0x72FsAB5AWbxQMrEaYjpzaoThQfBMfov6xf2XJ2E3M58ZtRQE6AfU/KG9e/XwvJISJ X-Received: by 2002:a65:448a:: with SMTP id l10mr548699pgq.53.1559869559284; Thu, 06 Jun 2019 18:05:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559869559; cv=none; d=google.com; s=arc-20160816; b=a5dLqe9UW75yj/VoLG5bhbrWjU7XK9W4ezxTx4tdq2fjzZDMvSc3CW0/AqesRhFJhh NTCzUSbJQr/TxMERjU7E3PeVdKz8VoXuc7vffdWcHEIRqvUk22vl4uE4QfdZdh7jfvNE mY8+0F5PyfTdGX3Qtwp9QGboxLXgz6oKSBVRhOHDLV3tkcBSzUxAjZaRqAJS3KO6Z0OQ SobGyhzTHC86zFJ0A6BBxuIh+WqR8tLhB/xHHlWABGOZQ8mr0WivWZqosMaSvV8w1crT zr50WaOIU3alQ/Z6pOslo/foT+uE82q3FRotaNW7DwLOU4VnTDtv2mnZtx3TbItXneQZ C1lw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent :content-transfer-encoding:references:in-reply-to:date:cc:to:from :subject:message-id:dkim-signature; bh=WDgkKbvNjTI7TQcswa020w5BuiCf7/a2j+oLoSP6fGA=; b=VaxjZw4TqxAn8BV5+WNAXs9kcD8rKZKvfCOxBcgorccfSb/28AyoAURp1QmivI/a6T /a1i8bzgeBOOblYCGPj7AqB5epyDamTmHNv54IcHExjPXF/YpKfnQG1jnvtb7NBYj0Ha j6y5cNwOrD7qBHGnbI8xLqTEZp9dbMGKJiup2i974UDVcXZomxyuE90QXs0BRsomMunR hdJOZaw/OQahhvgk27EFGLLdEWaBjyCDvoMgOSUdTwVyGc+In0yLQyN6by8n2WroSEFi z2Yu62VA6qEtRlJGS7f9NAf/uNcCNixNf+XmI8WQSSOHyg1SDXZVviwBLSsVraYGzDji oTvg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@neuling.org header.s=201811 header.b=jubTl1Xv; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id az12si531332plb.165.2019.06.06.18.05.42; Thu, 06 Jun 2019 18:05:59 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@neuling.org header.s=201811 header.b=jubTl1Xv; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727875AbfFGAuk (ORCPT + 99 others); Thu, 6 Jun 2019 20:50:40 -0400 Received: from bilbo.ozlabs.org ([203.11.71.1]:52993 "EHLO ozlabs.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726379AbfFGAuk (ORCPT ); Thu, 6 Jun 2019 20:50:40 -0400 Received: from neuling.org (localhost [127.0.0.1]) by ozlabs.org (Postfix) with ESMTP id 45KkTn2QZnz9sDX; Fri, 7 Jun 2019 10:50:37 +1000 (AEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=neuling.org; s=201811; t=1559868637; bh=U7nqidMeM/8XknoLlxj1vv8Py2UMz+gk+UbXzxDB/rU=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=jubTl1Xvy/MvBXMf1gKQk4fyUBHQ3Bl2M5rF752yfwnHKWsWX3kzbX2FffletZ9wq dc3RN39kLZunPSXp1JtabJ7hZZ0vpx09/rHI0iooM9b3aRSQo3JH1b2vpGEXqLTSDH NzuMAJ+oWy+2pQmVIaRfpzSJ4RTHjZRnwgwnY468O3O/IoBemdmL96ZOcAQ3pTIm5B toNb7AfP2RWk/Tk5CYj4mjTWOPTkcn5rm+blRpHO1H8qfAbGfoV0DOUt1rYmg5uWOm VOZRGS9FCrcKs7gn6gEBOpauXPFImAFjmvcn+ZcHfs5F5DFPM3+xV1xy1QU31adn9S UxOae1rZD4ukQ== Received: by neuling.org (Postfix, from userid 1000) id 49C912A27C4; Fri, 7 Jun 2019 10:50:37 +1000 (AEST) Message-ID: <80cfc8d7327d3bb744ea1f7e2843943a998d48de.camel@neuling.org> Subject: Re: [PATCH] Powerpc/Watchpoint: Restore nvgprs while returning from exception From: Michael Neuling To: Ravi Bangoria , mpe@ellerman.id.au Cc: benh@kernel.crashing.org, paulus@samba.org, npiggin@gmail.com, christophe.leroy@c-s.fr, mahesh@linux.vnet.ibm.com, linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org Date: Fri, 07 Jun 2019 10:50:37 +1000 In-Reply-To: <20190606072951.32116-1-ravi.bangoria@linux.ibm.com> References: <20190606072951.32116-1-ravi.bangoria@linux.ibm.com> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable User-Agent: Evolution 3.32.2 (3.32.2-1.fc30) MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 2019-06-06 at 12:59 +0530, Ravi Bangoria wrote: > Powerpc hw triggers watchpoint before executing the instruction. > To make trigger-after-execute behavior, kernel emulates the > instruction. If the instruction is 'load something into non- > volatile register', exception handler should restore emulated > register state while returning back, otherwise there will be > register state corruption. Ex, Adding a watchpoint on a list > can corrput the list: >=20 > # cat /proc/kallsyms | grep kthread_create_list > c00000000121c8b8 d kthread_create_list >=20 > Add watchpoint on kthread_create_list->next: >=20 > # perf record -e mem:0xc00000000121c8c0 >=20 > Run some workload such that new kthread gets invoked. Ex, I > just logged out from console: >=20 > list_add corruption. next->prev should be prev (c000000001214e00), \ > but was c00000000121c8b8. (next=3Dc00000000121c8b8). > WARNING: CPU: 59 PID: 309 at lib/list_debug.c:25 __list_add_valid+0xb4/= 0xc0 > CPU: 59 PID: 309 Comm: kworker/59:0 Kdump: loaded Not tainted 5.1.0-rc7= + #69 > ... > NIP __list_add_valid+0xb4/0xc0 > LR __list_add_valid+0xb0/0xc0 > Call Trace: > __list_add_valid+0xb0/0xc0 (unreliable) > __kthread_create_on_node+0xe0/0x260 > kthread_create_on_node+0x34/0x50 > create_worker+0xe8/0x260 > worker_thread+0x444/0x560 > kthread+0x160/0x1a0 > ret_from_kernel_thread+0x5c/0x70 >=20 > Signed-off-by: Ravi Bangoria How long has this been around? Should we be CCing stable? Mikey > --- > arch/powerpc/kernel/exceptions-64s.S | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) >=20 > diff --git a/arch/powerpc/kernel/exceptions-64s.S > b/arch/powerpc/kernel/exceptions-64s.S > index 9481a11..96de0d1 100644 > --- a/arch/powerpc/kernel/exceptions-64s.S > +++ b/arch/powerpc/kernel/exceptions-64s.S > @@ -1753,7 +1753,7 @@ handle_dabr_fault: > ld r5,_DSISR(r1) > addi r3,r1,STACK_FRAME_OVERHEAD > bl do_break > -12: b ret_from_except_lite > +12: b ret_from_except > =20 > =20 > #ifdef CONFIG_PPC_BOOK3S_64