Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1643410ybv; Sun, 23 Feb 2020 11:30:58 -0800 (PST) X-Google-Smtp-Source: APXvYqxIWp55rdC1z1TYRe5u8t+2LEzEmTAcOi+XPj18xCGS9ObQmTTx+4nWscEg3EX+jsfbNKZA X-Received: by 2002:aca:ac10:: with SMTP id v16mr9636628oie.123.1582486257906; Sun, 23 Feb 2020 11:30:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582486257; cv=none; d=google.com; s=arc-20160816; b=eq4jLSzVxgPwWgOz6qwxsih97AibBc/aS8E8Dcypc/PjabGfrG/RUjAVADbP12dmuE 3haL53XWhouFnXrkkbxWMZ+Rw0Y5GN8QYDaSpJAkz4PP4EUhmGVqyY8Uwlj5lYIWUs3X LatkRa05xgkqJMfEBQnswihwf9ddeWa3dbYUeML1R8ILvVQRx7JpjdcWp8tuIt6Yr+kZ gJUwueDhigy/NjRmVEuSY1Ine+u/hpC+TIGFdWayR24vM9ArinBGwLoOlk4xabWoLyXY iU+dRhI3CILVs7oo3M3jjc6837C6ECLZ6tWhzYknMR0MIYdbAiGrzLYpM6UxfWABCbFO aQ5A== 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=vFLovbsu9RYjHinDZfT0NReHYBysoBJkzBOCXvpIFfQ=; b=IA00f7D509bHAouZWu0FD4TEoj6oq0fz5QkcJ0yIxm6OXQeHffe/xoPMBt9HfAmhfr GnjVJ3XzVOGuHYO1H7Q9BO1zaLUIGx5JZpwjHpO7rRsxeBo6tAVBjToc3HxxJwPJjzIV Fp8ArHYiWFQJehoXLlJaBr9biYH5i1A5vvcQi/md1NqjKvvqrNSsVSdvwIVCMfZnE3UV fu6Q9v+CaM/vPPqPxnXBjD/WZKiwj+mpkB9R+cfVyHf8h83VaCd5kfG8dNquBiQ1V4G7 FlCweU/wkC4wZ0NCPG3UBris5hSmBayVhDr3/KdPwop2V6AeWQjoHX2S8kXR7xW4hibk PEhw== 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 a9si4167954oib.59.2020.02.23.11.30.46; Sun, 23 Feb 2020 11:30: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; 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 S1727423AbgBWTaV (ORCPT + 99 others); Sun, 23 Feb 2020 14:30:21 -0500 Received: from foss.arm.com ([217.140.110.172]:51524 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727339AbgBWTaR (ORCPT ); Sun, 23 Feb 2020 14:30:17 -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 22060101E; Sun, 23 Feb 2020 11:30:17 -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 4055C3F6CF; Sun, 23 Feb 2020 11:30:15 -0800 (PST) From: Qais Yousef To: Thomas Gleixner Cc: "Paul E . McKenney" , Qais Yousef , Greg Kroah-Hartman , "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 v3 15/15] cpu: Hide cpu_up/down Date: Sun, 23 Feb 2020 19:29:42 +0000 Message-Id: <20200223192942.18420-16-qais.yousef@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200223192942.18420-1-qais.yousef@arm.com> References: <20200223192942.18420-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 add/remove_cpu() 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 | 32 ++++++++++++++++++++++++++++---- 3 files changed, 32 insertions(+), 8 deletions(-) diff --git a/drivers/base/cpu.c b/drivers/base/cpu.c index 6265871a4af2..9a134cd362ee 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 3d3caecef395..e1bbd8d6ecec 100644 --- a/include/linux/cpu.h +++ b/include/linux/cpu.h @@ -88,8 +88,8 @@ 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 add_cpu(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); @@ -120,8 +120,8 @@ 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 remove_cpu(unsigned int cpu); +int cpu_subsys_down(struct device *dev); extern void smp_shutdown_nonboot_cpus(unsigned int primary_cpu); #else /* CONFIG_HOTPLUG_CPU */ diff --git a/kernel/cpu.c b/kernel/cpu.c index 7c6aa427a3a3..017e16dfcccd 100644 --- a/kernel/cpu.c +++ b/kernel/cpu.c @@ -1051,11 +1051,23 @@ 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); + +/** + * cpu_subsys_down - Bring down a cpu device + * @dev: Pointer to the cpu device to offline + * + * This function is meant to be used by device core cpu subsystem only. + * + * Other subsystems should use remove_cpu() instead. + */ +int cpu_subsys_down(struct device *dev) +{ + return cpu_down(dev->id); +} int remove_cpu(unsigned int cpu) { @@ -1257,11 +1269,23 @@ 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); + +/** + * cpu_subsys_up - Bring up a cpu device + * @dev: Pointer to the cpu device to online + * + * This function is meant to be used by device core cpu subsystem only. + * + * Other subsystems should use add_cpu() instead. + */ +int cpu_subsys_up(struct device *dev) +{ + return cpu_up(dev->id); +} int add_cpu(unsigned int cpu) { -- 2.17.1