From: Srinivasa Ds <srinivasa@in.ibm.com>
To: Srinivasa Ds <srinivasa@in.ibm.com>,
Benjamin Herrenschmidt <benh@kernel.crashing.org>,
anton@au1.ibm.com, paulus@samba.org, linuxppc-dev@ozlabs.org,
ego@in.ibm.com, Srivatsa Vaddagiri <vatsa@in.ibm.com>
Cc: linux-kernel@vger.kernel.org
Subject: Re: [RFC] [PATCH] cpu_hotplug on IBM JS20 system
Date: Tue, 14 Nov 2006 19:44:17 +0530 [thread overview]
Message-ID: <4559CF39.8090908@in.ibm.com> (raw)
In-Reply-To: <4559C6A9.4070204@in.ibm.com>
[-- Attachment #1: Type: text/plain, Size: 345 bytes --]
Srinivasa Ds wrote:
>
> Since we are not supported by hardware for cpu hotplug. I have
> developed the patch which will disable cpu hotplug on IBM bladecentre
> JS20. Please let me know your comments on this please.
>
Iam sorry, Just resending the patch after formatting it again.
Signed-off-by: Srinivasa DS <srinivasa@in.ibm.com>
[-- Attachment #2: cpu_hotplug.fix --]
[-- Type: text/plain, Size: 3874 bytes --]
arch/powerpc/kernel/rtas.c | 3 +++
include/linux/cpu.h | 4 ++++
kernel/cpu.c | 24 ++++++++++++++++++++++--
3 files changed, 29 insertions(+), 2 deletions(-)
Index: linux-2.6.19-rc5/arch/powerpc/kernel/rtas.c
===================================================================
--- linux-2.6.19-rc5.orig/arch/powerpc/kernel/rtas.c
+++ linux-2.6.19-rc5/arch/powerpc/kernel/rtas.c
@@ -19,6 +19,7 @@
#include <linux/init.h>
#include <linux/capability.h>
#include <linux/delay.h>
+#include <linux/cpu.h>
#include <asm/prom.h>
#include <asm/rtas.h>
@@ -881,6 +882,8 @@ void __init rtas_initialize(void)
#ifdef CONFIG_HOTPLUG_CPU
rtas_stop_self_args.token = rtas_token("stop-self");
+ if(rtas_stop_self_args.token == RTAS_UNKNOWN_SERVICE)
+ disable_cpu_hotplug_perm();
#endif /* CONFIG_HOTPLUG_CPU */
#ifdef CONFIG_RTAS_ERROR_LOGGING
rtas_last_error_token = rtas_token("rtas-last-error");
Index: linux-2.6.19-rc5/kernel/cpu.c
===================================================================
--- linux-2.6.19-rc5.orig/kernel/cpu.c
+++ linux-2.6.19-rc5/kernel/cpu.c
@@ -63,8 +63,20 @@ void unlock_cpu_hotplug(void)
}
EXPORT_SYMBOL_GPL(unlock_cpu_hotplug);
+void disable_cpu_hotplug_perm(void)
+{
+ mutex_lock(&cpu_add_remove_lock);
+ cpu_hotplug_disabled = PERM_DISABLED_CPU_HOTPLUG;
+ mutex_unlock(&cpu_add_remove_lock);
+}
+
#endif /* CONFIG_HOTPLUG_CPU */
+static int is_cpu_hotplug_perm_disabled()
+{
+ return cpu_hotplug_disabled == PERM_DISABLED_CPU_HOTPLUG;
+}
+
/* Need to know about CPUs going up/down? */
int __cpuinit register_cpu_notifier(struct notifier_block *nb)
{
@@ -193,7 +205,7 @@ int cpu_down(unsigned int cpu)
int err = 0;
mutex_lock(&cpu_add_remove_lock);
- if (cpu_hotplug_disabled)
+ if (cpu_hotplug_disabled || is_cpu_hotplug_perm_disabled())
err = -EBUSY;
else
err = _cpu_down(cpu);
@@ -244,7 +256,7 @@ int __devinit cpu_up(unsigned int cpu)
int err = 0;
mutex_lock(&cpu_add_remove_lock);
- if (cpu_hotplug_disabled)
+ if (cpu_hotplug_disabled || is_cpu_hotplug_perm_disabled())
err = -EBUSY;
else
err = _cpu_up(cpu);
@@ -261,6 +273,10 @@ int disable_nonboot_cpus(void)
int cpu, first_cpu, error;
mutex_lock(&cpu_add_remove_lock);
+ if(is_cpu_hotplug_perm_disabled()) {
+ error = -EBUSY;
+ goto out;
+ }
first_cpu = first_cpu(cpu_present_map);
if (!cpu_online(first_cpu)) {
error = _cpu_up(first_cpu);
@@ -311,6 +327,10 @@ void enable_nonboot_cpus(void)
/* Allow everyone to use the CPU hotplug again */
mutex_lock(&cpu_add_remove_lock);
+ if(is_cpu_hotplug_perm_disabled()) {
+ mutex_unlock(&cpu_add_remove_lock);
+ return;
+ }
cpu_hotplug_disabled = 0;
mutex_unlock(&cpu_add_remove_lock);
Index: linux-2.6.19-rc5/include/linux/cpu.h
===================================================================
--- linux-2.6.19-rc5.orig/include/linux/cpu.h
+++ linux-2.6.19-rc5/include/linux/cpu.h
@@ -31,6 +31,8 @@ struct cpu {
struct sys_device sysdev;
};
+#define PERM_DISABLED_CPU_HOTPLUG -1
+
extern int register_cpu(struct cpu *cpu, int num);
extern struct sys_device *get_cpu_sysdev(unsigned cpu);
#ifdef CONFIG_HOTPLUG_CPU
@@ -68,6 +70,7 @@ extern struct sysdev_class cpu_sysdev_cl
/* Stop CPUs going up and down. */
extern void lock_cpu_hotplug(void);
extern void unlock_cpu_hotplug(void);
+extern void disable_cpu_hotplug_perm(void);
#define hotcpu_notifier(fn, pri) { \
static struct notifier_block fn##_nb = \
{ .notifier_call = fn, .priority = pri }; \
@@ -80,6 +83,7 @@ int cpu_down(unsigned int cpu);
#else
#define lock_cpu_hotplug() do { } while (0)
#define unlock_cpu_hotplug() do { } while (0)
+#define disable_cpu_hotplug_perm() do { } while (0)
#define lock_cpu_hotplug_interruptible() 0
#define hotcpu_notifier(fn, pri) do { } while (0)
#define register_hotcpu_notifier(nb) do { } while (0)
next prev parent reply other threads:[~2006-11-14 13:27 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-11-13 13:10 [RFC] [PATCH] cpu_hotplug on IBM JS20 system Srinivasa Ds
2006-11-13 13:09 ` Heiko Carstens
2006-11-13 15:37 ` Gautham R Shenoy
2006-11-13 21:39 ` Benjamin Herrenschmidt
2006-11-14 13:37 ` Srinivasa Ds
2006-11-14 14:14 ` Srinivasa Ds [this message]
2006-11-15 2:58 ` Michael Ellerman
2006-11-15 2:58 ` Michael Ellerman
2006-11-15 4:50 ` Srinivasa Ds
2006-11-15 4:50 ` Srinivasa Ds
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4559CF39.8090908@in.ibm.com \
--to=srinivasa@in.ibm.com \
--cc=anton@au1.ibm.com \
--cc=benh@kernel.crashing.org \
--cc=ego@in.ibm.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linuxppc-dev@ozlabs.org \
--cc=paulus@samba.org \
--cc=vatsa@in.ibm.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.