Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp1025634ybx; Wed, 30 Oct 2019 08:44:28 -0700 (PDT) X-Google-Smtp-Source: APXvYqzo/++rYD10PjrWqQRrZBm+V66gUhZEa+gxM1wcERRZSLxahstHVFRM/uqlw/YI7eumym1S X-Received: by 2002:a17:906:218a:: with SMTP id 10mr206169eju.38.1572450268005; Wed, 30 Oct 2019 08:44:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572450267; cv=none; d=google.com; s=arc-20160816; b=PPlRdpr1QQ44Via7gcjyOAQ4pyhIZVjCEw6TrUgAE720lJ2EZzualVtaTyvS7YSRAx L7AGTWeOzpzScp385Oq1odIa266hHlx8J86hgKy43ycTXWKxcQqVwbf4gCRo/F7d8W6u xDDPZsKmhpNIgp4wG0hGBJ5JhTTOSPumajROpic0yhH1wkwHNTtBDQciPuOdy37QvXsO 2hWTjEl/hzTjPyFZey7iLQopn8wtKU8xnfDUNAgWRu06hNfOdiZuSL2NHj6aUnqEZOdn bsYfm3uSr0ZAOLl/xreS3SODLcxKZUOnSE5Nt1II/gGO0sx/svEjTOLY2MUCFaaTq38a PEfA== 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=wGxH2WPO0Nu9rUCjGgqMw5h9iRGhdundsXT5hvDEEHI=; b=wbuJoSK4alU2zQPCCSKulg1L6sPc+rYKMBhoyZvfMZ+EIS9jD3ODeCWtdnrq8tZExP KGAdt3zynZMJ/jd/1JNgREP/cDDVAqeADj+uc2UsLJdF90bmf4+GazdO8HTcmQL5rmL0 D7chrBucx0vMkwtEx0u7yu/wHdUazWO7F2wf92HAH60Dg1+yoQXk+0Ll1XntLAORnrlK JFhqsSQdQpe0wBjcLAYhxTyyc6bbjnCBdlvV3oNHrT+WgCPmT9beFa5++T6ZbLFiPSQZ UumMbBtnpRySnJ4eAxbr1YcvhR2/LElTPtQyAclc0V+DjuE3UL6eRIM6Z1nRCA4J6+dq udEw== 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 14si1745511edz.130.2019.10.30.08.44.04; Wed, 30 Oct 2019 08:44:27 -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; 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 S1727465AbfJ3Pmm (ORCPT + 99 others); Wed, 30 Oct 2019 11:42:42 -0400 Received: from foss.arm.com ([217.140.110.172]:36782 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727458AbfJ3Pml (ORCPT ); Wed, 30 Oct 2019 11:42:41 -0400 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 02F474F5; Wed, 30 Oct 2019 08:42:41 -0700 (PDT) Received: from e107158-lin.cambridge.arm.com (e107158-lin.cambridge.arm.com [10.1.195.37]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 371303F6C4; Wed, 30 Oct 2019 08:42:39 -0700 (PDT) From: Qais Yousef To: Thomas Gleixner , Greg Kroah-Hartman Cc: Qais Yousef , "Rafael J. Wysocki" , Josh Poimboeuf , Nicholas Piggin , "Peter Zijlstra (Intel)" , Jiri Kosina , Daniel Lezcano , Eiichi Tsukata , Zhenzhong Duan , Ingo Molnar , Pavankumar Kondeti , linux-kernel@vger.kernel.org Subject: [PATCH 12/12] cpu: Hide cpu_up/down Date: Wed, 30 Oct 2019 15:38:37 +0000 Message-Id: <20191030153837.18107-13-qais.yousef@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191030153837.18107-1-qais.yousef@arm.com> References: <20191030153837.18107-1-qais.yousef@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Provide a special exported function for the device core to bring a cpu up/down and hide the real cpu_up/down as they are treated as private functions. cpu_up/down are lower level API and users outside the cpu subsystem should use device_online/offline which will take care of extra housekeeping work like keeping sysfs in sync. Signed-off-by: Qais Yousef CC: Greg Kroah-Hartman CC: "Rafael J. Wysocki" CC: Thomas Gleixner CC: Josh Poimboeuf CC: Nicholas Piggin CC: "Peter Zijlstra (Intel)" CC: Jiri Kosina CC: Daniel Lezcano CC: Eiichi Tsukata CC: Zhenzhong Duan CC: Ingo Molnar CC: Pavankumar Kondeti CC: linux-kernel@vger.kernel.org --- drivers/base/cpu.c | 4 ++-- include/linux/cpu.h | 4 ++-- kernel/cpu.c | 26 ++++++++++++++++++++++---- 3 files changed, 26 insertions(+), 8 deletions(-) diff --git a/drivers/base/cpu.c b/drivers/base/cpu.c index cc37511de866..96c69c5fbfff 100644 --- a/drivers/base/cpu.c +++ b/drivers/base/cpu.c @@ -55,7 +55,7 @@ static int cpu_subsys_online(struct device *dev) if (from_nid == NUMA_NO_NODE) return -ENODEV; - ret = cpu_up(cpuid); + ret = cpu_subsys_up(dev); /* * When hot adding memory to memoryless node and enabling a cpu * on the node, node number of the cpu may internally change. @@ -69,7 +69,7 @@ static int cpu_subsys_online(struct device *dev) static int cpu_subsys_offline(struct device *dev) { - return cpu_down(dev->id); + return cpu_subsys_down(dev); } void unregister_cpu(struct cpu *cpu) diff --git a/include/linux/cpu.h b/include/linux/cpu.h index b1c7b788b8e9..6822e676f420 100644 --- a/include/linux/cpu.h +++ b/include/linux/cpu.h @@ -83,7 +83,7 @@ extern ssize_t arch_cpu_release(const char *, size_t); #ifdef CONFIG_SMP extern bool cpuhp_tasks_frozen; -int cpu_up(unsigned int cpu); +int cpu_subsys_up(struct device *dev); void notify_cpu_starting(unsigned int cpu); extern void cpu_maps_update_begin(void); extern void cpu_maps_update_done(void); @@ -114,7 +114,7 @@ extern void lockdep_assert_cpus_held(void); extern void cpu_hotplug_disable(void); extern void cpu_hotplug_enable(void); void clear_tasks_mm_cpumask(int cpu); -int cpu_down(unsigned int cpu); +int cpu_subsys_down(struct device *dev); #else /* CONFIG_HOTPLUG_CPU */ diff --git a/kernel/cpu.c b/kernel/cpu.c index e16695b841de..087c10dbfb99 100644 --- a/kernel/cpu.c +++ b/kernel/cpu.c @@ -1045,11 +1045,20 @@ static int do_cpu_down(unsigned int cpu, enum cpuhp_state target) return err; } -int cpu_down(unsigned int cpu) +static int cpu_down(unsigned int cpu) { return do_cpu_down(cpu, CPUHP_OFFLINE); } -EXPORT_SYMBOL(cpu_down); + +/* + * This function is meant to be used by device core cpu subsystem. + * + * Other subsystems should use device_offline(get_cpu_device(cpu)) instead. + */ +int cpu_subsys_down(struct device *dev) +{ + return cpu_down(dev->id); +} #else #define takedown_cpu NULL @@ -1191,11 +1200,20 @@ static int do_cpu_up(unsigned int cpu, enum cpuhp_state target) return err; } -int cpu_up(unsigned int cpu) +static int cpu_up(unsigned int cpu) { return do_cpu_up(cpu, CPUHP_ONLINE); } -EXPORT_SYMBOL_GPL(cpu_up); + +/* + * This function is meant to be used by device core cpu subsystem. + * + * Other subsystems should use device_online(get_cpu_device(cpu)) instead. + */ +int cpu_subsys_up(struct device *dev) +{ + return cpu_up(dev->id); +} int hibernation_bringup_sleep_cpu(unsigned int sleep_cpu) { -- 2.17.1