[PATCH] Synchronous hotplug for kobjects

From: Todd Poynor
Date: Mon May 10 2004 - 15:49:57 EST


As discussed recently, it's expected to be useful to generate
synchronous hotplug events from the kobject subsystem in certain
situations. This patch adds a kobject_hotplug_wait function that issues
a synchronous call. The function should be used for appropriate actions
that require synchronous semantics; please note many hotplug events
would suffer severe performance degradation if issued synchronously, and
one should exercise caution in choosing to use this function.

--- linux-2.6.6-orig/include/linux/kobject.h 2004-05-10 11:23:55.000000000 -0700
+++ linux-2.6.6-pm/include/linux/kobject.h 2004-05-10 11:41:25.000000000 -0700
@@ -57,6 +57,7 @@
extern void kobject_put(struct kobject *);

extern void kobject_hotplug(const char *action, struct kobject *);
+extern void kobject_hotplug_wait(const char *action, struct kobject *);

struct kobj_type {
void (*release)(struct kobject *);
--- linux-2.6.6-orig/lib/kobject.c 2004-05-10 11:26:35.000000000 -0700
+++ linux-2.6.6-pm/lib/kobject.c 2004-05-10 13:20:35.389369032 -0700
@@ -104,7 +104,7 @@
static spinlock_t sequence_lock = SPIN_LOCK_UNLOCKED;

static void kset_hotplug(const char *action, struct kset *kset,
- struct kobject *kobj)
+ struct kobject *kobj, int wait)
{
char *argv [3];
char **envp = NULL;
@@ -185,9 +185,9 @@
}
}

- pr_debug ("%s: %s %s %s %s %s %s %s\n", __FUNCTION__, argv[0], argv[1],
- envp[0], envp[1], envp[2], envp[3], envp[4]);
- retval = call_usermodehelper (argv[0], argv, envp, 0);
+ pr_debug ("%s: %s %s %s %s %s %s %s %d\n", __FUNCTION__, argv[0], argv[1],
+ envp[0], envp[1], envp[2], envp[3], envp[4], wait);
+ retval = call_usermodehelper (argv[0], argv, envp, wait);
if (retval)
pr_debug ("%s - call_usermodehelper returned %d\n",
__FUNCTION__, retval);
@@ -199,7 +199,8 @@
return;
}

-void kobject_hotplug(const char *action, struct kobject *kobj)
+static void kobject_hotplug_flags(const char *action, struct kobject *kobj,
+ int wait)
{
struct kobject * top_kobj = kobj;

@@ -212,13 +213,27 @@
}

if (top_kobj->kset && top_kobj->kset->hotplug_ops)
- kset_hotplug(action, top_kobj->kset, kobj);
+ kset_hotplug(action, top_kobj->kset, kobj, wait);
+}
+
+void kobject_hotplug(const char *action, struct kobject *kobj)
+{
+ kobject_hotplug_flags(action, kobj, 0);
+}
+
+void kobject_hotplug_wait(const char *action, struct kobject *kobj)
+{
+ kobject_hotplug_flags(action, kobj, 1);
}
#else
void kobject_hotplug(const char *action, struct kobject *kobj)
{
return;
}
+void kobject_hotplug_wait(const char *action, struct kobject *kobj)
+{
+ return;
+}
#endif /* CONFIG_HOTPLUG */

/**



--
Todd Poynor
MontaVista Software
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/