Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp3398271ybl; Mon, 27 Jan 2020 03:18:57 -0800 (PST) X-Google-Smtp-Source: APXvYqxoK7TrIf0sEi1JTWaPCU/gu4qOA9LZXbYUgjk5d02GIKMrugPaCB31RABDlQSnGEM5D0ac X-Received: by 2002:aca:d483:: with SMTP id l125mr6834384oig.124.1580123937560; Mon, 27 Jan 2020 03:18:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580123937; cv=none; d=google.com; s=arc-20160816; b=yIBarnKZ/nyv69IZ48PiUvrk1xLORH5nEzEozPufOrsORr3XMAfKO07eoMopl0gPPA A4ey5l+sFfVABWRb7btKr7XHY6+Y5lygd4Uq+AIyOQLvMXPYC0GvFAR02MEJuOfOvUCm V26SLnZyDi6zxuScM/LhNF2VKKBnJSe66xprfQ5oNzB/vwWPDKAeb9Xt8qZYF3W0JH4p yI3vgsMRGQmn+GgtCTeLvSieid++PyaBaaUyCrOHhj4+VBy3eteZMAr73ofM2qyknOlL yu1NeOBcKdJspZuCYIbRs9WEYTMc5vRRc244am38sFCJGhQDDR8RbRJ+RAcQB6mAZ9rh 9rNQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:cc:to:subject:from:message-id :dkim-signature; bh=QSas4AzfycVcrZrrY4ffgcs9Nqt9q9y8HeREqBisZ1g=; b=Bgw7ke97eZvhWUyn8YPIP34uwdyypS/lapWrx+D6WU2utmLaucYlSoBtxAarN2ZKSE tL9umvotM65RceUdRvHO2gf5O7/ul505tulNU5Ug387GOYWzz8hk3GztAFDIAHqkf+9Z r8L8BT6optP7nCQZU7Pk+01XwGDOAntuPgU5SPZP/Dg5ScXXp4put7lHNji/eo7j+/Hp ntbtbWXqDP+cTxL3iIHrVjQDBZwo2a3LGNjG0aGqyRtjWahw+hOqVkK3X+JOr6W2N0L6 YJGGwdaAaLBVw0cbtJDK+tqFqhB7AES8hFwUFSaKAx+7TppIprE7FTGR5cc/LejCnLP3 eiZg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@c-s.fr header.s=mail header.b=jYbS0ZG5; 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 o13si7385070otp.27.2020.01.27.03.18.45; Mon, 27 Jan 2020 03:18:57 -0800 (PST) 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=@c-s.fr header.s=mail header.b=jYbS0ZG5; 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 S1730004AbgA0KmI (ORCPT + 99 others); Mon, 27 Jan 2020 05:42:08 -0500 Received: from pegase1.c-s.fr ([93.17.236.30]:58985 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729054AbgA0KmH (ORCPT ); Mon, 27 Jan 2020 05:42:07 -0500 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 485mX91WVPz9v02y; Mon, 27 Jan 2020 11:42:01 +0100 (CET) Authentication-Results: localhost; dkim=pass reason="1024-bit key; insecure key" header.d=c-s.fr header.i=@c-s.fr header.b=jYbS0ZG5; dkim-adsp=pass; dkim-atps=neutral X-Virus-Scanned: Debian amavisd-new at c-s.fr Received: from pegase1.c-s.fr ([192.168.12.234]) by localhost (pegase1.c-s.fr [192.168.12.234]) (amavisd-new, port 10024) with ESMTP id wAs_VF93qg3X; Mon, 27 Jan 2020 11:42:01 +0100 (CET) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase1.c-s.fr (Postfix) with ESMTP id 485mX90Jr0z9v02x; Mon, 27 Jan 2020 11:42:01 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=c-s.fr; s=mail; t=1580121721; bh=QSas4AzfycVcrZrrY4ffgcs9Nqt9q9y8HeREqBisZ1g=; h=From:Subject:To:Cc:Date:From; b=jYbS0ZG5TuPWxcWiyHouSkNGKS6T7nOHGR/C/q6ryvjV5iouim64mr7SL5Cgs9goY Ov6I5aKw/QSgPMK1sIlPbI48lAmwds0y09CAp+yoKeClSQXmHGHqTJynVJdSzDGvpE WYlRjdNkkqeAAsSSwCLhq0XUxBCPB2y68rc3QwkQ= Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id CEEA48B79C; Mon, 27 Jan 2020 11:42:05 +0100 (CET) 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 V8fDMGbeqcJv; Mon, 27 Jan 2020 11:42:05 +0100 (CET) Received: from po14934vm.idsi0.si.c-s.fr (unknown [192.168.4.90]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 8E0AC8B752; Mon, 27 Jan 2020 11:42:05 +0100 (CET) Received: by po14934vm.idsi0.si.c-s.fr (Postfix, from userid 0) id 1A841651FA; Mon, 27 Jan 2020 10:42:04 +0000 (UTC) Message-Id: <6d02c3ae6ad77af34392e98117e44c2bf6d13ba1.1580121710.git.christophe.leroy@c-s.fr> From: Christophe Leroy Subject: [PATCH] powerpc/32s: Fix CPU wake-up from sleep mode To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Date: Mon, 27 Jan 2020 10:42:04 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit f7354ccac844 ("powerpc/32: Remove CURRENT_THREAD_INFO and rename TI_CPU") broke the CPU wake-up from sleep mode (i.e. when _TLF_SLEEPING is set) by delaying the tovirt(r2, r2). This is because r2 is not restored by fast_exception_return. It used to work (by chance ?) because CPU wake-up interrupt never comes from user, so r2 is expected to point to 'current' on return. Commit e2fb9f544431 ("powerpc/32: Prepare for Kernel Userspace Access Protection") broke it even more by clobbering r0 which is not restored by fast_exception_return either. Use r6 instead of r0. This is possible because r3-r6 are restored by fast_exception_return and only r3-r5 are used for exception arguments. For r2 it could be converted back to virtual address, but stay on the safe side and restore it from the stack instead. It should be live in the cache at that moment, so loading from the stack should make no difference compared to converting it from phys to virt. Fixes: f7354ccac844 ("powerpc/32: Remove CURRENT_THREAD_INFO and rename TI_CPU") Fixes: e2fb9f544431 ("powerpc/32: Prepare for Kernel Userspace Access Protection") Cc: stable@vger.kernel.org Signed-off-by: Christophe Leroy --- arch/powerpc/kernel/entry_32.S | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/arch/powerpc/kernel/entry_32.S b/arch/powerpc/kernel/entry_32.S index 73b80143ffac..27e2afce8b78 100644 --- a/arch/powerpc/kernel/entry_32.S +++ b/arch/powerpc/kernel/entry_32.S @@ -180,7 +180,7 @@ transfer_to_handler: 2: /* if from kernel, check interrupted DOZE/NAP mode and * check for stack overflow */ - kuap_save_and_lock r11, r12, r9, r2, r0 + kuap_save_and_lock r11, r12, r9, r2, r6 addi r2, r12, -THREAD #ifndef CONFIG_VMAP_STACK lwz r9,KSP_LIMIT(r12) @@ -288,6 +288,7 @@ reenable_mmu: rlwinm r9,r9,0,~MSR_EE lwz r12,_LINK(r11) /* and return to address in LR */ kuap_restore r11, r2, r3, r4, r5 + lwz r2, GPR2(r11) b fast_exception_return #endif -- 2.25.0