Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp3552183ybc; Mon, 18 Nov 2019 17:23:57 -0800 (PST) X-Google-Smtp-Source: APXvYqxSvqtepj0ohMZgVyo5ZGdcJ7OtrdQjQ4FGrrY6Qy8Lp0o33SVmDEjvkpFlCIJQz9gDiZEI X-Received: by 2002:a17:906:24d4:: with SMTP id f20mr31932107ejb.182.1574126637251; Mon, 18 Nov 2019 17:23:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574126637; cv=none; d=google.com; s=arc-20160816; b=H8vi+5NF47uXdKBtPaiNclP31q+3GMu6L/jRbUtoIMscsGw9eQbH6nLaZIawW7yhYQ 6GHVaJkdssfog5yCcWicm32DWYunhBPelOLSfemeod17dZwWAjkWY3hCqeEp5GRl4TVZ mT3+V5IN+mqx+gCr5r2XUfPyHwADWOAZtcHDAsFN4aWsMm1BOg90pRhK2g88X7q90LWi fxAwtKZpd8tohMam5vrnoIsE0Is2JvVZM9qrye8o7x+zCGlR3fKBoYP22xLSzyjBSNIl Hl84S5AEmcUWyo/gXhmotQrAWzOZEFV3pZCQ2JHgenrtoufAMN9qj2jZwNpTdibW1Hwa dHXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from:dkim-signature; bh=mOXjF2mQFWR4HzJvdWnFiOFSRE4vjpU4mx+D5bUpS8U=; b=NlotDysE8vfaUw26+/yC9aXDPiCx8MZ2/NGcuBKb7pTggonzuCXLooyLNN2jsXwIB2 zFAH+g8WKcDBL2uUoiwL3EKVH4hWjibxBTiaTXGZRbLp5teG9aLUPclBzdxkc5UzEDOw maH8zapNxfPkO6BdDQPr8H++jpANs+E/uT2e+sOnS5WqTkUHzIz0qMgdPkKdQr9CzwGN tO6CGrp52ef66l2SzRItJstVCbbZmzwMZ0Yx2TH4AvOysGnlpDZgEGa/740s/jn8mvGN DG9msA9949L7VNKYS1gAb9Y6COnmu92PST67LAavJ/pM3Kd86MorBGt8UqHWI2gKw3tJ unEg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ellerman.id.au header.s=201909 header.b=QDGQW6bh; 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 b15si12565223eju.362.2019.11.18.17.23.33; Mon, 18 Nov 2019 17:23: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=@ellerman.id.au header.s=201909 header.b=QDGQW6bh; 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 S1727164AbfKSBTp (ORCPT + 99 others); Mon, 18 Nov 2019 20:19:45 -0500 Received: from bilbo.ozlabs.org ([203.11.71.1]:43443 "EHLO ozlabs.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726952AbfKSBTo (ORCPT ); Mon, 18 Nov 2019 20:19:44 -0500 Received: from authenticated.ozlabs.org (localhost [127.0.0.1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by mail.ozlabs.org (Postfix) with ESMTPSA id 47H7K82zfhz9sPL; Tue, 19 Nov 2019 12:19:40 +1100 (AEDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ellerman.id.au; s=201909; t=1574126382; bh=maX43JYoFqxngt1nHc0oT20YehFVIccTW2ma2xMGkGM=; h=From:To:Cc:Subject:In-Reply-To:References:Date:From; b=QDGQW6bhsISaWKFrbk1hKjd7p5pQ0kdKTiSRd2sA8AYFk1XRjRuVmwYCkTZtHYwBK 7wRb2CrSoWyOz2jXyZLwfQ/jjPrGCggeitnii7FWhlJCN5XRcOf2lxjzhH8XIw7P6j Y9+qkRRzgHkGhLKh59mHWsIcv8jWnzd7qS5JwpeS7ZuRiLBU4N2u5BCFN5FOmTkG33 ruAWLHjJGjA/LwQ0sYNH5TL0vNFpOfWygeJjZleYhvCHJANuJFgSxJ/I1VsjlGDZxG NdDmPAc4YFtwVL6OE7jh8n/LlqNGBWTnD/CD6F/QOaq8v3YEf8jVwuorkhG7Rs4LdO 68ZJBJtybCrgA== From: Michael Ellerman To: Qais Yousef , Thomas Gleixner , Greg Kroah-Hartman Cc: Qais Yousef , Benjamin Herrenschmidt , Paul Mackerras , Enrico Weigelt , Ram Pai , Nicholas Piggin , Thiago Jung Bauermann , Christophe Leroy , linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 03/12] powerpc: Replace cpu_up/down with device_online/offline In-Reply-To: <20191030153837.18107-4-qais.yousef@arm.com> References: <20191030153837.18107-1-qais.yousef@arm.com> <20191030153837.18107-4-qais.yousef@arm.com> Date: Tue, 19 Nov 2019 12:19:39 +1100 Message-ID: <87h830d5n8.fsf@mpe.ellerman.id.au> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Qais Yousef writes: > The core device API performs extra housekeeping bits that are missing > from directly calling cpu_up/down. > > See commit a6717c01ddc2 ("powerpc/rtas: use device model APIs and > serialization during LPM") for an example description of what might go > wrong. > > This also prepares to make cpu_up/down a private interface for anything > but the cpu subsystem. > > Signed-off-by: Qais Yousef > CC: Benjamin Herrenschmidt > CC: Paul Mackerras > CC: Michael Ellerman > CC: Enrico Weigelt > CC: Ram Pai > CC: Nicholas Piggin > CC: Thiago Jung Bauermann > CC: Christophe Leroy > CC: Thomas Gleixner > CC: linuxppc-dev@lists.ozlabs.org > CC: linux-kernel@vger.kernel.org > --- > arch/powerpc/kernel/machine_kexec_64.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) My initial though is "what about kdump", but that function is not called during kdump, so there should be no issue with the extra locking leading to deadlocks in a crash. Acked-by: Michael Ellerman I assume you haven't actually tested it? cheers > diff --git a/arch/powerpc/kernel/machine_kexec_64.c b/arch/powerpc/kernel/machine_kexec_64.c > index 04a7cba58eff..ebf8cc7acc4d 100644 > --- a/arch/powerpc/kernel/machine_kexec_64.c > +++ b/arch/powerpc/kernel/machine_kexec_64.c > @@ -208,13 +208,15 @@ static void wake_offline_cpus(void) > { > int cpu = 0; > > + lock_device_hotplug(); > for_each_present_cpu(cpu) { > if (!cpu_online(cpu)) { > printk(KERN_INFO "kexec: Waking offline cpu %d.\n", > cpu); > - WARN_ON(cpu_up(cpu)); > + WARN_ON(device_online(get_cpu_device(cpu))); > } > } > + unlock_device_hotplug(); > } > > static void kexec_prepare_cpus(void) > -- > 2.17.1