Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2760387ybc; Mon, 25 Nov 2019 03:49:16 -0800 (PST) X-Google-Smtp-Source: APXvYqxgLFvVGb7SUHn9fPb2ntW+8IYUniDw+1k4v6dvj2J//gZadcXcSjt7+vVS3qYY39YM2AaX X-Received: by 2002:a17:906:5246:: with SMTP id y6mr37097903ejm.330.1574682556631; Mon, 25 Nov 2019 03:49:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574682556; cv=none; d=google.com; s=arc-20160816; b=DLFrCYI2YRhNZ4zir1X9TCFZnCIpebWGPV8cwj7Y/ei0Hv1ILt/+8GZTTunSdI+p4G +7+bunRLxToMKhVtJ+8YfsGguzFBiRBwfIDwgKnbxfbFhG4iIP8gciHcEc66Z6HMCygB dbTcUMPCxnplTEOmQc1/GJfZ6/WegTjOZrDZOyme2olyiGtY7KtwuWqSr7xwcFCzyzWA 4fWqVus7u+jB08FQixEt+7rcyUB6Bwr7Pm/OByP7VajzvFLkspNJ6jAmqaVPD2ife3Gf p701Fde7SoNnd8ULH1Q56WVt3+Tii6HkGJzDJearKL2TMVLJ4Tu3dFkqZg+0Q4gEyE5O iRrA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=CxjDVh/qi2N6vpKg1RZyaxjS00FPoyNtFVDUapNA76k=; b=x9oymq0EKygXYI2V26XUm6lt+MDsx8aDsUQI65A6ct+4lw/SA16gTxQ5O7lBgZc84q EGuv/vcw4D2y9uG3315gd+ZKNXYc4xWQkXaKioOZKAkh1bSXEqYV/tIVricMTDddx4/q 3xRqFdkXx0+MmM+6hU6J2/nQIrLW1hn2Xr6BRvqivd4bULtzul1pNgdVDoGhM7ZI5DMc B42lB89czEcXs1nRDQ4eoHPQQR6xb5etEvQ3XGpp+tnVrTQqGFiidgugWh3dycQpqPsT S1+a0nWYvJD73nApJnB0v2UfF+rx87K2ws4agI0onsSkWBzjU1Fqx93YsNRfYBR7XS2K hVfA== ARC-Authentication-Results: i=1; mx.google.com; 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 d17si4446007edq.144.2019.11.25.03.48.52; Mon, 25 Nov 2019 03:49:16 -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; 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 S1727787AbfKYL2T (ORCPT + 99 others); Mon, 25 Nov 2019 06:28:19 -0500 Received: from foss.arm.com ([217.140.110.172]:49026 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727743AbfKYL2Q (ORCPT ); Mon, 25 Nov 2019 06:28:16 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 5E2D3113E; Mon, 25 Nov 2019 03:28:16 -0800 (PST) Received: from e107158-lin.cambridge.arm.com (e107158-lin.cambridge.arm.com [10.1.195.21]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 27BC23F52E; Mon, 25 Nov 2019 03:28:15 -0800 (PST) From: Qais Yousef To: Thomas Gleixner , Greg Kroah-Hartman Cc: Qais Yousef , "David S. Miller" , Bjorn Helgaas , "Rafael J. Wysocki" , Sakari Ailus , sparclinux@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 07/14] sparc: Replace cpu_up/down with device_online/offline Date: Mon, 25 Nov 2019 11:27:47 +0000 Message-Id: <20191125112754.25223-8-qais.yousef@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191125112754.25223-1-qais.yousef@arm.com> References: <20191125112754.25223-1-qais.yousef@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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. Acked-by: David S. Miller Signed-off-by: Qais Yousef CC: "David S. Miller" CC: Thomas Gleixner CC: Bjorn Helgaas CC: "Rafael J. Wysocki" CC: Greg Kroah-Hartman CC: Sakari Ailus CC: sparclinux@vger.kernel.org CC: linux-kernel@vger.kernel.org --- arch/sparc/kernel/ds.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/arch/sparc/kernel/ds.c b/arch/sparc/kernel/ds.c index bbf59b3b4af8..39350e5dbaf1 100644 --- a/arch/sparc/kernel/ds.c +++ b/arch/sparc/kernel/ds.c @@ -550,12 +550,13 @@ static int dr_cpu_configure(struct ds_info *dp, struct ds_cap_state *cp, mdesc_populate_present_mask(mask); mdesc_fill_in_cpu_data(mask); + lock_device_hotplug(); for_each_cpu(cpu, mask) { int err; printk(KERN_INFO "ds-%llu: Starting cpu %d...\n", dp->id, cpu); - err = cpu_up(cpu); + err = device_online(get_cpu_device(cpu)); if (err) { __u32 res = DR_CPU_RES_FAILURE; __u32 stat = DR_CPU_STAT_UNCONFIGURED; @@ -574,6 +575,7 @@ static int dr_cpu_configure(struct ds_info *dp, struct ds_cap_state *cp, dr_cpu_mark(resp, cpu, ncpus, res, stat); } } + unlock_device_hotplug(); spin_lock_irqsave(&ds_lock, flags); __ds_send(dp->lp, resp, resp_len); @@ -606,17 +608,19 @@ static int dr_cpu_unconfigure(struct ds_info *dp, resp_len, ncpus, mask, DR_CPU_STAT_UNCONFIGURED); + lock_device_hotplug(); for_each_cpu(cpu, mask) { int err; printk(KERN_INFO "ds-%llu: Shutting down cpu %d...\n", dp->id, cpu); - err = cpu_down(cpu); + err = device_offline(get_cpu_device(cpu)); if (err) dr_cpu_mark(resp, cpu, ncpus, DR_CPU_RES_FAILURE, DR_CPU_STAT_CONFIGURED); } + unlock_device_hotplug(); spin_lock_irqsave(&ds_lock, flags); __ds_send(dp->lp, resp, resp_len); -- 2.17.1