[PATCH 151/196] Driver core: move the static kobject out of struct driver

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: <linux-kernel@...>
Cc: Greg Kroah-Hartman <gregkh@...>, Kay Sievers <kay.sievers@...>
Date: Friday, January 25, 2008 - 3:33 am

This patch removes the kobject, and a few other driver-core-only fields
out of struct driver and into the driver core only.  Now drivers can be
safely create on the stack or statically (like they currently are.)

Cc: Kay Sievers <kay.sievers@vrfy.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
---
 drivers/base/base.h     |    8 +++++
 drivers/base/bus.c      |   71 +++++++++++++++++++++++++---------------------
 drivers/base/dd.c       |   24 ++++++++--------
 drivers/base/driver.c   |   40 +++++++++++++++++---------
 drivers/base/module.c   |   12 ++++----
 drivers/base/platform.c |    2 +-
 include/linux/device.h  |   16 ++++------
 7 files changed, 99 insertions(+), 74 deletions(-)

diff --git a/drivers/base/base.h b/drivers/base/base.h
index 0547236..3b0f395 100644
--- a/drivers/base/base.h
+++ b/drivers/base/base.h
@@ -27,6 +27,14 @@ struct bus_type_private {
 	struct bus_type *bus;
 };
 
+struct driver_private {
+	struct kobject kobj;
+	struct klist klist_devices;
+	struct klist_node knode_bus;
+	struct module_kobject *mkobj;
+	struct device_driver *driver;
+};
+#define to_driver(obj) container_of(obj, struct driver_private, kobj)
 
 /* initialisation functions */
 extern int devices_init(void);
diff --git a/drivers/base/bus.c b/drivers/base/bus.c
index 04d3850..aa0c986 100644
--- a/drivers/base/bus.c
+++ b/drivers/base/bus.c
@@ -3,6 +3,8 @@
  *
  * Copyright (c) 2002-3 Patrick Mochel
  * Copyright (c) 2002-3 Open Source Development Labs
+ * Copyright (c) 2007 Greg Kroah-Hartman <gregkh@suse.de>
+ * Copyright (c) 2007 Novell Inc.
  *
  * This file is released under the GPLv2
  *
@@ -24,7 +26,6 @@
  */
 
 #define to_drv_attr(_attr) container_of(_attr, struct driver_attribute, attr)
-#define to_driver(obj) container_of(obj, struct device_driver, kobj)
 
 
 static int __must_check bus_rescan_devices_helper(struct device *dev,
@@ -49,11 +50,11 @@ static ssize_t
 drv_attr_show(struct kobject * kobj, struct attribute * attr, char * buf)
 {
 	struct driver_attribute * drv_attr = to_drv_attr(attr);
-	struct device_driver * drv = to_driver(kobj);
+	struct driver_private *drv_priv = to_driver(kobj);
 	ssize_t ret = -EIO;
 
 	if (drv_attr->show)
-		ret = drv_attr->show(drv, buf);
+		ret = drv_attr->show(drv_priv->driver, buf);
 	return ret;
 }
 
@@ -62,11 +63,11 @@ drv_attr_store(struct kobject * kobj, struct attribute * attr,
 	       const char * buf, size_t count)
 {
 	struct driver_attribute * drv_attr = to_drv_attr(attr);
-	struct device_driver * drv = to_driver(kobj);
+	struct driver_private *drv_priv = to_driver(kobj);
 	ssize_t ret = -EIO;
 
 	if (drv_attr->store)
-		ret = drv_attr->store(drv, buf, count);
+		ret = drv_attr->store(drv_priv->driver, buf, count);
 	return ret;
 }
 
@@ -75,22 +76,12 @@ static struct sysfs_ops driver_sysfs_ops = {
 	.store	= drv_attr_store,
 };
 
-
-static void driver_release(struct kobject * kobj)
+static void driver_release(struct kobject *kobj)
 {
-	/*
-	 * Yes this is an empty release function, it is this way because struct
-	 * device is always a static object, not a dynamic one.  Yes, this is
-	 * not nice and bad, but remember, drivers are code, reference counted
-	 * by the module count, not a device, which is really data.  And yes,
-	 * in the future I do want to have all drivers be created dynamically,
-	 * and am working toward that goal, but it will take a bit longer...
-	 *
-	 * But do not let this example give _anyone_ the idea that they can
-	 * create a release function without any code in it at all, to do that
-	 * is almost always wrong.  If you have any questions about this,
-	 * please send an email to <greg@kroah.com>
-	 */
+	struct driver_private *drv_priv = to_driver(kobj);
+
+	pr_debug("%s: freeing %s\n", __FUNCTION__, kobject_name(kobj));
+	kfree(drv_priv);
 }
 
 static struct kobj_type driver_ktype = {
@@ -350,7 +341,13 @@ struct device * bus_find_device(struct bus_type *bus,
 static struct device_driver * next_driver(struct klist_iter * i)
 {
 	struct klist_node * n = klist_next(i);
-	return n ? container_of(n, struct device_driver, knode_bus) : NULL;
+	struct driver_private *drv_priv;
+
+	if (n) {
+		drv_priv = container_of(n, struct driver_private, knode_bus);
+		return drv_priv->driver;
+	}
+	return NULL;
 }
 
 /**
@@ -384,7 +381,7 @@ int bus_for_each_drv(struct bus_type * bus, struct device_driver * start,
 		return -EINVAL;
 
 	klist_iter_init_node(&bus->p->klist_drivers, &i,
-			     start ? &start->knode_bus : NULL);
+			     start ? &start->p->knode_bus : NULL);
 	while ((drv = next_driver(&i)) && !error)
 		error = fn(drv, data);
 	klist_iter_exit(&i);
@@ -620,7 +617,7 @@ static ssize_t driver_uevent_store(struct device_driver *drv,
 	enum kobject_action action;
 
 	if (kobject_action_type(buf, count, &action) == 0)
-		kobject_uevent(&drv->kobj, action);
+		kobject_uevent(&drv->p->kobj, action);
 	return count;
 }
 static DRIVER_ATTR(uevent, S_IWUSR, NULL, driver_uevent_store);
@@ -632,19 +629,29 @@ static DRIVER_ATTR(uevent, S_IWUSR, NULL, driver_uevent_store);
  */
 int bus_add_driver(struct device_driver *drv)
 {
-	struct bus_type * bus = bus_get(drv->bus);
+	struct bus_type *bus;
+	struct driver_private *priv;
 	int error = 0;
 
+	bus = bus_get(drv->bus);
 	if (!bus)
 		return -EINVAL;
 
 	pr_debug("bus %s: add driver %s\n", bus->name, drv->name);
-	error = kobject_set_name(&drv->kobj, "%s", drv->name);
+
+	priv = kzalloc(sizeof(*priv), GFP_KERNEL);
+	if (!priv)
+		return -ENOMEM;
+
+	error = kobject_set_name(&priv->kobj, "%s", drv->name);
 	if (error)
 		goto out_put_bus;
-	drv->kobj.kset = bus->p->drivers_kset;
-	drv->kobj.ktype = &driver_ktype;
-	error = kobject_register(&drv->kobj);
+	priv->kobj.kset = bus->p->drivers_kset;
+	priv->kobj.ktype = &driver_ktype;
+	klist_init(&priv->klist_devices, NULL, NULL);
+	priv->driver = drv;
+	drv->p = priv;
+	error = kobject_register(&priv->kobj);
 	if (error)
 		goto out_put_bus;
 
@@ -653,7 +660,7 @@ int bus_add_driver(struct device_driver *drv)
 		if (error)
 			goto out_unregister;
 	}
-	klist_add_tail(&drv->knode_bus, &bus->p->klist_drivers);
+	klist_add_tail(&priv->knode_bus, &bus->p->klist_drivers);
 	module_add_driver(drv->owner, drv);
 
 	error = driver_create_file(drv, &driver_attr_uevent);
@@ -676,7 +683,7 @@ int bus_add_driver(struct device_driver *drv)
 
 	return error;
 out_unregister:
-	kobject_unregister(&drv->kobj);
+	kobject_unregister(&priv->kobj);
 out_put_bus:
 	bus_put(bus);
 	return error;
@@ -699,11 +706,11 @@ void bus_remove_driver(struct device_driver * drv)
 	remove_bind_files(drv);
 	driver_remove_attrs(drv->bus, drv);
 	driver_remove_file(drv, &driver_attr_uevent);
-	klist_remove(&drv->knode_bus);
+	klist_remove(&drv->p->knode_bus);
 	pr_debug("bus %s: remove driver %s\n", drv->bus->name, drv->name);
 	driver_detach(drv);
 	module_remove_driver(drv);
-	kobject_unregister(&drv->kobj);
+	kobject_unregister(&drv->p->kobj);
 	bus_put(drv->bus);
 }
 
diff --git a/drivers/base/dd.c b/drivers/base/dd.c
index 7bf0e67..87a348c 100644
--- a/drivers/base/dd.c
+++ b/drivers/base/dd.c
@@ -11,6 +11,8 @@
  *
  *	Copyright (c) 2002-5 Patrick Mochel
  *	Copyright (c) 2002-3 Open Source Development Labs
+ *	Copyright (c) 2007 Greg Kroah-Hartman <gregkh@suse.de>
+ *	Copyright (c) 2007 Novell Inc.
  *
  *	This file is released under the GPLv2
  */
@@ -23,8 +25,6 @@
 #include "base.h"
 #include "power/power.h"
 
-#define to_drv(node) container_of(node, struct device_driver, kobj.entry)
-
 
 static void driver_bound(struct device *dev)
 {
@@ -41,20 +41,20 @@ static void driver_bound(struct device *dev)
 		blocking_notifier_call_chain(&dev->bus->p->bus_notifier,
 					     BUS_NOTIFY_BOUND_DRIVER, dev);
 
-	klist_add_tail(&dev->knode_driver, &dev->driver->klist_devices);
+	klist_add_tail(&dev->knode_driver, &dev->driver->p->klist_devices);
 }
 
 static int driver_sysfs_add(struct device *dev)
 {
 	int ret;
 
-	ret = sysfs_create_link(&dev->driver->kobj, &dev->kobj,
+	ret = sysfs_create_link(&dev->driver->p->kobj, &dev->kobj,
 			  kobject_name(&dev->kobj));
 	if (ret == 0) {
-		ret = sysfs_create_link(&dev->kobj, &dev->driver->kobj,
+		ret = sysfs_create_link(&dev->kobj, &dev->driver->p->kobj,
 					"driver");
 		if (ret)
-			sysfs_remove_link(&dev->driver->kobj,
+			sysfs_remove_link(&dev->driver->p->kobj,
 					kobject_name(&dev->kobj));
 	}
 	return ret;
@@ -65,7 +65,7 @@ static void driver_sysfs_remove(struct device *dev)
 	struct device_driver *drv = dev->driver;
 
 	if (drv) {
-		sysfs_remove_link(&drv->kobj, kobject_name(&dev->kobj));
+		sysfs_remove_link(&drv->p->kobj, kobject_name(&dev->kobj));
 		sysfs_remove_link(&dev->kobj, "driver");
 	}
 }
@@ -339,15 +339,15 @@ void driver_detach(struct device_driver * drv)
 	struct device * dev;
 
 	for (;;) {
-		spin_lock(&drv->klist_devices.k_lock);
-		if (list_empty(&drv->klist_devices.k_list)) {
-			spin_unlock(&drv->klist_devices.k_lock);
+		spin_lock(&drv->p->klist_devices.k_lock);
+		if (list_empty(&drv->p->klist_devices.k_list)) {
+			spin_unlock(&drv->p->klist_devices.k_lock);
 			break;
 		}
-		dev = list_entry(drv->klist_devices.k_list.prev,
+		dev = list_entry(drv->p->klist_devices.k_list.prev,
 				struct device, knode_driver.n_node);
 		get_device(dev);
-		spin_unlock(&drv->klist_devices.k_lock);
+		spin_unlock(&drv->p->klist_devices.k_lock);
 
 		if (dev->parent)	/* Needed for USB */
 			down(&dev->parent->sem);
diff --git a/drivers/base/driver.c b/drivers/base/driver.c
index 633ae1d..5aacff2 100644
--- a/drivers/base/driver.c
+++ b/drivers/base/driver.c
@@ -3,6 +3,8 @@
  *
  * Copyright (c) 2002-3 Patrick Mochel
  * Copyright (c) 2002-3 Open Source Development Labs
+ * Copyright (c) 2007 Greg Kroah-Hartman <gregkh@suse.de>
+ * Copyright (c) 2007 Novell Inc.
  *
  * This file is released under the GPLv2
  *
@@ -15,7 +17,6 @@
 #include "base.h"
 
 #define to_dev(node) container_of(node, struct device, driver_list)
-#define to_drv(obj) container_of(obj, struct device_driver, kobj)
 
 
 static struct device * next_device(struct klist_iter * i)
@@ -44,7 +45,7 @@ int driver_for_each_device(struct device_driver * drv, struct device * start,
 	if (!drv)
 		return -EINVAL;
 
-	klist_iter_init_node(&drv->klist_devices, &i,
+	klist_iter_init_node(&drv->p->klist_devices, &i,
 			     start ? &start->knode_driver : NULL);
 	while ((dev = next_device(&i)) && !error)
 		error = fn(dev, data);
@@ -80,7 +81,7 @@ struct device * driver_find_device(struct device_driver *drv,
 	if (!drv)
 		return NULL;
 
-	klist_iter_init_node(&drv->klist_devices, &i,
+	klist_iter_init_node(&drv->p->klist_devices, &i,
 			     (start ? &start->knode_driver : NULL));
 	while ((dev = next_device(&i)))
 		if (match(dev, data) && get_device(dev))
@@ -100,7 +101,7 @@ int driver_create_file(struct device_driver * drv, struct driver_attribute * att
 {
 	int error;
 	if (get_driver(drv)) {
-		error = sysfs_create_file(&drv->kobj, &attr->attr);
+		error = sysfs_create_file(&drv->p->kobj, &attr->attr);
 		put_driver(drv);
 	} else
 		error = -EINVAL;
@@ -117,7 +118,7 @@ int driver_create_file(struct device_driver * drv, struct driver_attribute * att
 void driver_remove_file(struct device_driver * drv, struct driver_attribute * attr)
 {
 	if (get_driver(drv)) {
-		sysfs_remove_file(&drv->kobj, &attr->attr);
+		sysfs_remove_file(&drv->p->kobj, &attr->attr);
 		put_driver(drv);
 	}
 }
@@ -143,7 +144,7 @@ int driver_add_kobj(struct device_driver *drv, struct kobject *kobj,
 	if (!name)
 		return -ENOMEM;
 
-	return kobject_add_ng(kobj, &drv->kobj, "%s", name);
+	return kobject_add_ng(kobj, &drv->p->kobj, "%s", name);
 }
 EXPORT_SYMBOL_GPL(driver_add_kobj);
 
@@ -153,7 +154,15 @@ EXPORT_SYMBOL_GPL(driver_add_kobj);
  */
 struct device_driver * get_driver(struct device_driver * drv)
 {
-	return drv ? to_drv(kobject_get(&drv->kobj)) : NULL;
+	if (drv) {
+		struct driver_private *priv;
+		struct kobject *kobj;
+
+		kobj = kobject_get(&drv->p->kobj);
+		priv = to_driver(kobj);
+		return priv->driver;
+	}
+	return NULL;
 }
 
 
@@ -163,7 +172,7 @@ struct device_driver * get_driver(struct device_driver * drv)
  */
 void put_driver(struct device_driver * drv)
 {
-	kobject_put(&drv->kobj);
+	kobject_put(&drv->p->kobj);
 }
 
 static int driver_add_groups(struct device_driver *drv,
@@ -174,10 +183,10 @@ static int driver_add_groups(struct device_driver *drv,
 
 	if (groups) {
 		for (i = 0; groups[i]; i++) {
-			error = sysfs_create_group(&drv->kobj, groups[i]);
+			error = sysfs_create_group(&drv->p->kobj, groups[i]);
 			if (error) {
 				while (--i >= 0)
-					sysfs_remove_group(&drv->kobj,
+					sysfs_remove_group(&drv->p->kobj,
 							   groups[i]);
 				break;
 			}
@@ -193,7 +202,7 @@ static void driver_remove_groups(struct device_driver *drv,
 
 	if (groups)
 		for (i = 0; groups[i]; i++)
-			sysfs_remove_group(&drv->kobj, groups[i]);
+			sysfs_remove_group(&drv->p->kobj, groups[i]);
 }
 
 
@@ -214,7 +223,6 @@ int driver_register(struct device_driver * drv)
 	    (drv->bus->shutdown && drv->shutdown)) {
 		printk(KERN_WARNING "Driver '%s' needs updating - please use bus_type methods\n", drv->name);
 	}
-	klist_init(&drv->klist_devices, NULL, NULL);
 	ret = bus_add_driver(drv);
 	if (ret)
 		return ret;
@@ -250,8 +258,12 @@ void driver_unregister(struct device_driver * drv)
 struct device_driver *driver_find(const char *name, struct bus_type *bus)
 {
 	struct kobject *k = kset_find_obj(bus->p->drivers_kset, name);
-	if (k)
-		return to_drv(k);
+	struct driver_private *priv;
+
+	if (k) {
+		priv = to_driver(k);
+		return priv->driver;
+	}
 	return NULL;
 }
 
diff --git a/drivers/base/module.c b/drivers/base/module.c
index cad07be..103be9c 100644
--- a/drivers/base/module.c
+++ b/drivers/base/module.c
@@ -50,7 +50,7 @@ void module_add_driver(struct module *mod, struct device_driver *drv)
 		if (mkobj) {
 			mk = container_of(mkobj, struct module_kobject, kobj);
 			/* remember our module structure */
-			drv->mkobj = mk;
+			drv->p->mkobj = mk;
 			/* kset_find_obj took a reference */
 			kobject_put(mkobj);
 		}
@@ -60,11 +60,11 @@ void module_add_driver(struct module *mod, struct device_driver *drv)
 		return;
 
 	/* Don't check return codes; these calls are idempotent */
-	no_warn = sysfs_create_link(&drv->kobj, &mk->kobj, "module");
+	no_warn = sysfs_create_link(&drv->p->kobj, &mk->kobj, "module");
 	driver_name = make_driver_name(drv);
 	if (driver_name) {
 		module_create_drivers_dir(mk);
-		no_warn = sysfs_create_link(mk->drivers_dir, &drv->kobj,
+		no_warn = sysfs_create_link(mk->drivers_dir, &drv->p->kobj,
 					    driver_name);
 		kfree(driver_name);
 	}
@@ -78,12 +78,12 @@ void module_remove_driver(struct device_driver *drv)
 	if (!drv)
 		return;
 
-	sysfs_remove_link(&drv->kobj, "module");
+	sysfs_remove_link(&drv->p->kobj, "module");
 
 	if (drv->owner)
 		mk = &drv->owner->mkobj;
-	else if (drv->mkobj)
-		mk = drv->mkobj;
+	else if (drv->p->mkobj)
+		mk = drv->p->mkobj;
 	if (mk && mk->drivers_dir) {
 		driver_name = make_driver_name(drv);
 		if (driver_name) {
diff --git a/drivers/base/platform.c b/drivers/base/platform.c
index d56a05f..bdd59e8 100644
--- a/drivers/base/platform.c
+++ b/drivers/base/platform.c
@@ -499,7 +499,7 @@ int __init_or_module platform_driver_probe(struct platform_driver *drv,
 	 */
 	spin_lock(&platform_bus_type.p->klist_drivers.k_lock);
 	drv->probe = NULL;
-	if (code == 0 && list_empty(&drv->driver.klist_devices.k_list))
+	if (code == 0 && list_empty(&drv->driver.p->klist_devices.k_list))
 		retval = -ENODEV;
 	drv->driver.probe = platform_drv_probe_fail;
 	spin_unlock(&platform_bus_type.p->klist_drivers.k_lock);
diff --git a/include/linux/device.h b/include/linux/device.h
index 721ee31..92ba3a8 100644
--- a/include/linux/device.h
+++ b/include/linux/device.h
@@ -32,6 +32,7 @@
 
 struct device;
 struct device_driver;
+struct driver_private;
 struct class;
 struct class_device;
 struct bus_type;
@@ -113,16 +114,11 @@ extern struct kset *bus_get_kset(struct bus_type *bus);
 extern struct klist *bus_get_device_klist(struct bus_type *bus);
 
 struct device_driver {
-	const char		* name;
-	struct bus_type		* bus;
-
-	struct kobject		kobj;
-	struct klist		klist_devices;
-	struct klist_node	knode_bus;
+	const char		*name;
+	struct bus_type		*bus;
 
-	struct module		* owner;
-	const char 		* mod_name;	/* used for built-in modules */
-	struct module_kobject	* mkobj;
+	struct module		*owner;
+	const char 		*mod_name;	/* used for built-in modules */
 
 	int	(*probe)	(struct device * dev);
 	int	(*remove)	(struct device * dev);
@@ -130,6 +126,8 @@ struct device_driver {
 	int	(*suspend)	(struct device * dev, pm_message_t state);
 	int	(*resume)	(struct device * dev);
 	struct attribute_group **groups;
+
+	struct driver_private *p;
 };
 
 
-- 
1.5.3.8

--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[GIT PATCH] driver core patches against 2.6.24, Greg KH, (Fri Jan 25, 3:11 am)
Re: [GIT PATCH] driver core patches against 2.6.24, Linus Torvalds, (Fri Jan 25, 2:44 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Jon Masters, (Fri Jan 25, 5:11 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Rusty Russell, (Sat Jan 26, 12:50 am)
Re: [GIT PATCH] driver core patches against 2.6.24, Linus Torvalds, (Sun Jan 27, 2:42 am)
Re: [GIT PATCH] driver core patches against 2.6.24, Rusty Russell, (Tue Jan 29, 1:49 am)
Re: [GIT PATCH] driver core patches against 2.6.24, Rusty Russell, (Sat Jan 26, 5:19 am)
Re: [GIT PATCH] driver core patches against 2.6.24, Linus Torvalds, (Fri Jan 25, 4:23 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Linus Torvalds, (Fri Jan 25, 3:11 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Arjan van de Ven, (Sat Jan 26, 2:31 am)
Re: [GIT PATCH] driver core patches against 2.6.24, Jeremy Fitzhardinge, (Fri Jan 25, 3:56 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Jon Masters, (Fri Jan 25, 5:20 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Linus Torvalds, (Fri Jan 25, 5:49 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Jeremy Fitzhardinge, (Fri Jan 25, 5:58 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Peter Zijlstra, (Fri Jan 25, 6:26 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Helge Hafting, (Mon Jan 28, 4:26 am)
Re: [GIT PATCH] driver core patches against 2.6.24, Ingo Molnar, (Fri Jan 25, 8:05 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Peter Zijlstra, (Fri Jan 25, 8:27 pm)
Re: [GIT PATCH] driver core patches against 2.6.24, Jon Masters, (Fri Jan 25, 8:40 pm)
[PATCH 143/196] PCI: use proper call to driver_create_file, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 115/196] Kobject: change drivers/cpuidle/sysfs.c to u..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 164/196] Kobject: rename kobject_add_ng() to kobject_..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 121/196] Kobject: change arch/sh/kernel/cpu/sh4/sq.c ..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 159/196] Kobject: convert block/elevator.c to use kob..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 160/196] Kobject: convert block/ll_rw_blk.c to use ko..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 183/196] driver core: fix build with SYSFS=n, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
Re: [PATCH 183/196] driver core: fix build with SYSFS=n, Harvey Harrison, (Fri Jan 25, 7:27 pm)
Re: [PATCH 183/196] driver core: fix build with SYSFS=n, Andrew Morton, (Fri Jan 25, 6:33 pm)
[PATCH 145/196] driver core: Introduce default attribute gro..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 174/196] Kobject: convert remaining kobject_unregiste..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 185/196] UIO: constify function pointer tables, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 129/196] Kobject: convert drivers/base/class.c to use..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 166/196] Kobject: rename kobject_init_ng() to kobject..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 155/196] Driver core: fix class glue dir cleanup logic, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 151/196] Driver core: move the static kobject out of ..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 178/196] kobject: update the kobject/kset documentation, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 158/196] Driver core: convert block from raw kobjects..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 126/196] Kobject: change arch/x86/kernel/cpu/mcheck/m..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 180/196] kobject: add sample code for how to use kset..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 150/196] Driver core: move the driver specific module..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 162/196] Kobject: convert kernel/module.c to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 139/196] driver core: add way to get to bus device kl..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 135/196] Kobject: convert mm/slub.c to use kobject_in..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
Re: [PATCH 135/196] Kobject: convert mm/slub.c to use kobjec..., Christoph Lameter, (Fri Jan 25, 2:17 pm)
[PATCH 147/196] zfcp: Use device_driver default attribute gr..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 120/196] Kobject: change drivers/block/pktcdvd.c to u..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 125/196] Kobject: change drivers/md/md.c to use kobje..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 131/196] Kobject: convert drivers/net/iseries_veth.c ..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 128/196] Kobject: the cris iop_fw_load.c code is broken, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 186/196] Driver core: Cleanup get_device_parent() in ..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 156/196] sysfs: fix /sys/module/*/holders after sysfs..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 132/196] Kobject: convert fs/char_dev.c to use kobjec..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 112/196] Kobject: change drivers/firmware/efivars.c t..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 146/196] netiucv: Use device_driver default attribute..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 187/196] Driver Core: add class iteration api, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 138/196] driver core: add way to get to bus kset, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 194/196] Kobject: fix coding style issues in kobject.h, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 133/196] Kobject: convert kernel/params.c to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 152/196] Driver core: clean up debugging messages, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 195/196] Kobject: fix coding style issues in kobject ..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 175/196] Kobject: remove kobject_unregister() as no o..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 176/196] Driver core: change sysdev classes to use dy..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 116/196] Kobject: change drivers/pci/hotplug/pci_hotp..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 193/196] Driver core: fix coding style issues in devi..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 144/196] PCI: remove foolish code from pci-driver.c, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 168/196] Kset: remove kset_add function, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 173/196] Kobject: convert fs/* from kobject_unregiste..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 117/196] Kobject: change drivers/base/sys.c to use ko..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 141/196] USB: use proper call to driver_create_file, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 136/196] Kobject: convert net/bridge/br_if.c to use k..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
Re: [PATCH 136/196] Kobject: convert net/bridge/br_if.c to u..., Stephen Hemminger, (Fri Jan 25, 12:20 pm)
[PATCH 157/196] Kobject: drop child-&gt;parent ref at unregi..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 114/196] Kobject: change drivers/edac to use kobject_..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 167/196] Kobject: remove kobject_register(), Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 142/196] PCMCIA: use proper call to driver_create_file, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 130/196] Kobject: convert drivers/base/core.c to use ..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 127/196] Kobject: change arch/x86/kernel/cpu/mcheck/m..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 181/196] Driver core: use LIST_HEAD instead of call t..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 137/196] driver core: remove owner field from struct ..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 171/196] Kobject: convert arch/* from kobject_unregis..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 118/196] Kobject: change arch/x86/kernel/cpu/intel_ca..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 196/196] Driver core: coding style fixes, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 165/196] Kobject: remove kobject_init() as no one use..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 123/196] Kobject: change drivers/parisc/pdc_stable.c ..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 161/196] Kobject: convert drivers/md/md.c to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 140/196] driver core: remove fields from struct bus_t..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 148/196] Infiniband: make ipath driver use default dr..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 169/196] Kobject: auto-cleanup on final unref, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 179/196] kobject: add sample code for how to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 119/196] Kobject: change drivers/acpi/system.c to use..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 191/196] scsi: use class iteration api, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
Re: [PATCH 191/196] scsi: use class iteration api, James Bottomley, (Fri Jan 25, 10:55 am)
[PATCH 149/196] Driver: add driver_add_kobj for looney iseri..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 122/196] Kobject: change drivers/net/ibmveth.c to use..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 172/196] Kobject: convert drivers/* from kobject_unre..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 111/196] Kobject: change drivers/firmware/edd.c to us..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 188/196] ieee1394: use class iteration api, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 190/196] rtc: use class iteration api, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 153/196] Kobject: change drivers/base/bus to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 124/196] Kobject: change arch/ia64/kernel/topology.c ..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 177/196] kobject: remove old, outdated documentation., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 182/196] sysfs: make SYSFS_DEPRECATED depend on SYSFS, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 189/196] power supply : use class iteration api, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 192/196] spi: use class iteration api, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 170/196] Modules: remove unneeded release function, Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 134/196] Kobject: convert kernel/user.c to use kobjec..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 163/196] Kobject: remove kobject_add() as no one uses..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 113/196] Kobject: change drivers/cpufreq/cpufreq.c to..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 154/196] Driver core: fix race in __device_release_dr..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 184/196] Driver Core: constify the name passed to pla..., Greg Kroah-Hartman, (Fri Jan 25, 3:33 am)
[PATCH 110/196] Kobject: change drivers/infiniband to use ko..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 109/196] Kobject: change GFS2 to use kobject_init_and..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 108/196] Kobject: change net/bridge to use kobject_cr..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
Re: [PATCH 108/196] Kobject: change net/bridge to use kobjec..., Stephen Hemminger, (Fri Jan 25, 12:19 pm)
[PATCH 107/196] UIO: fix kobject usage, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 106/196] kobject: clean up debugging messages, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 105/196] kobject: grab the kset reference in kobject_..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 104/196] driver core: make /sys/power a kobject, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 103/196] driver core: clean up device_shutdown, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 102/196] driver core: clean up shutdown.c, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 101/196] kobject: convert parisc/pdc_stable to use ko..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 100/196] kobject: convert efivars to use kobject_create, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 099/196] kobject: convert ecryptfs to use kobject_cre..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 098/196] kobject: clean up rpadlpar horrid sysfs abuse, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 097/196] kobject: remove subsystem_(un)register funct..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 096/196] kobject: convert kernel_kset to be a kobject, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 095/196] kset: remove decl_subsys macro, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 094/196] kset: convert block_subsys to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 093/196] kset: convert ocfs2 to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 092/196] firmware: change firmware_kset to firmware_k..., Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 091/196] firmware: remove firmware_(un)register(), Greg Kroah-Hartman, (Fri Jan 25, 3:32 am)
[PATCH 090/196] kobject: convert /sys/firmware/acpi/ to use ..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 089/196] kset: convert edd to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 088/196] Driver Core: kill subsys_attribute and defau..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 087/196] kset: convert parisc/pdc_stable.c to use kse..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 086/196] kobject: convert parisc/pdc_stable to kobj_a..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 085/196] kset: convert s390 ipl.c to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 084/196] kobject: convert s390 ipl.c to kobj_attr int..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 083/196] kobject: convert pseries/power.c to kobj_att..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 082/196] kobject: convert arm/mach-omap1/pm.c to kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 081/196] kset: convert efivars to use kset_create for..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 080/196] kset: convert efivars to use kset_create for..., Greg Kroah-Hartman, (Fri Jan 25, 3:31 am)
[PATCH 081/196] kset: convert efivars to use kset_create for..., Greg Kroah-Hartman, (Fri Jan 25, 3:28 am)
[PATCH 080/196] kset: convert efivars to use kset_create for..., Greg Kroah-Hartman, (Fri Jan 25, 3:28 am)
[PATCH 004/196] Chinese: add translation of SubmittingPatches, Greg Kroah-Hartman, (Fri Jan 25, 3:27 am)
[PATCH 002/196] Chinese: rephrase English introduction in HO..., Greg Kroah-Hartman, (Fri Jan 25, 3:27 am)
[PATCH 001/196] Chinese: Add the known_regression URI to the..., Greg Kroah-Hartman, (Fri Jan 25, 3:27 am)
[PATCH 081/196] kset: convert efivars to use kset_create for..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 080/196] kset: convert efivars to use kset_create for..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 079/196] firmware: export firmware_kset so that peopl..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 078/196] kobject: convert efivars to kobj_attr interf..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 077/196] efivars: make new_var and del_var binary sys..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 076/196] ecryptfs: remove version_str file from sysfs, Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 075/196] fix struct user_info export's sysfs interact..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 074/196] Driver Core: switch all dynamic ksets to kob..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 073/196] Driver Core: add kobj_attribute handling, Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 072/196] kset: convert struct bus_device-&gt;drivers ..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 071/196] kset: convert struct bus_device-&gt;devices ..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 070/196] kset: convert /sys/power to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 069/196] kset: convert /sys/module to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 068/196] kset: move /sys/slab to /sys/kernel/slab, Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 067/196] kset: convert slub to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
Re: [PATCH 067/196] kset: convert slub to use kset_create, Christoph Lameter, (Fri Jan 25, 2:16 pm)
[PATCH 066/196] kset: convert /sys/devices/system to use kse..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 065/196] kobject: convert s390 hypervisor to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 064/196] kobject: convert /sys/hypervisor to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 063/196] kset: convert /sys/devices to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 062/196] kset: convert drivers/base/firmware.c to use..., Greg Kroah-Hartman, (Fri Jan 25, 3:10 am)
[PATCH 061/196] kset: convert drivers/base/class.c to use ks..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 060/196] kset: convert drivers/base/bus.c to use kset..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 059/196] kset: convert kernel_subsys to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 058/196] kset: remove decl_subsys_name, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 057/196] kset: convert pci hotplug to use kset_create..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 056/196] kset: convert dlm to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 055/196] kset: convert gfs2 dlm to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 054/196] kset: convert gfs2 to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 053/196] kobject: convert main fs kobject to use kobj..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 052/196] kset: convert ecryptfs to use kset_create, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 051/196] kobject: convert configfs to use kobject_cre..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 050/196] kobject: convert debugfs to use kobject_create, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 049/196] kobject: convert securityfs to use kobject_c..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 048/196] kobject: convert fuse to use kobject_create, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 047/196] kobject: get rid of kobject_kset_add_dir, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 046/196] kobject: get rid of kobject_add_dir, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 045/196] kobject: add kobject_create_and_add function, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 044/196] kset: add kset_create_and_add function, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 043/196] kobject: remove kobj_set_kset_s as no one is..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 042/196] kobject: remove struct kobj_type from struct..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 041/196] kobject: add kobject_init_and_add function, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 040/196] kobject: add kobject_add_ng function, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 039/196] kobject: add kobject_init_ng function, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 038/196] kobject: make kobject_cleanup be static, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 037/196] kobject: fix up kobject_set_name to use kvas..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 036/196] kobject: convert icom to use kref, not kobject, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 035/196] kobject: convert hvcs to use kref, not kobject, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 034/196] kobject: convert hvc_console to use kref, no..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 033/196] kobject: convert ibmasm to use kref, not kob..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 032/196] sysfs: remove SPIN_LOCK_UNLOCKED, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 031/196] sysfs: create optimal relative symlink targets, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 030/196] driver core: Make the dev_*() family of macr..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 029/196] ecryptfs: clean up attribute mess, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 028/196] cosa: Convert from class_device to device fo..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 027/196] tifm: Convert from class_device to device fo..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 026/196] pktcdvd: Convert from class_device to device..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 025/196] paride: Convert from class_device to device ..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 024/196] mtd: Convert from class_device to device for..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 023/196] MCP_UCB1200: Convert from class_device to de..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 022/196] adb: Convert from class_device to device, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 021/196] ISDN: Convert from class_device to device fo..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 020/196] IDE: Convert from class_device to device for..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 019/196] DMA: Convert from class_device to device for..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 018/196] coda: convert struct class_device to struct ..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 017/196] aoechr: Convert from class_device to device, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 016/196] kref: add kref_set(), Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 015/196] PM: Acquire device locks on suspend, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 014/196] kobject: remove incorrect comment in kobject..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 013/196] Documentation: Replace obsolete "driverfs" w..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 012/196] nozomi driver, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
Re: [PATCH 012/196] nozomi driver, Jan Engelhardt, (Fri Jan 25, 4:31 am)
Re: [PATCH 012/196] nozomi driver, Frank Seidel, (Fri Jan 25, 8:44 am)
Re: [PATCH 012/196] nozomi driver, Jan Engelhardt, (Fri Jan 25, 9:21 am)
Re: [PATCH 012/196] nozomi driver, , (Fri Jan 25, 1:02 pm)
Re: [PATCH 012/196 ver2] nozomi driver, Frank Seidel, (Fri Jan 25, 8:44 am)
Re: [PATCH 012/196 ver2] nozomi driver, Greg KH, (Fri Jan 25, 2:55 pm)
Re: [PATCH 012/196 ver2] nozomi driver, Frank Seidel, (Fri Jan 25, 4:13 pm)
Re: [PATCH 012/196 ver2] nozomi driver, Frank Seidel, (Fri Jan 25, 3:33 pm)
Re: [PATCH 012/196 ver2] nozomi driver, Greg KH, (Fri Jan 25, 3:43 pm)
Re: [PATCH 012/196 ver2] nozomi driver, Frank Seidel, (Fri Jan 25, 4:14 pm)
Re: [PATCH 012/196] nozomi driver, Stefan Richter, (Fri Jan 25, 7:56 am)
[PATCH 011/196] sysfs: Fix a copy-n-paste typo in comment, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 010/196] Chinese: add translation of Codingstyle, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 009/196] Chinese: add translation of sparse.txt, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 008/196] Chinese: add translation of volatile-conside..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 007/196] Chinese: add translation of stable_kernel_ru..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 006/196] Chinese: add translation of oops-tracing.txt, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 005/196] Chinese: add translation of SubmittingDrivers, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 004/196] Chinese: add translation of SubmittingPatches, Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 002/196] Chinese: rephrase English introduction in HO..., Greg Kroah-Hartman, (Fri Jan 25, 3:09 am)
[PATCH 001/196] Chinese: Add the known_regression URI to the..., Greg Kroah-Hartman, (Fri Jan 25, 3:08 am)