aboutsummaryrefslogtreecommitdiffstats
path: root/driver
diff options
context:
space:
mode:
authorGreg KH <greg@press.kroah.org>2005-10-31 22:15:35 -0800
committerGreg Kroah-Hartman <gregkh@suse.de>2005-10-31 22:15:35 -0800
commit7fb5309bdd88fdc01678006436ea41eb93806fe7 (patch)
tree8aaf1c31aa240db8c1dc9fd3c9d44ae2a8501590 /driver
parent5212892cf03dbed8e17f739c14044c72ca144d28 (diff)
downloadpatches-7fb5309bdd88fdc01678006436ea41eb93806fe7.tar.gz
remove the driver patches that went into 2.6.14-git1
Diffstat (limited to 'driver')
-rw-r--r--driver/aoe-01.patch65
-rw-r--r--driver/aoe-02.patch25
-rw-r--r--driver/class-device.h-documentation.patch41
-rw-r--r--driver/class_dev_child.patch315
-rw-r--r--driver/class_device_create_api_fixup.patch776
-rw-r--r--driver/coldplug-emit-hotplug-events-from-sysfs.patch341
-rw-r--r--driver/driver-core-big-kfree-null-check-cleanup-documentation.patch31
-rw-r--r--driver/driver-ide-tape-sysfs.patch106
-rw-r--r--driver/driver-interface-pass.patch173
-rw-r--r--driver/driver-kobject-typo.patch28
-rw-r--r--driver/driver-model-get-rid-of-the-obsolete-tri-level-suspend-resume-callbacks.patch2344
-rw-r--r--driver/driver-model-wakeup-01.patch176
-rw-r--r--driver/driver-model-wakeup-02.patch59
-rw-r--r--driver/driver-porting-typo.patch33
-rw-r--r--driver/driver-send-hotplug-before-adding-class_interface.patch37
-rw-r--r--driver/drivers-base-fix-sparse-warnings.patch138
-rw-r--r--driver/fix-documentation-of-driver-suspend-resume-callbacks.patch43
-rw-r--r--driver/i2o-class-01.patch103
-rw-r--r--driver/i2o-remove-class-interface.patch398
-rw-r--r--driver/i2o-remove-i2o_device_class.patch236
-rw-r--r--driver/input-class_device-move.patch122
-rw-r--r--driver/input-convert-to-dynamic-beep.patch120
-rw-r--r--driver/input-convert-to-dynamic-bluetooth.patch68
-rw-r--r--driver/input-convert-to-dynamic-joystick.patch4565
-rw-r--r--driver/input-convert-to-dynamic-keyboard.patch1669
-rw-r--r--driver/input-convert-to-dynamic-konicawc.patch157
-rw-r--r--driver/input-convert-to-dynamic-macintosh.patch525
-rw-r--r--driver/input-convert-to-dynamic-media.patch1081
-rw-r--r--driver/input-convert-to-dynamic-misc.patch233
-rw-r--r--driver/input-convert-to-dynamic-mouse.patch1406
-rw-r--r--driver/input-convert-to-dynamic-onetouch.patch203
-rw-r--r--driver/input-convert-to-dynamic-sonypi.patch161
-rw-r--r--driver/input-convert-to-dynamic-touchscreen.patch1054
-rw-r--r--driver/input-convert-to-dynamic-ucb1x00-ts.patch104
-rw-r--r--driver/input-convert-to-dynamic-usb.patch3561
-rw-r--r--driver/input-export-input_dev-data-in-sysfs.patch241
-rw-r--r--driver/input-input_dev_class-export.patch39
-rw-r--r--driver/input-register-class_device-sooner.patch34
-rw-r--r--driver/input-remove-custom-hotplug.patch335
-rw-r--r--driver/input-remove-devfs.patch188
-rw-r--r--driver/input-remove-input_class.patch78
-rw-r--r--driver/input-rename-input_dev_class.patch182
-rw-r--r--driver/input-show-sysfs-path-in-proc.patch50
-rw-r--r--driver/input-sysfs-intregration.patch207
-rw-r--r--driver/input_backward_compatible_symlink.patch154
-rw-r--r--driver/input_oops_fix.patch57
-rw-r--r--driver/kernel-doc-drivers-base-fixes.patch53
-rw-r--r--driver/update-udev-version.patch25
48 files changed, 0 insertions, 22140 deletions
diff --git a/driver/aoe-01.patch b/driver/aoe-01.patch
deleted file mode 100644
index 72d7f1dd11d4d..0000000000000
--- a/driver/aoe-01.patch
+++ /dev/null
@@ -1,65 +0,0 @@
-From ecashin@coraid.com Thu Sep 29 10:06:27 2005
-From: "Ed L. Cashin" <ecashin@coraid.com>
-CC: ecashin@coraid.com, Greg K-H <greg@kroah.com>, "David S. Miller" <davem@davemloft.net>
-Subject: aoe: use get_unaligned for accesses in ATA id buffer
-Date: Thu, 29 Sep 2005 12:47:40 -0400
-Message-ID: <87mzlvakib.fsf@coraid.com>
-
-Signed-off-by: "Ed L. Cashin" <ecashin@coraid.com>
-Signed-off-by: David S. Miller <davem@davemloft.net>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-Use get_unaligned for possibly-unaligned multi-byte accesses to the
-ATA device identify response buffer.
-
----
- drivers/block/aoe/aoecmd.c | 15 ++++++++-------
- 1 file changed, 8 insertions(+), 7 deletions(-)
-
---- gregkh-2.6.orig/drivers/block/aoe/aoecmd.c
-+++ gregkh-2.6/drivers/block/aoe/aoecmd.c
-@@ -8,6 +8,7 @@
- #include <linux/blkdev.h>
- #include <linux/skbuff.h>
- #include <linux/netdevice.h>
-+#include <asm/unaligned.h>
- #include "aoe.h"
-
- #define TIMERTICK (HZ / 10)
-@@ -311,16 +312,16 @@ ataid_complete(struct aoedev *d, unsigne
- u16 n;
-
- /* word 83: command set supported */
-- n = le16_to_cpup((__le16 *) &id[83<<1]);
-+ n = le16_to_cpu(get_unaligned((__le16 *) &id[83<<1]));
-
- /* word 86: command set/feature enabled */
-- n |= le16_to_cpup((__le16 *) &id[86<<1]);
-+ n |= le16_to_cpu(get_unaligned((__le16 *) &id[86<<1]));
-
- if (n & (1<<10)) { /* bit 10: LBA 48 */
- d->flags |= DEVFL_EXT;
-
- /* word 100: number lba48 sectors */
-- ssize = le64_to_cpup((__le64 *) &id[100<<1]);
-+ ssize = le64_to_cpu(get_unaligned((__le64 *) &id[100<<1]));
-
- /* set as in ide-disk.c:init_idedisk_capacity */
- d->geo.cylinders = ssize;
-@@ -331,12 +332,12 @@ ataid_complete(struct aoedev *d, unsigne
- d->flags &= ~DEVFL_EXT;
-
- /* number lba28 sectors */
-- ssize = le32_to_cpup((__le32 *) &id[60<<1]);
-+ ssize = le32_to_cpu(get_unaligned((__le32 *) &id[60<<1]));
-
- /* NOTE: obsolete in ATA 6 */
-- d->geo.cylinders = le16_to_cpup((__le16 *) &id[54<<1]);
-- d->geo.heads = le16_to_cpup((__le16 *) &id[55<<1]);
-- d->geo.sectors = le16_to_cpup((__le16 *) &id[56<<1]);
-+ d->geo.cylinders = le16_to_cpu(get_unaligned((__le16 *) &id[54<<1]));
-+ d->geo.heads = le16_to_cpu(get_unaligned((__le16 *) &id[55<<1]));
-+ d->geo.sectors = le16_to_cpu(get_unaligned((__le16 *) &id[56<<1]));
- }
- d->ssize = ssize;
- d->geo.start = 0;
diff --git a/driver/aoe-02.patch b/driver/aoe-02.patch
deleted file mode 100644
index 9e3a450c58bcd..0000000000000
--- a/driver/aoe-02.patch
+++ /dev/null
@@ -1,25 +0,0 @@
-From ecashin@coraid.com Thu Sep 29 10:06:31 2005
-From: "Ed L. Cashin" <ecashin@coraid.com>
-CC: ecashin@coraid.com, Greg K-H <greg@kroah.com>
-Subject: aoe: update to version 14
-Date: Thu, 29 Sep 2005 12:47:55 -0400
-Message-ID: <87ek77akhw.fsf@coraid.com>
-
-Signed-off-by: "Ed L. Cashin" <ecashin@coraid.com>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-Update driver version number to 14.
-
----
- drivers/block/aoe/aoe.h | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
---- gregkh-2.6.orig/drivers/block/aoe/aoe.h
-+++ gregkh-2.6/drivers/block/aoe/aoe.h
-@@ -1,5 +1,5 @@
- /* Copyright (c) 2004 Coraid, Inc. See COPYING for GPL terms. */
--#define VERSION "12"
-+#define VERSION "14"
- #define AOE_MAJOR 152
- #define DEVICE_NAME "aoe"
-
diff --git a/driver/class-device.h-documentation.patch b/driver/class-device.h-documentation.patch
deleted file mode 100644
index 6bf70b4e44b4f..0000000000000
--- a/driver/class-device.h-documentation.patch
+++ /dev/null
@@ -1,41 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: Driver Core: document struct class_device properly
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- include/linux/device.h | 24 ++++++++++++++++++++++++
- 1 file changed, 24 insertions(+)
-
---- gregkh-2.6.orig/include/linux/device.h
-+++ gregkh-2.6/include/linux/device.h
-@@ -203,6 +203,30 @@ struct class_device_attribute class_devi
- extern int class_device_create_file(struct class_device *,
- const struct class_device_attribute *);
-
-+/**
-+ * struct class_device - class devices
-+ * @class: pointer to the parent class for this class device. This is required.
-+ * @devt: for internal use by the driver core only.
-+ * @node: for internal use by the driver core only.
-+ * @kobj: for internal use by the driver core only.
-+ * @devt_attr: for internal use by the driver core only.
-+ * @dev: if set, a symlink to the struct device is created in the sysfs
-+ * directory for this struct class device.
-+ * @class_data: pointer to whatever you want to store here for this struct
-+ * class_device. Use class_get_devdata() and class_set_devdata() to get and
-+ * set this pointer.
-+ * @parent: pointer to a struct class_device that is the parent of this struct
-+ * class_device. If NULL, this class_device will show up at the root of the
-+ * struct class in sysfs (which is probably what you want to have happen.)
-+ * @release: pointer to a release function for this struct class_device. If
-+ * set, this will be called instead of the class specific release function.
-+ * Only use this if you want to override the default release function, like
-+ * when you are nesting class_device structures.
-+ * @hotplug: pointer to a hotplug function for this struct class_device. If
-+ * set, this will be called instead of the class specific hotplug function.
-+ * Only use this if you want to override the default hotplug function, like
-+ * when you are nesting class_device structures.
-+ */
- struct class_device {
- struct list_head node;
-
diff --git a/driver/class_dev_child.patch b/driver/class_dev_child.patch
deleted file mode 100644
index 052ed9cba468c..0000000000000
--- a/driver/class_dev_child.patch
+++ /dev/null
@@ -1,315 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: Driver Core: add the ability for class_device structures to be nested
-
-This patch allows struct class_device to be nested, so that another
-struct class_device can be the parent of a new one, instead of only
-having the struct class be the parent. This will allow us to
-(hopefully) fix up the input and video class subsystem mess.
-
-But please people, don't go crazy and start making huge trees of class
-devices, you should only need 2 levels deep to get everything to work
-(remember to use a class_interface to get notification of a new class
-device being added to the system.)
-
-Oh, this also allows us to have the possibility of potentially, someday,
-moving /sys/block into /sys/class. The main hindrance is that pesky
-/dev numberspace issue...
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/base/class.c | 125 +++++++++++++++++++++++++++++++------------------
- include/linux/device.h | 13 +++--
- 2 files changed, 91 insertions(+), 47 deletions(-)
-
---- gregkh-2.6.orig/drivers/base/class.c
-+++ gregkh-2.6/drivers/base/class.c
-@@ -99,7 +99,8 @@ struct class * class_get(struct class *
-
- void class_put(struct class * cls)
- {
-- subsys_put(&cls->subsys);
-+ if (cls)
-+ subsys_put(&cls->subsys);
- }
-
-
-@@ -165,14 +166,25 @@ void class_unregister(struct class * cls
-
- static void class_create_release(struct class *cls)
- {
-+ pr_debug("%s called for %s\n", __FUNCTION__, cls->name);
- kfree(cls);
- }
-
- static void class_device_create_release(struct class_device *class_dev)
- {
-+ pr_debug("%s called for %s\n", __FUNCTION__, class_dev->class_id);
- kfree(class_dev);
- }
-
-+/* needed to allow these devices to have parent class devices */
-+static int class_device_create_hotplug(struct class_device *class_dev,
-+ char **envp, int num_envp,
-+ char *buffer, int buffer_size)
-+{
-+ pr_debug("%s called for %s\n", __FUNCTION__, class_dev->class_id);
-+ return 0;
-+}
-+
- /**
- * class_create - create a struct class structure
- * @owner: pointer to the module that is to "own" this struct class
-@@ -301,10 +313,12 @@ static void class_dev_release(struct kob
- kfree(cd->devt_attr);
- cd->devt_attr = NULL;
-
-- if (cls->release)
-+ if (cd->release)
-+ cd->release(cd);
-+ else if (cls->release)
- cls->release(cd);
- else {
-- printk(KERN_ERR "Device class '%s' does not have a release() function, "
-+ printk(KERN_ERR "Class Device '%s' does not have a release() function, "
- "it is broken and must be fixed.\n",
- cd->class_id);
- WARN_ON(1);
-@@ -382,14 +396,18 @@ static int class_hotplug(struct kset *ks
- buffer = &buffer[length];
- buffer_size -= length;
-
-- if (class_dev->class->hotplug) {
-- /* have the bus specific function add its stuff */
-- retval = class_dev->class->hotplug (class_dev, envp, num_envp,
-- buffer, buffer_size);
-- if (retval) {
-- pr_debug ("%s - hotplug() returned %d\n",
-- __FUNCTION__, retval);
-- }
-+ if (class_dev->hotplug) {
-+ /* have the class device specific function add its stuff */
-+ retval = class_dev->hotplug(class_dev, envp, num_envp,
-+ buffer, buffer_size);
-+ if (retval)
-+ pr_debug("class_dev->hotplug() returned %d\n", retval);
-+ } else if (class_dev->class->hotplug) {
-+ /* have the class specific function add its stuff */
-+ retval = class_dev->class->hotplug(class_dev, envp, num_envp,
-+ buffer, buffer_size);
-+ if (retval)
-+ pr_debug("class->hotplug() returned %d\n", retval);
- }
-
- return retval;
-@@ -476,37 +494,42 @@ static char *make_class_name(struct clas
-
- int class_device_add(struct class_device *class_dev)
- {
-- struct class * parent = NULL;
-- struct class_interface * class_intf;
-+ struct class *parent_class = NULL;
-+ struct class_device *parent_class_dev = NULL;
-+ struct class_interface *class_intf;
- char *class_name = NULL;
-- int error;
-+ int error = -EINVAL;
-
- class_dev = class_device_get(class_dev);
- if (!class_dev)
- return -EINVAL;
-
-- if (!strlen(class_dev->class_id)) {
-- error = -EINVAL;
-+ if (!strlen(class_dev->class_id))
- goto register_done;
-- }
-
-- parent = class_get(class_dev->class);
-+ parent_class = class_get(class_dev->class);
-+ if (!parent_class)
-+ goto register_done;
-+ parent_class_dev = class_device_get(class_dev->parent);
-
- pr_debug("CLASS: registering class device: ID = '%s'\n",
- class_dev->class_id);
-
- /* first, register with generic layer. */
- kobject_set_name(&class_dev->kobj, "%s", class_dev->class_id);
-- if (parent)
-- class_dev->kobj.parent = &parent->subsys.kset.kobj;
-+ if (parent_class_dev)
-+ class_dev->kobj.parent = &parent_class_dev->kobj;
-+ else
-+ class_dev->kobj.parent = &parent_class->subsys.kset.kobj;
-
-- if ((error = kobject_add(&class_dev->kobj)))
-+ error = kobject_add(&class_dev->kobj);
-+ if (error)
- goto register_done;
-
- /* add the needed attributes to this device */
- class_dev->uevent_attr.attr.name = "uevent";
- class_dev->uevent_attr.attr.mode = S_IWUSR;
-- class_dev->uevent_attr.attr.owner = parent->owner;
-+ class_dev->uevent_attr.attr.owner = parent_class->owner;
- class_dev->uevent_attr.store = store_uevent;
- class_device_create_file(class_dev, &class_dev->uevent_attr);
-
-@@ -520,7 +543,7 @@ int class_device_add(struct class_device
- }
- attr->attr.name = "dev";
- attr->attr.mode = S_IRUGO;
-- attr->attr.owner = parent->owner;
-+ attr->attr.owner = parent_class->owner;
- attr->show = show_dev;
- class_device_create_file(class_dev, attr);
- class_dev->devt_attr = attr;
-@@ -538,18 +561,20 @@ int class_device_add(struct class_device
- kobject_hotplug(&class_dev->kobj, KOBJ_ADD);
-
- /* notify any interfaces this device is now here */
-- if (parent) {
-- down(&parent->sem);
-- list_add_tail(&class_dev->node, &parent->children);
-- list_for_each_entry(class_intf, &parent->interfaces, node)
-+ if (parent_class) {
-+ down(&parent_class->sem);
-+ list_add_tail(&class_dev->node, &parent_class->children);
-+ list_for_each_entry(class_intf, &parent_class->interfaces, node)
- if (class_intf->add)
- class_intf->add(class_dev, class_intf);
-- up(&parent->sem);
-+ up(&parent_class->sem);
- }
-
- register_done:
-- if (error && parent)
-- class_put(parent);
-+ if (error) {
-+ class_put(parent_class);
-+ class_device_put(parent_class_dev);
-+ }
- class_device_put(class_dev);
- kfree(class_name);
- return error;
-@@ -564,21 +589,28 @@ int class_device_register(struct class_d
- /**
- * class_device_create - creates a class device and registers it with sysfs
- * @cs: pointer to the struct class that this device should be registered to.
-+ * @parent: pointer to the parent struct class_device of this new device, if any.
- * @dev: the dev_t for the char device to be added.
- * @device: a pointer to a struct device that is assiociated with this class device.
- * @fmt: string for the class device's name
- *
- * This function can be used by char device classes. A struct
- * class_device will be created in sysfs, registered to the specified
-- * class. A "dev" file will be created, showing the dev_t for the
-- * device. The pointer to the struct class_device will be returned from
-- * the call. Any further sysfs files that might be required can be
-- * created using this pointer.
-+ * class.
-+ * A "dev" file will be created, showing the dev_t for the device, if
-+ * the dev_t is not 0,0.
-+ * If a pointer to a parent struct class_device is passed in, the newly
-+ * created struct class_device will be a child of that device in sysfs.
-+ * The pointer to the struct class_device will be returned from the
-+ * call. Any further sysfs files that might be required can be created
-+ * using this pointer.
- *
- * Note: the struct class passed to this function must have previously
- * been created with a call to class_create().
- */
--struct class_device *class_device_create(struct class *cls, dev_t devt,
-+struct class_device *class_device_create(struct class *cls,
-+ struct class_device *parent,
-+ dev_t devt,
- struct device *device, char *fmt, ...)
- {
- va_list args;
-@@ -597,6 +629,9 @@ struct class_device *class_device_create
- class_dev->devt = devt;
- class_dev->dev = device;
- class_dev->class = cls;
-+ class_dev->parent = parent;
-+ class_dev->release = class_device_create_release;
-+ class_dev->hotplug = class_device_create_hotplug;
-
- va_start(args, fmt);
- vsnprintf(class_dev->class_id, BUS_ID_SIZE, fmt, args);
-@@ -614,17 +649,18 @@ error:
-
- void class_device_del(struct class_device *class_dev)
- {
-- struct class * parent = class_dev->class;
-- struct class_interface * class_intf;
-+ struct class *parent_class = class_dev->class;
-+ struct class_device *parent_device = class_dev->parent;
-+ struct class_interface *class_intf;
- char *class_name = NULL;
-
-- if (parent) {
-- down(&parent->sem);
-+ if (parent_class) {
-+ down(&parent_class->sem);
- list_del_init(&class_dev->node);
-- list_for_each_entry(class_intf, &parent->interfaces, node)
-+ list_for_each_entry(class_intf, &parent_class->interfaces, node)
- if (class_intf->remove)
- class_intf->remove(class_dev, class_intf);
-- up(&parent->sem);
-+ up(&parent_class->sem);
- }
-
- if (class_dev->dev) {
-@@ -640,8 +676,8 @@ void class_device_del(struct class_devic
- kobject_hotplug(&class_dev->kobj, KOBJ_REMOVE);
- kobject_del(&class_dev->kobj);
-
-- if (parent)
-- class_put(parent);
-+ class_device_put(parent_device);
-+ class_put(parent_class);
- kfree(class_name);
- }
-
-@@ -721,7 +757,8 @@ struct class_device * class_device_get(s
-
- void class_device_put(struct class_device *class_dev)
- {
-- kobject_put(&class_dev->kobj);
-+ if (class_dev)
-+ kobject_put(&class_dev->kobj);
- }
-
-
---- gregkh-2.6.orig/include/linux/device.h
-+++ gregkh-2.6/include/linux/device.h
-@@ -213,7 +213,11 @@ struct class_device {
- struct class_device_attribute uevent_attr;
- struct device * dev; /* not necessary, but nice to have */
- void * class_data; /* class-specific data */
-+ struct class_device *parent; /* parent of this child device, if there is one */
-
-+ void (*release)(struct class_device *dev);
-+ int (*hotplug)(struct class_device *dev, char **envp,
-+ int num_envp, char *buffer, int buffer_size);
- char class_id[BUS_ID_SIZE]; /* unique to this class */
- };
-
-@@ -261,9 +265,12 @@ extern void class_interface_unregister(s
-
- extern struct class *class_create(struct module *owner, char *name);
- extern void class_destroy(struct class *cls);
--extern struct class_device *class_device_create(struct class *cls, dev_t devt,
-- struct device *device, char *fmt, ...)
-- __attribute__((format(printf,4,5)));
-+extern struct class_device *class_device_create(struct class *cls,
-+ struct class_device *parent,
-+ dev_t devt,
-+ struct device *device,
-+ char *fmt, ...)
-+ __attribute__((format(printf,5,6)));
- extern void class_device_destroy(struct class *cls, dev_t devt);
-
-
diff --git a/driver/class_device_create_api_fixup.patch b/driver/class_device_create_api_fixup.patch
deleted file mode 100644
index 1e4db408df117..0000000000000
--- a/driver/class_device_create_api_fixup.patch
+++ /dev/null
@@ -1,776 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: Driver Core: fix up all callers of class_device_create()
-
-The previous patch adding the ability to nest struct class_device
-changed the paramaters to the call class_device_create(). This patch
-fixes up all in-kernel users of the function.
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- arch/i386/kernel/cpuid.c | 2 +-
- arch/i386/kernel/msr.c | 2 +-
- drivers/block/aoe/aoechr.c | 2 +-
- drivers/block/paride/pg.c | 2 +-
- drivers/block/paride/pt.c | 4 ++--
- drivers/char/dsp56k.c | 2 +-
- drivers/char/ftape/zftape/zftape-init.c | 12 ++++++------
- drivers/char/ip2main.c | 10 ++++++----
- drivers/char/ipmi/ipmi_devintf.c | 2 +-
- drivers/char/istallion.c | 3 ++-
- drivers/char/lp.c | 2 +-
- drivers/char/mem.c | 3 ++-
- drivers/char/misc.c | 2 +-
- drivers/char/ppdev.c | 2 +-
- drivers/char/raw.c | 4 ++--
- drivers/char/snsc.c | 2 +-
- drivers/char/stallion.c | 4 +++-
- drivers/char/tipar.c | 2 +-
- drivers/char/tty_io.c | 10 +++++-----
- drivers/char/vc_screen.c | 10 ++++++----
- drivers/char/viotape.c | 4 ++--
- drivers/hwmon/hwmon.c | 2 +-
- drivers/ide/ide-tape.c | 4 ++--
- drivers/ieee1394/dv1394.c | 2 +-
- drivers/ieee1394/raw1394.c | 2 +-
- drivers/ieee1394/video1394.c | 2 +-
- drivers/infiniband/core/ucm.c | 2 +-
- drivers/input/evdev.c | 2 +-
- drivers/input/joydev.c | 2 +-
- drivers/input/mousedev.c | 4 ++--
- drivers/input/tsdev.c | 2 +-
- drivers/isdn/capi/capi.c | 2 +-
- drivers/macintosh/adb.c | 2 +-
- drivers/media/dvb/dvb-core/dvbdev.c | 2 +-
- drivers/message/i2o/iop.c | 2 +-
- drivers/mtd/mtdchar.c | 4 ++--
- drivers/net/ppp_generic.c | 2 +-
- drivers/net/wan/cosa.c | 2 +-
- drivers/s390/char/tape_class.c | 1 +
- drivers/s390/char/vmlogrdr.c | 1 +
- drivers/scsi/ch.c | 2 +-
- drivers/scsi/osst.c | 2 +-
- drivers/scsi/sg.c | 2 +-
- drivers/scsi/st.c | 2 +-
- drivers/usb/core/devio.c | 2 +-
- drivers/usb/core/file.c | 4 +++-
- drivers/usb/core/hcd.c | 3 ++-
- drivers/video/fbmem.c | 2 +-
- fs/coda/psdev.c | 4 ++--
- sound/core/sound.c | 2 +-
- sound/oss/soundcard.c | 4 ++--
- sound/sound_core.c | 2 +-
- 52 files changed, 86 insertions(+), 73 deletions(-)
-
---- gregkh-2.6.orig/drivers/usb/core/devio.c
-+++ gregkh-2.6/drivers/usb/core/devio.c
-@@ -1509,7 +1509,7 @@ void usbdev_add(struct usb_device *dev)
- {
- int minor = ((dev->bus->busnum-1) * 128) + (dev->devnum-1);
-
-- dev->class_dev = class_device_create(usb_device_class,
-+ dev->class_dev = class_device_create(usb_device_class, NULL,
- MKDEV(USB_DEVICE_MAJOR, minor), &dev->dev,
- "usbdev%d.%d", dev->bus->busnum, dev->devnum);
-
---- gregkh-2.6.orig/drivers/usb/core/file.c
-+++ gregkh-2.6/drivers/usb/core/file.c
-@@ -172,7 +172,9 @@ int usb_register_dev(struct usb_interfac
- ++temp;
- else
- temp = name;
-- intf->class_dev = class_device_create(usb_class, MKDEV(USB_MAJOR, minor), &intf->dev, "%s", temp);
-+ intf->class_dev = class_device_create(usb_class, NULL,
-+ MKDEV(USB_MAJOR, minor),
-+ &intf->dev, "%s", temp);
- if (IS_ERR(intf->class_dev)) {
- spin_lock (&minor_lock);
- usb_minors[intf->minor] = NULL;
---- gregkh-2.6.orig/drivers/usb/core/hcd.c
-+++ gregkh-2.6/drivers/usb/core/hcd.c
-@@ -782,7 +782,8 @@ static int usb_register_bus(struct usb_b
- return -E2BIG;
- }
-
-- bus->class_dev = class_device_create(usb_host_class, MKDEV(0,0), bus->controller, "usb_host%d", busnum);
-+ bus->class_dev = class_device_create(usb_host_class, NULL, MKDEV(0,0),
-+ bus->controller, "usb_host%d", busnum);
- if (IS_ERR(bus->class_dev)) {
- clear_bit(busnum, busmap.busmap);
- up(&usb_bus_list_lock);
---- gregkh-2.6.orig/drivers/video/fbmem.c
-+++ gregkh-2.6/drivers/video/fbmem.c
-@@ -1031,7 +1031,7 @@ register_framebuffer(struct fb_info *fb_
- break;
- fb_info->node = i;
-
-- fb_info->class_device = class_device_create(fb_class, MKDEV(FB_MAJOR, i),
-+ fb_info->class_device = class_device_create(fb_class, NULL, MKDEV(FB_MAJOR, i),
- fb_info->device, "fb%d", i);
- if (IS_ERR(fb_info->class_device)) {
- /* Not fatal */
---- gregkh-2.6.orig/drivers/block/aoe/aoechr.c
-+++ gregkh-2.6/drivers/block/aoe/aoechr.c
-@@ -224,7 +224,7 @@ aoechr_init(void)
- return PTR_ERR(aoe_class);
- }
- for (i = 0; i < ARRAY_SIZE(chardevs); ++i)
-- class_device_create(aoe_class,
-+ class_device_create(aoe_class, NULL,
- MKDEV(AOE_MAJOR, chardevs[i].minor),
- NULL, chardevs[i].name);
-
---- gregkh-2.6.orig/drivers/block/paride/pg.c
-+++ gregkh-2.6/drivers/block/paride/pg.c
-@@ -674,7 +674,7 @@ static int __init pg_init(void)
- for (unit = 0; unit < PG_UNITS; unit++) {
- struct pg *dev = &devices[unit];
- if (dev->present) {
-- class_device_create(pg_class, MKDEV(major, unit),
-+ class_device_create(pg_class, NULL, MKDEV(major, unit),
- NULL, "pg%u", unit);
- err = devfs_mk_cdev(MKDEV(major, unit),
- S_IFCHR | S_IRUSR | S_IWUSR, "pg/%u",
---- gregkh-2.6.orig/drivers/block/paride/pt.c
-+++ gregkh-2.6/drivers/block/paride/pt.c
-@@ -971,7 +971,7 @@ static int __init pt_init(void)
- devfs_mk_dir("pt");
- for (unit = 0; unit < PT_UNITS; unit++)
- if (pt[unit].present) {
-- class_device_create(pt_class, MKDEV(major, unit),
-+ class_device_create(pt_class, NULL, MKDEV(major, unit),
- NULL, "pt%d", unit);
- err = devfs_mk_cdev(MKDEV(major, unit),
- S_IFCHR | S_IRUSR | S_IWUSR,
-@@ -980,7 +980,7 @@ static int __init pt_init(void)
- class_device_destroy(pt_class, MKDEV(major, unit));
- goto out_class;
- }
-- class_device_create(pt_class, MKDEV(major, unit + 128),
-+ class_device_create(pt_class, NULL, MKDEV(major, unit + 128),
- NULL, "pt%dn", unit);
- err = devfs_mk_cdev(MKDEV(major, unit + 128),
- S_IFCHR | S_IRUSR | S_IWUSR,
---- gregkh-2.6.orig/drivers/char/dsp56k.c
-+++ gregkh-2.6/drivers/char/dsp56k.c
-@@ -515,7 +515,7 @@ static int __init dsp56k_init_driver(voi
- err = PTR_ERR(dsp56k_class);
- goto out_chrdev;
- }
-- class_device_create(dsp56k_class, MKDEV(DSP56K_MAJOR, 0), NULL, "dsp56k");
-+ class_device_create(dsp56k_class, NULL, MKDEV(DSP56K_MAJOR, 0), NULL, "dsp56k");
-
- err = devfs_mk_cdev(MKDEV(DSP56K_MAJOR, 0),
- S_IFCHR | S_IRUSR | S_IWUSR, "dsp56k");
---- gregkh-2.6.orig/drivers/char/ip2main.c
-+++ gregkh-2.6/drivers/char/ip2main.c
-@@ -721,8 +721,9 @@ ip2_loadmain(int *iop, int *irqp, unsign
- }
-
- if ( NULL != ( pB = i2BoardPtrTable[i] ) ) {
-- class_device_create(ip2_class, MKDEV(IP2_IPL_MAJOR,
-- 4 * i), NULL, "ipl%d", i);
-+ class_device_create(ip2_class, NULL,
-+ MKDEV(IP2_IPL_MAJOR, 4 * i),
-+ NULL, "ipl%d", i);
- err = devfs_mk_cdev(MKDEV(IP2_IPL_MAJOR, 4 * i),
- S_IRUSR | S_IWUSR | S_IRGRP | S_IFCHR,
- "ip2/ipl%d", i);
-@@ -732,8 +733,9 @@ ip2_loadmain(int *iop, int *irqp, unsign
- goto out_class;
- }
-
-- class_device_create(ip2_class, MKDEV(IP2_IPL_MAJOR,
-- 4 * i + 1), NULL, "stat%d", i);
-+ class_device_create(ip2_class, NULL,
-+ MKDEV(IP2_IPL_MAJOR, 4 * i + 1),
-+ NULL, "stat%d", i);
- err = devfs_mk_cdev(MKDEV(IP2_IPL_MAJOR, 4 * i + 1),
- S_IRUSR | S_IWUSR | S_IRGRP | S_IFCHR,
- "ip2/stat%d", i);
---- gregkh-2.6.orig/drivers/char/istallion.c
-+++ gregkh-2.6/drivers/char/istallion.c
-@@ -5246,7 +5246,8 @@ int __init stli_init(void)
- devfs_mk_cdev(MKDEV(STL_SIOMEMMAJOR, i),
- S_IFCHR | S_IRUSR | S_IWUSR,
- "staliomem/%d", i);
-- class_device_create(istallion_class, MKDEV(STL_SIOMEMMAJOR, i),
-+ class_device_create(istallion_class, NULL,
-+ MKDEV(STL_SIOMEMMAJOR, i),
- NULL, "staliomem%d", i);
- }
-
---- gregkh-2.6.orig/drivers/char/lp.c
-+++ gregkh-2.6/drivers/char/lp.c
-@@ -805,7 +805,7 @@ static int lp_register(int nr, struct pa
- if (reset)
- lp_reset(nr);
-
-- class_device_create(lp_class, MKDEV(LP_MAJOR, nr), NULL,
-+ class_device_create(lp_class, NULL, MKDEV(LP_MAJOR, nr), NULL,
- "lp%d", nr);
- devfs_mk_cdev(MKDEV(LP_MAJOR, nr), S_IFCHR | S_IRUGO | S_IWUGO,
- "printers/%d", nr);
---- gregkh-2.6.orig/drivers/char/mem.c
-+++ gregkh-2.6/drivers/char/mem.c
-@@ -920,7 +920,8 @@ static int __init chr_dev_init(void)
-
- mem_class = class_create(THIS_MODULE, "mem");
- for (i = 0; i < ARRAY_SIZE(devlist); i++) {
-- class_device_create(mem_class, MKDEV(MEM_MAJOR, devlist[i].minor),
-+ class_device_create(mem_class, NULL,
-+ MKDEV(MEM_MAJOR, devlist[i].minor),
- NULL, devlist[i].name);
- devfs_mk_cdev(MKDEV(MEM_MAJOR, devlist[i].minor),
- S_IFCHR | devlist[i].mode, devlist[i].name);
---- gregkh-2.6.orig/drivers/char/misc.c
-+++ gregkh-2.6/drivers/char/misc.c
-@@ -234,7 +234,7 @@ int misc_register(struct miscdevice * mi
- }
- dev = MKDEV(MISC_MAJOR, misc->minor);
-
-- misc->class = class_device_create(misc_class, dev, misc->dev,
-+ misc->class = class_device_create(misc_class, NULL, dev, misc->dev,
- "%s", misc->name);
- if (IS_ERR(misc->class)) {
- err = PTR_ERR(misc->class);
---- gregkh-2.6.orig/drivers/char/ppdev.c
-+++ gregkh-2.6/drivers/char/ppdev.c
-@@ -752,7 +752,7 @@ static struct file_operations pp_fops =
-
- static void pp_attach(struct parport *port)
- {
-- class_device_create(ppdev_class, MKDEV(PP_MAJOR, port->number),
-+ class_device_create(ppdev_class, NULL, MKDEV(PP_MAJOR, port->number),
- NULL, "parport%d", port->number);
- }
-
---- gregkh-2.6.orig/drivers/char/raw.c
-+++ gregkh-2.6/drivers/char/raw.c
-@@ -128,7 +128,7 @@ raw_ioctl(struct inode *inode, struct fi
- static void bind_device(struct raw_config_request *rq)
- {
- class_device_destroy(raw_class, MKDEV(RAW_MAJOR, rq->raw_minor));
-- class_device_create(raw_class, MKDEV(RAW_MAJOR, rq->raw_minor),
-+ class_device_create(raw_class, NULL, MKDEV(RAW_MAJOR, rq->raw_minor),
- NULL, "raw%d", rq->raw_minor);
- }
-
-@@ -307,7 +307,7 @@ static int __init raw_init(void)
- unregister_chrdev_region(dev, MAX_RAW_MINORS);
- goto error;
- }
-- class_device_create(raw_class, MKDEV(RAW_MAJOR, 0), NULL, "rawctl");
-+ class_device_create(raw_class, NULL, MKDEV(RAW_MAJOR, 0), NULL, "rawctl");
-
- devfs_mk_cdev(MKDEV(RAW_MAJOR, 0),
- S_IFCHR | S_IRUGO | S_IWUGO,
---- gregkh-2.6.orig/drivers/char/snsc.c
-+++ gregkh-2.6/drivers/char/snsc.c
-@@ -437,7 +437,7 @@ scdrv_init(void)
- continue;
- }
-
-- class_device_create(snsc_class, dev, NULL,
-+ class_device_create(snsc_class, NULL, dev, NULL,
- "%s", devname);
-
- ia64_sn_irtr_intr_enable(scd->scd_nasid,
---- gregkh-2.6.orig/drivers/char/stallion.c
-+++ gregkh-2.6/drivers/char/stallion.c
-@@ -3095,7 +3095,9 @@ static int __init stl_init(void)
- devfs_mk_cdev(MKDEV(STL_SIOMEMMAJOR, i),
- S_IFCHR|S_IRUSR|S_IWUSR,
- "staliomem/%d", i);
-- class_device_create(stallion_class, MKDEV(STL_SIOMEMMAJOR, i), NULL, "staliomem%d", i);
-+ class_device_create(stallion_class, NULL,
-+ MKDEV(STL_SIOMEMMAJOR, i), NULL,
-+ "staliomem%d", i);
- }
-
- stl_serial->owner = THIS_MODULE;
---- gregkh-2.6.orig/drivers/char/tipar.c
-+++ gregkh-2.6/drivers/char/tipar.c
-@@ -436,7 +436,7 @@ tipar_register(int nr, struct parport *p
- goto out;
- }
-
-- class_device_create(tipar_class, MKDEV(TIPAR_MAJOR,
-+ class_device_create(tipar_class, NULL, MKDEV(TIPAR_MAJOR,
- TIPAR_MINOR + nr), NULL, "par%d", nr);
- /* Use devfs, tree: /dev/ticables/par/[0..2] */
- err = devfs_mk_cdev(MKDEV(TIPAR_MAJOR, TIPAR_MINOR + nr),
---- gregkh-2.6.orig/drivers/char/tty_io.c
-+++ gregkh-2.6/drivers/char/tty_io.c
-@@ -2728,7 +2728,7 @@ void tty_register_device(struct tty_driv
- pty_line_name(driver, index, name);
- else
- tty_line_name(driver, index, name);
-- class_device_create(tty_class, dev, device, name);
-+ class_device_create(tty_class, NULL, dev, device, "%s", name);
- }
-
- /**
-@@ -2983,14 +2983,14 @@ static int __init tty_init(void)
- register_chrdev_region(MKDEV(TTYAUX_MAJOR, 0), 1, "/dev/tty") < 0)
- panic("Couldn't register /dev/tty driver\n");
- devfs_mk_cdev(MKDEV(TTYAUX_MAJOR, 0), S_IFCHR|S_IRUGO|S_IWUGO, "tty");
-- class_device_create(tty_class, MKDEV(TTYAUX_MAJOR, 0), NULL, "tty");
-+ class_device_create(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 0), NULL, "tty");
-
- cdev_init(&console_cdev, &console_fops);
- if (cdev_add(&console_cdev, MKDEV(TTYAUX_MAJOR, 1), 1) ||
- register_chrdev_region(MKDEV(TTYAUX_MAJOR, 1), 1, "/dev/console") < 0)
- panic("Couldn't register /dev/console driver\n");
- devfs_mk_cdev(MKDEV(TTYAUX_MAJOR, 1), S_IFCHR|S_IRUSR|S_IWUSR, "console");
-- class_device_create(tty_class, MKDEV(TTYAUX_MAJOR, 1), NULL, "console");
-+ class_device_create(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 1), NULL, "console");
-
- #ifdef CONFIG_UNIX98_PTYS
- cdev_init(&ptmx_cdev, &ptmx_fops);
-@@ -2998,7 +2998,7 @@ static int __init tty_init(void)
- register_chrdev_region(MKDEV(TTYAUX_MAJOR, 2), 1, "/dev/ptmx") < 0)
- panic("Couldn't register /dev/ptmx driver\n");
- devfs_mk_cdev(MKDEV(TTYAUX_MAJOR, 2), S_IFCHR|S_IRUGO|S_IWUGO, "ptmx");
-- class_device_create(tty_class, MKDEV(TTYAUX_MAJOR, 2), NULL, "ptmx");
-+ class_device_create(tty_class, NULL, MKDEV(TTYAUX_MAJOR, 2), NULL, "ptmx");
- #endif
-
- #ifdef CONFIG_VT
-@@ -3007,7 +3007,7 @@ static int __init tty_init(void)
- register_chrdev_region(MKDEV(TTY_MAJOR, 0), 1, "/dev/vc/0") < 0)
- panic("Couldn't register /dev/tty0 driver\n");
- devfs_mk_cdev(MKDEV(TTY_MAJOR, 0), S_IFCHR|S_IRUSR|S_IWUSR, "vc/0");
-- class_device_create(tty_class, MKDEV(TTY_MAJOR, 0), NULL, "tty0");
-+ class_device_create(tty_class, NULL, MKDEV(TTY_MAJOR, 0), NULL, "tty0");
-
- vty_init();
- #endif
---- gregkh-2.6.orig/drivers/char/ftape/zftape/zftape-init.c
-+++ gregkh-2.6/drivers/char/ftape/zftape/zftape-init.c
-@@ -331,27 +331,27 @@ KERN_INFO
-
- zft_class = class_create(THIS_MODULE, "zft");
- for (i = 0; i < 4; i++) {
-- class_device_create(zft_class, MKDEV(QIC117_TAPE_MAJOR, i), NULL, "qft%i", i);
-+ class_device_create(zft_class, NULL, MKDEV(QIC117_TAPE_MAJOR, i), NULL, "qft%i", i);
- devfs_mk_cdev(MKDEV(QIC117_TAPE_MAJOR, i),
- S_IFCHR | S_IRUSR | S_IWUSR,
- "qft%i", i);
-- class_device_create(zft_class, MKDEV(QIC117_TAPE_MAJOR, i + 4), NULL, "nqft%i", i);
-+ class_device_create(zft_class, NULL, MKDEV(QIC117_TAPE_MAJOR, i + 4), NULL, "nqft%i", i);
- devfs_mk_cdev(MKDEV(QIC117_TAPE_MAJOR, i + 4),
- S_IFCHR | S_IRUSR | S_IWUSR,
- "nqft%i", i);
-- class_device_create(zft_class, MKDEV(QIC117_TAPE_MAJOR, i + 16), NULL, "zqft%i", i);
-+ class_device_create(zft_class, NULL, MKDEV(QIC117_TAPE_MAJOR, i + 16), NULL, "zqft%i", i);
- devfs_mk_cdev(MKDEV(QIC117_TAPE_MAJOR, i + 16),
- S_IFCHR | S_IRUSR | S_IWUSR,
- "zqft%i", i);
-- class_device_create(zft_class, MKDEV(QIC117_TAPE_MAJOR, i + 20), NULL, "nzqft%i", i);
-+ class_device_create(zft_class, NULL, MKDEV(QIC117_TAPE_MAJOR, i + 20), NULL, "nzqft%i", i);
- devfs_mk_cdev(MKDEV(QIC117_TAPE_MAJOR, i + 20),
- S_IFCHR | S_IRUSR | S_IWUSR,
- "nzqft%i", i);
-- class_device_create(zft_class, MKDEV(QIC117_TAPE_MAJOR, i + 32), NULL, "rawqft%i", i);
-+ class_device_create(zft_class, NULL, MKDEV(QIC117_TAPE_MAJOR, i + 32), NULL, "rawqft%i", i);
- devfs_mk_cdev(MKDEV(QIC117_TAPE_MAJOR, i + 32),
- S_IFCHR | S_IRUSR | S_IWUSR,
- "rawqft%i", i);
-- class_device_create(zft_class, MKDEV(QIC117_TAPE_MAJOR, i + 36), NULL, "nrawrawqft%i", i);
-+ class_device_create(zft_class, NULL, MKDEV(QIC117_TAPE_MAJOR, i + 36), NULL, "nrawrawqft%i", i);
- devfs_mk_cdev(MKDEV(QIC117_TAPE_MAJOR, i + 36),
- S_IFCHR | S_IRUSR | S_IWUSR,
- "nrawqft%i", i);
---- gregkh-2.6.orig/drivers/char/ipmi/ipmi_devintf.c
-+++ gregkh-2.6/drivers/char/ipmi/ipmi_devintf.c
-@@ -798,7 +798,7 @@ static void ipmi_new_smi(int if_num)
- devfs_mk_cdev(dev, S_IFCHR | S_IRUSR | S_IWUSR,
- "ipmidev/%d", if_num);
-
-- class_device_create(ipmi_class, dev, NULL, "ipmi%d", if_num);
-+ class_device_create(ipmi_class, NULL, dev, NULL, "ipmi%d", if_num);
- }
-
- static void ipmi_smi_gone(int if_num)
---- gregkh-2.6.orig/drivers/char/vc_screen.c
-+++ gregkh-2.6/drivers/char/vc_screen.c
-@@ -484,8 +484,10 @@ void vcs_make_devfs(struct tty_struct *t
- devfs_mk_cdev(MKDEV(VCS_MAJOR, tty->index + 129),
- S_IFCHR|S_IRUSR|S_IWUSR,
- "vcc/a%u", tty->index + 1);
-- class_device_create(vc_class, MKDEV(VCS_MAJOR, tty->index + 1), NULL, "vcs%u", tty->index + 1);
-- class_device_create(vc_class, MKDEV(VCS_MAJOR, tty->index + 129), NULL, "vcsa%u", tty->index + 1);
-+ class_device_create(vc_class, NULL, MKDEV(VCS_MAJOR, tty->index + 1),
-+ NULL, "vcs%u", tty->index + 1);
-+ class_device_create(vc_class, NULL, MKDEV(VCS_MAJOR, tty->index + 129),
-+ NULL, "vcsa%u", tty->index + 1);
- }
- void vcs_remove_devfs(struct tty_struct *tty)
- {
-@@ -503,7 +505,7 @@ int __init vcs_init(void)
-
- devfs_mk_cdev(MKDEV(VCS_MAJOR, 0), S_IFCHR|S_IRUSR|S_IWUSR, "vcc/0");
- devfs_mk_cdev(MKDEV(VCS_MAJOR, 128), S_IFCHR|S_IRUSR|S_IWUSR, "vcc/a0");
-- class_device_create(vc_class, MKDEV(VCS_MAJOR, 0), NULL, "vcs");
-- class_device_create(vc_class, MKDEV(VCS_MAJOR, 128), NULL, "vcsa");
-+ class_device_create(vc_class, NULL, MKDEV(VCS_MAJOR, 0), NULL, "vcs");
-+ class_device_create(vc_class, NULL, MKDEV(VCS_MAJOR, 128), NULL, "vcsa");
- return 0;
- }
---- gregkh-2.6.orig/drivers/char/viotape.c
-+++ gregkh-2.6/drivers/char/viotape.c
-@@ -956,9 +956,9 @@ static int viotape_probe(struct vio_dev
- state[i].cur_part = 0;
- for (j = 0; j < MAX_PARTITIONS; ++j)
- state[i].part_stat_rwi[j] = VIOT_IDLE;
-- class_device_create(tape_class, MKDEV(VIOTAPE_MAJOR, i), NULL,
-+ class_device_create(tape_class, NULL, MKDEV(VIOTAPE_MAJOR, i), NULL,
- "iseries!vt%d", i);
-- class_device_create(tape_class, MKDEV(VIOTAPE_MAJOR, i | 0x80),
-+ class_device_create(tape_class, NULL, MKDEV(VIOTAPE_MAJOR, i | 0x80),
- NULL, "iseries!nvt%d", i);
- devfs_mk_cdev(MKDEV(VIOTAPE_MAJOR, i), S_IFCHR | S_IRUSR | S_IWUSR,
- "iseries/vt%d", i);
---- gregkh-2.6.orig/drivers/hwmon/hwmon.c
-+++ gregkh-2.6/drivers/hwmon/hwmon.c
-@@ -45,7 +45,7 @@ struct class_device *hwmon_device_regist
- return ERR_PTR(-ENOMEM);
-
- id = id & MAX_ID_MASK;
-- cdev = class_device_create(hwmon_class, MKDEV(0,0), dev,
-+ cdev = class_device_create(hwmon_class, NULL, MKDEV(0,0), dev,
- HWMON_ID_FORMAT, id);
-
- if (IS_ERR(cdev))
---- gregkh-2.6.orig/drivers/ide/ide-tape.c
-+++ gregkh-2.6/drivers/ide/ide-tape.c
-@@ -4884,9 +4884,9 @@ static int ide_tape_probe(struct device
-
- idetape_setup(drive, tape, minor);
-
-- class_device_create(idetape_sysfs_class,
-+ class_device_create(idetape_sysfs_class, NULL,
- MKDEV(IDETAPE_MAJOR, minor), dev, "%s", tape->name);
-- class_device_create(idetape_sysfs_class,
-+ class_device_create(idetape_sysfs_class, NULL,
- MKDEV(IDETAPE_MAJOR, minor + 128), dev, "n%s", tape->name);
-
- devfs_mk_cdev(MKDEV(HWIF(drive)->major, minor),
---- gregkh-2.6.orig/drivers/ieee1394/dv1394.c
-+++ gregkh-2.6/drivers/ieee1394/dv1394.c
-@@ -2361,7 +2361,7 @@ static void dv1394_add_host (struct hpsb
-
- ohci = (struct ti_ohci *)host->hostdata;
-
-- class_device_create(hpsb_protocol_class, MKDEV(
-+ class_device_create(hpsb_protocol_class, NULL, MKDEV(
- IEEE1394_MAJOR, IEEE1394_MINOR_BLOCK_DV1394 * 16 + (id<<2)),
- NULL, "dv1394-%d", id);
- devfs_mk_dir("ieee1394/dv/host%d", id);
---- gregkh-2.6.orig/drivers/ieee1394/raw1394.c
-+++ gregkh-2.6/drivers/ieee1394/raw1394.c
-@@ -2912,7 +2912,7 @@ static int __init init_raw1394(void)
-
- hpsb_register_highlevel(&raw1394_highlevel);
-
-- if (IS_ERR(class_device_create(hpsb_protocol_class, MKDEV(
-+ if (IS_ERR(class_device_create(hpsb_protocol_class, NULL, MKDEV(
- IEEE1394_MAJOR, IEEE1394_MINOR_BLOCK_RAW1394 * 16),
- NULL, RAW1394_DEVICE_NAME))) {
- ret = -EFAULT;
---- gregkh-2.6.orig/drivers/ieee1394/video1394.c
-+++ gregkh-2.6/drivers/ieee1394/video1394.c
-@@ -1370,7 +1370,7 @@ static void video1394_add_host (struct h
- hpsb_set_hostinfo_key(&video1394_highlevel, host, ohci->host->id);
-
- minor = IEEE1394_MINOR_BLOCK_VIDEO1394 * 16 + ohci->host->id;
-- class_device_create(hpsb_protocol_class, MKDEV(
-+ class_device_create(hpsb_protocol_class, NULL, MKDEV(
- IEEE1394_MAJOR, minor),
- NULL, "%s-%d", VIDEO1394_DRIVER_NAME, ohci->host->id);
- devfs_mk_cdev(MKDEV(IEEE1394_MAJOR, minor),
---- gregkh-2.6.orig/drivers/infiniband/core/ucm.c
-+++ gregkh-2.6/drivers/infiniband/core/ucm.c
-@@ -1300,7 +1300,7 @@ static int __init ib_ucm_init(void)
- goto err_class;
- }
-
-- class_device_create(ib_ucm_class, IB_UCM_DEV, NULL, "ucm");
-+ class_device_create(ib_ucm_class, NULL, IB_UCM_DEV, NULL, "ucm");
-
- idr_init(&ctx_id_table);
- init_MUTEX(&ctx_id_mutex);
---- gregkh-2.6.orig/drivers/isdn/capi/capi.c
-+++ gregkh-2.6/drivers/isdn/capi/capi.c
-@@ -1505,7 +1505,7 @@ static int __init capi_init(void)
- return PTR_ERR(capi_class);
- }
-
-- class_device_create(capi_class, MKDEV(capi_major, 0), NULL, "capi");
-+ class_device_create(capi_class, NULL, MKDEV(capi_major, 0), NULL, "capi");
- devfs_mk_cdev(MKDEV(capi_major, 0), S_IFCHR | S_IRUSR | S_IWUSR,
- "isdn/capi20");
-
---- gregkh-2.6.orig/drivers/macintosh/adb.c
-+++ gregkh-2.6/drivers/macintosh/adb.c
-@@ -905,5 +905,5 @@ adbdev_init(void)
- adb_dev_class = class_create(THIS_MODULE, "adb");
- if (IS_ERR(adb_dev_class))
- return;
-- class_device_create(adb_dev_class, MKDEV(ADB_MAJOR, 0), NULL, "adb");
-+ class_device_create(adb_dev_class, NULL, MKDEV(ADB_MAJOR, 0), NULL, "adb");
- }
---- gregkh-2.6.orig/drivers/media/dvb/dvb-core/dvbdev.c
-+++ gregkh-2.6/drivers/media/dvb/dvb-core/dvbdev.c
-@@ -235,7 +235,7 @@ int dvb_register_device(struct dvb_adapt
- S_IFCHR | S_IRUSR | S_IWUSR,
- "dvb/adapter%d/%s%d", adap->num, dnames[type], id);
-
-- class_device_create(dvb_class, MKDEV(DVB_MAJOR, nums2minor(adap->num, type, id)),
-+ class_device_create(dvb_class, NULL, MKDEV(DVB_MAJOR, nums2minor(adap->num, type, id)),
- NULL, "dvb%d.%s%d", adap->num, dnames[type], id);
-
- dprintk("DVB: register adapter%d/%s%d @ minor: %i (0x%02x)\n",
---- gregkh-2.6.orig/drivers/message/i2o/iop.c
-+++ gregkh-2.6/drivers/message/i2o/iop.c
-@@ -1141,7 +1141,7 @@ int i2o_iop_add(struct i2o_controller *c
- goto iop_reset;
- }
-
-- c->classdev = class_device_create(i2o_controller_class, 0,
-+ c->classdev = class_device_create(i2o_controller_class, NULL, MKDEV(0,0),
- &c->device, "iop%d", c->unit);
- if (IS_ERR(c->classdev)) {
- osm_err("%s: could not add controller class\n", c->name);
---- gregkh-2.6.orig/drivers/mtd/mtdchar.c
-+++ gregkh-2.6/drivers/mtd/mtdchar.c
-@@ -24,10 +24,10 @@ static void mtd_notify_add(struct mtd_in
- if (!mtd)
- return;
-
-- class_device_create(mtd_class, MKDEV(MTD_CHAR_MAJOR, mtd->index*2),
-+ class_device_create(mtd_class, NULL, MKDEV(MTD_CHAR_MAJOR, mtd->index*2),
- NULL, "mtd%d", mtd->index);
-
-- class_device_create(mtd_class,
-+ class_device_create(mtd_class, NULL,
- MKDEV(MTD_CHAR_MAJOR, mtd->index*2+1),
- NULL, "mtd%dro", mtd->index);
- }
---- gregkh-2.6.orig/drivers/net/ppp_generic.c
-+++ gregkh-2.6/drivers/net/ppp_generic.c
-@@ -863,7 +863,7 @@ static int __init ppp_init(void)
- err = PTR_ERR(ppp_class);
- goto out_chrdev;
- }
-- class_device_create(ppp_class, MKDEV(PPP_MAJOR, 0), NULL, "ppp");
-+ class_device_create(ppp_class, NULL, MKDEV(PPP_MAJOR, 0), NULL, "ppp");
- err = devfs_mk_cdev(MKDEV(PPP_MAJOR, 0),
- S_IFCHR|S_IRUSR|S_IWUSR, "ppp");
- if (err)
---- gregkh-2.6.orig/drivers/net/wan/cosa.c
-+++ gregkh-2.6/drivers/net/wan/cosa.c
-@@ -400,7 +400,7 @@ static int __init cosa_init(void)
- goto out_chrdev;
- }
- for (i=0; i<nr_cards; i++) {
-- class_device_create(cosa_class, MKDEV(cosa_major, i),
-+ class_device_create(cosa_class, NULL, MKDEV(cosa_major, i),
- NULL, "cosa%d", i);
- err = devfs_mk_cdev(MKDEV(cosa_major, i),
- S_IFCHR|S_IRUSR|S_IWUSR,
---- gregkh-2.6.orig/drivers/s390/char/tape_class.c
-+++ gregkh-2.6/drivers/s390/char/tape_class.c
-@@ -72,6 +72,7 @@ struct tape_class_device *register_tape_
-
- tcd->class_device = class_device_create(
- tape_class,
-+ NULL,
- tcd->char_device->dev,
- device,
- "%s", tcd->device_name
---- gregkh-2.6.orig/drivers/s390/char/vmlogrdr.c
-+++ gregkh-2.6/drivers/s390/char/vmlogrdr.c
-@@ -787,6 +787,7 @@ vmlogrdr_register_device(struct vmlogrdr
- return ret;
- }
- priv->class_device = class_device_create(
-+ NULL,
- vmlogrdr_class,
- MKDEV(vmlogrdr_major, priv->minor_num),
- dev,
---- gregkh-2.6.orig/drivers/scsi/ch.c
-+++ gregkh-2.6/drivers/scsi/ch.c
-@@ -936,7 +936,7 @@ static int ch_probe(struct device *dev)
- if (init)
- ch_init_elem(ch);
-
-- class_device_create(ch_sysfs_class,
-+ class_device_create(ch_sysfs_class, NULL,
- MKDEV(SCSI_CHANGER_MAJOR,ch->minor),
- dev, "s%s", ch->name);
-
---- gregkh-2.6.orig/drivers/scsi/osst.c
-+++ gregkh-2.6/drivers/scsi/osst.c
-@@ -5627,7 +5627,7 @@ static void osst_sysfs_add(dev_t dev, st
-
- if (!osst_sysfs_valid) return;
-
-- osst_class_member = class_device_create(osst_sysfs_class, dev, device, "%s", name);
-+ osst_class_member = class_device_create(osst_sysfs_class, NULL, dev, device, "%s", name);
- if (IS_ERR(osst_class_member)) {
- printk(KERN_WARNING "osst :W: Unable to add sysfs class member %s\n", name);
- return;
---- gregkh-2.6.orig/drivers/scsi/sg.c
-+++ gregkh-2.6/drivers/scsi/sg.c
-@@ -1550,7 +1550,7 @@ sg_add(struct class_device *cl_dev, stru
- if (sg_sysfs_valid) {
- struct class_device * sg_class_member;
-
-- sg_class_member = class_device_create(sg_sysfs_class,
-+ sg_class_member = class_device_create(sg_sysfs_class, NULL,
- MKDEV(SCSI_GENERIC_MAJOR, k),
- cl_dev->dev, "%s",
- disk->disk_name);
---- gregkh-2.6.orig/drivers/scsi/st.c
-+++ gregkh-2.6/drivers/scsi/st.c
-@@ -4375,7 +4375,7 @@ static void do_create_class_files(struct
- snprintf(name, 10, "%s%s%s", rew ? "n" : "",
- STp->disk->disk_name, st_formats[i]);
- st_class_member =
-- class_device_create(st_sysfs_class,
-+ class_device_create(st_sysfs_class, NULL,
- MKDEV(SCSI_TAPE_MAJOR,
- TAPE_MINOR(dev_num, mode, rew)),
- &STp->device->sdev_gendev, "%s", name);
---- gregkh-2.6.orig/drivers/input/evdev.c
-+++ gregkh-2.6/drivers/input/evdev.c
-@@ -689,7 +689,7 @@ static struct input_handle *evdev_connec
-
- devfs_mk_cdev(MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor),
- S_IFCHR|S_IRUGO|S_IWUSR, "input/event%d", minor);
-- class_device_create(input_class,
-+ class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor),
- dev->dev, "event%d", minor);
-
---- gregkh-2.6.orig/drivers/input/joydev.c
-+++ gregkh-2.6/drivers/input/joydev.c
-@@ -516,7 +516,7 @@ static struct input_handle *joydev_conne
-
- devfs_mk_cdev(MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + minor),
- S_IFCHR|S_IRUGO|S_IWUSR, "input/js%d", minor);
-- class_device_create(input_class,
-+ class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + minor),
- dev->dev, "js%d", minor);
-
---- gregkh-2.6.orig/drivers/input/mousedev.c
-+++ gregkh-2.6/drivers/input/mousedev.c
-@@ -651,7 +651,7 @@ static struct input_handle *mousedev_con
-
- devfs_mk_cdev(MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + minor),
- S_IFCHR|S_IRUGO|S_IWUSR, "input/mouse%d", minor);
-- class_device_create(input_class,
-+ class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + minor),
- dev->dev, "mouse%d", minor);
-
-@@ -740,7 +740,7 @@ static int __init mousedev_init(void)
-
- devfs_mk_cdev(MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX),
- S_IFCHR|S_IRUGO|S_IWUSR, "input/mice");
-- class_device_create(input_class,
-+ class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX), NULL, "mice");
-
- #ifdef CONFIG_INPUT_MOUSEDEV_PSAUX
---- gregkh-2.6.orig/drivers/input/tsdev.c
-+++ gregkh-2.6/drivers/input/tsdev.c
-@@ -414,7 +414,7 @@ static struct input_handle *tsdev_connec
- S_IFCHR|S_IRUGO|S_IWUSR, "input/ts%d", minor);
- devfs_mk_cdev(MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor + TSDEV_MINORS/2),
- S_IFCHR|S_IRUGO|S_IWUSR, "input/tsraw%d", minor);
-- class_device_create(input_class,
-+ class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor),
- dev->dev, "ts%d", minor);
-
---- gregkh-2.6.orig/arch/i386/kernel/cpuid.c
-+++ gregkh-2.6/arch/i386/kernel/cpuid.c
-@@ -163,7 +163,7 @@ static int cpuid_class_device_create(int
- int err = 0;
- struct class_device *class_err;
-
-- class_err = class_device_create(cpuid_class, MKDEV(CPUID_MAJOR, i), NULL, "cpu%d",i);
-+ class_err = class_device_create(cpuid_class, NULL, MKDEV(CPUID_MAJOR, i), NULL, "cpu%d",i);
- if (IS_ERR(class_err))
- err = PTR_ERR(class_err);
- return err;
---- gregkh-2.6.orig/arch/i386/kernel/msr.c
-+++ gregkh-2.6/arch/i386/kernel/msr.c
-@@ -246,7 +246,7 @@ static int msr_class_device_create(int i
- int err = 0;
- struct class_device *class_err;
-
-- class_err = class_device_create(msr_class, MKDEV(MSR_MAJOR, i), NULL, "msr%d",i);
-+ class_err = class_device_create(msr_class, NULL, MKDEV(MSR_MAJOR, i), NULL, "msr%d",i);
- if (IS_ERR(class_err))
- err = PTR_ERR(class_err);
- return err;
---- gregkh-2.6.orig/sound/core/sound.c
-+++ gregkh-2.6/sound/core/sound.c
-@@ -231,7 +231,7 @@ int snd_register_device(int type, snd_ca
- devfs_mk_cdev(MKDEV(major, minor), S_IFCHR | device_mode, "snd/%s", name);
- if (card)
- device = card->dev;
-- class_device_create(sound_class, MKDEV(major, minor), device, "%s", name);
-+ class_device_create(sound_class, NULL, MKDEV(major, minor), device, "%s", name);
-
- up(&sound_mutex);
- return 0;
---- gregkh-2.6.orig/sound/oss/soundcard.c
-+++ gregkh-2.6/sound/oss/soundcard.c
-@@ -567,7 +567,7 @@ static int __init oss_init(void)
- devfs_mk_cdev(MKDEV(SOUND_MAJOR, dev_list[i].minor),
- S_IFCHR | dev_list[i].mode,
- "sound/%s", dev_list[i].name);
-- class_device_create(sound_class,
-+ class_device_create(sound_class, NULL,
- MKDEV(SOUND_MAJOR, dev_list[i].minor),
- NULL, "%s", dev_list[i].name);
-
-@@ -579,7 +579,7 @@ static int __init oss_init(void)
- dev_list[i].minor + (j*0x10)),
- S_IFCHR | dev_list[i].mode,
- "sound/%s%d", dev_list[i].name, j);
-- class_device_create(sound_class,
-+ class_device_create(sound_class, NULL,
- MKDEV(SOUND_MAJOR, dev_list[i].minor + (j*0x10)),
- NULL, "%s%d", dev_list[i].name, j);
- }
---- gregkh-2.6.orig/sound/sound_core.c
-+++ gregkh-2.6/sound/sound_core.c
-@@ -174,7 +174,7 @@ static int sound_insert_unit(struct soun
-
- devfs_mk_cdev(MKDEV(SOUND_MAJOR, s->unit_minor),
- S_IFCHR | mode, s->name);
-- class_device_create(sound_class, MKDEV(SOUND_MAJOR, s->unit_minor),
-+ class_device_create(sound_class, NULL, MKDEV(SOUND_MAJOR, s->unit_minor),
- dev, s->name+6);
- return r;
-
---- gregkh-2.6.orig/fs/coda/psdev.c
-+++ gregkh-2.6/fs/coda/psdev.c
-@@ -370,8 +370,8 @@ static int init_coda_psdev(void)
- }
- devfs_mk_dir ("coda");
- for (i = 0; i < MAX_CODADEVS; i++) {
-- class_device_create(coda_psdev_class, MKDEV(CODA_PSDEV_MAJOR,i),
-- NULL, "cfs%d", i);
-+ class_device_create(coda_psdev_class, NULL,
-+ MKDEV(CODA_PSDEV_MAJOR,i), NULL, "cfs%d", i);
- err = devfs_mk_cdev(MKDEV(CODA_PSDEV_MAJOR, i),
- S_IFCHR|S_IRUSR|S_IWUSR, "coda/%d", i);
- if (err)
diff --git a/driver/coldplug-emit-hotplug-events-from-sysfs.patch b/driver/coldplug-emit-hotplug-events-from-sysfs.patch
deleted file mode 100644
index daa3860adae41..0000000000000
--- a/driver/coldplug-emit-hotplug-events-from-sysfs.patch
+++ /dev/null
@@ -1,341 +0,0 @@
-From kay.sievers@vrfy.org Sat Oct 1 05:50:20 2005
-Date: Sat, 1 Oct 2005 14:49:43 +0200
-From: Kay Sievers <kay.sievers@suse.de>
-Subject: add sysfs attr to re-emit device hotplug event
-Cc: Greg KH <greg@kroah.com>
-Message-ID: <20051001124943.GA26076@vrfy.org>
-
-
-A "coldplug + udevstart" can be simple like this:
- for i in /sys/block/*/*/uevent; do echo 1 > $i; done
- for i in /sys/class/*/*/uevent; do echo 1 > $i; done
- for i in /sys/bus/*/devices/*/uevent; do echo 1 > $i; done
-
-Signed-off-by: Kay Sievers <kay.sievers@suse.de>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/base/class.c | 16 ++++++++++++-
- drivers/base/core.c | 16 +++++++++++++
- drivers/block/genhd.c | 25 +++++++++++++++++++++
- fs/partitions/check.c | 27 ++++++++++++++++++++++-
- include/linux/device.h | 57 ++++++++++++++++++++++++-------------------------
- include/linux/genhd.h | 1
- 6 files changed, 110 insertions(+), 32 deletions(-)
-
---- gregkh-2.6.orig/drivers/base/class.c
-+++ gregkh-2.6/drivers/base/class.c
-@@ -442,6 +442,13 @@ static ssize_t show_dev(struct class_dev
- return print_dev_t(buf, class_dev->devt);
- }
-
-+static ssize_t store_uevent(struct class_device *class_dev,
-+ const char *buf, size_t count)
-+{
-+ kobject_hotplug(&class_dev->kobj, KOBJ_ADD);
-+ return count;
-+}
-+
- void class_device_initialize(struct class_device *class_dev)
- {
- kobj_set_kset_s(class_dev, class_obj_subsys);
-@@ -497,6 +504,12 @@ int class_device_add(struct class_device
- goto register_done;
-
- /* add the needed attributes to this device */
-+ class_dev->uevent_attr.attr.name = "uevent";
-+ class_dev->uevent_attr.attr.mode = S_IWUSR;
-+ class_dev->uevent_attr.attr.owner = parent->owner;
-+ class_dev->uevent_attr.store = store_uevent;
-+ class_device_create_file(class_dev, &class_dev->uevent_attr);
-+
- if (MAJOR(class_dev->devt)) {
- struct class_device_attribute *attr;
- attr = kzalloc(sizeof(*attr), GFP_KERNEL);
-@@ -505,12 +518,10 @@ int class_device_add(struct class_device
- kobject_del(&class_dev->kobj);
- goto register_done;
- }
--
- attr->attr.name = "dev";
- attr->attr.mode = S_IRUGO;
- attr->attr.owner = parent->owner;
- attr->show = show_dev;
-- attr->store = NULL;
- class_device_create_file(class_dev, attr);
- class_dev->devt_attr = attr;
- }
-@@ -621,6 +632,7 @@ void class_device_del(struct class_devic
- sysfs_remove_link(&class_dev->kobj, "device");
- sysfs_remove_link(&class_dev->dev->kobj, class_name);
- }
-+ class_device_remove_file(class_dev, &class_dev->uevent_attr);
- if (class_dev->devt_attr)
- class_device_remove_file(class_dev, class_dev->devt_attr);
- class_device_remove_attrs(class_dev);
---- gregkh-2.6.orig/drivers/base/core.c
-+++ gregkh-2.6/drivers/base/core.c
-@@ -154,6 +154,13 @@ static struct kset_hotplug_ops device_ho
- .hotplug = dev_hotplug,
- };
-
-+static ssize_t store_uevent(struct device *dev, struct device_attribute *attr,
-+ const char *buf, size_t count)
-+{
-+ kobject_hotplug(&dev->kobj, KOBJ_ADD);
-+ return count;
-+}
-+
- /**
- * device_subsys - structure to be registered with kobject core.
- */
-@@ -259,6 +266,14 @@ int device_add(struct device *dev)
-
- if ((error = kobject_add(&dev->kobj)))
- goto Error;
-+
-+ dev->uevent_attr.attr.name = "uevent";
-+ dev->uevent_attr.attr.mode = S_IWUSR;
-+ if (dev->driver)
-+ dev->uevent_attr.attr.owner = dev->driver->owner;
-+ dev->uevent_attr.store = store_uevent;
-+ device_create_file(dev, &dev->uevent_attr);
-+
- kobject_hotplug(&dev->kobj, KOBJ_ADD);
- if ((error = device_pm_add(dev)))
- goto PMError;
-@@ -350,6 +365,7 @@ void device_del(struct device * dev)
-
- if (parent)
- klist_del(&dev->knode_parent);
-+ device_remove_file(dev, &dev->uevent_attr);
-
- /* Notify the platform of the removal, in case they
- * need to do anything...
---- gregkh-2.6.orig/drivers/block/genhd.c
-+++ gregkh-2.6/drivers/block/genhd.c
-@@ -337,10 +337,30 @@ static ssize_t disk_attr_show(struct kob
- return ret;
- }
-
-+static ssize_t disk_attr_store(struct kobject * kobj, struct attribute * attr,
-+ const char *page, size_t count)
-+{
-+ struct gendisk *disk = to_disk(kobj);
-+ struct disk_attribute *disk_attr =
-+ container_of(attr,struct disk_attribute,attr);
-+ ssize_t ret = 0;
-+
-+ if (disk_attr->store)
-+ ret = disk_attr->store(disk, page, count);
-+ return ret;
-+}
-+
- static struct sysfs_ops disk_sysfs_ops = {
- .show = &disk_attr_show,
-+ .store = &disk_attr_store,
- };
-
-+static ssize_t disk_uevent_store(struct gendisk * disk,
-+ const char *buf, size_t count)
-+{
-+ kobject_hotplug(&disk->kobj, KOBJ_ADD);
-+ return count;
-+}
- static ssize_t disk_dev_read(struct gendisk * disk, char *page)
- {
- dev_t base = MKDEV(disk->major, disk->first_minor);
-@@ -382,6 +402,10 @@ static ssize_t disk_stats_read(struct ge
- jiffies_to_msecs(disk_stat_read(disk, io_ticks)),
- jiffies_to_msecs(disk_stat_read(disk, time_in_queue)));
- }
-+static struct disk_attribute disk_attr_uevent = {
-+ .attr = {.name = "uevent", .mode = S_IWUSR },
-+ .store = disk_uevent_store
-+};
- static struct disk_attribute disk_attr_dev = {
- .attr = {.name = "dev", .mode = S_IRUGO },
- .show = disk_dev_read
-@@ -404,6 +428,7 @@ static struct disk_attribute disk_attr_s
- };
-
- static struct attribute * default_attrs[] = {
-+ &disk_attr_uevent.attr,
- &disk_attr_dev.attr,
- &disk_attr_range.attr,
- &disk_attr_removable.attr,
---- gregkh-2.6.orig/fs/partitions/check.c
-+++ gregkh-2.6/fs/partitions/check.c
-@@ -192,6 +192,7 @@ check_partition(struct gendisk *hd, stru
- struct part_attribute {
- struct attribute attr;
- ssize_t (*show)(struct hd_struct *,char *);
-+ ssize_t (*store)(struct hd_struct *,const char *, size_t);
- };
-
- static ssize_t
-@@ -201,14 +202,33 @@ part_attr_show(struct kobject * kobj, st
- struct part_attribute * part_attr = container_of(attr,struct part_attribute,attr);
- ssize_t ret = 0;
- if (part_attr->show)
-- ret = part_attr->show(p,page);
-+ ret = part_attr->show(p, page);
-+ return ret;
-+}
-+static ssize_t
-+part_attr_store(struct kobject * kobj, struct attribute * attr,
-+ const char *page, size_t count)
-+{
-+ struct hd_struct * p = container_of(kobj,struct hd_struct,kobj);
-+ struct part_attribute * part_attr = container_of(attr,struct part_attribute,attr);
-+ ssize_t ret = 0;
-+
-+ if (part_attr->store)
-+ ret = part_attr->store(p, page, count);
- return ret;
- }
-
- static struct sysfs_ops part_sysfs_ops = {
- .show = part_attr_show,
-+ .store = part_attr_store,
- };
-
-+static ssize_t part_uevent_store(struct hd_struct * p,
-+ const char *page, size_t count)
-+{
-+ kobject_hotplug(&p->kobj, KOBJ_ADD);
-+ return count;
-+}
- static ssize_t part_dev_read(struct hd_struct * p, char *page)
- {
- struct gendisk *disk = container_of(p->kobj.parent,struct gendisk,kobj);
-@@ -229,6 +249,10 @@ static ssize_t part_stat_read(struct hd_
- p->reads, (unsigned long long)p->read_sectors,
- p->writes, (unsigned long long)p->write_sectors);
- }
-+static struct part_attribute part_attr_uevent = {
-+ .attr = {.name = "uevent", .mode = S_IWUSR },
-+ .store = part_uevent_store
-+};
- static struct part_attribute part_attr_dev = {
- .attr = {.name = "dev", .mode = S_IRUGO },
- .show = part_dev_read
-@@ -247,6 +271,7 @@ static struct part_attribute part_attr_s
- };
-
- static struct attribute * default_attrs[] = {
-+ &part_attr_uevent.attr,
- &part_attr_dev.attr,
- &part_attr_start.attr,
- &part_attr_size.attr,
---- gregkh-2.6.orig/include/linux/device.h
-+++ gregkh-2.6/include/linux/device.h
-@@ -190,6 +190,18 @@ struct class_attribute class_attr_##_nam
- extern int class_create_file(struct class *, const struct class_attribute *);
- extern void class_remove_file(struct class *, const struct class_attribute *);
-
-+struct class_device_attribute {
-+ struct attribute attr;
-+ ssize_t (*show)(struct class_device *, char * buf);
-+ ssize_t (*store)(struct class_device *, const char * buf, size_t count);
-+};
-+
-+#define CLASS_DEVICE_ATTR(_name,_mode,_show,_store) \
-+struct class_device_attribute class_device_attr_##_name = \
-+ __ATTR(_name,_mode,_show,_store)
-+
-+extern int class_device_create_file(struct class_device *,
-+ const struct class_device_attribute *);
-
- struct class_device {
- struct list_head node;
-@@ -198,6 +210,7 @@ struct class_device {
- struct class * class; /* required */
- dev_t devt; /* dev_t, creates the sysfs "dev" */
- struct class_device_attribute *devt_attr;
-+ struct class_device_attribute uevent_attr;
- struct device * dev; /* not necessary, but nice to have */
- void * class_data; /* class-specific data */
-
-@@ -228,18 +241,6 @@ extern int class_device_rename(struct cl
- extern struct class_device * class_device_get(struct class_device *);
- extern void class_device_put(struct class_device *);
-
--struct class_device_attribute {
-- struct attribute attr;
-- ssize_t (*show)(struct class_device *, char * buf);
-- ssize_t (*store)(struct class_device *, const char * buf, size_t count);
--};
--
--#define CLASS_DEVICE_ATTR(_name,_mode,_show,_store) \
--struct class_device_attribute class_device_attr_##_name = \
-- __ATTR(_name,_mode,_show,_store)
--
--extern int class_device_create_file(struct class_device *,
-- const struct class_device_attribute *);
- extern void class_device_remove_file(struct class_device *,
- const struct class_device_attribute *);
- extern int class_device_create_bin_file(struct class_device *,
-@@ -266,6 +267,20 @@ extern struct class_device *class_device
- extern void class_device_destroy(struct class *cls, dev_t devt);
-
-
-+/* interface for exporting device attributes */
-+struct device_attribute {
-+ struct attribute attr;
-+ ssize_t (*show)(struct device *dev, struct device_attribute *attr,
-+ char *buf);
-+ ssize_t (*store)(struct device *dev, struct device_attribute *attr,
-+ const char *buf, size_t count);
-+};
-+
-+#define DEVICE_ATTR(_name,_mode,_show,_store) \
-+struct device_attribute dev_attr_##_name = __ATTR(_name,_mode,_show,_store)
-+
-+extern int device_create_file(struct device *device, struct device_attribute * entry);
-+extern void device_remove_file(struct device * dev, struct device_attribute * attr);
- struct device {
- struct klist klist_children;
- struct klist_node knode_parent; /* node in sibling list */
-@@ -275,6 +290,7 @@ struct device {
-
- struct kobject kobj;
- char bus_id[BUS_ID_SIZE]; /* position on parent bus */
-+ struct device_attribute uevent_attr;
-
- struct semaphore sem; /* semaphore to synchronize calls to
- * its driver.
-@@ -343,23 +359,6 @@ extern int device_attach(struct device
- extern void driver_attach(struct device_driver * drv);
-
-
--/* driverfs interface for exporting device attributes */
--
--struct device_attribute {
-- struct attribute attr;
-- ssize_t (*show)(struct device *dev, struct device_attribute *attr,
-- char *buf);
-- ssize_t (*store)(struct device *dev, struct device_attribute *attr,
-- const char *buf, size_t count);
--};
--
--#define DEVICE_ATTR(_name,_mode,_show,_store) \
--struct device_attribute dev_attr_##_name = __ATTR(_name,_mode,_show,_store)
--
--
--extern int device_create_file(struct device *device, struct device_attribute * entry);
--extern void device_remove_file(struct device * dev, struct device_attribute * attr);
--
- /*
- * Platform "fixup" functions - allow the platform to have their say
- * about devices and actions that the general device layer doesn't
---- gregkh-2.6.orig/include/linux/genhd.h
-+++ gregkh-2.6/include/linux/genhd.h
-@@ -132,6 +132,7 @@ struct gendisk {
- struct disk_attribute {
- struct attribute attr;
- ssize_t (*show)(struct gendisk *, char *);
-+ ssize_t (*store)(struct gendisk *, const char *, size_t);
- };
-
- /*
diff --git a/driver/driver-core-big-kfree-null-check-cleanup-documentation.patch b/driver/driver-core-big-kfree-null-check-cleanup-documentation.patch
deleted file mode 100644
index 27d01861cb125..0000000000000
--- a/driver/driver-core-big-kfree-null-check-cleanup-documentation.patch
+++ /dev/null
@@ -1,31 +0,0 @@
-From jesper.juhl@gmail.com Thu Oct 13 13:21:11 2005
-From: Jesper Juhl <jesper.juhl@gmail.com>
-Subject: Driver Core: Big kfree NULL check cleanup - Documentation
-Date: Thu, 13 Oct 2005 21:31:08 +0200
-Cc: Andrew Morton <akpm@osdl.org>, "Greg Kroah-Hartman" <gregkh@suse.de>, Jesper Juhl <jesper.juhl@gmail.com>
-Content-Disposition: inline
-Message-Id: <200510132131.09134.jesper.juhl@gmail.com>
-
-This is the Documentation/ part of the big kfree cleanup patch.
-
-Remove pointless checks for NULL prior to calling kfree() in example code in Documentation/.
-
-
-Signed-off-by: Jesper Juhl <jesper.juhl@gmail.com>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- Documentation/DocBook/writing_usb_driver.tmpl | 3 +--
- 1 file changed, 1 insertion(+), 2 deletions(-)
-
---- gregkh-2.6.orig/Documentation/DocBook/writing_usb_driver.tmpl
-+++ gregkh-2.6/Documentation/DocBook/writing_usb_driver.tmpl
-@@ -345,8 +345,7 @@ if (!retval) {
- <programlisting>
- static inline void skel_delete (struct usb_skel *dev)
- {
-- if (dev->bulk_in_buffer != NULL)
-- kfree (dev->bulk_in_buffer);
-+ kfree (dev->bulk_in_buffer);
- if (dev->bulk_out_buffer != NULL)
- usb_buffer_free (dev->udev, dev->bulk_out_size,
- dev->bulk_out_buffer,
diff --git a/driver/driver-ide-tape-sysfs.patch b/driver/driver-ide-tape-sysfs.patch
deleted file mode 100644
index 6fffd8aadaf2e..0000000000000
--- a/driver/driver-ide-tape-sysfs.patch
+++ /dev/null
@@ -1,106 +0,0 @@
-From akpm@osdl.org Fri Sep 16 03:00:38 2005
-Message-Id: <200509160955.j8G9tcOZ019958@shell0.pdx.osdl.net>
-Subject: add sysfs support for ide tape
-To: will.dyson@gmail.com, gadio@netvision.net.il, greg@kroah.com,
-From: akpm@osdl.org
-Date: Fri, 16 Sep 2005 02:55:07 -0700
-
-
-From: Will Dyson <will.dyson@gmail.com>
-
-I was recently given an old Travan tape drive and asked to do something
-useful with it. The ide-scsi + st (+serverworks ide controller) combo
-results in a hard lockup of the machine which I have not had the energy to
-debug, so I turned to ide-tape (which seems to work). The system in
-question debian stable, using udev to manage /dev.
-
-The following patch to ide-tape.c allows udev to create the cdev nodes for
-my drive.
-
-Cc: Gadi Oxman <gadio@netvision.net.il>
-Cc: Greg KH <greg@kroah.com>
-Signed-off-by: Andrew Morton <akpm@osdl.org>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/ide/ide-tape.c | 38 ++++++++++++++++++++++++++++++++++++--
- 1 file changed, 36 insertions(+), 2 deletions(-)
-
---- gregkh-2.6.orig/drivers/ide/ide-tape.c
-+++ gregkh-2.6/drivers/ide/ide-tape.c
-@@ -1013,6 +1013,8 @@ typedef struct ide_tape_obj {
-
- static DECLARE_MUTEX(idetape_ref_sem);
-
-+static struct class *idetape_sysfs_class;
-+
- #define to_ide_tape(obj) container_of(obj, struct ide_tape_obj, kref)
-
- #define ide_tape_g(disk) \
-@@ -4704,6 +4706,10 @@ static void ide_tape_release(struct kref
-
- drive->dsc_overlap = 0;
- drive->driver_data = NULL;
-+ class_device_destroy(idetape_sysfs_class,
-+ MKDEV(IDETAPE_MAJOR, tape->minor));
-+ class_device_destroy(idetape_sysfs_class,
-+ MKDEV(IDETAPE_MAJOR, tape->minor + 128));
- devfs_remove("%s/mt", drive->devfs_name);
- devfs_remove("%s/mtn", drive->devfs_name);
- devfs_unregister_tape(g->number);
-@@ -4878,6 +4884,11 @@ static int ide_tape_probe(struct device
-
- idetape_setup(drive, tape, minor);
-
-+ class_device_create(idetape_sysfs_class,
-+ MKDEV(IDETAPE_MAJOR, minor), dev, "%s", tape->name);
-+ class_device_create(idetape_sysfs_class,
-+ MKDEV(IDETAPE_MAJOR, minor + 128), dev, "n%s", tape->name);
-+
- devfs_mk_cdev(MKDEV(HWIF(drive)->major, minor),
- S_IFCHR | S_IRUGO | S_IWUGO,
- "%s/mt", drive->devfs_name);
-@@ -4903,6 +4914,7 @@ MODULE_LICENSE("GPL");
- static void __exit idetape_exit (void)
- {
- driver_unregister(&idetape_driver.gen_driver);
-+ class_destroy(idetape_sysfs_class);
- unregister_chrdev(IDETAPE_MAJOR, "ht");
- }
-
-@@ -4911,11 +4923,33 @@ static void __exit idetape_exit (void)
- */
- static int idetape_init (void)
- {
-+ int error = 1;
-+ idetape_sysfs_class = class_create(THIS_MODULE, "ide_tape");
-+ if (IS_ERR(idetape_sysfs_class)) {
-+ idetape_sysfs_class = NULL;
-+ printk(KERN_ERR "Unable to create sysfs class for ide tapes\n");
-+ error = -EBUSY;
-+ goto out;
-+ }
-+
- if (register_chrdev(IDETAPE_MAJOR, "ht", &idetape_fops)) {
- printk(KERN_ERR "ide-tape: Failed to register character device interface\n");
-- return -EBUSY;
-+ error = -EBUSY;
-+ goto out_free_class;
- }
-- return driver_register(&idetape_driver.gen_driver);
-+
-+ error = driver_register(&idetape_driver.gen_driver);
-+ if (error)
-+ goto out_free_driver;
-+
-+ return 0;
-+
-+out_free_driver:
-+ driver_unregister(&idetape_driver.gen_driver);
-+out_free_class:
-+ class_destroy(idetape_sysfs_class);
-+out:
-+ return error;
- }
-
- module_init(idetape_init);
diff --git a/driver/driver-interface-pass.patch b/driver/driver-interface-pass.patch
deleted file mode 100644
index 74e294c9252eb..0000000000000
--- a/driver/driver-interface-pass.patch
+++ /dev/null
@@ -1,173 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:03 2005
-Message-Id: <20050915070302.455068000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:36 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: Driver core: pass interface to class interface methods
-
-Driver core: pass interface to class intreface methods
-
-Pass interface as argument to add() and remove() class interface
-methods. This way a subsystem can implement generic add/remove
-handlers and then call interface-specific ones.
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/base/class.c | 8 ++++----
- drivers/pcmcia/ds.c | 6 ++++--
- drivers/pcmcia/rsrc_nonstatic.c | 6 ++++--
- drivers/pcmcia/socket_sysfs.c | 6 ++++--
- drivers/scsi/sg.c | 8 ++++----
- include/linux/device.h | 4 ++--
- 6 files changed, 22 insertions(+), 16 deletions(-)
-
---- gregkh-2.6.orig/drivers/base/class.c
-+++ gregkh-2.6/drivers/base/class.c
-@@ -532,7 +532,7 @@ int class_device_add(struct class_device
- list_add_tail(&class_dev->node, &parent->children);
- list_for_each_entry(class_intf, &parent->interfaces, node)
- if (class_intf->add)
-- class_intf->add(class_dev);
-+ class_intf->add(class_dev, class_intf);
- up(&parent->sem);
- }
-
-@@ -612,7 +612,7 @@ void class_device_del(struct class_devic
- list_del_init(&class_dev->node);
- list_for_each_entry(class_intf, &parent->interfaces, node)
- if (class_intf->remove)
-- class_intf->remove(class_dev);
-+ class_intf->remove(class_dev, class_intf);
- up(&parent->sem);
- }
-
-@@ -729,7 +729,7 @@ int class_interface_register(struct clas
- list_add_tail(&class_intf->node, &parent->interfaces);
- if (class_intf->add) {
- list_for_each_entry(class_dev, &parent->children, node)
-- class_intf->add(class_dev);
-+ class_intf->add(class_dev, class_intf);
- }
- up(&parent->sem);
-
-@@ -748,7 +748,7 @@ void class_interface_unregister(struct c
- list_del_init(&class_intf->node);
- if (class_intf->remove) {
- list_for_each_entry(class_dev, &parent->children, node)
-- class_intf->remove(class_dev);
-+ class_intf->remove(class_dev, class_intf);
- }
- up(&parent->sem);
-
---- gregkh-2.6.orig/include/linux/device.h
-+++ gregkh-2.6/include/linux/device.h
-@@ -251,8 +251,8 @@ struct class_interface {
- struct list_head node;
- struct class *class;
-
-- int (*add) (struct class_device *);
-- void (*remove) (struct class_device *);
-+ int (*add) (struct class_device *, struct class_interface *);
-+ void (*remove) (struct class_device *, struct class_interface *);
- };
-
- extern int class_interface_register(struct class_interface *);
---- gregkh-2.6.orig/drivers/pcmcia/ds.c
-+++ gregkh-2.6/drivers/pcmcia/ds.c
-@@ -1157,7 +1157,8 @@ static struct pcmcia_callback pcmcia_bus
- .requery = pcmcia_bus_rescan,
- };
-
--static int __devinit pcmcia_bus_add_socket(struct class_device *class_dev)
-+static int __devinit pcmcia_bus_add_socket(struct class_device *class_dev,
-+ struct class_interface *class_intf)
- {
- struct pcmcia_socket *socket = class_get_devdata(class_dev);
- int ret;
-@@ -1192,7 +1193,8 @@ static int __devinit pcmcia_bus_add_sock
- return 0;
- }
-
--static void pcmcia_bus_remove_socket(struct class_device *class_dev)
-+static void pcmcia_bus_remove_socket(struct class_device *class_dev,
-+ struct class_interface *class_intf)
- {
- struct pcmcia_socket *socket = class_get_devdata(class_dev);
-
---- gregkh-2.6.orig/drivers/pcmcia/rsrc_nonstatic.c
-+++ gregkh-2.6/drivers/pcmcia/rsrc_nonstatic.c
-@@ -994,7 +994,8 @@ static struct class_device_attribute *pc
- NULL,
- };
-
--static int __devinit pccard_sysfs_add_rsrc(struct class_device *class_dev)
-+static int __devinit pccard_sysfs_add_rsrc(struct class_device *class_dev,
-+ struct class_interface *class_intf)
- {
- struct pcmcia_socket *s = class_get_devdata(class_dev);
- struct class_device_attribute **attr;
-@@ -1011,7 +1012,8 @@ static int __devinit pccard_sysfs_add_rs
- return ret;
- }
-
--static void __devexit pccard_sysfs_remove_rsrc(struct class_device *class_dev)
-+static void __devexit pccard_sysfs_remove_rsrc(struct class_device *class_dev,
-+ struct class_interface *class_intf)
- {
- struct pcmcia_socket *s = class_get_devdata(class_dev);
- struct class_device_attribute **attr;
---- gregkh-2.6.orig/drivers/pcmcia/socket_sysfs.c
-+++ gregkh-2.6/drivers/pcmcia/socket_sysfs.c
-@@ -341,7 +341,8 @@ static struct bin_attribute pccard_cis_a
- .write = pccard_store_cis,
- };
-
--static int __devinit pccard_sysfs_add_socket(struct class_device *class_dev)
-+static int __devinit pccard_sysfs_add_socket(struct class_device *class_dev,
-+ struct class_interface *class_intf)
- {
- struct class_device_attribute **attr;
- int ret = 0;
-@@ -357,7 +358,8 @@ static int __devinit pccard_sysfs_add_so
- return ret;
- }
-
--static void __devexit pccard_sysfs_remove_socket(struct class_device *class_dev)
-+static void __devexit pccard_sysfs_remove_socket(struct class_device *class_dev,
-+ struct class_interface *class_intf)
- {
- struct class_device_attribute **attr;
-
---- gregkh-2.6.orig/drivers/scsi/sg.c
-+++ gregkh-2.6/drivers/scsi/sg.c
-@@ -104,8 +104,8 @@ static int sg_allow_dio = SG_ALLOW_DIO_D
-
- #define SG_DEV_ARR_LUMP 32 /* amount to over allocate sg_dev_arr by */
-
--static int sg_add(struct class_device *);
--static void sg_remove(struct class_device *);
-+static int sg_add(struct class_device *, struct class_interface *);
-+static void sg_remove(struct class_device *, struct class_interface *);
-
- static Scsi_Request *dummy_cmdp; /* only used for sizeof */
-
-@@ -1506,7 +1506,7 @@ static int sg_alloc(struct gendisk *disk
- }
-
- static int
--sg_add(struct class_device *cl_dev)
-+sg_add(struct class_device *cl_dev, struct class_interface *cl_intf)
- {
- struct scsi_device *scsidp = to_scsi_device(cl_dev->dev);
- struct gendisk *disk;
-@@ -1582,7 +1582,7 @@ out:
- }
-
- static void
--sg_remove(struct class_device *cl_dev)
-+sg_remove(struct class_device *cl_dev, struct class_interface *cl_intf)
- {
- struct scsi_device *scsidp = to_scsi_device(cl_dev->dev);
- Sg_device *sdp = NULL;
diff --git a/driver/driver-kobject-typo.patch b/driver/driver-kobject-typo.patch
deleted file mode 100644
index cb2cba35f5812..0000000000000
--- a/driver/driver-kobject-typo.patch
+++ /dev/null
@@ -1,28 +0,0 @@
-From ehovland@s383.jpl.nasa.gov Thu Oct 6 10:49:43 2005
-Date: Thu, 6 Oct 2005 10:45:30 -0700
-From: Erik Hovland <erik@hovland.org>
-To: gregkh@suse.de
-Cc: trivial@rustcorp.com.au
-Subject: [trivial patch] kobject_uevent.c has a typo in a comment
-Message-ID: <20051006174530.GG25998@mage.jpl.nasa.gov>
-
-This patch changes trough to through in a comment in kobject_uevent.c.
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-
----
- lib/kobject_uevent.c | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
---- gregkh-2.6.orig/lib/kobject_uevent.c
-+++ gregkh-2.6/lib/kobject_uevent.c
-@@ -54,7 +54,7 @@ static char *action_to_string(enum kobje
- static struct sock *uevent_sock;
-
- /**
-- * send_uevent - notify userspace by sending event trough netlink socket
-+ * send_uevent - notify userspace by sending event through netlink socket
- *
- * @signal: signal name
- * @obj: object path (kobject)
diff --git a/driver/driver-model-get-rid-of-the-obsolete-tri-level-suspend-resume-callbacks.patch b/driver/driver-model-get-rid-of-the-obsolete-tri-level-suspend-resume-callbacks.patch
deleted file mode 100644
index 948dc29216ec8..0000000000000
--- a/driver/driver-model-get-rid-of-the-obsolete-tri-level-suspend-resume-callbacks.patch
+++ /dev/null
@@ -1,2344 +0,0 @@
-From foo@baz Thu Sep 29 10:06:31 2005
-From: Russell King <rmk+kernel@arm.linux.org.uk>
-Subject: DRIVER MODEL: Get rid of the obsolete tri-level suspend/resume callbacks
-
-In PM v1, all devices were called at SUSPEND_DISABLE level. Then
-all devices were called at SUSPEND_SAVE_STATE level, and finally
-SUSPEND_POWER_DOWN level. However, with PM v2, to maintain
-compatibility for platform devices, I arranged for the PM v2
-suspend/resume callbacks to call the old PM v1 suspend/resume
-callbacks three times with each level in order so that existing
-drivers continued to work.
-
-Since this is obsolete infrastructure which is no longer necessary,
-we can remove it. Here's an (untested) patch to do exactly that.
-
-Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- Documentation/driver-model/driver.txt | 60 +---------------------------------
- arch/arm/common/locomo.c | 10 +----
- arch/arm/common/sa1111.c | 11 +-----
- arch/arm/common/scoop.c | 24 ++++++-------
- arch/arm/mach-pxa/corgi_ssp.c | 24 ++++++-------
- arch/arm/mach-sa1100/neponset.c | 28 ++++++---------
- drivers/base/platform.c | 20 +++--------
- drivers/char/s3c2410-rtc.c | 20 +++++------
- drivers/char/sonypi.c | 14 +++----
- drivers/char/watchdog/s3c2410_wdt.c | 34 ++++++++-----------
- drivers/hwmon/hdaps.c | 6 +--
- drivers/i2c/busses/i2c-s3c2410.c | 8 +---
- drivers/i2c/i2c-core.c | 4 +-
- drivers/ieee1394/nodemgr.c | 4 +-
- drivers/input/keyboard/corgikbd.c | 22 +++++-------
- drivers/input/keyboard/spitzkbd.c | 44 +++++++++++-------------
- drivers/input/serio/i8042.c | 13 ++-----
- drivers/input/touchscreen/corgi_ts.c | 38 ++++++++++-----------
- drivers/media/video/msp3400.c | 8 ++--
- drivers/media/video/tda9887.c | 4 +-
- drivers/media/video/tuner-core.c | 4 +-
- drivers/mfd/mcp-sa11x0.c | 20 +++++------
- drivers/mmc/pxamci.c | 8 ++--
- drivers/mmc/wbsd.c | 4 +-
- drivers/mtd/maps/sa1100-flash.c | 8 ++--
- drivers/net/dm9000.c | 8 ++--
- drivers/net/irda/sa1100_ir.c | 8 ++--
- drivers/net/irda/smsc-ircc2.c | 12 +++---
- drivers/net/phy/mdio_bus.c | 20 +++--------
- drivers/net/smc91x.c | 8 ++--
- drivers/pci/pcie/portdrv_core.c | 4 +-
- drivers/pcmcia/au1000_generic.c | 21 +----------
- drivers/pcmcia/hd64465_ss.c | 20 +----------
- drivers/pcmcia/i82365.c | 20 +----------
- drivers/pcmcia/m32r_cfc.c | 21 +----------
- drivers/pcmcia/m32r_pcc.c | 21 +----------
- drivers/pcmcia/omap_cf.c | 18 +---------
- drivers/pcmcia/pxa2xx_base.c | 26 +++-----------
- drivers/pcmcia/sa1100_generic.c | 20 +----------
- drivers/pcmcia/tcic.c | 20 +----------
- drivers/pcmcia/vrc4171_card.c | 24 +------------
- drivers/serial/8250.c | 10 +----
- drivers/serial/imx.c | 8 ++--
- drivers/serial/mpc52xx_uart.c | 8 ++--
- drivers/serial/pxa.c | 8 ++--
- drivers/serial/s3c2410.c | 9 ++---
- drivers/serial/sa1100.c | 8 ++--
- drivers/serial/vr41xx_siu.c | 10 +----
- drivers/usb/gadget/dummy_hcd.c | 22 ++----------
- drivers/usb/gadget/omap_udc.c | 9 +----
- drivers/usb/gadget/pxa2xx_udc.c | 17 ++++-----
- drivers/usb/host/isp116x-hcd.c | 14 ++-----
- drivers/usb/host/ohci-omap.c | 10 +----
- drivers/usb/host/ohci-pxa27x.c | 4 +-
- drivers/usb/host/sl811-hcd.c | 10 +----
- drivers/video/backlight/corgi_bl.c | 10 ++---
- drivers/video/imxfb.c | 10 ++---
- drivers/video/pxafb.c | 10 ++---
- drivers/video/s1d13xxxfb.c | 7 +--
- drivers/video/s3c2410fb.c | 29 ++++++----------
- drivers/video/sa1100fb.c | 10 ++---
- drivers/video/w100fb.c | 48 +++++++++++++--------------
- include/linux/device.h | 17 +--------
- sound/arm/pxa2xx-ac97.c | 8 ++--
- sound/core/init.c | 14 ++-----
- sound/pci/ac97/ac97_bus.c | 6 ++-
- 66 files changed, 330 insertions(+), 697 deletions(-)
-
---- gregkh-2.6.orig/Documentation/driver-model/driver.txt
-+++ gregkh-2.6/Documentation/driver-model/driver.txt
-@@ -196,67 +196,11 @@ it into a supported low-power state.
-
- int (*suspend) (struct device * dev, pm_message_t state, u32 level);
-
--suspend is called to put the device in a low power state. There are
--several stages to successfully suspending a device, which is denoted in
--the @level parameter. Breaking the suspend transition into several
--stages affords the platform flexibility in performing device power
--management based on the requirements of the system and the
--user-defined policy.
--
--SUSPEND_NOTIFY notifies the device that a suspend transition is about
--to happen. This happens on system power state transitions to verify
--that all devices can successfully suspend.
--
--A driver may choose to fail on this call, which should cause the
--entire suspend transition to fail. A driver should fail only if it
--knows that the device will not be able to be resumed properly when the
--system wakes up again. It could also fail if it somehow determines it
--is in the middle of an operation too important to stop.
--
--SUSPEND_DISABLE tells the device to stop I/O transactions. When it
--stops transactions, or what it should do with unfinished transactions
--is a policy of the driver. After this call, the driver should not
--accept any other I/O requests.
--
--SUSPEND_SAVE_STATE tells the device to save the context of the
--hardware. This includes any bus-specific hardware state and
--device-specific hardware state. A pointer to this saved state can be
--stored in the device's saved_state field.
--
--SUSPEND_POWER_DOWN tells the driver to place the device in the low
--power state requested.
--
--Whether suspend is called with a given level is a policy of the
--platform. Some levels may be omitted; drivers must not assume the
--reception of any level. However, all levels must be called in the
--order above; i.e. notification will always come before disabling;
--disabling the device will come before suspending the device.
--
--All calls are made with interrupts enabled, except for the
--SUSPEND_POWER_DOWN level.
-+suspend is called to put the device in a low power state.
-
- int (*resume) (struct device * dev, u32 level);
-
--Resume is used to bring a device back from a low power state. Like the
--suspend transition, it happens in several stages.
--
--RESUME_POWER_ON tells the driver to set the power state to the state
--before the suspend call (The device could have already been in a low
--power state before the suspend call to put in a lower power state).
--
--RESUME_RESTORE_STATE tells the driver to restore the state saved by
--the SUSPEND_SAVE_STATE suspend call.
--
--RESUME_ENABLE tells the driver to start accepting I/O transactions
--again. Depending on driver policy, the device may already have pending
--I/O requests.
--
--RESUME_POWER_ON is called with interrupts disabled. The other resume
--levels are called with interrupts enabled.
--
--As with the various suspend stages, the driver must not assume that
--any other resume calls have been or will be made. Each call should be
--self-contained and not dependent on any external state.
-+Resume is used to bring a device back from a low power state.
-
-
- Attributes
---- gregkh-2.6.orig/arch/arm/common/locomo.c
-+++ gregkh-2.6/arch/arm/common/locomo.c
-@@ -550,15 +550,12 @@ struct locomo_save_data {
- u16 LCM_SPIMD;
- };
-
--static int locomo_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int locomo_suspend(struct device *dev, pm_message_t state)
- {
- struct locomo *lchip = dev_get_drvdata(dev);
- struct locomo_save_data *save;
- unsigned long flags;
-
-- if (level != SUSPEND_DISABLE)
-- return 0;
--
- save = kmalloc(sizeof(struct locomo_save_data), GFP_KERNEL);
- if (!save)
- return -ENOMEM;
-@@ -597,16 +594,13 @@ static int locomo_suspend(struct device
- return 0;
- }
-
--static int locomo_resume(struct device *dev, u32 level)
-+static int locomo_resume(struct device *dev)
- {
- struct locomo *lchip = dev_get_drvdata(dev);
- struct locomo_save_data *save;
- unsigned long r;
- unsigned long flags;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- save = (struct locomo_save_data *) dev->power.saved_state;
- if (!save)
- return 0;
---- gregkh-2.6.orig/arch/arm/common/sa1111.c
-+++ gregkh-2.6/arch/arm/common/sa1111.c
-@@ -801,7 +801,7 @@ struct sa1111_save_data {
-
- #ifdef CONFIG_PM
-
--static int sa1111_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int sa1111_suspend(struct device *dev, pm_message_t state)
- {
- struct sa1111 *sachip = dev_get_drvdata(dev);
- struct sa1111_save_data *save;
-@@ -809,9 +809,6 @@ static int sa1111_suspend(struct device
- unsigned int val;
- void __iomem *base;
-
-- if (level != SUSPEND_DISABLE)
-- return 0;
--
- save = kmalloc(sizeof(struct sa1111_save_data), GFP_KERNEL);
- if (!save)
- return -ENOMEM;
-@@ -856,23 +853,19 @@ static int sa1111_suspend(struct device
- /*
- * sa1111_resume - Restore the SA1111 device state.
- * @dev: device to restore
-- * @level: resume level
- *
- * Restore the general state of the SA1111; clock control and
- * interrupt controller. Other parts of the SA1111 must be
- * restored by their respective drivers, and must be called
- * via LDM after this function.
- */
--static int sa1111_resume(struct device *dev, u32 level)
-+static int sa1111_resume(struct device *dev)
- {
- struct sa1111 *sachip = dev_get_drvdata(dev);
- struct sa1111_save_data *save;
- unsigned long flags, id;
- void __iomem *base;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- save = (struct sa1111_save_data *)dev->power.saved_state;
- if (!save)
- return 0;
---- gregkh-2.6.orig/arch/arm/common/scoop.c
-+++ gregkh-2.6/arch/arm/common/scoop.c
-@@ -102,26 +102,24 @@ static void check_scoop_reg(struct scoop
- }
-
- #ifdef CONFIG_PM
--static int scoop_suspend(struct device *dev, pm_message_t state, uint32_t level)
-+static int scoop_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN) {
-- struct scoop_dev *sdev = dev_get_drvdata(dev);
-+ struct scoop_dev *sdev = dev_get_drvdata(dev);
-+
-+ check_scoop_reg(sdev);
-+ sdev->scoop_gpwr = SCOOP_REG(sdev->base, SCOOP_GPWR);
-+ SCOOP_REG(sdev->base, SCOOP_GPWR) = (sdev->scoop_gpwr & ~sdev->suspend_clr) | sdev->suspend_set;
-
-- check_scoop_reg(sdev);
-- sdev->scoop_gpwr = SCOOP_REG(sdev->base, SCOOP_GPWR);
-- SCOOP_REG(sdev->base, SCOOP_GPWR) = (sdev->scoop_gpwr & ~sdev->suspend_clr) | sdev->suspend_set;
-- }
- return 0;
- }
-
--static int scoop_resume(struct device *dev, uint32_t level)
-+static int scoop_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON) {
-- struct scoop_dev *sdev = dev_get_drvdata(dev);
-+ struct scoop_dev *sdev = dev_get_drvdata(dev);
-+
-+ check_scoop_reg(sdev);
-+ SCOOP_REG(sdev->base,SCOOP_GPWR) = sdev->scoop_gpwr;
-
-- check_scoop_reg(sdev);
-- SCOOP_REG(sdev->base,SCOOP_GPWR) = sdev->scoop_gpwr;
-- }
- return 0;
- }
- #else
---- gregkh-2.6.orig/arch/arm/mach-pxa/corgi_ssp.c
-+++ gregkh-2.6/arch/arm/mach-pxa/corgi_ssp.c
-@@ -222,24 +222,22 @@ static int corgi_ssp_remove(struct devic
- return 0;
- }
-
--static int corgi_ssp_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int corgi_ssp_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN) {
-- ssp_flush(&corgi_ssp_dev);
-- ssp_save_state(&corgi_ssp_dev,&corgi_ssp_state);
-- }
-+ ssp_flush(&corgi_ssp_dev);
-+ ssp_save_state(&corgi_ssp_dev,&corgi_ssp_state);
-+
- return 0;
- }
-
--static int corgi_ssp_resume(struct device *dev, u32 level)
-+static int corgi_ssp_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON) {
-- GPSR(ssp_machinfo->cs_lcdcon) = GPIO_bit(ssp_machinfo->cs_lcdcon); /* High - Disable LCD Control/Timing Gen */
-- GPSR(ssp_machinfo->cs_max1111) = GPIO_bit(ssp_machinfo->cs_max1111); /* High - Disable MAX1111*/
-- GPSR(ssp_machinfo->cs_ads7846) = GPIO_bit(ssp_machinfo->cs_ads7846); /* High - Disable ADS7846*/
-- ssp_restore_state(&corgi_ssp_dev,&corgi_ssp_state);
-- ssp_enable(&corgi_ssp_dev);
-- }
-+ GPSR(ssp_machinfo->cs_lcdcon) = GPIO_bit(ssp_machinfo->cs_lcdcon); /* High - Disable LCD Control/Timing Gen */
-+ GPSR(ssp_machinfo->cs_max1111) = GPIO_bit(ssp_machinfo->cs_max1111); /* High - Disable MAX1111*/
-+ GPSR(ssp_machinfo->cs_ads7846) = GPIO_bit(ssp_machinfo->cs_ads7846); /* High - Disable ADS7846*/
-+ ssp_restore_state(&corgi_ssp_dev,&corgi_ssp_state);
-+ ssp_enable(&corgi_ssp_dev);
-+
- return 0;
- }
-
---- gregkh-2.6.orig/arch/arm/mach-sa1100/neponset.c
-+++ gregkh-2.6/arch/arm/mach-sa1100/neponset.c
-@@ -178,33 +178,27 @@ static int neponset_probe(struct device
- /*
- * LDM power management.
- */
--static int neponset_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int neponset_suspend(struct device *dev, pm_message_t state)
- {
- /*
- * Save state.
- */
-- if (level == SUSPEND_SAVE_STATE ||
-- level == SUSPEND_DISABLE ||
-- level == SUSPEND_POWER_DOWN) {
-- if (!dev->power.saved_state)
-- dev->power.saved_state = kmalloc(sizeof(unsigned int), GFP_KERNEL);
-- if (!dev->power.saved_state)
-- return -ENOMEM;
-+ if (!dev->power.saved_state)
-+ dev->power.saved_state = kmalloc(sizeof(unsigned int), GFP_KERNEL);
-+ if (!dev->power.saved_state)
-+ return -ENOMEM;
-
-- *(unsigned int *)dev->power.saved_state = NCR_0;
-- }
-+ *(unsigned int *)dev->power.saved_state = NCR_0;
-
- return 0;
- }
-
--static int neponset_resume(struct device *dev, u32 level)
-+static int neponset_resume(struct device *dev)
- {
-- if (level == RESUME_RESTORE_STATE || level == RESUME_ENABLE) {
-- if (dev->power.saved_state) {
-- NCR_0 = *(unsigned int *)dev->power.saved_state;
-- kfree(dev->power.saved_state);
-- dev->power.saved_state = NULL;
-- }
-+ if (dev->power.saved_state) {
-+ NCR_0 = *(unsigned int *)dev->power.saved_state;
-+ kfree(dev->power.saved_state);
-+ dev->power.saved_state = NULL;
- }
-
- return 0;
---- gregkh-2.6.orig/drivers/base/platform.c
-+++ gregkh-2.6/drivers/base/platform.c
-@@ -281,13 +281,9 @@ static int platform_suspend(struct devic
- {
- int ret = 0;
-
-- if (dev->driver && dev->driver->suspend) {
-- ret = dev->driver->suspend(dev, state, SUSPEND_DISABLE);
-- if (ret == 0)
-- ret = dev->driver->suspend(dev, state, SUSPEND_SAVE_STATE);
-- if (ret == 0)
-- ret = dev->driver->suspend(dev, state, SUSPEND_POWER_DOWN);
-- }
-+ if (dev->driver && dev->driver->suspend)
-+ ret = dev->driver->suspend(dev, state);
-+
- return ret;
- }
-
-@@ -295,13 +291,9 @@ static int platform_resume(struct device
- {
- int ret = 0;
-
-- if (dev->driver && dev->driver->resume) {
-- ret = dev->driver->resume(dev, RESUME_POWER_ON);
-- if (ret == 0)
-- ret = dev->driver->resume(dev, RESUME_RESTORE_STATE);
-- if (ret == 0)
-- ret = dev->driver->resume(dev, RESUME_ENABLE);
-- }
-+ if (dev->driver && dev->driver->resume)
-+ ret = dev->driver->resume(dev);
-+
- return ret;
- }
-
---- gregkh-2.6.orig/drivers/char/s3c2410-rtc.c
-+++ gregkh-2.6/drivers/char/s3c2410-rtc.c
-@@ -519,30 +519,28 @@ static struct timespec s3c2410_rtc_delta
-
- static int ticnt_save;
-
--static int s3c2410_rtc_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int s3c2410_rtc_suspend(struct device *dev, pm_message_t state)
- {
- struct rtc_time tm;
- struct timespec time;
-
- time.tv_nsec = 0;
-
-- if (level == SUSPEND_POWER_DOWN) {
-- /* save TICNT for anyone using periodic interrupts */
-+ /* save TICNT for anyone using periodic interrupts */
-
-- ticnt_save = readb(S3C2410_TICNT);
-+ ticnt_save = readb(S3C2410_TICNT);
-
-- /* calculate time delta for suspend */
-+ /* calculate time delta for suspend */
-
-- s3c2410_rtc_gettime(&tm);
-- rtc_tm_to_time(&tm, &time.tv_sec);
-- save_time_delta(&s3c2410_rtc_delta, &time);
-- s3c2410_rtc_enable(dev, 0);
-- }
-+ s3c2410_rtc_gettime(&tm);
-+ rtc_tm_to_time(&tm, &time.tv_sec);
-+ save_time_delta(&s3c2410_rtc_delta, &time);
-+ s3c2410_rtc_enable(dev, 0);
-
- return 0;
- }
-
--static int s3c2410_rtc_resume(struct device *dev, u32 level)
-+static int s3c2410_rtc_resume(struct device *dev)
- {
- struct rtc_time tm;
- struct timespec time;
---- gregkh-2.6.orig/drivers/char/sonypi.c
-+++ gregkh-2.6/drivers/char/sonypi.c
-@@ -1167,19 +1167,17 @@ static int sonypi_disable(void)
- #ifdef CONFIG_PM
- static int old_camera_power;
-
--static int sonypi_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int sonypi_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_DISABLE) {
-- old_camera_power = sonypi_device.camera_power;
-- sonypi_disable();
-- }
-+ old_camera_power = sonypi_device.camera_power;
-+ sonypi_disable();
-+
- return 0;
- }
-
--static int sonypi_resume(struct device *dev, u32 level)
-+static int sonypi_resume(struct device *dev)
- {
-- if (level == RESUME_ENABLE)
-- sonypi_enable(old_camera_power);
-+ sonypi_enable(old_camera_power);
- return 0;
- }
- #endif
---- gregkh-2.6.orig/drivers/char/watchdog/s3c2410_wdt.c
-+++ gregkh-2.6/drivers/char/watchdog/s3c2410_wdt.c
-@@ -464,32 +464,28 @@ static void s3c2410wdt_shutdown(struct d
- static unsigned long wtcon_save;
- static unsigned long wtdat_save;
-
--static int s3c2410wdt_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int s3c2410wdt_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN) {
-- /* Save watchdog state, and turn it off. */
-- wtcon_save = readl(wdt_base + S3C2410_WTCON);
-- wtdat_save = readl(wdt_base + S3C2410_WTDAT);
--
-- /* Note that WTCNT doesn't need to be saved. */
-- s3c2410wdt_stop();
-- }
-+ /* Save watchdog state, and turn it off. */
-+ wtcon_save = readl(wdt_base + S3C2410_WTCON);
-+ wtdat_save = readl(wdt_base + S3C2410_WTDAT);
-+
-+ /* Note that WTCNT doesn't need to be saved. */
-+ s3c2410wdt_stop();
-
- return 0;
- }
-
--static int s3c2410wdt_resume(struct device *dev, u32 level)
-+static int s3c2410wdt_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON) {
-- /* Restore watchdog state. */
-+ /* Restore watchdog state. */
-+
-+ writel(wtdat_save, wdt_base + S3C2410_WTDAT);
-+ writel(wtdat_save, wdt_base + S3C2410_WTCNT); /* Reset count */
-+ writel(wtcon_save, wdt_base + S3C2410_WTCON);
-
-- writel(wtdat_save, wdt_base + S3C2410_WTDAT);
-- writel(wtdat_save, wdt_base + S3C2410_WTCNT); /* Reset count */
-- writel(wtcon_save, wdt_base + S3C2410_WTCON);
--
-- printk(KERN_INFO PFX "watchdog %sabled\n",
-- (wtcon_save & S3C2410_WTCON_ENABLE) ? "en" : "dis");
-- }
-+ printk(KERN_INFO PFX "watchdog %sabled\n",
-+ (wtcon_save & S3C2410_WTCON_ENABLE) ? "en" : "dis");
-
- return 0;
- }
---- gregkh-2.6.orig/drivers/hwmon/hdaps.c
-+++ gregkh-2.6/drivers/hwmon/hdaps.c
-@@ -296,11 +296,9 @@ static int hdaps_probe(struct device *de
- return 0;
- }
-
--static int hdaps_resume(struct device *dev, u32 level)
-+static int hdaps_resume(struct device *dev)
- {
-- if (level == RESUME_ENABLE)
-- return hdaps_device_init();
-- return 0;
-+ return hdaps_device_init();
- }
-
- static struct device_driver hdaps_driver = {
---- gregkh-2.6.orig/drivers/i2c/busses/i2c-s3c2410.c
-+++ gregkh-2.6/drivers/i2c/busses/i2c-s3c2410.c
-@@ -879,14 +879,12 @@ static int s3c24xx_i2c_remove(struct dev
- }
-
- #ifdef CONFIG_PM
--static int s3c24xx_i2c_resume(struct device *dev, u32 level)
-+static int s3c24xx_i2c_resume(struct device *dev)
- {
- struct s3c24xx_i2c *i2c = dev_get_drvdata(dev);
--
-- if (i2c != NULL && level == RESUME_ENABLE) {
-- dev_dbg(dev, "resume: level %d\n", level);
-+
-+ if (i2c != NULL)
- s3c24xx_i2c_init(i2c);
-- }
-
- return 0;
- }
---- gregkh-2.6.orig/drivers/i2c/i2c-core.c
-+++ gregkh-2.6/drivers/i2c/i2c-core.c
-@@ -48,7 +48,7 @@ static int i2c_bus_suspend(struct device
- int rc = 0;
-
- if (dev->driver && dev->driver->suspend)
-- rc = dev->driver->suspend(dev,state,0);
-+ rc = dev->driver->suspend(dev, state);
- return rc;
- }
-
-@@ -57,7 +57,7 @@ static int i2c_bus_resume(struct device
- int rc = 0;
-
- if (dev->driver && dev->driver->resume)
-- rc = dev->driver->resume(dev,0);
-+ rc = dev->driver->resume(dev);
- return rc;
- }
-
---- gregkh-2.6.orig/drivers/ieee1394/nodemgr.c
-+++ gregkh-2.6/drivers/ieee1394/nodemgr.c
-@@ -1292,7 +1292,7 @@ static void nodemgr_suspend_ne(struct no
-
- if (ud->device.driver &&
- (!ud->device.driver->suspend ||
-- ud->device.driver->suspend(&ud->device, PMSG_SUSPEND, 0)))
-+ ud->device.driver->suspend(&ud->device, PMSG_SUSPEND)))
- device_release_driver(&ud->device);
- }
- up_write(&ne->device.bus->subsys.rwsem);
-@@ -1315,7 +1315,7 @@ static void nodemgr_resume_ne(struct nod
- continue;
-
- if (ud->device.driver && ud->device.driver->resume)
-- ud->device.driver->resume(&ud->device, 0);
-+ ud->device.driver->resume(&ud->device);
- }
- up_read(&ne->device.bus->subsys.rwsem);
-
---- gregkh-2.6.orig/drivers/input/keyboard/corgikbd.c
-+++ gregkh-2.6/drivers/input/keyboard/corgikbd.c
-@@ -259,24 +259,22 @@ static void corgikbd_hinge_timer(unsigne
- }
-
- #ifdef CONFIG_PM
--static int corgikbd_suspend(struct device *dev, pm_message_t state, uint32_t level)
-+static int corgikbd_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN) {
-- struct corgikbd *corgikbd = dev_get_drvdata(dev);
-- corgikbd->suspended = 1;
-- }
-+ struct corgikbd *corgikbd = dev_get_drvdata(dev);
-+ corgikbd->suspended = 1;
-+
- return 0;
- }
-
--static int corgikbd_resume(struct device *dev, uint32_t level)
-+static int corgikbd_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON) {
-- struct corgikbd *corgikbd = dev_get_drvdata(dev);
-+ struct corgikbd *corgikbd = dev_get_drvdata(dev);
-+
-+ /* Upon resume, ignore the suspend key for a short while */
-+ corgikbd->suspend_jiffies=jiffies;
-+ corgikbd->suspended = 0;
-
-- /* Upon resume, ignore the suspend key for a short while */
-- corgikbd->suspend_jiffies=jiffies;
-- corgikbd->suspended = 0;
-- }
- return 0;
- }
- #else
---- gregkh-2.6.orig/drivers/input/keyboard/spitzkbd.c
-+++ gregkh-2.6/drivers/input/keyboard/spitzkbd.c
-@@ -309,34 +309,32 @@ static void spitzkbd_hinge_timer(unsigne
- }
-
- #ifdef CONFIG_PM
--static int spitzkbd_suspend(struct device *dev, pm_message_t state, uint32_t level)
-+static int spitzkbd_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN) {
-- int i;
-- struct spitzkbd *spitzkbd = dev_get_drvdata(dev);
-- spitzkbd->suspended = 1;
--
-- /* Set Strobe lines as inputs - *except* strobe line 0 leave this
-- enabled so we can detect a power button press for resume */
-- for (i = 1; i < SPITZ_KEY_STROBE_NUM; i++)
-- pxa_gpio_mode(spitz_strobes[i] | GPIO_IN);
-- }
-+ int i;
-+ struct spitzkbd *spitzkbd = dev_get_drvdata(dev);
-+ spitzkbd->suspended = 1;
-+
-+ /* Set Strobe lines as inputs - *except* strobe line 0 leave this
-+ enabled so we can detect a power button press for resume */
-+ for (i = 1; i < SPITZ_KEY_STROBE_NUM; i++)
-+ pxa_gpio_mode(spitz_strobes[i] | GPIO_IN);
-+
- return 0;
- }
-
--static int spitzkbd_resume(struct device *dev, uint32_t level)
-+static int spitzkbd_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON) {
-- int i;
-- struct spitzkbd *spitzkbd = dev_get_drvdata(dev);
--
-- for (i = 0; i < SPITZ_KEY_STROBE_NUM; i++)
-- pxa_gpio_mode(spitz_strobes[i] | GPIO_OUT | GPIO_DFLT_HIGH);
--
-- /* Upon resume, ignore the suspend key for a short while */
-- spitzkbd->suspend_jiffies = jiffies;
-- spitzkbd->suspended = 0;
-- }
-+ int i;
-+ struct spitzkbd *spitzkbd = dev_get_drvdata(dev);
-+
-+ for (i = 0; i < SPITZ_KEY_STROBE_NUM; i++)
-+ pxa_gpio_mode(spitz_strobes[i] | GPIO_OUT | GPIO_DFLT_HIGH);
-+
-+ /* Upon resume, ignore the suspend key for a short while */
-+ spitzkbd->suspend_jiffies = jiffies;
-+ spitzkbd->suspended = 0;
-+
- return 0;
- }
- #else
---- gregkh-2.6.orig/drivers/input/serio/i8042.c
-+++ gregkh-2.6/drivers/input/serio/i8042.c
-@@ -911,12 +911,10 @@ static long i8042_panic_blink(long count
- * Here we try to restore the original BIOS settings
- */
-
--static int i8042_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int i8042_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_DISABLE) {
-- del_timer_sync(&i8042_timer);
-- i8042_controller_reset();
-- }
-+ del_timer_sync(&i8042_timer);
-+ i8042_controller_reset();
-
- return 0;
- }
-@@ -926,13 +924,10 @@ static int i8042_suspend(struct device *
- * Here we try to reset everything back to a state in which suspended
- */
-
--static int i8042_resume(struct device *dev, u32 level)
-+static int i8042_resume(struct device *dev)
- {
- int i;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- if (i8042_ctl_test())
- return -1;
-
---- gregkh-2.6.orig/drivers/input/touchscreen/corgi_ts.c
-+++ gregkh-2.6/drivers/input/touchscreen/corgi_ts.c
-@@ -231,34 +231,32 @@ static irqreturn_t ts_interrupt(int irq,
- }
-
- #ifdef CONFIG_PM
--static int corgits_suspend(struct device *dev, pm_message_t state, uint32_t level)
-+static int corgits_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN) {
-- struct corgi_ts *corgi_ts = dev_get_drvdata(dev);
--
-- if (corgi_ts->pendown) {
-- del_timer_sync(&corgi_ts->timer);
-- corgi_ts->tc.pressure = 0;
-- new_data(corgi_ts, NULL);
-- corgi_ts->pendown = 0;
-- }
-- corgi_ts->power_mode = PWR_MODE_SUSPEND;
-+ struct corgi_ts *corgi_ts = dev_get_drvdata(dev);
-
-- corgi_ssp_ads7846_putget((1u << ADSCTRL_ADR_SH) | ADSCTRL_STS);
-+ if (corgi_ts->pendown) {
-+ del_timer_sync(&corgi_ts->timer);
-+ corgi_ts->tc.pressure = 0;
-+ new_data(corgi_ts, NULL);
-+ corgi_ts->pendown = 0;
- }
-+ corgi_ts->power_mode = PWR_MODE_SUSPEND;
-+
-+ corgi_ssp_ads7846_putget((1u << ADSCTRL_ADR_SH) | ADSCTRL_STS);
-+
- return 0;
- }
-
--static int corgits_resume(struct device *dev, uint32_t level)
-+static int corgits_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON) {
-- struct corgi_ts *corgi_ts = dev_get_drvdata(dev);
-+ struct corgi_ts *corgi_ts = dev_get_drvdata(dev);
-+
-+ corgi_ssp_ads7846_putget((4u << ADSCTRL_ADR_SH) | ADSCTRL_STS);
-+ /* Enable Falling Edge */
-+ set_irq_type(corgi_ts->irq_gpio, IRQT_FALLING);
-+ corgi_ts->power_mode = PWR_MODE_ACTIVE;
-
-- corgi_ssp_ads7846_putget((4u << ADSCTRL_ADR_SH) | ADSCTRL_STS);
-- /* Enable Falling Edge */
-- set_irq_type(corgi_ts->irq_gpio, IRQT_FALLING);
-- corgi_ts->power_mode = PWR_MODE_ACTIVE;
-- }
- return 0;
- }
- #else
---- gregkh-2.6.orig/drivers/media/video/msp3400.c
-+++ gregkh-2.6/drivers/media/video/msp3400.c
-@@ -1420,8 +1420,8 @@ static int msp_detach(struct i2c_client
- static int msp_probe(struct i2c_adapter *adap);
- static int msp_command(struct i2c_client *client, unsigned int cmd, void *arg);
-
--static int msp_suspend(struct device * dev, pm_message_t state, u32 level);
--static int msp_resume(struct device * dev, u32 level);
-+static int msp_suspend(struct device * dev, pm_message_t state);
-+static int msp_resume(struct device * dev);
-
- static void msp_wake_thread(struct i2c_client *client);
-
-@@ -1821,7 +1821,7 @@ static int msp_command(struct i2c_client
- return 0;
- }
-
--static int msp_suspend(struct device * dev, pm_message_t state, u32 level)
-+static int msp_suspend(struct device * dev, pm_message_t state)
- {
- struct i2c_client *c = container_of(dev, struct i2c_client, dev);
-
-@@ -1830,7 +1830,7 @@ static int msp_suspend(struct device * d
- return 0;
- }
-
--static int msp_resume(struct device * dev, u32 level)
-+static int msp_resume(struct device * dev)
- {
- struct i2c_client *c = container_of(dev, struct i2c_client, dev);
-
---- gregkh-2.6.orig/drivers/media/video/tda9887.c
-+++ gregkh-2.6/drivers/media/video/tda9887.c
-@@ -784,13 +784,13 @@ tda9887_command(struct i2c_client *clien
- return 0;
- }
-
--static int tda9887_suspend(struct device * dev, pm_message_t state, u32 level)
-+static int tda9887_suspend(struct device * dev, pm_message_t state)
- {
- dprintk("tda9887: suspend\n");
- return 0;
- }
-
--static int tda9887_resume(struct device * dev, u32 level)
-+static int tda9887_resume(struct device * dev)
- {
- struct i2c_client *c = container_of(dev, struct i2c_client, dev);
- struct tda9887 *t = i2c_get_clientdata(c);
---- gregkh-2.6.orig/drivers/media/video/tuner-core.c
-+++ gregkh-2.6/drivers/media/video/tuner-core.c
-@@ -697,7 +697,7 @@ static int tuner_command(struct i2c_clie
- return 0;
- }
-
--static int tuner_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int tuner_suspend(struct device *dev, pm_message_t state)
- {
- struct i2c_client *c = container_of (dev, struct i2c_client, dev);
- struct tuner *t = i2c_get_clientdata (c);
-@@ -707,7 +707,7 @@ static int tuner_suspend(struct device *
- return 0;
- }
-
--static int tuner_resume(struct device *dev, u32 level)
-+static int tuner_resume(struct device *dev)
- {
- struct i2c_client *c = container_of (dev, struct i2c_client, dev);
- struct tuner *t = i2c_get_clientdata (c);
---- gregkh-2.6.orig/drivers/mfd/mcp-sa11x0.c
-+++ gregkh-2.6/drivers/mfd/mcp-sa11x0.c
-@@ -219,26 +219,24 @@ static int mcp_sa11x0_remove(struct devi
- return 0;
- }
-
--static int mcp_sa11x0_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int mcp_sa11x0_suspend(struct device *dev, pm_message_t state)
- {
- struct mcp *mcp = dev_get_drvdata(dev);
-
-- if (level == SUSPEND_DISABLE) {
-- priv(mcp)->mccr0 = Ser4MCCR0;
-- priv(mcp)->mccr1 = Ser4MCCR1;
-- Ser4MCCR0 &= ~MCCR0_MCE;
-- }
-+ priv(mcp)->mccr0 = Ser4MCCR0;
-+ priv(mcp)->mccr1 = Ser4MCCR1;
-+ Ser4MCCR0 &= ~MCCR0_MCE;
-+
- return 0;
- }
-
--static int mcp_sa11x0_resume(struct device *dev, u32 level)
-+static int mcp_sa11x0_resume(struct device *dev)
- {
- struct mcp *mcp = dev_get_drvdata(dev);
-
-- if (level == RESUME_RESTORE_STATE) {
-- Ser4MCCR1 = priv(mcp)->mccr1;
-- Ser4MCCR0 = priv(mcp)->mccr0;
-- }
-+ Ser4MCCR1 = priv(mcp)->mccr1;
-+ Ser4MCCR0 = priv(mcp)->mccr0;
-+
- return 0;
- }
-
---- gregkh-2.6.orig/drivers/mmc/pxamci.c
-+++ gregkh-2.6/drivers/mmc/pxamci.c
-@@ -571,23 +571,23 @@ static int pxamci_remove(struct device *
- }
-
- #ifdef CONFIG_PM
--static int pxamci_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int pxamci_suspend(struct device *dev, pm_message_t state)
- {
- struct mmc_host *mmc = dev_get_drvdata(dev);
- int ret = 0;
-
-- if (mmc && level == SUSPEND_DISABLE)
-+ if (mmc)
- ret = mmc_suspend_host(mmc, state);
-
- return ret;
- }
-
--static int pxamci_resume(struct device *dev, u32 level)
-+static int pxamci_resume(struct device *dev)
- {
- struct mmc_host *mmc = dev_get_drvdata(dev);
- int ret = 0;
-
-- if (mmc && level == RESUME_ENABLE)
-+ if (mmc)
- ret = mmc_resume_host(mmc);
-
- return ret;
---- gregkh-2.6.orig/drivers/mmc/wbsd.c
-+++ gregkh-2.6/drivers/mmc/wbsd.c
-@@ -1955,14 +1955,14 @@ static void __devexit wbsd_pnp_remove(st
- */
-
- #ifdef CONFIG_PM
--static int wbsd_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int wbsd_suspend(struct device *dev, pm_message_t state)
- {
- DBGF("Not yet supported\n");
-
- return 0;
- }
-
--static int wbsd_resume(struct device *dev, u32 level)
-+static int wbsd_resume(struct device *dev)
- {
- DBGF("Not yet supported\n");
-
---- gregkh-2.6.orig/drivers/mtd/maps/sa1100-flash.c
-+++ gregkh-2.6/drivers/mtd/maps/sa1100-flash.c
-@@ -402,21 +402,21 @@ static int __exit sa1100_mtd_remove(stru
- }
-
- #ifdef CONFIG_PM
--static int sa1100_mtd_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int sa1100_mtd_suspend(struct device *dev, pm_message_t state)
- {
- struct sa_info *info = dev_get_drvdata(dev);
- int ret = 0;
-
-- if (info && level == SUSPEND_SAVE_STATE)
-+ if (info)
- ret = info->mtd->suspend(info->mtd);
-
- return ret;
- }
-
--static int sa1100_mtd_resume(struct device *dev, u32 level)
-+static int sa1100_mtd_resume(struct device *dev)
- {
- struct sa_info *info = dev_get_drvdata(dev);
-- if (info && level == RESUME_RESTORE_STATE)
-+ if (info)
- info->mtd->resume(info->mtd);
- return 0;
- }
---- gregkh-2.6.orig/drivers/net/dm9000.c
-+++ gregkh-2.6/drivers/net/dm9000.c
-@@ -1140,11 +1140,11 @@ dm9000_phy_write(struct net_device *dev,
- }
-
- static int
--dm9000_drv_suspend(struct device *dev, pm_message_t state, u32 level)
-+dm9000_drv_suspend(struct device *dev, pm_message_t state)
- {
- struct net_device *ndev = dev_get_drvdata(dev);
-
-- if (ndev && level == SUSPEND_DISABLE) {
-+ if (ndev) {
- if (netif_running(ndev)) {
- netif_device_detach(ndev);
- dm9000_shutdown(ndev);
-@@ -1154,12 +1154,12 @@ dm9000_drv_suspend(struct device *dev, p
- }
-
- static int
--dm9000_drv_resume(struct device *dev, u32 level)
-+dm9000_drv_resume(struct device *dev)
- {
- struct net_device *ndev = dev_get_drvdata(dev);
- board_info_t *db = (board_info_t *) ndev->priv;
-
-- if (ndev && level == RESUME_ENABLE) {
-+ if (ndev) {
-
- if (netif_running(ndev)) {
- dm9000_reset(db);
---- gregkh-2.6.orig/drivers/net/irda/sa1100_ir.c
-+++ gregkh-2.6/drivers/net/irda/sa1100_ir.c
-@@ -291,12 +291,12 @@ static void sa1100_irda_shutdown(struct
- /*
- * Suspend the IrDA interface.
- */
--static int sa1100_irda_suspend(struct device *_dev, pm_message_t state, u32 level)
-+static int sa1100_irda_suspend(struct device *_dev, pm_message_t state)
- {
- struct net_device *dev = dev_get_drvdata(_dev);
- struct sa1100_irda *si;
-
-- if (!dev || level != SUSPEND_DISABLE)
-+ if (!dev)
- return 0;
-
- si = dev->priv;
-@@ -316,12 +316,12 @@ static int sa1100_irda_suspend(struct de
- /*
- * Resume the IrDA interface.
- */
--static int sa1100_irda_resume(struct device *_dev, u32 level)
-+static int sa1100_irda_resume(struct device *_dev)
- {
- struct net_device *dev = dev_get_drvdata(_dev);
- struct sa1100_irda *si;
-
-- if (!dev || level != RESUME_ENABLE)
-+ if (!dev)
- return 0;
-
- si = dev->priv;
---- gregkh-2.6.orig/drivers/net/irda/smsc-ircc2.c
-+++ gregkh-2.6/drivers/net/irda/smsc-ircc2.c
-@@ -213,8 +213,8 @@ static int smsc_ircc_probe_transceiver_
-
- /* Power Management */
-
--static int smsc_ircc_suspend(struct device *dev, pm_message_t state, u32 level);
--static int smsc_ircc_resume(struct device *dev, u32 level);
-+static int smsc_ircc_suspend(struct device *dev, pm_message_t state);
-+static int smsc_ircc_resume(struct device *dev);
-
- static struct device_driver smsc_ircc_driver = {
- .name = SMSC_IRCC2_DRIVER_NAME,
-@@ -1646,13 +1646,13 @@ static int smsc_ircc_net_close(struct ne
- return 0;
- }
-
--static int smsc_ircc_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int smsc_ircc_suspend(struct device *dev, pm_message_t state)
- {
- struct smsc_ircc_cb *self = dev_get_drvdata(dev);
-
- IRDA_MESSAGE("%s, Suspending\n", driver_name);
-
-- if (level == SUSPEND_DISABLE && !self->io.suspended) {
-+ if (!self->io.suspended) {
- smsc_ircc_net_close(self->netdev);
- self->io.suspended = 1;
- }
-@@ -1660,11 +1660,11 @@ static int smsc_ircc_suspend(struct devi
- return 0;
- }
-
--static int smsc_ircc_resume(struct device *dev, u32 level)
-+static int smsc_ircc_resume(struct device *dev)
- {
- struct smsc_ircc_cb *self = dev_get_drvdata(dev);
-
-- if (level == RESUME_ENABLE && self->io.suspended) {
-+ if (self->io.suspended) {
-
- smsc_ircc_net_open(self->netdev);
- self->io.suspended = 0;
---- gregkh-2.6.orig/drivers/net/phy/mdio_bus.c
-+++ gregkh-2.6/drivers/net/phy/mdio_bus.c
-@@ -133,13 +133,9 @@ static int mdio_bus_suspend(struct devic
- int ret = 0;
- struct device_driver *drv = dev->driver;
-
-- if (drv && drv->suspend) {
-- ret = drv->suspend(dev, state, SUSPEND_DISABLE);
-- if (ret == 0)
-- ret = drv->suspend(dev, state, SUSPEND_SAVE_STATE);
-- if (ret == 0)
-- ret = drv->suspend(dev, state, SUSPEND_POWER_DOWN);
-- }
-+ if (drv && drv->suspend)
-+ ret = drv->suspend(dev, state);
-+
- return ret;
- }
-
-@@ -148,13 +144,9 @@ static int mdio_bus_resume(struct device
- int ret = 0;
- struct device_driver *drv = dev->driver;
-
-- if (drv && drv->resume) {
-- ret = drv->resume(dev, RESUME_POWER_ON);
-- if (ret == 0)
-- ret = drv->resume(dev, RESUME_RESTORE_STATE);
-- if (ret == 0)
-- ret = drv->resume(dev, RESUME_ENABLE);
-- }
-+ if (drv && drv->resume)
-+ ret = drv->resume(dev);
-+
- return ret;
- }
-
---- gregkh-2.6.orig/drivers/net/smc91x.c
-+++ gregkh-2.6/drivers/net/smc91x.c
-@@ -2291,11 +2291,11 @@ static int smc_drv_remove(struct device
- return 0;
- }
-
--static int smc_drv_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int smc_drv_suspend(struct device *dev, pm_message_t state)
- {
- struct net_device *ndev = dev_get_drvdata(dev);
-
-- if (ndev && level == SUSPEND_DISABLE) {
-+ if (ndev) {
- if (netif_running(ndev)) {
- netif_device_detach(ndev);
- smc_shutdown(ndev);
-@@ -2305,12 +2305,12 @@ static int smc_drv_suspend(struct device
- return 0;
- }
-
--static int smc_drv_resume(struct device *dev, u32 level)
-+static int smc_drv_resume(struct device *dev)
- {
- struct platform_device *pdev = to_platform_device(dev);
- struct net_device *ndev = dev_get_drvdata(dev);
-
-- if (ndev && level == RESUME_ENABLE) {
-+ if (ndev) {
- struct smc_local *lp = netdev_priv(ndev);
- smc_enable_device(pdev);
- if (netif_running(ndev)) {
---- gregkh-2.6.orig/drivers/pci/pcie/portdrv_core.c
-+++ gregkh-2.6/drivers/pci/pcie/portdrv_core.c
-@@ -61,7 +61,7 @@ static int pcie_port_remove_service(stru
-
- static void pcie_port_shutdown_service(struct device *dev) {}
-
--static int pcie_port_suspend_service(struct device *dev, pm_message_t state, u32 level)
-+static int pcie_port_suspend_service(struct device *dev, pm_message_t state)
- {
- struct pcie_device *pciedev;
- struct pcie_port_service_driver *driver;
-@@ -76,7 +76,7 @@ static int pcie_port_suspend_service(str
- return 0;
- }
-
--static int pcie_port_resume_service(struct device *dev, u32 level)
-+static int pcie_port_resume_service(struct device *dev)
- {
- struct pcie_device *pciedev;
- struct pcie_port_service_driver *driver;
---- gregkh-2.6.orig/drivers/pcmcia/au1000_generic.c
-+++ gregkh-2.6/drivers/pcmcia/au1000_generic.c
-@@ -519,30 +519,13 @@ static int au1x00_drv_pcmcia_probe(struc
- }
-
-
--static int au1x00_drv_pcmcia_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
--
--static int au1x00_drv_pcmcia_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- ret = pcmcia_socket_dev_resume(dev);
-- return ret;
--}
--
--
- static struct device_driver au1x00_pcmcia_driver = {
- .probe = au1x00_drv_pcmcia_probe,
- .remove = au1x00_drv_pcmcia_remove,
- .name = "au1x00-pcmcia",
- .bus = &platform_bus_type,
-- .suspend = au1x00_drv_pcmcia_suspend,
-- .resume = au1x00_drv_pcmcia_resume
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static struct platform_device au1x00_device = {
---- gregkh-2.6.orig/drivers/pcmcia/hd64465_ss.c
-+++ gregkh-2.6/drivers/pcmcia/hd64465_ss.c
-@@ -844,27 +844,11 @@ static void hs_exit_socket(hs_socket_t *
- local_irq_restore(flags);
- }
-
--static int hd64465_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
--
--static int hd64465_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- ret = pcmcia_socket_dev_resume(dev);
-- return ret;
--}
--
- static struct device_driver hd64465_driver = {
- .name = "hd64465-pcmcia",
- .bus = &platform_bus_type,
-- .suspend = hd64465_suspend,
-- .resume = hd64465_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static struct platform_device hd64465_device = {
---- gregkh-2.6.orig/drivers/pcmcia/i82365.c
-+++ gregkh-2.6/drivers/pcmcia/i82365.c
-@@ -1332,27 +1332,11 @@ static struct pccard_operations pcic_ope
-
- /*====================================================================*/
-
--static int i82365_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
--
--static int i82365_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- ret = pcmcia_socket_dev_resume(dev);
-- return ret;
--}
--
- static struct device_driver i82365_driver = {
- .name = "i82365",
- .bus = &platform_bus_type,
-- .suspend = i82365_suspend,
-- .resume = i82365_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static struct platform_device i82365_device = {
---- gregkh-2.6.orig/drivers/pcmcia/m32r_cfc.c
-+++ gregkh-2.6/drivers/pcmcia/m32r_cfc.c
-@@ -731,28 +731,11 @@ static struct pccard_operations pcc_oper
-
- /*====================================================================*/
-
--static int m32r_pcc_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
--
--static int m32r_pcc_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- ret = pcmcia_socket_dev_resume(dev);
-- return ret;
--}
--
--
- static struct device_driver pcc_driver = {
- .name = "cfc",
- .bus = &platform_bus_type,
-- .suspend = m32r_pcc_suspend,
-- .resume = m32r_pcc_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static struct platform_device pcc_device = {
---- gregkh-2.6.orig/drivers/pcmcia/m32r_pcc.c
-+++ gregkh-2.6/drivers/pcmcia/m32r_pcc.c
-@@ -695,28 +695,11 @@ static struct pccard_operations pcc_oper
-
- /*====================================================================*/
-
--static int m32r_pcc_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
--
--static int m32r_pcc_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- ret = pcmcia_socket_dev_resume(dev);
-- return ret;
--}
--
--
- static struct device_driver pcc_driver = {
- .name = "pcc",
- .bus = &platform_bus_type,
-- .suspend = m32r_pcc_suspend,
-- .resume = m32r_pcc_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static struct platform_device pcc_device = {
---- gregkh-2.6.orig/drivers/pcmcia/omap_cf.c
-+++ gregkh-2.6/drivers/pcmcia/omap_cf.c
-@@ -329,27 +329,13 @@ static int __devexit omap_cf_remove(stru
- return 0;
- }
-
--static int omap_cf_suspend(struct device *dev, pm_message_t mesg, u32 level)
--{
-- if (level != SUSPEND_SAVE_STATE)
-- return 0;
-- return pcmcia_socket_dev_suspend(dev, mesg);
--}
--
--static int omap_cf_resume(struct device *dev, u32 level)
--{
-- if (level != RESUME_RESTORE_STATE)
-- return 0;
-- return pcmcia_socket_dev_resume(dev);
--}
--
- static struct device_driver omap_cf_driver = {
- .name = (char *) driver_name,
- .bus = &platform_bus_type,
- .probe = omap_cf_probe,
- .remove = __devexit_p(omap_cf_remove),
-- .suspend = omap_cf_suspend,
-- .resume = omap_cf_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static int __init omap_cf_init(void)
---- gregkh-2.6.orig/drivers/pcmcia/pxa2xx_base.c
-+++ gregkh-2.6/drivers/pcmcia/pxa2xx_base.c
-@@ -205,32 +205,20 @@ int pxa2xx_drv_pcmcia_probe(struct devic
- }
- EXPORT_SYMBOL(pxa2xx_drv_pcmcia_probe);
-
--static int pxa2xx_drv_pcmcia_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int pxa2xx_drv_pcmcia_resume(struct device *dev)
- {
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
-+ struct pcmcia_low_level *ops = dev->platform_data;
-+ int nr = ops ? ops->nr : 0;
-
--static int pxa2xx_drv_pcmcia_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- {
-- struct pcmcia_low_level *ops = dev->platform_data;
-- int nr = ops ? ops->nr : 0;
--
-- MECR = nr > 1 ? MECR_CIT | MECR_NOS : (nr > 0 ? MECR_CIT : 0);
-- ret = pcmcia_socket_dev_resume(dev);
-- }
-- return ret;
-+ MECR = nr > 1 ? MECR_CIT | MECR_NOS : (nr > 0 ? MECR_CIT : 0);
-+
-+ return pcmcia_socket_dev_resume(dev);
- }
-
- static struct device_driver pxa2xx_pcmcia_driver = {
- .probe = pxa2xx_drv_pcmcia_probe,
- .remove = soc_common_drv_pcmcia_remove,
-- .suspend = pxa2xx_drv_pcmcia_suspend,
-+ .suspend = pcmcia_socket_dev_suspend,
- .resume = pxa2xx_drv_pcmcia_resume,
- .name = "pxa2xx-pcmcia",
- .bus = &platform_bus_type,
---- gregkh-2.6.orig/drivers/pcmcia/sa1100_generic.c
-+++ gregkh-2.6/drivers/pcmcia/sa1100_generic.c
-@@ -74,29 +74,13 @@ static int sa11x0_drv_pcmcia_probe(struc
- return ret;
- }
-
--static int sa11x0_drv_pcmcia_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
--
--static int sa11x0_drv_pcmcia_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- ret = pcmcia_socket_dev_resume(dev);
-- return ret;
--}
--
- static struct device_driver sa11x0_pcmcia_driver = {
- .probe = sa11x0_drv_pcmcia_probe,
- .remove = soc_common_drv_pcmcia_remove,
- .name = "sa11x0-pcmcia",
- .bus = &platform_bus_type,
-- .suspend = sa11x0_drv_pcmcia_suspend,
-- .resume = sa11x0_drv_pcmcia_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- /* sa11x0_pcmcia_init()
---- gregkh-2.6.orig/drivers/pcmcia/tcic.c
-+++ gregkh-2.6/drivers/pcmcia/tcic.c
-@@ -372,27 +372,11 @@ static int __init get_tcic_id(void)
-
- /*====================================================================*/
-
--static int tcic_drv_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int ret = 0;
-- if (level == SUSPEND_SAVE_STATE)
-- ret = pcmcia_socket_dev_suspend(dev, state);
-- return ret;
--}
--
--static int tcic_drv_resume(struct device *dev, u32 level)
--{
-- int ret = 0;
-- if (level == RESUME_RESTORE_STATE)
-- ret = pcmcia_socket_dev_resume(dev);
-- return ret;
--}
--
- static struct device_driver tcic_driver = {
- .name = "tcic-pcmcia",
- .bus = &platform_bus_type,
-- .suspend = tcic_drv_suspend,
-- .resume = tcic_drv_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static struct platform_device tcic_device = {
---- gregkh-2.6.orig/drivers/pcmcia/vrc4171_card.c
-+++ gregkh-2.6/drivers/pcmcia/vrc4171_card.c
-@@ -774,31 +774,11 @@ static int __devinit vrc4171_card_setup(
-
- __setup("vrc4171_card=", vrc4171_card_setup);
-
--static int vrc4171_card_suspend(struct device *dev, pm_message_t state, u32 level)
--{
-- int retval = 0;
--
-- if (level == SUSPEND_SAVE_STATE)
-- retval = pcmcia_socket_dev_suspend(dev, state);
--
-- return retval;
--}
--
--static int vrc4171_card_resume(struct device *dev, u32 level)
--{
-- int retval = 0;
--
-- if (level == RESUME_RESTORE_STATE)
-- retval = pcmcia_socket_dev_resume(dev);
--
-- return retval;
--}
--
- static struct device_driver vrc4171_card_driver = {
- .name = vrc4171_card_name,
- .bus = &platform_bus_type,
-- .suspend = vrc4171_card_suspend,
-- .resume = vrc4171_card_resume,
-+ .suspend = pcmcia_socket_dev_suspend,
-+ .resume = pcmcia_socket_dev_resume,
- };
-
- static int __devinit vrc4171_card_init(void)
---- gregkh-2.6.orig/drivers/serial/8250.c
-+++ gregkh-2.6/drivers/serial/8250.c
-@@ -2358,13 +2358,10 @@ static int __devexit serial8250_remove(s
- return 0;
- }
-
--static int serial8250_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int serial8250_suspend(struct device *dev, pm_message_t state)
- {
- int i;
-
-- if (level != SUSPEND_DISABLE)
-- return 0;
--
- for (i = 0; i < UART_NR; i++) {
- struct uart_8250_port *up = &serial8250_ports[i];
-
-@@ -2375,13 +2372,10 @@ static int serial8250_suspend(struct dev
- return 0;
- }
-
--static int serial8250_resume(struct device *dev, u32 level)
-+static int serial8250_resume(struct device *dev)
- {
- int i;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- for (i = 0; i < UART_NR; i++) {
- struct uart_8250_port *up = &serial8250_ports[i];
-
---- gregkh-2.6.orig/drivers/serial/imx.c
-+++ gregkh-2.6/drivers/serial/imx.c
-@@ -921,21 +921,21 @@ static struct uart_driver imx_reg = {
- .cons = IMX_CONSOLE,
- };
-
--static int serial_imx_suspend(struct device *_dev, pm_message_t state, u32 level)
-+static int serial_imx_suspend(struct device *_dev, pm_message_t state)
- {
- struct imx_port *sport = dev_get_drvdata(_dev);
-
-- if (sport && level == SUSPEND_DISABLE)
-+ if (sport)
- uart_suspend_port(&imx_reg, &sport->port);
-
- return 0;
- }
-
--static int serial_imx_resume(struct device *_dev, u32 level)
-+static int serial_imx_resume(struct device *_dev)
- {
- struct imx_port *sport = dev_get_drvdata(_dev);
-
-- if (sport && level == RESUME_ENABLE)
-+ if (sport)
- uart_resume_port(&imx_reg, &sport->port);
-
- return 0;
---- gregkh-2.6.orig/drivers/serial/mpc52xx_uart.c
-+++ gregkh-2.6/drivers/serial/mpc52xx_uart.c
-@@ -781,22 +781,22 @@ mpc52xx_uart_remove(struct device *dev)
-
- #ifdef CONFIG_PM
- static int
--mpc52xx_uart_suspend(struct device *dev, pm_message_t state, u32 level)
-+mpc52xx_uart_suspend(struct device *dev, pm_message_t state)
- {
- struct uart_port *port = (struct uart_port *) dev_get_drvdata(dev);
-
-- if (sport && level == SUSPEND_DISABLE)
-+ if (sport)
- uart_suspend_port(&mpc52xx_uart_driver, port);
-
- return 0;
- }
-
- static int
--mpc52xx_uart_resume(struct device *dev, u32 level)
-+mpc52xx_uart_resume(struct device *dev)
- {
- struct uart_port *port = (struct uart_port *) dev_get_drvdata(dev);
-
-- if (port && level == RESUME_ENABLE)
-+ if (port)
- uart_resume_port(&mpc52xx_uart_driver, port);
-
- return 0;
---- gregkh-2.6.orig/drivers/serial/pxa.c
-+++ gregkh-2.6/drivers/serial/pxa.c
-@@ -786,21 +786,21 @@ static struct uart_driver serial_pxa_reg
- .cons = PXA_CONSOLE,
- };
-
--static int serial_pxa_suspend(struct device *_dev, pm_message_t state, u32 level)
-+static int serial_pxa_suspend(struct device *_dev, pm_message_t state)
- {
- struct uart_pxa_port *sport = dev_get_drvdata(_dev);
-
-- if (sport && level == SUSPEND_DISABLE)
-+ if (sport)
- uart_suspend_port(&serial_pxa_reg, &sport->port);
-
- return 0;
- }
-
--static int serial_pxa_resume(struct device *_dev, u32 level)
-+static int serial_pxa_resume(struct device *_dev)
- {
- struct uart_pxa_port *sport = dev_get_drvdata(_dev);
-
-- if (sport && level == RESUME_ENABLE)
-+ if (sport)
- uart_resume_port(&serial_pxa_reg, &sport->port);
-
- return 0;
---- gregkh-2.6.orig/drivers/serial/s3c2410.c
-+++ gregkh-2.6/drivers/serial/s3c2410.c
-@@ -1134,23 +1134,22 @@ static int s3c24xx_serial_remove(struct
-
- #ifdef CONFIG_PM
-
--static int s3c24xx_serial_suspend(struct device *dev, pm_message_t state,
-- u32 level)
-+static int s3c24xx_serial_suspend(struct device *dev, pm_message_t state)
- {
- struct uart_port *port = s3c24xx_dev_to_port(dev);
-
-- if (port && level == SUSPEND_DISABLE)
-+ if (port)
- uart_suspend_port(&s3c24xx_uart_drv, port);
-
- return 0;
- }
-
--static int s3c24xx_serial_resume(struct device *dev, u32 level)
-+static int s3c24xx_serial_resume(struct device *dev)
- {
- struct uart_port *port = s3c24xx_dev_to_port(dev);
- struct s3c24xx_uart_port *ourport = to_ourport(port);
-
-- if (port && level == RESUME_ENABLE) {
-+ if (port) {
- clk_enable(ourport->clk);
- s3c24xx_serial_resetport(port, s3c24xx_port_to_cfg(port));
- clk_disable(ourport->clk);
---- gregkh-2.6.orig/drivers/serial/sa1100.c
-+++ gregkh-2.6/drivers/serial/sa1100.c
-@@ -834,21 +834,21 @@ static struct uart_driver sa1100_reg = {
- .cons = SA1100_CONSOLE,
- };
-
--static int sa1100_serial_suspend(struct device *_dev, pm_message_t state, u32 level)
-+static int sa1100_serial_suspend(struct device *_dev, pm_message_t state)
- {
- struct sa1100_port *sport = dev_get_drvdata(_dev);
-
-- if (sport && level == SUSPEND_DISABLE)
-+ if (sport)
- uart_suspend_port(&sa1100_reg, &sport->port);
-
- return 0;
- }
-
--static int sa1100_serial_resume(struct device *_dev, u32 level)
-+static int sa1100_serial_resume(struct device *_dev)
- {
- struct sa1100_port *sport = dev_get_drvdata(_dev);
-
-- if (sport && level == RESUME_ENABLE)
-+ if (sport)
- uart_resume_port(&sa1100_reg, &sport->port);
-
- return 0;
---- gregkh-2.6.orig/drivers/serial/vr41xx_siu.c
-+++ gregkh-2.6/drivers/serial/vr41xx_siu.c
-@@ -976,14 +976,11 @@ static int siu_remove(struct device *dev
- return 0;
- }
-
--static int siu_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int siu_suspend(struct device *dev, pm_message_t state)
- {
- struct uart_port *port;
- int i;
-
-- if (level != SUSPEND_DISABLE)
-- return 0;
--
- for (i = 0; i < siu_uart_driver.nr; i++) {
- port = &siu_uart_ports[i];
- if ((port->type == PORT_VR41XX_SIU ||
-@@ -995,14 +992,11 @@ static int siu_suspend(struct device *de
- return 0;
- }
-
--static int siu_resume(struct device *dev, u32 level)
-+static int siu_resume(struct device *dev)
- {
- struct uart_port *port;
- int i;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- for (i = 0; i < siu_uart_driver.nr; i++) {
- port = &siu_uart_ports[i];
- if ((port->type == PORT_VR41XX_SIU ||
---- gregkh-2.6.orig/drivers/usb/gadget/dummy_hcd.c
-+++ gregkh-2.6/drivers/usb/gadget/dummy_hcd.c
-@@ -935,14 +935,10 @@ static int dummy_udc_remove (struct devi
- return 0;
- }
-
--static int dummy_udc_suspend (struct device *dev, pm_message_t state,
-- u32 level)
-+static int dummy_udc_suspend (struct device *dev, pm_message_t state)
- {
- struct dummy *dum = dev_get_drvdata(dev);
-
-- if (level != SUSPEND_DISABLE)
-- return 0;
--
- dev_dbg (dev, "%s\n", __FUNCTION__);
- spin_lock_irq (&dum->lock);
- dum->udc_suspended = 1;
-@@ -954,13 +950,10 @@ static int dummy_udc_suspend (struct dev
- return 0;
- }
-
--static int dummy_udc_resume (struct device *dev, u32 level)
-+static int dummy_udc_resume (struct device *dev)
- {
- struct dummy *dum = dev_get_drvdata(dev);
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- dev_dbg (dev, "%s\n", __FUNCTION__);
- spin_lock_irq (&dum->lock);
- dum->udc_suspended = 0;
-@@ -1936,14 +1929,10 @@ static int dummy_hcd_remove (struct devi
- return 0;
- }
-
--static int dummy_hcd_suspend (struct device *dev, pm_message_t state,
-- u32 level)
-+static int dummy_hcd_suspend (struct device *dev, pm_message_t state)
- {
- struct usb_hcd *hcd;
-
-- if (level != SUSPEND_DISABLE)
-- return 0;
--
- dev_dbg (dev, "%s\n", __FUNCTION__);
- hcd = dev_get_drvdata (dev);
-
-@@ -1958,13 +1947,10 @@ static int dummy_hcd_suspend (struct dev
- return 0;
- }
-
--static int dummy_hcd_resume (struct device *dev, u32 level)
-+static int dummy_hcd_resume (struct device *dev)
- {
- struct usb_hcd *hcd;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- dev_dbg (dev, "%s\n", __FUNCTION__);
- hcd = dev_get_drvdata (dev);
- hcd->state = HC_STATE_RUNNING;
---- gregkh-2.6.orig/drivers/usb/gadget/omap_udc.c
-+++ gregkh-2.6/drivers/usb/gadget/omap_udc.c
-@@ -2909,12 +2909,10 @@ static int __exit omap_udc_remove(struct
- * may involve talking to an external transceiver (e.g. isp1301).
- */
-
--static int omap_udc_suspend(struct device *dev, pm_message_t message, u32 level)
-+static int omap_udc_suspend(struct device *dev, pm_message_t message)
- {
- u32 devstat;
-
-- if (level != SUSPEND_POWER_DOWN)
-- return 0;
- devstat = UDC_DEVSTAT_REG;
-
- /* we're requesting 48 MHz clock if the pullup is enabled
-@@ -2931,11 +2929,8 @@ static int omap_udc_suspend(struct devic
- return 0;
- }
-
--static int omap_udc_resume(struct device *dev, u32 level)
-+static int omap_udc_resume(struct device *dev)
- {
-- if (level != RESUME_POWER_ON)
-- return 0;
--
- DBG("resume + wakeup/SRP\n");
- omap_pullup(&udc->gadget, 1);
-
---- gregkh-2.6.orig/drivers/usb/gadget/pxa2xx_udc.c
-+++ gregkh-2.6/drivers/usb/gadget/pxa2xx_udc.c
-@@ -2602,24 +2602,23 @@ static int __exit pxa2xx_udc_remove(stru
- * VBUS IRQs should probably be ignored so that the PXA device just acts
- * "dead" to USB hosts until system resume.
- */
--static int pxa2xx_udc_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int pxa2xx_udc_suspend(struct device *dev, pm_message_t state)
- {
- struct pxa2xx_udc *udc = dev_get_drvdata(dev);
-
-- if (level == SUSPEND_POWER_DOWN) {
-- if (!udc->mach->udc_command)
-- WARN("USB host won't detect disconnect!\n");
-- pullup(udc, 0);
-- }
-+ if (!udc->mach->udc_command)
-+ WARN("USB host won't detect disconnect!\n");
-+ pullup(udc, 0);
-+
- return 0;
- }
-
--static int pxa2xx_udc_resume(struct device *dev, u32 level)
-+static int pxa2xx_udc_resume(struct device *dev)
- {
- struct pxa2xx_udc *udc = dev_get_drvdata(dev);
-
-- if (level == RESUME_POWER_ON)
-- pullup(udc, 1);
-+ pullup(udc, 1);
-+
- return 0;
- }
-
---- gregkh-2.6.orig/drivers/usb/host/isp116x-hcd.c
-+++ gregkh-2.6/drivers/usb/host/isp116x-hcd.c
-@@ -1774,15 +1774,12 @@ static int __init isp116x_probe(struct d
- /*
- Suspend of platform device
- */
--static int isp116x_suspend(struct device *dev, pm_message_t state, u32 phase)
-+static int isp116x_suspend(struct device *dev, pm_message_t state)
- {
- int ret = 0;
- struct usb_hcd *hcd = dev_get_drvdata(dev);
-
-- VDBG("%s: state %x, phase %x\n", __func__, state, phase);
--
-- if (phase != SUSPEND_DISABLE && phase != SUSPEND_POWER_DOWN)
-- return 0;
-+ VDBG("%s: state %x\n", __func__, state);
-
- ret = usb_suspend_device(hcd->self.root_hub, state);
- if (!ret) {
-@@ -1797,15 +1794,12 @@ static int isp116x_suspend(struct device
- /*
- Resume platform device
- */
--static int isp116x_resume(struct device *dev, u32 phase)
-+static int isp116x_resume(struct device *dev)
- {
- int ret = 0;
- struct usb_hcd *hcd = dev_get_drvdata(dev);
-
-- VDBG("%s: state %x, phase %x\n", __func__, dev->power.power_state,
-- phase);
-- if (phase != RESUME_POWER_ON)
-- return 0;
-+ VDBG("%s: state %x\n", __func__, dev->power.power_state);
-
- ret = usb_resume_device(hcd->self.root_hub);
- if (!ret) {
---- gregkh-2.6.orig/drivers/usb/host/ohci-omap.c
-+++ gregkh-2.6/drivers/usb/host/ohci-omap.c
-@@ -455,14 +455,11 @@ static int ohci_hcd_omap_drv_remove(stru
-
- #ifdef CONFIG_PM
-
--static int ohci_omap_suspend(struct device *dev, pm_message_t message, u32 level)
-+static int ohci_omap_suspend(struct device *dev, pm_message_t message)
- {
- struct ohci_hcd *ohci = hcd_to_ohci(dev_get_drvdata(dev));
- int status = -EINVAL;
-
-- if (level != SUSPEND_POWER_DOWN)
-- return 0;
--
- down(&ohci_to_hcd(ohci)->self.root_hub->serialize);
- status = ohci_hub_suspend(ohci_to_hcd(ohci));
- if (status == 0) {
-@@ -476,14 +473,11 @@ static int ohci_omap_suspend(struct devi
- return status;
- }
-
--static int ohci_omap_resume(struct device *dev, u32 level)
-+static int ohci_omap_resume(struct device *dev)
- {
- struct ohci_hcd *ohci = hcd_to_ohci(dev_get_drvdata(dev));
- int status = 0;
-
-- if (level != RESUME_POWER_ON)
-- return 0;
--
- if (time_before(jiffies, ohci->next_statechange))
- msleep(5);
- ohci->next_statechange = jiffies;
---- gregkh-2.6.orig/drivers/usb/host/ohci-pxa27x.c
-+++ gregkh-2.6/drivers/usb/host/ohci-pxa27x.c
-@@ -309,7 +309,7 @@ static int ohci_hcd_pxa27x_drv_remove(st
- return 0;
- }
-
--static int ohci_hcd_pxa27x_drv_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int ohci_hcd_pxa27x_drv_suspend(struct device *dev, pm_message_t state)
- {
- // struct platform_device *pdev = to_platform_device(dev);
- // struct usb_hcd *hcd = dev_get_drvdata(dev);
-@@ -318,7 +318,7 @@ static int ohci_hcd_pxa27x_drv_suspend(s
- return 0;
- }
-
--static int ohci_hcd_pxa27x_drv_resume(struct device *dev, u32 level)
-+static int ohci_hcd_pxa27x_drv_resume(struct device *dev)
- {
- // struct platform_device *pdev = to_platform_device(dev);
- // struct usb_hcd *hcd = dev_get_drvdata(dev);
---- gregkh-2.6.orig/drivers/usb/host/sl811-hcd.c
-+++ gregkh-2.6/drivers/usb/host/sl811-hcd.c
-@@ -1784,15 +1784,12 @@ sl811h_probe(struct device *dev)
- */
-
- static int
--sl811h_suspend(struct device *dev, pm_message_t state, u32 phase)
-+sl811h_suspend(struct device *dev, pm_message_t state)
- {
- struct usb_hcd *hcd = dev_get_drvdata(dev);
- struct sl811 *sl811 = hcd_to_sl811(hcd);
- int retval = 0;
-
-- if (phase != SUSPEND_POWER_DOWN)
-- return retval;
--
- if (state.event == PM_EVENT_FREEZE)
- retval = sl811h_hub_suspend(hcd);
- else if (state.event == PM_EVENT_SUSPEND)
-@@ -1803,14 +1800,11 @@ sl811h_suspend(struct device *dev, pm_me
- }
-
- static int
--sl811h_resume(struct device *dev, u32 phase)
-+sl811h_resume(struct device *dev)
- {
- struct usb_hcd *hcd = dev_get_drvdata(dev);
- struct sl811 *sl811 = hcd_to_sl811(hcd);
-
-- if (phase != RESUME_POWER_ON)
-- return 0;
--
- /* with no "check to see if VBUS is still powered" board hook,
- * let's assume it'd only be powered to enable remote wakeup.
- */
---- gregkh-2.6.orig/drivers/video/backlight/corgi_bl.c
-+++ gregkh-2.6/drivers/video/backlight/corgi_bl.c
-@@ -73,17 +73,15 @@ static void corgibl_blank(int blank)
- }
-
- #ifdef CONFIG_PM
--static int corgibl_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int corgibl_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN)
-- corgibl_blank(FB_BLANK_POWERDOWN);
-+ corgibl_blank(FB_BLANK_POWERDOWN);
- return 0;
- }
-
--static int corgibl_resume(struct device *dev, u32 level)
-+static int corgibl_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON)
-- corgibl_blank(FB_BLANK_UNBLANK);
-+ corgibl_blank(FB_BLANK_UNBLANK);
- return 0;
- }
- #else
---- gregkh-2.6.orig/drivers/video/imxfb.c
-+++ gregkh-2.6/drivers/video/imxfb.c
-@@ -424,23 +424,21 @@ static void imxfb_setup_gpio(struct imxf
- * Power management hooks. Note that we won't be called from IRQ context,
- * unlike the blank functions above, so we may sleep.
- */
--static int imxfb_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int imxfb_suspend(struct device *dev, pm_message_t state)
- {
- struct imxfb_info *fbi = dev_get_drvdata(dev);
- pr_debug("%s\n",__FUNCTION__);
-
-- if (level == SUSPEND_DISABLE || level == SUSPEND_POWER_DOWN)
-- imxfb_disable_controller(fbi);
-+ imxfb_disable_controller(fbi);
- return 0;
- }
-
--static int imxfb_resume(struct device *dev, u32 level)
-+static int imxfb_resume(struct device *dev)
- {
- struct imxfb_info *fbi = dev_get_drvdata(dev);
- pr_debug("%s\n",__FUNCTION__);
-
-- if (level == RESUME_ENABLE)
-- imxfb_enable_controller(fbi);
-+ imxfb_enable_controller(fbi);
- return 0;
- }
- #else
---- gregkh-2.6.orig/drivers/video/pxafb.c
-+++ gregkh-2.6/drivers/video/pxafb.c
-@@ -981,21 +981,19 @@ pxafb_freq_policy(struct notifier_block
- * Power management hooks. Note that we won't be called from IRQ context,
- * unlike the blank functions above, so we may sleep.
- */
--static int pxafb_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int pxafb_suspend(struct device *dev, pm_message_t state)
- {
- struct pxafb_info *fbi = dev_get_drvdata(dev);
-
-- if (level == SUSPEND_DISABLE || level == SUSPEND_POWER_DOWN)
-- set_ctrlr_state(fbi, C_DISABLE_PM);
-+ set_ctrlr_state(fbi, C_DISABLE_PM);
- return 0;
- }
-
--static int pxafb_resume(struct device *dev, u32 level)
-+static int pxafb_resume(struct device *dev)
- {
- struct pxafb_info *fbi = dev_get_drvdata(dev);
-
-- if (level == RESUME_ENABLE)
-- set_ctrlr_state(fbi, C_ENABLE_PM);
-+ set_ctrlr_state(fbi, C_ENABLE_PM);
- return 0;
- }
- #else
---- gregkh-2.6.orig/drivers/video/s1d13xxxfb.c
-+++ gregkh-2.6/drivers/video/s1d13xxxfb.c
-@@ -655,7 +655,7 @@ bail:
- }
-
- #ifdef CONFIG_PM
--static int s1d13xxxfb_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int s1d13xxxfb_suspend(struct device *dev, pm_message_t state)
- {
- struct fb_info *info = dev_get_drvdata(dev);
- struct s1d13xxxfb_par *s1dfb = info->par;
-@@ -702,15 +702,12 @@ static int s1d13xxxfb_suspend(struct dev
- return 0;
- }
-
--static int s1d13xxxfb_resume(struct device *dev, u32 level)
-+static int s1d13xxxfb_resume(struct device *dev)
- {
- struct fb_info *info = dev_get_drvdata(dev);
- struct s1d13xxxfb_par *s1dfb = info->par;
- struct s1d13xxxfb_pdata *pdata = NULL;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- /* awaken the chip */
- s1d13xxxfb_writereg(s1dfb, S1DREG_PS_CNF, 0x10);
-
---- gregkh-2.6.orig/drivers/video/s3c2410fb.c
-+++ gregkh-2.6/drivers/video/s3c2410fb.c
-@@ -847,37 +847,32 @@ static int s3c2410fb_remove(struct devic
-
- /* suspend and resume support for the lcd controller */
-
--static int s3c2410fb_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int s3c2410fb_suspend(struct device *dev, pm_message_t state)
- {
- struct fb_info *fbinfo = dev_get_drvdata(dev);
- struct s3c2410fb_info *info = fbinfo->par;
-
-- if (level == SUSPEND_DISABLE || level == SUSPEND_POWER_DOWN) {
-- s3c2410fb_stop_lcd();
-+ s3c2410fb_stop_lcd();
-
-- /* sleep before disabling the clock, we need to ensure
-- * the LCD DMA engine is not going to get back on the bus
-- * before the clock goes off again (bjd) */
--
-- msleep(1);
-- clk_disable(info->clk);
-- }
-+ /* sleep before disabling the clock, we need to ensure
-+ * the LCD DMA engine is not going to get back on the bus
-+ * before the clock goes off again (bjd) */
-+
-+ msleep(1);
-+ clk_disable(info->clk);
-
- return 0;
- }
-
--static int s3c2410fb_resume(struct device *dev, u32 level)
-+static int s3c2410fb_resume(struct device *dev)
- {
- struct fb_info *fbinfo = dev_get_drvdata(dev);
- struct s3c2410fb_info *info = fbinfo->par;
-
-- if (level == RESUME_ENABLE) {
-- clk_enable(info->clk);
-- msleep(1);
--
-- s3c2410fb_init_registers(info);
-+ clk_enable(info->clk);
-+ msleep(1);
-
-- }
-+ s3c2410fb_init_registers(info);
-
- return 0;
- }
---- gregkh-2.6.orig/drivers/video/sa1100fb.c
-+++ gregkh-2.6/drivers/video/sa1100fb.c
-@@ -1309,21 +1309,19 @@ sa1100fb_freq_policy(struct notifier_blo
- * Power management hooks. Note that we won't be called from IRQ context,
- * unlike the blank functions above, so we may sleep.
- */
--static int sa1100fb_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int sa1100fb_suspend(struct device *dev, pm_message_t state)
- {
- struct sa1100fb_info *fbi = dev_get_drvdata(dev);
-
-- if (level == SUSPEND_DISABLE || level == SUSPEND_POWER_DOWN)
-- set_ctrlr_state(fbi, C_DISABLE_PM);
-+ set_ctrlr_state(fbi, C_DISABLE_PM);
- return 0;
- }
-
--static int sa1100fb_resume(struct device *dev, u32 level)
-+static int sa1100fb_resume(struct device *dev)
- {
- struct sa1100fb_info *fbi = dev_get_drvdata(dev);
-
-- if (level == RESUME_ENABLE)
-- set_ctrlr_state(fbi, C_ENABLE_PM);
-+ set_ctrlr_state(fbi, C_ENABLE_PM);
- return 0;
- }
- #else
---- gregkh-2.6.orig/drivers/video/w100fb.c
-+++ gregkh-2.6/drivers/video/w100fb.c
-@@ -438,36 +438,34 @@ static void w100fb_restore_vidmem(struct
- }
- }
-
--static int w100fb_suspend(struct device *dev, pm_message_t state, uint32_t level)
-+static int w100fb_suspend(struct device *dev, pm_message_t state)
- {
-- if (level == SUSPEND_POWER_DOWN) {
-- struct fb_info *info = dev_get_drvdata(dev);
-- struct w100fb_par *par=info->par;
-- struct w100_tg_info *tg = par->mach->tg;
--
-- w100fb_save_vidmem(par);
-- if(tg && tg->suspend)
-- tg->suspend(par);
-- w100_suspend(W100_SUSPEND_ALL);
-- par->blanked = 1;
-- }
-+ struct fb_info *info = dev_get_drvdata(dev);
-+ struct w100fb_par *par=info->par;
-+ struct w100_tg_info *tg = par->mach->tg;
-+
-+ w100fb_save_vidmem(par);
-+ if(tg && tg->suspend)
-+ tg->suspend(par);
-+ w100_suspend(W100_SUSPEND_ALL);
-+ par->blanked = 1;
-+
- return 0;
- }
-
--static int w100fb_resume(struct device *dev, uint32_t level)
-+static int w100fb_resume(struct device *dev)
- {
-- if (level == RESUME_POWER_ON) {
-- struct fb_info *info = dev_get_drvdata(dev);
-- struct w100fb_par *par=info->par;
-- struct w100_tg_info *tg = par->mach->tg;
--
-- w100_hw_init(par);
-- w100fb_activate_var(par);
-- w100fb_restore_vidmem(par);
-- if(tg && tg->resume)
-- tg->resume(par);
-- par->blanked = 0;
-- }
-+ struct fb_info *info = dev_get_drvdata(dev);
-+ struct w100fb_par *par=info->par;
-+ struct w100_tg_info *tg = par->mach->tg;
-+
-+ w100_hw_init(par);
-+ w100fb_activate_var(par);
-+ w100fb_restore_vidmem(par);
-+ if(tg && tg->resume)
-+ tg->resume(par);
-+ par->blanked = 0;
-+
- return 0;
- }
- #else
---- gregkh-2.6.orig/include/linux/device.h
-+++ gregkh-2.6/include/linux/device.h
-@@ -28,19 +28,6 @@
- #define BUS_ID_SIZE KOBJ_NAME_LEN
-
-
--enum {
-- SUSPEND_NOTIFY,
-- SUSPEND_SAVE_STATE,
-- SUSPEND_DISABLE,
-- SUSPEND_POWER_DOWN,
--};
--
--enum {
-- RESUME_POWER_ON,
-- RESUME_RESTORE_STATE,
-- RESUME_ENABLE,
--};
--
- struct device;
- struct device_driver;
- struct class;
-@@ -115,8 +102,8 @@ struct device_driver {
- int (*probe) (struct device * dev);
- int (*remove) (struct device * dev);
- void (*shutdown) (struct device * dev);
-- int (*suspend) (struct device * dev, pm_message_t state, u32 level);
-- int (*resume) (struct device * dev, u32 level);
-+ int (*suspend) (struct device * dev, pm_message_t state);
-+ int (*resume) (struct device * dev);
- };
-
-
---- gregkh-2.6.orig/sound/arm/pxa2xx-ac97.c
-+++ gregkh-2.6/sound/arm/pxa2xx-ac97.c
-@@ -275,23 +275,23 @@ static int pxa2xx_ac97_do_resume(snd_car
- return 0;
- }
-
--static int pxa2xx_ac97_suspend(struct device *_dev, pm_message_t state, u32 level)
-+static int pxa2xx_ac97_suspend(struct device *_dev, pm_message_t state)
- {
- snd_card_t *card = dev_get_drvdata(_dev);
- int ret = 0;
-
-- if (card && level == SUSPEND_DISABLE)
-+ if (card)
- ret = pxa2xx_ac97_do_suspend(card, PMSG_SUSPEND);
-
- return ret;
- }
-
--static int pxa2xx_ac97_resume(struct device *_dev, u32 level)
-+static int pxa2xx_ac97_resume(struct device *_dev)
- {
- snd_card_t *card = dev_get_drvdata(_dev);
- int ret = 0;
-
-- if (card && level == RESUME_ENABLE)
-+ if (card)
- ret = pxa2xx_ac97_do_resume(card);
-
- return ret;
---- gregkh-2.6.orig/sound/core/init.c
-+++ gregkh-2.6/sound/core/init.c
-@@ -676,8 +676,8 @@ struct snd_generic_device {
- #define SND_GENERIC_NAME "snd_generic"
-
- #ifdef CONFIG_PM
--static int snd_generic_suspend(struct device *dev, pm_message_t state, u32 level);
--static int snd_generic_resume(struct device *dev, u32 level);
-+static int snd_generic_suspend(struct device *dev, pm_message_t state);
-+static int snd_generic_resume(struct device *dev);
- #endif
-
- /* initialized in sound.c */
-@@ -818,13 +818,10 @@ int snd_card_set_pm_callback(snd_card_t
-
- #ifdef CONFIG_SND_GENERIC_DRIVER
- /* suspend/resume callbacks for snd_generic platform device */
--static int snd_generic_suspend(struct device *dev, pm_message_t state, u32 level)
-+static int snd_generic_suspend(struct device *dev, pm_message_t state)
- {
- snd_card_t *card;
-
-- if (level != SUSPEND_DISABLE)
-- return 0;
--
- card = get_snd_generic_card(dev);
- if (card->power_state == SNDRV_CTL_POWER_D3hot)
- return 0;
-@@ -834,13 +831,10 @@ static int snd_generic_suspend(struct de
- return 0;
- }
-
--static int snd_generic_resume(struct device *dev, u32 level)
-+static int snd_generic_resume(struct device *dev)
- {
- snd_card_t *card;
-
-- if (level != RESUME_ENABLE)
-- return 0;
--
- card = get_snd_generic_card(dev);
- if (card->power_state == SNDRV_CTL_POWER_D0)
- return 0;
---- gregkh-2.6.orig/sound/pci/ac97/ac97_bus.c
-+++ gregkh-2.6/sound/pci/ac97/ac97_bus.c
-@@ -31,7 +31,8 @@ static int ac97_bus_suspend(struct devic
- int ret = 0;
-
- if (dev->driver && dev->driver->suspend)
-- ret = dev->driver->suspend(dev, state, SUSPEND_POWER_DOWN);
-+ ret = dev->driver->suspend(dev, state);
-+
- return ret;
- }
-
-@@ -40,7 +41,8 @@ static int ac97_bus_resume(struct device
- int ret = 0;
-
- if (dev->driver && dev->driver->resume)
-- ret = dev->driver->resume(dev, RESUME_POWER_ON);
-+ ret = dev->driver->resume(dev);
-+
- return ret;
- }
-
diff --git a/driver/driver-model-wakeup-01.patch b/driver/driver-model-wakeup-01.patch
deleted file mode 100644
index 03b199c4286bc..0000000000000
--- a/driver/driver-model-wakeup-01.patch
+++ /dev/null
@@ -1,176 +0,0 @@
-From linux-pm-bounces@lists.osdl.org Mon Sep 12 21:30:24 2005
-From: David Brownell <david-b@pacbell.net>
-Date: Mon, 12 Sep 2005 19:39:34 -0700
-Message-Id: <200509121939.35026.david-b@pacbell.net>
-Subject: [linux-pm] [patch 1/3] driver model wakeup flags
-
-
-This is a refresh of an earlier patch to add "wakeup" support to the
-PM core model. This provides per-device bus-neutral control of the
-use of wakeup events.
-
- * "struct device_pm_info" has two bits that are initialized as
- part of setting up the enclosing struct device:
- - "can_wakeup", reflecting hardware capabilities
- - "may_wakeup", the policy setting (when CONFIG_PM)
-
- * There's a writeable sysfs "wakeup" file, with one of two values:
- - "enabled", when the policy is to allow wakeup
- - "disabled", when the policy is not to allow it
- - "" if the device can't currently issue wakeups
-
-By default, wakeup is enabled on all devices that support it. If its
-driver doesn't support it ... treat it as a bug. :)
-
-Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/base/core.c | 1
- drivers/base/power/sysfs.c | 73 +++++++++++++++++++++++++++++++++++++++++++++
- include/linux/pm.h | 26 +++++++++++++++-
- 3 files changed, 99 insertions(+), 1 deletion(-)
-
---- gregkh-2.6.orig/include/linux/pm.h
-+++ gregkh-2.6/include/linux/pm.h
-@@ -219,7 +219,9 @@ typedef struct pm_message {
-
- struct dev_pm_info {
- pm_message_t power_state;
-+ unsigned can_wakeup:1;
- #ifdef CONFIG_PM
-+ unsigned should_wakeup:1;
- pm_message_t prev_state;
- void * saved_state;
- atomic_t pm_users;
-@@ -236,13 +238,35 @@ extern void device_resume(void);
-
- #ifdef CONFIG_PM
- extern int device_suspend(pm_message_t state);
--#else
-+
-+#define device_set_wakeup_enable(dev,val) \
-+ ((dev)->power.should_wakeup = !!(val))
-+#define device_may_wakeup(dev) \
-+ (device_can_wakeup(dev) && (dev)->power.should_wakeup)
-+
-+#else /* !CONFIG_PM */
-+
- static inline int device_suspend(pm_message_t state)
- {
- return 0;
- }
-+
-+#define device_set_wakeup_enable(dev,val) do{}while(0)
-+#define device_may_wakeup(dev) (0)
-+
- #endif
-
-+/* changes to device_may_wakeup take effect on the next pm state change.
-+ * by default, devices should wakeup if they can.
-+ */
-+#define device_can_wakeup(dev) \
-+ ((dev)->power.can_wakeup)
-+#define device_init_wakeup(dev,val) \
-+ do { \
-+ device_can_wakeup(dev) = !!(val); \
-+ device_set_wakeup_enable(dev,val); \
-+ } while(0)
-+
- #endif /* __KERNEL__ */
-
- #endif /* _LINUX_PM_H */
---- gregkh-2.6.orig/drivers/base/core.c
-+++ gregkh-2.6/drivers/base/core.c
-@@ -225,6 +225,7 @@ void device_initialize(struct device *de
- klist_children_put);
- INIT_LIST_HEAD(&dev->dma_pools);
- init_MUTEX(&dev->sem);
-+ device_init_wakeup(dev, 0);
- }
-
- /**
---- gregkh-2.6.orig/drivers/base/power/sysfs.c
-+++ gregkh-2.6/drivers/base/power/sysfs.c
-@@ -48,8 +48,81 @@ static ssize_t state_store(struct device
- static DEVICE_ATTR(state, 0644, state_show, state_store);
-
-
-+/*
-+ * wakeup - Report/change current wakeup option for device
-+ *
-+ * Some devices support "wakeup" events, which are hardware signals
-+ * used to activate devices from suspended or low power states. Such
-+ * devices have one of three values for the sysfs power/wakeup file:
-+ *
-+ * + "enabled\n" to issue the events;
-+ * + "disabled\n" not to do so; or
-+ * + "\n" for temporary or permanent inability to issue wakeup.
-+ *
-+ * (For example, unconfigured USB devices can't issue wakeups.)
-+ *
-+ * Familiar examples of devices that can issue wakeup events include
-+ * keyboards and mice (both PS2 and USB styles), power buttons, modems,
-+ * "Wake-On-LAN" Ethernet links, GPIO lines, and more. Some events
-+ * will wake the entire system from a suspend state; others may just
-+ * wake up the device (if the system as a whole is already active).
-+ * Some wakeup events use normal IRQ lines; other use special out
-+ * of band signaling.
-+ *
-+ * It is the responsibility of device drivers to enable (or disable)
-+ * wakeup signaling as part of changing device power states, respecting
-+ * the policy choices provided through the driver model.
-+ *
-+ * Devices may not be able to generate wakeup events from all power
-+ * states. Also, the events may be ignored in some configurations;
-+ * for example, they might need help from other devices that aren't
-+ * active, or which may have wakeup disabled. Some drivers rely on
-+ * wakeup events internally (unless they are disabled), keeping
-+ * their hardware in low power modes whenever they're unused. This
-+ * saves runtime power, without requiring system-wide sleep states.
-+ */
-+
-+static const char enabled[] = "enabled";
-+static const char disabled[] = "disabled";
-+
-+static ssize_t
-+wake_show(struct device * dev, struct device_attribute *attr, char * buf)
-+{
-+ return sprintf(buf, "%s\n", device_can_wakeup(dev)
-+ ? (device_may_wakeup(dev) ? enabled : disabled)
-+ : "");
-+}
-+
-+static ssize_t
-+wake_store(struct device * dev, struct device_attribute *attr,
-+ const char * buf, size_t n)
-+{
-+ char *cp;
-+ int len = n;
-+
-+ if (!device_can_wakeup(dev))
-+ return -EINVAL;
-+
-+ cp = memchr(buf, '\n', n);
-+ if (cp)
-+ len = cp - buf;
-+ if (len == sizeof enabled - 1
-+ && strncmp(buf, enabled, sizeof enabled - 1) == 0)
-+ device_set_wakeup_enable(dev, 1);
-+ else if (len == sizeof disabled - 1
-+ && strncmp(buf, disabled, sizeof disabled - 1) == 0)
-+ device_set_wakeup_enable(dev, 0);
-+ else
-+ return -EINVAL;
-+ return n;
-+}
-+
-+static DEVICE_ATTR(wakeup, 0644, wake_show, wake_store);
-+
-+
- static struct attribute * power_attrs[] = {
- &dev_attr_state.attr,
-+ &dev_attr_wakeup.attr,
- NULL,
- };
- static struct attribute_group pm_attr_group = {
diff --git a/driver/driver-model-wakeup-02.patch b/driver/driver-model-wakeup-02.patch
deleted file mode 100644
index e46ea24c915ac..0000000000000
--- a/driver/driver-model-wakeup-02.patch
+++ /dev/null
@@ -1,59 +0,0 @@
-From linux-pm-bounces@lists.osdl.org Mon Sep 12 21:30:53 2005
-From: David Brownell <david-b@pacbell.net>
-Date: Mon, 12 Sep 2005 19:39:39 -0700
-Message-Id: <200509121939.39358.david-b@pacbell.net>
-Subject: [linux-pm] [patch 2/3] usb device wakeup flags
-
-
-This patch teaches "usb_device" about the new driver model wakeup support:
-
- - It updates device wakeup capabilities when entering a configuration
- with the WAKEUP attribute;
-
- - During suspend processing it consults the policy bit to see
- whether it should enable wakeup for that device. (This resolves
- a FIXME to not assume the answer is always "yes"; some devices
- lie about supporting remote wakeup.)
-
-Support for root hubs and the HCDs is separate (and more complex).
-
-Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/usb/core/hub.c | 16 +++++++++-------
- 1 file changed, 9 insertions(+), 7 deletions(-)
-
---- gregkh-2.6.orig/drivers/usb/core/hub.c
-+++ gregkh-2.6/drivers/usb/core/hub.c
-@@ -1020,9 +1020,15 @@ void usb_set_device_state(struct usb_dev
- spin_lock_irqsave(&device_state_lock, flags);
- if (udev->state == USB_STATE_NOTATTACHED)
- ; /* do nothing */
-- else if (new_state != USB_STATE_NOTATTACHED)
-+ else if (new_state != USB_STATE_NOTATTACHED) {
- udev->state = new_state;
-- else
-+ if (new_state == USB_STATE_CONFIGURED)
-+ device_init_wakeup(&udev->dev,
-+ (udev->actconfig->desc.bmAttributes
-+ & USB_CONFIG_ATT_WAKEUP));
-+ else if (new_state != USB_STATE_SUSPENDED)
-+ device_init_wakeup(&udev->dev, 0);
-+ } else
- recursively_mark_NOTATTACHED(udev);
- spin_unlock_irqrestore(&device_state_lock, flags);
- }
-@@ -1546,11 +1552,7 @@ static int hub_port_suspend(struct usb_h
- * NOTE: OTG devices may issue remote wakeup (or SRP) even when
- * we don't explicitly enable it here.
- */
-- if (udev->actconfig
-- // && FIXME (remote wakeup enabled on this bus)
-- // ... currently assuming it's always appropriate
-- && (udev->actconfig->desc.bmAttributes
-- & USB_CONFIG_ATT_WAKEUP) != 0) {
-+ if (device_may_wakeup(&udev->dev)) {
- status = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
- USB_REQ_SET_FEATURE, USB_RECIP_DEVICE,
- USB_DEVICE_REMOTE_WAKEUP, 0,
diff --git a/driver/driver-porting-typo.patch b/driver/driver-porting-typo.patch
deleted file mode 100644
index 1f0279b2dc1d3..0000000000000
--- a/driver/driver-porting-typo.patch
+++ /dev/null
@@ -1,33 +0,0 @@
-From ehovland@s383.jpl.nasa.gov Thu Oct 6 10:49:42 2005
-Date: Thu, 6 Oct 2005 10:47:49 -0700
-From: Erik Hovland <erik@hovland.org>
-To: gregkh@suse.de
-Cc: trivial@rustcorp.com.au
-Subject: [trivial patch] changes device to driver in porting.txt
-Message-ID: <20051006174749.GH25998@mage.jpl.nasa.gov>
-
-The document porting.txt in Documentation/driver-model says:
-When a device is successfully bound to a device
-
-I think it should say:
-When a device is successfully bound to a driver
-
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-
----
- Documentation/driver-model/porting.txt | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
---- gregkh-2.6.orig/Documentation/driver-model/porting.txt
-+++ gregkh-2.6/Documentation/driver-model/porting.txt
-@@ -350,7 +350,7 @@ When a driver is registered, the bus's l
- over. bus->match() is called for each device that is not already
- claimed by a driver.
-
--When a device is successfully bound to a device, device->driver is
-+When a device is successfully bound to a driver, device->driver is
- set, the device is added to a per-driver list of devices, and a
- symlink is created in the driver's sysfs directory that points to the
- device's physical directory:
diff --git a/driver/driver-send-hotplug-before-adding-class_interface.patch b/driver/driver-send-hotplug-before-adding-class_interface.patch
deleted file mode 100644
index d1e79e0ee528a..0000000000000
--- a/driver/driver-send-hotplug-before-adding-class_interface.patch
+++ /dev/null
@@ -1,37 +0,0 @@
-From linux-kernel-owner+greg=40kroah.com-S965240AbVIOHcf@vger.kernel.org Thu Sep 15 00:47:08 2005
-Message-Id: <20050915070302.574089000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:37 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: Driver core: send hotplug event before adding class interfaces
-
-Move call to kobject_hotplug() above code that adds interfaces
-to a class device, otherwise children's hotplug events may reach
-userspace first.
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/base/class.c | 3 ++-
- 1 file changed, 2 insertions(+), 1 deletion(-)
-
---- gregkh-2.6.orig/drivers/base/class.c
-+++ gregkh-2.6/drivers/base/class.c
-@@ -524,6 +524,8 @@ int class_device_add(struct class_device
- class_name);
- }
-
-+ kobject_hotplug(&class_dev->kobj, KOBJ_ADD);
-+
- /* notify any interfaces this device is now here */
- if (parent) {
- down(&parent->sem);
-@@ -533,7 +535,6 @@ int class_device_add(struct class_device
- class_intf->add(class_dev);
- up(&parent->sem);
- }
-- kobject_hotplug(&class_dev->kobj, KOBJ_ADD);
-
- register_done:
- if (error && parent)
diff --git a/driver/drivers-base-fix-sparse-warnings.patch b/driver/drivers-base-fix-sparse-warnings.patch
deleted file mode 100644
index 95f3404d06c49..0000000000000
--- a/driver/drivers-base-fix-sparse-warnings.patch
+++ /dev/null
@@ -1,138 +0,0 @@
-From ben@fluff.org.uk Thu Oct 13 10:05:58 2005
-Date: Thu, 13 Oct 2005 17:54:41 +0100
-From: Ben Dooks <ben-linux@fluff.org>
-To: linux-kernel@vger.kernel.org, gregkh@suse.de
-Subject: [PATCH] drivers/base - fix sparse warnings
-Message-ID: <20051013165441.GA18360@home.fluff.org>
-Content-Disposition: inline
-
-There are a number of sparse warnings from the latest sparse
-snapshot being generated from the drivers/base build. The
-main culprits are due to the initialisation functions not
-being declared in a header file.
-
-Also, the firmware.c file should include <linux/device.h>
-to get the prototype of firmware_register() and
-firmware_unregister().
-
-This patch moves the init function declerations from the
-init.c file to the base.h, and ensures it is included in
-all the relevant c sources. It also adds <linux/device.h>
-to the included headers for firmware.c.
-
-The patch does not solve all the sparse errors generated,
-but reduces the count significantly.
-
-drivers/base/core.c:161:1: warning: symbol 'devices_subsys' was not declared. Should it be static?
-drivers/base/core.c:417:12: warning: symbol 'devices_init' was not declared. Should it be static?
-drivers/base/sys.c:253:6: warning: symbol 'sysdev_shutdown' was not declared. Should it be static?
-drivers/base/sys.c:326:5: warning: symbol 'sysdev_suspend' was not declared. Should it be static?
-drivers/base/sys.c:428:5: warning: symbol 'sysdev_resume' was not declared. Should it be static?
-drivers/base/sys.c:450:12: warning: symbol 'system_bus_init' was not declared. Should it be static?
-drivers/base/bus.c:133:1: warning: symbol 'bus_subsys' was not declared. Should it be static?
-drivers/base/bus.c:667:12: warning: symbol 'buses_init' was not declared. Should it be static?
-drivers/base/class.c:759:12: warning: symbol 'classes_init' was not declared. Should it be static?
-drivers/base/platform.c:313:12: warning: symbol 'platform_bus_init' was not declared. Should it be static?
-drivers/base/cpu.c:110:12: warning: symbol 'cpu_dev_init' was not declared. Should it be static?
-drivers/base/firmware.c:17:5: warning: symbol 'firmware_register' was not declared. Should it be static?
-drivers/base/firmware.c:23:6: warning: symbol 'firmware_unregister' was not declared. Should it be static?
-drivers/base/firmware.c:28:12: warning: symbol 'firmware_init' was not declared. Should it be static?
-drivers/base/init.c:28:13: warning: symbol 'driver_init' was not declared. Should it be static?
-drivers/base/dmapool.c:174:10: warning: implicit cast from nocast type
-drivers/base/attribute_container.c:439:1: warning: symbol 'attribute_container_init' was not declared. Should it be static?
-drivers/base/power/runtime.c:76:6: warning: symbol 'dpm_set_power_state' was not declared. Should it be static?
-
-Signed-off-by: Ben Dooks <ben-linux@fluff.org>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-
----
- drivers/base/attribute_container.c | 2 ++
- drivers/base/base.h | 12 ++++++++++++
- drivers/base/cpu.c | 1 +
- drivers/base/firmware.c | 3 +++
- drivers/base/init.c | 10 ++--------
- drivers/base/platform.c | 2 ++
- 6 files changed, 22 insertions(+), 8 deletions(-)
-
---- gregkh-2.6.orig/drivers/base/attribute_container.c
-+++ gregkh-2.6/drivers/base/attribute_container.c
-@@ -19,6 +19,8 @@
- #include <linux/list.h>
- #include <linux/module.h>
-
-+#include "base.h"
-+
- /* This is a private structure used to tie the classdev and the
- * container .. it should never be visible outside this file */
- struct internal_container {
---- gregkh-2.6.orig/drivers/base/base.h
-+++ gregkh-2.6/drivers/base/base.h
-@@ -1,3 +1,15 @@
-+
-+/* initialisation functions */
-+
-+extern int devices_init(void);
-+extern int buses_init(void);
-+extern int classes_init(void);
-+extern int firmware_init(void);
-+extern int platform_bus_init(void);
-+extern int system_bus_init(void);
-+extern int cpu_dev_init(void);
-+extern int attribute_container_init(void);
-+
- extern int bus_add_device(struct device * dev);
- extern void bus_remove_device(struct device * dev);
-
---- gregkh-2.6.orig/drivers/base/cpu.c
-+++ gregkh-2.6/drivers/base/cpu.c
-@@ -9,6 +9,7 @@
- #include <linux/topology.h>
- #include <linux/device.h>
-
-+#include "base.h"
-
- struct sysdev_class cpu_sysdev_class = {
- set_kset_name("cpu"),
---- gregkh-2.6.orig/drivers/base/firmware.c
-+++ gregkh-2.6/drivers/base/firmware.c
-@@ -11,6 +11,9 @@
- #include <linux/kobject.h>
- #include <linux/module.h>
- #include <linux/init.h>
-+#include <linux/device.h>
-+
-+#include "base.h"
-
- static decl_subsys(firmware, NULL, NULL);
-
---- gregkh-2.6.orig/drivers/base/init.c
-+++ gregkh-2.6/drivers/base/init.c
-@@ -10,14 +10,8 @@
- #include <linux/device.h>
- #include <linux/init.h>
-
--extern int devices_init(void);
--extern int buses_init(void);
--extern int classes_init(void);
--extern int firmware_init(void);
--extern int platform_bus_init(void);
--extern int system_bus_init(void);
--extern int cpu_dev_init(void);
--extern int attribute_container_init(void);
-+#include "base.h"
-+
- /**
- * driver_init - initialize driver model.
- *
---- gregkh-2.6.orig/drivers/base/platform.c
-+++ gregkh-2.6/drivers/base/platform.c
-@@ -17,6 +17,8 @@
- #include <linux/bootmem.h>
- #include <linux/err.h>
-
-+#include "base.h"
-+
- struct device platform_bus = {
- .bus_id = "platform",
- };
diff --git a/driver/fix-documentation-of-driver-suspend-resume-callbacks.patch b/driver/fix-documentation-of-driver-suspend-resume-callbacks.patch
deleted file mode 100644
index 3cf09d4a54838..0000000000000
--- a/driver/fix-documentation-of-driver-suspend-resume-callbacks.patch
+++ /dev/null
@@ -1,43 +0,0 @@
-From tiwai@suse.de Fri Oct 28 07:50:37 2005
-Date: Fri, 28 Oct 2005 16:45:34 +0200
-Message-ID: <s5hoe59bsz5.wl%tiwai@suse.de>
-From: Takashi Iwai <tiwai@suse.de>
-To: Russell King <rmk+lkml@arm.linux.org.uk>
-Cc: Greg K-H <greg@kroah.com>
-Subject: Fix documentation of driver suspend/resume callbacks
-
-Signed-off-by: Takashi Iwai <tiwai@suse.de>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-
----
- Documentation/driver-model/driver.txt | 8 ++++----
- 1 file changed, 4 insertions(+), 4 deletions(-)
-
---- gregkh-2.6.orig/Documentation/driver-model/driver.txt
-+++ gregkh-2.6/Documentation/driver-model/driver.txt
-@@ -14,8 +14,8 @@ struct device_driver {
- int (*probe) (struct device * dev);
- int (*remove) (struct device * dev);
-
-- int (*suspend) (struct device * dev, pm_message_t state, u32 level);
-- int (*resume) (struct device * dev, u32 level);
-+ int (*suspend) (struct device * dev, pm_message_t state);
-+ int (*resume) (struct device * dev);
- };
-
-
-@@ -194,11 +194,11 @@ device; i.e. anything in the device's dr
- If the device is still present, it should quiesce the device and place
- it into a supported low-power state.
-
-- int (*suspend) (struct device * dev, pm_message_t state, u32 level);
-+ int (*suspend) (struct device * dev, pm_message_t state);
-
- suspend is called to put the device in a low power state.
-
-- int (*resume) (struct device * dev, u32 level);
-+ int (*resume) (struct device * dev);
-
- Resume is used to bring a device back from a low power state.
-
diff --git a/driver/i2o-class-01.patch b/driver/i2o-class-01.patch
deleted file mode 100644
index c5f5cf19200f5..0000000000000
--- a/driver/i2o-class-01.patch
+++ /dev/null
@@ -1,103 +0,0 @@
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/message/i2o/iop.c | 22 ++++++++++------------
- include/linux/i2o.h | 2 +-
- 2 files changed, 11 insertions(+), 13 deletions(-)
-
---- gregkh-2.6.orig/drivers/message/i2o/iop.c
-+++ gregkh-2.6/drivers/message/i2o/iop.c
-@@ -833,6 +833,7 @@ void i2o_iop_remove(struct i2o_controlle
- list_for_each_entry_safe(dev, tmp, &c->devices, list)
- i2o_device_remove(dev);
-
-+ class_device_unregister(c->classdev);
- device_del(&c->device);
-
- /* Ask the IOP to switch to RESET state */
-@@ -1077,9 +1078,7 @@ static void i2o_iop_release(struct devic
- };
-
- /* I2O controller class */
--static struct class i2o_controller_class = {
-- .name = "i2o_controller",
--};
-+static struct class *i2o_controller_class;
-
- /**
- * i2o_iop_alloc - Allocate and initialize a i2o_controller struct
-@@ -1110,14 +1109,10 @@ struct i2o_controller *i2o_iop_alloc(voi
- sprintf(c->name, "iop%d", c->unit);
-
- device_initialize(&c->device);
-- class_device_initialize(&c->classdev);
-
- c->device.release = &i2o_iop_release;
-- c->classdev.class = &i2o_controller_class;
-- c->classdev.dev = &c->device;
-
- snprintf(c->device.bus_id, BUS_ID_SIZE, "iop%d", c->unit);
-- snprintf(c->classdev.class_id, BUS_ID_SIZE, "iop%d", c->unit);
-
- #if BITS_PER_LONG == 64
- spin_lock_init(&c->context_list_lock);
-@@ -1146,7 +1141,9 @@ int i2o_iop_add(struct i2o_controller *c
- goto iop_reset;
- }
-
-- if ((rc = class_device_add(&c->classdev))) {
-+ c->classdev = class_device_create(i2o_controller_class, 0,
-+ &c->device, "iop%d", c->unit);
-+ if (IS_ERR(c->classdev)) {
- osm_err("%s: could not add controller class\n", c->name);
- goto device_del;
- }
-@@ -1184,7 +1181,7 @@ int i2o_iop_add(struct i2o_controller *c
- return 0;
-
- class_del:
-- class_device_del(&c->classdev);
-+ class_device_unregister(c->classdev);
-
- device_del:
- device_del(&c->device);
-@@ -1250,7 +1247,8 @@ static int __init i2o_iop_init(void)
- if (rc)
- goto exit;
-
-- if ((rc = class_register(&i2o_controller_class))) {
-+ i2o_controller_class = class_create(THIS_MODULE, "i2o_controller");
-+ if (IS_ERR(i2o_controller_class)) {
- osm_err("can't register class i2o_controller\n");
- goto device_exit;
- }
-@@ -1273,7 +1271,7 @@ static int __init i2o_iop_init(void)
- i2o_driver_exit();
-
- class_exit:
-- class_unregister(&i2o_controller_class);
-+ class_destroy(i2o_controller_class);
-
- device_exit:
- i2o_device_exit();
-@@ -1292,7 +1290,7 @@ static void __exit i2o_iop_exit(void)
- i2o_pci_exit();
- i2o_exec_exit();
- i2o_driver_exit();
-- class_unregister(&i2o_controller_class);
-+ class_destroy(i2o_controller_class);
- i2o_device_exit();
- };
-
---- gregkh-2.6.orig/include/linux/i2o.h
-+++ gregkh-2.6/include/linux/i2o.h
-@@ -194,7 +194,7 @@ struct i2o_controller {
- struct resource mem_resource; /* Mem resource allocated to the IOP */
-
- struct device device;
-- struct class_device classdev; /* I2O controller class */
-+ struct class_device *classdev; /* I2O controller class device */
- struct i2o_device *exec; /* Executive */
- #if BITS_PER_LONG == 64
- spinlock_t context_list_lock; /* lock for context_list */
diff --git a/driver/i2o-remove-class-interface.patch b/driver/i2o-remove-class-interface.patch
deleted file mode 100644
index ae108e2fd2907..0000000000000
--- a/driver/i2o-remove-class-interface.patch
+++ /dev/null
@@ -1,398 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:49:52 2005
-Message-Id: <20050915070301.943754000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:32 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: I2O: remove class interface
-
-I2O: remove i2o_device_class_interface misuse
-
-The intent of class interfaces was to provide different
-'views' at the same object, not just run some code every
-time a new class device is registered. Kill interface
-structure, make class core register default attributes
-and set up sysfs links right when registering class
-devices.
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/message/i2o/device.c | 255 ++++++++++++++++++++-----------------------
- 1 file changed, 122 insertions(+), 133 deletions(-)
-
---- gregkh-2.6.orig/drivers/message/i2o/device.c
-+++ gregkh-2.6/drivers/message/i2o/device.c
-@@ -45,10 +45,10 @@ static inline int i2o_device_issue_claim
- writel(type, &msg->body[0]);
-
- return i2o_msg_post_wait(dev->iop, m, 60);
--};
-+}
-
- /**
-- * i2o_device_claim - claim a device for use by an OSM
-+ * i2o_device_claim - claim a device for use by an OSM
- * @dev: I2O device to claim
- * @drv: I2O driver which wants to claim the device
- *
-@@ -73,7 +73,7 @@ int i2o_device_claim(struct i2o_device *
- up(&dev->lock);
-
- return rc;
--};
-+}
-
- /**
- * i2o_device_claim_release - release a device that the OSM is using
-@@ -119,7 +119,8 @@ int i2o_device_claim_release(struct i2o_
- up(&dev->lock);
-
- return rc;
--};
-+}
-+
-
- /**
- * i2o_device_release - release the memory for a I2O device
-@@ -135,39 +136,62 @@ static void i2o_device_release(struct de
- pr_debug("i2o: device %s released\n", dev->bus_id);
-
- kfree(i2o_dev);
--};
-+}
-
- /**
-- * i2o_device_class_release - Remove I2O device attributes
-+ * i2o_device_class_release - I2O class device release function
- * @cd: I2O class device which is added to the I2O device class
- *
-- * Removes attributes from the I2O device again. Also search each device
-- * on the controller for I2O devices which refert to this device as parent
-- * or user and remove this links also.
-+ * The function is just a stub - memory will be freed when
-+ * associated I2O device is released.
- */
- static void i2o_device_class_release(struct class_device *cd)
- {
-- struct i2o_device *i2o_dev, *tmp;
-- struct i2o_controller *c;
-+ /* empty */
-+}
-
-- i2o_dev = to_i2o_device(cd->dev);
-- c = i2o_dev->iop;
-+/**
-+ * i2o_device_class_show_class_id - Displays class id of I2O device
-+ * @cd: class device of which the class id should be displayed
-+ * @buf: buffer into which the class id should be printed
-+ *
-+ * Returns the number of bytes which are printed into the buffer.
-+ */
-+static ssize_t i2o_device_class_show_class_id(struct class_device *cd,
-+ char *buf)
-+{
-+ struct i2o_device *dev = to_i2o_device(cd->dev);
-
-- sysfs_remove_link(&i2o_dev->device.kobj, "parent");
-- sysfs_remove_link(&i2o_dev->device.kobj, "user");
-+ sprintf(buf, "0x%03x\n", dev->lct_data.class_id);
-+ return strlen(buf) + 1;
-+}
-
-- list_for_each_entry(tmp, &c->devices, list) {
-- if (tmp->lct_data.parent_tid == i2o_dev->lct_data.tid)
-- sysfs_remove_link(&tmp->device.kobj, "parent");
-- if (tmp->lct_data.user_tid == i2o_dev->lct_data.tid)
-- sysfs_remove_link(&tmp->device.kobj, "user");
-- }
-+/**
-+ * i2o_device_class_show_tid - Displays TID of I2O device
-+ * @cd: class device of which the TID should be displayed
-+ * @buf: buffer into which the class id should be printed
-+ *
-+ * Returns the number of bytes which are printed into the buffer.
-+ */
-+static ssize_t i2o_device_class_show_tid(struct class_device *cd, char *buf)
-+{
-+ struct i2o_device *dev = to_i2o_device(cd->dev);
-+
-+ sprintf(buf, "0x%03x\n", dev->lct_data.tid);
-+ return strlen(buf) + 1;
-+}
-+
-+static struct class_device_attribute i2o_device_class_attrs[] = {
-+ __ATTR(class_id, S_IRUGO, i2o_device_class_show_class_id, NULL),
-+ __ATTR(tid, S_IRUGO, i2o_device_class_show_tid, NULL),
-+ __ATTR_NULL
- };
-
- /* I2O device class */
- static struct class i2o_device_class = {
-- .name = "i2o_device",
-- .release = i2o_device_class_release
-+ .name = "i2o_device",
-+ .release = i2o_device_class_release,
-+ .class_dev_attrs = i2o_device_class_attrs,
- };
-
- /**
-@@ -197,7 +221,67 @@ static struct i2o_device *i2o_device_all
- dev->classdev.dev = &dev->device;
-
- return dev;
--};
-+}
-+
-+/**
-+ * i2o_setup_sysfs_links - Adds attributes to the I2O device
-+ * @cd: I2O class device which is added to the I2O device class
-+ *
-+ * This function get called when a I2O device is added to the class. It
-+ * creates the attributes for each device and creates user/parent symlink
-+ * if necessary.
-+ *
-+ * Returns 0 on success or negative error code on failure.
-+ */
-+static void i2o_setup_sysfs_links(struct i2o_device *i2o_dev)
-+{
-+ struct i2o_controller *c = i2o_dev->iop;
-+ struct i2o_device *tmp;
-+
-+ /* create user entries for this device */
-+ tmp = i2o_iop_find_device(i2o_dev->iop, i2o_dev->lct_data.user_tid);
-+ if (tmp && tmp != i2o_dev)
-+ sysfs_create_link(&i2o_dev->device.kobj,
-+ &tmp->device.kobj, "user");
-+
-+ /* create user entries refering to this device */
-+ list_for_each_entry(tmp, &c->devices, list)
-+ if (tmp->lct_data.user_tid == i2o_dev->lct_data.tid &&
-+ tmp != i2o_dev)
-+ sysfs_create_link(&tmp->device.kobj,
-+ &i2o_dev->device.kobj, "user");
-+
-+ /* create parent entries for this device */
-+ tmp = i2o_iop_find_device(i2o_dev->iop, i2o_dev->lct_data.parent_tid);
-+ if (tmp && tmp != i2o_dev)
-+ sysfs_create_link(&i2o_dev->device.kobj,
-+ &tmp->device.kobj, "parent");
-+
-+ /* create parent entries refering to this device */
-+ list_for_each_entry(tmp, &c->devices, list)
-+ if (tmp->lct_data.parent_tid == i2o_dev->lct_data.tid &&
-+ tmp != i2o_dev)
-+ sysfs_create_link(&tmp->device.kobj,
-+ &i2o_dev->device.kobj, "parent");
-+}
-+
-+static void i2o_remove_sysfs_links(struct i2o_device *i2o_dev)
-+{
-+ struct i2o_controller *c = i2o_dev->iop;
-+ struct i2o_device *tmp;
-+
-+ sysfs_remove_link(&i2o_dev->device.kobj, "parent");
-+ sysfs_remove_link(&i2o_dev->device.kobj, "user");
-+
-+ list_for_each_entry(tmp, &c->devices, list) {
-+ if (tmp->lct_data.parent_tid == i2o_dev->lct_data.tid)
-+ sysfs_remove_link(&tmp->device.kobj, "parent");
-+ if (tmp->lct_data.user_tid == i2o_dev->lct_data.tid)
-+ sysfs_remove_link(&tmp->device.kobj, "user");
-+ }
-+}
-+
-+
-
- /**
- * i2o_device_add - allocate a new I2O device and add it to the IOP
-@@ -222,6 +306,7 @@ static struct i2o_device *i2o_device_add
- }
-
- dev->lct_data = *entry;
-+ dev->iop = c;
-
- snprintf(dev->device.bus_id, BUS_ID_SIZE, "%d:%03x", c->unit,
- dev->lct_data.tid);
-@@ -229,7 +314,6 @@ static struct i2o_device *i2o_device_add
- snprintf(dev->classdev.class_id, BUS_ID_SIZE, "%d:%03x", c->unit,
- dev->lct_data.tid);
-
-- dev->iop = c;
- dev->device.parent = &c->device;
-
- device_register(&dev->device);
-@@ -238,12 +322,14 @@ static struct i2o_device *i2o_device_add
-
- class_device_register(&dev->classdev);
-
-+ i2o_setup_sysfs_links(dev);
-+
- i2o_driver_notify_device_add_all(dev);
-
- pr_debug("i2o: device %s added\n", dev->device.bus_id);
-
- return dev;
--};
-+}
-
- /**
- * i2o_device_remove - remove an I2O device from the I2O core
-@@ -256,10 +342,11 @@ static struct i2o_device *i2o_device_add
- void i2o_device_remove(struct i2o_device *i2o_dev)
- {
- i2o_driver_notify_device_remove_all(i2o_dev);
-+ i2o_remove_sysfs_links(i2o_dev);
- class_device_unregister(&i2o_dev->classdev);
- list_del(&i2o_dev->list);
- device_unregister(&i2o_dev->device);
--};
-+}
-
- /**
- * i2o_device_parse_lct - Parse a previously fetched LCT and create devices
-@@ -337,99 +424,8 @@ int i2o_device_parse_lct(struct i2o_cont
- up(&c->lct_lock);
-
- return 0;
--};
--
--/**
-- * i2o_device_class_show_class_id - Displays class id of I2O device
-- * @cd: class device of which the class id should be displayed
-- * @buf: buffer into which the class id should be printed
-- *
-- * Returns the number of bytes which are printed into the buffer.
-- */
--static ssize_t i2o_device_class_show_class_id(struct class_device *cd,
-- char *buf)
--{
-- struct i2o_device *dev = to_i2o_device(cd->dev);
--
-- sprintf(buf, "0x%03x\n", dev->lct_data.class_id);
-- return strlen(buf) + 1;
--};
--
--/**
-- * i2o_device_class_show_tid - Displays TID of I2O device
-- * @cd: class device of which the TID should be displayed
-- * @buf: buffer into which the class id should be printed
-- *
-- * Returns the number of bytes which are printed into the buffer.
-- */
--static ssize_t i2o_device_class_show_tid(struct class_device *cd, char *buf)
--{
-- struct i2o_device *dev = to_i2o_device(cd->dev);
--
-- sprintf(buf, "0x%03x\n", dev->lct_data.tid);
-- return strlen(buf) + 1;
--};
--
--/* I2O device class attributes */
--static CLASS_DEVICE_ATTR(class_id, S_IRUGO, i2o_device_class_show_class_id,
-- NULL);
--static CLASS_DEVICE_ATTR(tid, S_IRUGO, i2o_device_class_show_tid, NULL);
--
--/**
-- * i2o_device_class_add - Adds attributes to the I2O device
-- * @cd: I2O class device which is added to the I2O device class
-- *
-- * This function get called when a I2O device is added to the class. It
-- * creates the attributes for each device and creates user/parent symlink
-- * if necessary.
-- *
-- * Returns 0 on success or negative error code on failure.
-- */
--static int i2o_device_class_add(struct class_device *cd)
--{
-- struct i2o_device *i2o_dev, *tmp;
-- struct i2o_controller *c;
--
-- i2o_dev = to_i2o_device(cd->dev);
-- c = i2o_dev->iop;
--
-- class_device_create_file(cd, &class_device_attr_class_id);
-- class_device_create_file(cd, &class_device_attr_tid);
--
-- /* create user entries for this device */
-- tmp = i2o_iop_find_device(i2o_dev->iop, i2o_dev->lct_data.user_tid);
-- if (tmp && (tmp != i2o_dev))
-- sysfs_create_link(&i2o_dev->device.kobj, &tmp->device.kobj,
-- "user");
--
-- /* create user entries refering to this device */
-- list_for_each_entry(tmp, &c->devices, list)
-- if ((tmp->lct_data.user_tid == i2o_dev->lct_data.tid)
-- && (tmp != i2o_dev))
-- sysfs_create_link(&tmp->device.kobj,
-- &i2o_dev->device.kobj, "user");
--
-- /* create parent entries for this device */
-- tmp = i2o_iop_find_device(i2o_dev->iop, i2o_dev->lct_data.parent_tid);
-- if (tmp && (tmp != i2o_dev))
-- sysfs_create_link(&i2o_dev->device.kobj, &tmp->device.kobj,
-- "parent");
--
-- /* create parent entries refering to this device */
-- list_for_each_entry(tmp, &c->devices, list)
-- if ((tmp->lct_data.parent_tid == i2o_dev->lct_data.tid)
-- && (tmp != i2o_dev))
-- sysfs_create_link(&tmp->device.kobj,
-- &i2o_dev->device.kobj, "parent");
--
-- return 0;
--};
-+}
-
--/* I2O device class interface */
--static struct class_interface i2o_device_class_interface = {
-- .class = &i2o_device_class,
-- .add = i2o_device_class_add
--};
-
- /*
- * Run time support routines
-@@ -553,11 +549,11 @@ int i2o_parm_field_get(struct i2o_device
- }
-
- /*
-- * if oper == I2O_PARAMS_TABLE_GET, get from all rows
-- * if fieldcount == -1 return all fields
-+ * if oper == I2O_PARAMS_TABLE_GET, get from all rows
-+ * if fieldcount == -1 return all fields
- * ibuf and ibuflen are unused (use NULL, 0)
-- * else return specific fields
-- * ibuf contains fieldindexes
-+ * else return specific fields
-+ * ibuf contains fieldindexes
- *
- * if oper == I2O_PARAMS_LIST_GET, get from specific rows
- * if fieldcount == -1 return all fields
-@@ -611,14 +607,8 @@ int i2o_parm_table_get(struct i2o_device
- */
- int i2o_device_init(void)
- {
-- int rc;
--
-- rc = class_register(&i2o_device_class);
-- if (rc)
-- return rc;
--
-- return class_interface_register(&i2o_device_class_interface);
--};
-+ return class_register(&i2o_device_class);
-+}
-
- /**
- * i2o_device_exit - I2O devices exit function
-@@ -627,9 +617,8 @@ int i2o_device_init(void)
- */
- void i2o_device_exit(void)
- {
-- class_interface_register(&i2o_device_class_interface);
- class_unregister(&i2o_device_class);
--};
-+}
-
- EXPORT_SYMBOL(i2o_device_claim);
- EXPORT_SYMBOL(i2o_device_claim_release);
diff --git a/driver/i2o-remove-i2o_device_class.patch b/driver/i2o-remove-i2o_device_class.patch
deleted file mode 100644
index b3beae92b5f94..0000000000000
--- a/driver/i2o-remove-i2o_device_class.patch
+++ /dev/null
@@ -1,236 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 29 05:10:24 2005
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-To: Greg KH <gregkh@suse.de>
-Subject: I2O: remove i2o_device_class
-Date: Thu, 29 Sep 2005 00:40:07 -0500
-Message-Id: <200509290040.07805.dtor_core@ameritech.net>
-
-I2O: cleanup - remove i2o_device_class
-
-I2O devices reside on their own bus so there should be no reason
-to also have i2c_device class that mirros i2o bus.
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-
----
- drivers/message/i2o/core.h | 3 -
- drivers/message/i2o/device.c | 71 +++++++------------------------------------
- drivers/message/i2o/driver.c | 3 +
- drivers/message/i2o/iop.c | 10 ------
- include/linux/i2o.h | 2 -
- 5 files changed, 17 insertions(+), 72 deletions(-)
-
---- gregkh-2.6.orig/drivers/message/i2o/device.c
-+++ gregkh-2.6/drivers/message/i2o/device.c
-@@ -138,17 +138,6 @@ static void i2o_device_release(struct de
- kfree(i2o_dev);
- }
-
--/**
-- * i2o_device_class_release - I2O class device release function
-- * @cd: I2O class device which is added to the I2O device class
-- *
-- * The function is just a stub - memory will be freed when
-- * associated I2O device is released.
-- */
--static void i2o_device_class_release(struct class_device *cd)
--{
-- /* empty */
--}
-
- /**
- * i2o_device_class_show_class_id - Displays class id of I2O device
-@@ -157,12 +146,13 @@ static void i2o_device_class_release(str
- *
- * Returns the number of bytes which are printed into the buffer.
- */
--static ssize_t i2o_device_class_show_class_id(struct class_device *cd,
-- char *buf)
-+static ssize_t i2o_device_show_class_id(struct device *dev,
-+ struct device_attribute *attr,
-+ char *buf)
- {
-- struct i2o_device *dev = to_i2o_device(cd->dev);
-+ struct i2o_device *i2o_dev = to_i2o_device(dev);
-
-- sprintf(buf, "0x%03x\n", dev->lct_data.class_id);
-+ sprintf(buf, "0x%03x\n", i2o_dev->lct_data.class_id);
- return strlen(buf) + 1;
- }
-
-@@ -173,27 +163,22 @@ static ssize_t i2o_device_class_show_cla
- *
- * Returns the number of bytes which are printed into the buffer.
- */
--static ssize_t i2o_device_class_show_tid(struct class_device *cd, char *buf)
-+static ssize_t i2o_device_show_tid(struct device *dev,
-+ struct device_attribute *attr,
-+ char *buf)
- {
-- struct i2o_device *dev = to_i2o_device(cd->dev);
-+ struct i2o_device *i2o_dev = to_i2o_device(dev);
-
-- sprintf(buf, "0x%03x\n", dev->lct_data.tid);
-+ sprintf(buf, "0x%03x\n", i2o_dev->lct_data.tid);
- return strlen(buf) + 1;
- }
-
--static struct class_device_attribute i2o_device_class_attrs[] = {
-- __ATTR(class_id, S_IRUGO, i2o_device_class_show_class_id, NULL),
-- __ATTR(tid, S_IRUGO, i2o_device_class_show_tid, NULL),
-+struct device_attribute i2o_device_attrs[] = {
-+ __ATTR(class_id, S_IRUGO, i2o_device_show_class_id, NULL),
-+ __ATTR(tid, S_IRUGO, i2o_device_show_tid, NULL),
- __ATTR_NULL
- };
-
--/* I2O device class */
--static struct class i2o_device_class = {
-- .name = "i2o_device",
-- .release = i2o_device_class_release,
-- .class_dev_attrs = i2o_device_class_attrs,
--};
--
- /**
- * i2o_device_alloc - Allocate a I2O device and initialize it
- *
-@@ -217,8 +202,6 @@ static struct i2o_device *i2o_device_all
-
- dev->device.bus = &i2o_bus_type;
- dev->device.release = &i2o_device_release;
-- dev->classdev.class = &i2o_device_class;
-- dev->classdev.dev = &dev->device;
-
- return dev;
- }
-@@ -311,17 +294,12 @@ static struct i2o_device *i2o_device_add
- snprintf(dev->device.bus_id, BUS_ID_SIZE, "%d:%03x", c->unit,
- dev->lct_data.tid);
-
-- snprintf(dev->classdev.class_id, BUS_ID_SIZE, "%d:%03x", c->unit,
-- dev->lct_data.tid);
--
- dev->device.parent = &c->device;
-
- device_register(&dev->device);
-
- list_add_tail(&dev->list, &c->devices);
-
-- class_device_register(&dev->classdev);
--
- i2o_setup_sysfs_links(dev);
-
- i2o_driver_notify_device_add_all(dev);
-@@ -343,7 +321,6 @@ void i2o_device_remove(struct i2o_device
- {
- i2o_driver_notify_device_remove_all(i2o_dev);
- i2o_remove_sysfs_links(i2o_dev);
-- class_device_unregister(&i2o_dev->classdev);
- list_del(&i2o_dev->list);
- device_unregister(&i2o_dev->device);
- }
-@@ -598,28 +575,6 @@ int i2o_parm_table_get(struct i2o_device
- return size;
- }
-
--/**
-- * i2o_device_init - Initialize I2O devices
-- *
-- * Registers the I2O device class.
-- *
-- * Returns 0 on success or negative error code on failure.
-- */
--int i2o_device_init(void)
--{
-- return class_register(&i2o_device_class);
--}
--
--/**
-- * i2o_device_exit - I2O devices exit function
-- *
-- * Unregisters the I2O device class.
-- */
--void i2o_device_exit(void)
--{
-- class_unregister(&i2o_device_class);
--}
--
- EXPORT_SYMBOL(i2o_device_claim);
- EXPORT_SYMBOL(i2o_device_claim_release);
- EXPORT_SYMBOL(i2o_parm_field_get);
---- gregkh-2.6.orig/drivers/message/i2o/driver.c
-+++ gregkh-2.6/drivers/message/i2o/driver.c
-@@ -58,9 +58,12 @@ static int i2o_bus_match(struct device *
- };
-
- /* I2O bus type */
-+extern struct device_attribute i2o_device_attrs[];
-+
- struct bus_type i2o_bus_type = {
- .name = "i2o",
- .match = i2o_bus_match,
-+ .dev_attrs = i2o_device_attrs,
- };
-
- /**
---- gregkh-2.6.orig/include/linux/i2o.h
-+++ gregkh-2.6/include/linux/i2o.h
-@@ -66,8 +66,6 @@ struct i2o_device {
- struct device device;
-
- struct semaphore lock; /* device lock */
--
-- struct class_device classdev; /* i2o device class */
- };
-
- /*
---- gregkh-2.6.orig/drivers/message/i2o/core.h
-+++ gregkh-2.6/drivers/message/i2o/core.h
-@@ -36,9 +36,6 @@ extern void __exit i2o_pci_exit(void);
- extern void i2o_device_remove(struct i2o_device *);
- extern int i2o_device_parse_lct(struct i2o_controller *);
-
--extern int i2o_device_init(void);
--extern void i2o_device_exit(void);
--
- /* IOP */
- extern struct i2o_controller *i2o_iop_alloc(void);
- extern void i2o_iop_free(struct i2o_controller *);
---- gregkh-2.6.orig/drivers/message/i2o/iop.c
-+++ gregkh-2.6/drivers/message/i2o/iop.c
-@@ -1243,14 +1243,10 @@ static int __init i2o_iop_init(void)
-
- printk(KERN_INFO OSM_DESCRIPTION " v" OSM_VERSION "\n");
-
-- rc = i2o_device_init();
-- if (rc)
-- goto exit;
--
- i2o_controller_class = class_create(THIS_MODULE, "i2o_controller");
- if (IS_ERR(i2o_controller_class)) {
- osm_err("can't register class i2o_controller\n");
-- goto device_exit;
-+ goto exit;
- }
-
- if ((rc = i2o_driver_init()))
-@@ -1273,9 +1269,6 @@ static int __init i2o_iop_init(void)
- class_exit:
- class_destroy(i2o_controller_class);
-
-- device_exit:
-- i2o_device_exit();
--
- exit:
- return rc;
- }
-@@ -1291,7 +1284,6 @@ static void __exit i2o_iop_exit(void)
- i2o_exec_exit();
- i2o_driver_exit();
- class_destroy(i2o_controller_class);
-- i2o_device_exit();
- };
-
- module_init(i2o_iop_init);
diff --git a/driver/input-class_device-move.patch b/driver/input-class_device-move.patch
deleted file mode 100644
index aea86dfbca4f4..0000000000000
--- a/driver/input-class_device-move.patch
+++ /dev/null
@@ -1,122 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: INPUT: move the input class devices under their new input_dev devices
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/input/evdev.c | 6 +++---
- drivers/input/joydev.c | 6 +++---
- drivers/input/mousedev.c | 10 +++++-----
- drivers/input/tsdev.c | 6 +++---
- 4 files changed, 14 insertions(+), 14 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/mousedev.c
-+++ gregkh-2.6/drivers/input/mousedev.c
-@@ -648,9 +648,9 @@ static struct input_handle *mousedev_con
-
- mousedev_table[minor] = mousedev;
-
-- class_device_create(input_class, NULL,
-+ class_device_create(&input_dev_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + minor),
-- dev->dev, "mouse%d", minor);
-+ dev->cdev.dev, "mouse%d", minor);
-
- return &mousedev->handle;
- }
-@@ -660,7 +660,7 @@ static void mousedev_disconnect(struct i
- struct mousedev *mousedev = handle->private;
- struct mousedev_list *list;
-
-- class_device_destroy(input_class,
-+ class_device_destroy(&input_dev_class,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + mousedev->minor));
- mousedev->exist = 0;
-
-@@ -734,7 +734,7 @@ static int __init mousedev_init(void)
- mousedev_mix.exist = 1;
- mousedev_mix.minor = MOUSEDEV_MIX;
-
-- class_device_create(input_class, NULL,
-+ class_device_create(&input_dev_class, NULL,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX), NULL, "mice");
-
- #ifdef CONFIG_INPUT_MOUSEDEV_PSAUX
-@@ -753,7 +753,7 @@ static void __exit mousedev_exit(void)
- if (psaux_registered)
- misc_deregister(&psaux_mouse);
- #endif
-- class_device_destroy(input_class,
-+ class_device_destroy(&input_dev_class,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX));
- input_unregister_handler(&mousedev_handler);
- }
---- gregkh-2.6.orig/drivers/input/evdev.c
-+++ gregkh-2.6/drivers/input/evdev.c
-@@ -686,9 +686,9 @@ static struct input_handle *evdev_connec
-
- evdev_table[minor] = evdev;
-
-- class_device_create(input_class, NULL,
-+ class_device_create(&input_dev_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor),
-- dev->dev, "event%d", minor);
-+ dev->cdev.dev, "event%d", minor);
-
- return &evdev->handle;
- }
-@@ -698,7 +698,7 @@ static void evdev_disconnect(struct inpu
- struct evdev *evdev = handle->private;
- struct evdev_list *list;
-
-- class_device_destroy(input_class,
-+ class_device_destroy(&input_dev_class,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + evdev->minor));
- evdev->exist = 0;
-
---- gregkh-2.6.orig/drivers/input/joydev.c
-+++ gregkh-2.6/drivers/input/joydev.c
-@@ -513,9 +513,9 @@ static struct input_handle *joydev_conne
-
- joydev_table[minor] = joydev;
-
-- class_device_create(input_class, NULL,
-+ class_device_create(&input_dev_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + minor),
-- dev->dev, "js%d", minor);
-+ dev->cdev.dev, "js%d", minor);
-
- return &joydev->handle;
- }
-@@ -525,7 +525,7 @@ static void joydev_disconnect(struct inp
- struct joydev *joydev = handle->private;
- struct joydev_list *list;
-
-- class_device_destroy(input_class, MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + joydev->minor));
-+ class_device_destroy(&input_dev_class, MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + joydev->minor));
- joydev->exist = 0;
-
- if (joydev->open) {
---- gregkh-2.6.orig/drivers/input/tsdev.c
-+++ gregkh-2.6/drivers/input/tsdev.c
-@@ -409,9 +409,9 @@ static struct input_handle *tsdev_connec
-
- tsdev_table[minor] = tsdev;
-
-- class_device_create(input_class, NULL,
-+ class_device_create(&input_dev_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor),
-- dev->dev, "ts%d", minor);
-+ dev->cdev.dev, "ts%d", minor);
-
- return &tsdev->handle;
- }
-@@ -421,7 +421,7 @@ static void tsdev_disconnect(struct inpu
- struct tsdev *tsdev = handle->private;
- struct tsdev_list *list;
-
-- class_device_destroy(input_class,
-+ class_device_destroy(&input_dev_class,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + tsdev->minor));
- tsdev->exist = 0;
-
diff --git a/driver/input-convert-to-dynamic-beep.patch b/driver/input-convert-to-dynamic-beep.patch
deleted file mode 100644
index 178fe2ed029fd..0000000000000
--- a/driver/input-convert-to-dynamic-beep.patch
+++ /dev/null
@@ -1,120 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:20 2005
-Message-Id: <20050915070304.373499000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:49 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 18/28] Input: convert sound/ppc/beep to dynamic input_dev allocation
-
-Input: convert sound/ppc/beep to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- sound/ppc/beep.c | 68 ++++++++++++++++++++++++++++++-------------------------
- 1 file changed, 38 insertions(+), 30 deletions(-)
-
---- gregkh-2.6.orig/sound/ppc/beep.c
-+++ gregkh-2.6/sound/ppc/beep.c
-@@ -31,14 +31,14 @@
- #include "pmac.h"
-
- struct snd_pmac_beep {
-- int running; /* boolean */
-- int volume; /* mixer volume: 0-100 */
-+ int running; /* boolean */
-+ int volume; /* mixer volume: 0-100 */
- int volume_play; /* currently playing volume */
- int hz;
- int nsamples;
- short *buf; /* allocated wave buffer */
- dma_addr_t addr; /* physical address of buffer */
-- struct input_dev dev;
-+ struct input_dev *dev;
- };
-
- /*
-@@ -212,47 +212,55 @@ static snd_kcontrol_new_t snd_pmac_beep_
- int __init snd_pmac_attach_beep(pmac_t *chip)
- {
- pmac_beep_t *beep;
-- int err;
--
-- beep = kmalloc(sizeof(*beep), GFP_KERNEL);
-- if (! beep)
-- return -ENOMEM;
--
-- memset(beep, 0, sizeof(*beep));
-- beep->buf = dma_alloc_coherent(&chip->pdev->dev, BEEP_BUFLEN * 4,
-- &beep->addr, GFP_KERNEL);
--
-- beep->dev.evbit[0] = BIT(EV_SND);
-- beep->dev.sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-- beep->dev.event = snd_pmac_beep_event;
-- beep->dev.private = chip;
-+ struct input_dev *input_dev;
-+ void *dmabuf;
-+ int err = -ENOMEM;
-+
-+ beep = kzalloc(sizeof(*beep), GFP_KERNEL);
-+ dmabuf = dma_alloc_coherent(&chip->pdev->dev, BEEP_BUFLEN * 4,
-+ &beep->addr, GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!beep || !dmabuf || !input_dev)
-+ goto fail;
-
- /* FIXME: set more better values */
-- beep->dev.name = "PowerMac Beep";
-- beep->dev.phys = "powermac/beep";
-- beep->dev.id.bustype = BUS_ADB;
-- beep->dev.id.vendor = 0x001f;
-- beep->dev.id.product = 0x0001;
-- beep->dev.id.version = 0x0100;
-+ input_dev->name = "PowerMac Beep";
-+ input_dev->phys = "powermac/beep";
-+ input_dev->id.bustype = BUS_ADB;
-+ input_dev->id.vendor = 0x001f;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+
-+ input_dev->evbit[0] = BIT(EV_SND);
-+ input_dev->sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-+ input_dev->event = snd_pmac_beep_event;
-+ input_dev->private = chip;
-+ input_dev->cdev.dev = &chip->pdev->dev;
-
-+ beep->dev = input_dev;
-+ beep->buf = dmabuf;
- beep->volume = BEEP_VOLUME;
- beep->running = 0;
-- if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_pmac_beep_mixer, chip))) < 0) {
-- kfree(beep->buf);
-- kfree(beep);
-- return err;
-- }
-+
-+ err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_pmac_beep_mixer, chip));
-+ if (err < 0)
-+ goto fail;
-
- chip->beep = beep;
-- input_register_device(&beep->dev);
-+ input_register_device(beep->dev);
-
- return 0;
-+
-+ fail: input_free_device(input_dev);
-+ kfree(dmabuf);
-+ kfree(beep);
-+ return err;
- }
-
- void snd_pmac_detach_beep(pmac_t *chip)
- {
- if (chip->beep) {
-- input_unregister_device(&chip->beep->dev);
-+ input_unregister_device(chip->beep->dev);
- dma_free_coherent(&chip->pdev->dev, BEEP_BUFLEN * 4,
- chip->beep->buf, chip->beep->addr);
- kfree(chip->beep);
diff --git a/driver/input-convert-to-dynamic-bluetooth.patch b/driver/input-convert-to-dynamic-bluetooth.patch
deleted file mode 100644
index b9e751a7e713d..0000000000000
--- a/driver/input-convert-to-dynamic-bluetooth.patch
+++ /dev/null
@@ -1,68 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:03 2005
-Message-Id: <20050915070302.931769000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:40 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 09/28] Input: convert net/bluetooth to dynamic input_dev allocation
-
-Input: convert net/bluetooth to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- net/bluetooth/hidp/core.c | 13 ++++++++-----
- 1 file changed, 8 insertions(+), 5 deletions(-)
-
---- gregkh-2.6.orig/net/bluetooth/hidp/core.c
-+++ gregkh-2.6/net/bluetooth/hidp/core.c
-@@ -520,7 +520,7 @@ static int hidp_session(void *arg)
-
- if (session->input) {
- input_unregister_device(session->input);
-- kfree(session->input);
-+ session->input = NULL;
- }
-
- up_write(&hidp_session_sem);
-@@ -536,6 +536,8 @@ static inline void hidp_setup_input(stru
-
- input->private = session;
-
-+ input->name = "Bluetooth HID Boot Protocol Device";
-+
- input->id.bustype = BUS_BLUETOOTH;
- input->id.vendor = req->vendor;
- input->id.product = req->product;
-@@ -582,16 +584,15 @@ int hidp_add_connection(struct hidp_conn
- return -ENOTUNIQ;
-
- session = kmalloc(sizeof(struct hidp_session), GFP_KERNEL);
-- if (!session)
-+ if (!session)
- return -ENOMEM;
- memset(session, 0, sizeof(struct hidp_session));
-
-- session->input = kmalloc(sizeof(struct input_dev), GFP_KERNEL);
-+ session->input = input_allocate_device();
- if (!session->input) {
- kfree(session);
- return -ENOMEM;
- }
-- memset(session->input, 0, sizeof(struct input_dev));
-
- down_write(&hidp_session_sem);
-
-@@ -651,8 +652,10 @@ unlink:
-
- __hidp_unlink_session(session);
-
-- if (session->input)
-+ if (session->input) {
- input_unregister_device(session->input);
-+ session->input = NULL; /* don't try to free it here */
-+ }
-
- failed:
- up_write(&hidp_session_sem);
diff --git a/driver/input-convert-to-dynamic-joystick.patch b/driver/input-convert-to-dynamic-joystick.patch
deleted file mode 100644
index 576f1af63ae08..0000000000000
--- a/driver/input-convert-to-dynamic-joystick.patch
+++ /dev/null
@@ -1,4565 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:15 2005
-Message-Id: <20050915070304.862317000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:52 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 21/28] drivers/input/joystick: convert to dynamic input_dev allocation
-
-Input: convert drivers/input/joystick to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/joystick/adi.c | 93 +++--
- drivers/input/joystick/amijoy.c | 87 +++--
- drivers/input/joystick/analog.c | 100 ++----
- drivers/input/joystick/cobra.c | 70 ++--
- drivers/input/joystick/db9.c | 292 +++++++++++-------
- drivers/input/joystick/gamecon.c | 396 +++++++++++++------------
- drivers/input/joystick/gf2k.c | 71 ++--
- drivers/input/joystick/grip.c | 85 ++---
- drivers/input/joystick/grip_mp.c | 149 +++++----
- drivers/input/joystick/guillemot.c | 53 +--
- drivers/input/joystick/iforce/iforce-main.c | 106 +++---
- drivers/input/joystick/iforce/iforce-packets.c | 5
- drivers/input/joystick/iforce/iforce-serio.c | 10
- drivers/input/joystick/iforce/iforce-usb.c | 22 -
- drivers/input/joystick/iforce/iforce.h | 2
- drivers/input/joystick/interact.c | 55 +--
- drivers/input/joystick/magellan.c | 71 ++--
- drivers/input/joystick/sidewinder.c | 72 ++--
- drivers/input/joystick/spaceball.c | 82 ++---
- drivers/input/joystick/spaceorb.c | 78 ++--
- drivers/input/joystick/stinger.c | 75 ++--
- drivers/input/joystick/tmdc.c | 324 ++++++++++++--------
- drivers/input/joystick/turbografx.c | 223 ++++++++------
- drivers/input/joystick/twidjoy.c | 118 +++----
- drivers/input/joystick/warrior.c | 83 ++---
- 25 files changed, 1476 insertions(+), 1246 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/joystick/spaceball.c
-+++ gregkh-2.6/drivers/input/joystick/spaceball.c
-@@ -70,8 +70,7 @@ static char *spaceball_names[] = {
- */
-
- struct spaceball {
-- struct input_dev dev;
-- struct serio *serio;
-+ struct input_dev *dev;
- int idx;
- int escape;
- unsigned char data[SPACEBALL_MAX_LENGTH];
-@@ -85,7 +84,7 @@ struct spaceball {
-
- static void spaceball_process_packet(struct spaceball* spaceball, struct pt_regs *regs)
- {
-- struct input_dev *dev = &spaceball->dev;
-+ struct input_dev *dev = spaceball->dev;
- unsigned char *data = spaceball->data;
- int i;
-
-@@ -193,9 +192,9 @@ static void spaceball_disconnect(struct
- {
- struct spaceball* spaceball = serio_get_drvdata(serio);
-
-- input_unregister_device(&spaceball->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(spaceball->dev);
- kfree(spaceball);
- }
-
-@@ -208,69 +207,62 @@ static void spaceball_disconnect(struct
- static int spaceball_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct spaceball *spaceball;
-- int i, t, id;
-- int err;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-+ int i, id;
-
- if ((id = serio->id.id) > SPACEBALL_MAX_ID)
- return -ENODEV;
-
-- if (!(spaceball = kmalloc(sizeof(struct spaceball), GFP_KERNEL)))
-- return - ENOMEM;
-+ spaceball = kmalloc(sizeof(struct spaceball), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!spaceball || !input_dev)
-+ goto fail;
-
-- memset(spaceball, 0, sizeof(struct spaceball));
-+ spaceball->dev = input_dev;
-+ sprintf(spaceball->phys, "%s/input0", serio->phys);
-+
-+ input_dev->name = spaceball_names[id];
-+ input_dev->phys = spaceball->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_SPACEBALL;
-+ input_dev->id.product = id;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = spaceball;
-
-- spaceball->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- switch (id) {
- case SPACEBALL_4000FLX:
- case SPACEBALL_4000FLX_L:
-- spaceball->dev.keybit[LONG(BTN_0)] |= BIT(BTN_9);
-- spaceball->dev.keybit[LONG(BTN_A)] |= BIT(BTN_A) | BIT(BTN_B) | BIT(BTN_C) | BIT(BTN_MODE);
-+ input_dev->keybit[LONG(BTN_0)] |= BIT(BTN_9);
-+ input_dev->keybit[LONG(BTN_A)] |= BIT(BTN_A) | BIT(BTN_B) | BIT(BTN_C) | BIT(BTN_MODE);
- default:
-- spaceball->dev.keybit[LONG(BTN_0)] |= BIT(BTN_2) | BIT(BTN_3) | BIT(BTN_4)
-+ input_dev->keybit[LONG(BTN_0)] |= BIT(BTN_2) | BIT(BTN_3) | BIT(BTN_4)
- | BIT(BTN_5) | BIT(BTN_6) | BIT(BTN_7) | BIT(BTN_8);
- case SPACEBALL_3003C:
-- spaceball->dev.keybit[LONG(BTN_0)] |= BIT(BTN_1) | BIT(BTN_8);
-+ input_dev->keybit[LONG(BTN_0)] |= BIT(BTN_1) | BIT(BTN_8);
- }
-
-- for (i = 0; i < 6; i++) {
-- t = spaceball_axes[i];
-- set_bit(t, spaceball->dev.absbit);
-- spaceball->dev.absmin[t] = i < 3 ? -8000 : -1600;
-- spaceball->dev.absmax[t] = i < 3 ? 8000 : 1600;
-- spaceball->dev.absflat[t] = i < 3 ? 40 : 8;
-- spaceball->dev.absfuzz[t] = i < 3 ? 8 : 2;
-+ for (i = 0; i < 3; i++) {
-+ input_set_abs_params(input_dev, ABS_X + i, -8000, 8000, 8, 40);
-+ input_set_abs_params(input_dev, ABS_RX + i, -1600, 1600, 2, 8);
- }
-
-- spaceball->serio = serio;
-- spaceball->dev.private = spaceball;
--
-- sprintf(spaceball->phys, "%s/input0", serio->phys);
--
-- init_input_dev(&spaceball->dev);
-- spaceball->dev.name = spaceball_names[id];
-- spaceball->dev.phys = spaceball->phys;
-- spaceball->dev.id.bustype = BUS_RS232;
-- spaceball->dev.id.vendor = SERIO_SPACEBALL;
-- spaceball->dev.id.product = id;
-- spaceball->dev.id.version = 0x0100;
-- spaceball->dev.dev = &serio->dev;
--
- serio_set_drvdata(serio, spaceball);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(spaceball);
-- return err;
-- }
--
-- input_register_device(&spaceball->dev);
--
-- printk(KERN_INFO "input: %s on serio%s\n",
-- spaceball_names[id], serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(spaceball->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(spaceball);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/joystick/twidjoy.c
-+++ gregkh-2.6/drivers/input/joystick/twidjoy.c
-@@ -69,8 +69,6 @@ MODULE_LICENSE("GPL");
-
- #define TWIDJOY_MAX_LENGTH 5
-
--static char *twidjoy_name = "Handykey Twiddler";
--
- static struct twidjoy_button_spec {
- int bitshift;
- int bitmask;
-@@ -95,7 +93,7 @@ twidjoy_buttons[] = {
- */
-
- struct twidjoy {
-- struct input_dev dev;
-+ struct input_dev *dev;
- int idx;
- unsigned char data[TWIDJOY_MAX_LENGTH];
- char phys[32];
-@@ -108,37 +106,33 @@ struct twidjoy {
-
- static void twidjoy_process_packet(struct twidjoy *twidjoy, struct pt_regs *regs)
- {
-- if (twidjoy->idx == TWIDJOY_MAX_LENGTH) {
-- struct input_dev *dev = &twidjoy->dev;
-- unsigned char *data = twidjoy->data;
-- struct twidjoy_button_spec *bp;
-- int button_bits, abs_x, abs_y;
--
-- button_bits = ((data[1] & 0x7f) << 7) | (data[0] & 0x7f);
-+ struct input_dev *dev = twidjoy->dev;
-+ unsigned char *data = twidjoy->data;
-+ struct twidjoy_button_spec *bp;
-+ int button_bits, abs_x, abs_y;
-
-- input_regs(dev, regs);
-+ button_bits = ((data[1] & 0x7f) << 7) | (data[0] & 0x7f);
-
-- for (bp = twidjoy_buttons; bp->bitmask; bp++) {
-- int value = (button_bits & (bp->bitmask << bp->bitshift)) >> bp->bitshift;
-- int i;
-+ input_regs(dev, regs);
-
-- for (i = 0; i < bp->bitmask; i++)
-- input_report_key(dev, bp->buttons[i], i+1 == value);
-- }
-+ for (bp = twidjoy_buttons; bp->bitmask; bp++) {
-+ int value = (button_bits & (bp->bitmask << bp->bitshift)) >> bp->bitshift;
-+ int i;
-
-- abs_x = ((data[4] & 0x07) << 5) | ((data[3] & 0x7C) >> 2);
-- if (data[4] & 0x08) abs_x -= 256;
-+ for (i = 0; i < bp->bitmask; i++)
-+ input_report_key(dev, bp->buttons[i], i+1 == value);
-+ }
-
-- abs_y = ((data[3] & 0x01) << 7) | ((data[2] & 0x7F) >> 0);
-- if (data[3] & 0x02) abs_y -= 256;
-+ abs_x = ((data[4] & 0x07) << 5) | ((data[3] & 0x7C) >> 2);
-+ if (data[4] & 0x08) abs_x -= 256;
-
-- input_report_abs(dev, ABS_X, -abs_x);
-- input_report_abs(dev, ABS_Y, +abs_y);
-+ abs_y = ((data[3] & 0x01) << 7) | ((data[2] & 0x7F) >> 0);
-+ if (data[3] & 0x02) abs_y -= 256;
-
-- input_sync(dev);
-- }
-+ input_report_abs(dev, ABS_X, -abs_x);
-+ input_report_abs(dev, ABS_Y, +abs_y);
-
-- return;
-+ input_sync(dev);
- }
-
- /*
-@@ -179,9 +173,9 @@ static void twidjoy_disconnect(struct se
- {
- struct twidjoy *twidjoy = serio_get_drvdata(serio);
-
-- input_unregister_device(&twidjoy->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(twidjoy->dev);
- kfree(twidjoy);
- }
-
-@@ -195,59 +189,49 @@ static int twidjoy_connect(struct serio
- {
- struct twidjoy_button_spec *bp;
- struct twidjoy *twidjoy;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
- int i;
-- int err;
--
-- if (!(twidjoy = kmalloc(sizeof(struct twidjoy), GFP_KERNEL)))
-- return -ENOMEM;
-
-- memset(twidjoy, 0, sizeof(struct twidjoy));
-+ twidjoy = kzalloc(sizeof(struct twidjoy), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!twidjoy || !input_dev)
-+ goto fail;
-
-+ twidjoy->dev = input_dev;
- sprintf(twidjoy->phys, "%s/input0", serio->phys);
-
-- init_input_dev(&twidjoy->dev);
-- twidjoy->dev.name = twidjoy_name;
-- twidjoy->dev.phys = twidjoy->phys;
-- twidjoy->dev.id.bustype = BUS_RS232;
-- twidjoy->dev.id.vendor = SERIO_TWIDJOY;
-- twidjoy->dev.id.product = 0x0001;
-- twidjoy->dev.id.version = 0x0100;
-- twidjoy->dev.dev = &serio->dev;
-+ input_dev->name = "Handykey Twiddler";
-+ input_dev->phys = twidjoy->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_TWIDJOY;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = twidjoy;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-+ input_set_abs_params(input_dev, ABS_X, -50, 50, 4, 4);
-+ input_set_abs_params(input_dev, ABS_Y, -50, 50, 4, 4);
-
-- twidjoy->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
--
-- for (bp = twidjoy_buttons; bp->bitmask; bp++) {
-+ for (bp = twidjoy_buttons; bp->bitmask; bp++)
- for (i = 0; i < bp->bitmask; i++)
-- set_bit(bp->buttons[i], twidjoy->dev.keybit);
-- }
--
-- twidjoy->dev.absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
--
-- for (i = 0; i < 2; i++) {
-- twidjoy->dev.absmax[ABS_X+i] = 50;
-- twidjoy->dev.absmin[ABS_X+i] = -50;
--
-- /* TODO: arndt 20010708: Are these values appropriate? */
-- twidjoy->dev.absfuzz[ABS_X+i] = 4;
-- twidjoy->dev.absflat[ABS_X+i] = 4;
-- }
--
-- twidjoy->dev.private = twidjoy;
-+ set_bit(bp->buttons[i], input_dev->keybit);
-
- serio_set_drvdata(serio, twidjoy);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(twidjoy);
-- return err;
-- }
--
-- input_register_device(&twidjoy->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", twidjoy_name, serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(twidjoy->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(twidjoy);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/joystick/warrior.c
-+++ gregkh-2.6/drivers/input/joystick/warrior.c
-@@ -47,14 +47,13 @@ MODULE_LICENSE("GPL");
-
- #define WARRIOR_MAX_LENGTH 16
- static char warrior_lengths[] = { 0, 4, 12, 3, 4, 4, 0, 0 };
--static char *warrior_name = "Logitech WingMan Warrior";
-
- /*
- * Per-Warrior data.
- */
-
- struct warrior {
-- struct input_dev dev;
-+ struct input_dev *dev;
- int idx, len;
- unsigned char data[WARRIOR_MAX_LENGTH];
- char phys[32];
-@@ -67,7 +66,7 @@ struct warrior {
-
- static void warrior_process_packet(struct warrior *warrior, struct pt_regs *regs)
- {
-- struct input_dev *dev = &warrior->dev;
-+ struct input_dev *dev = warrior->dev;
- unsigned char *data = warrior->data;
-
- if (!warrior->idx) return;
-@@ -131,9 +130,9 @@ static void warrior_disconnect(struct se
- {
- struct warrior *warrior = serio_get_drvdata(serio);
-
-- input_unregister_device(&warrior->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(warrior->dev);
- kfree(warrior);
- }
-
-@@ -146,60 +145,48 @@ static void warrior_disconnect(struct se
- static int warrior_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct warrior *warrior;
-- int i;
-- int err;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-
-- if (!(warrior = kmalloc(sizeof(struct warrior), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(warrior, 0, sizeof(struct warrior));
--
-- warrior->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REL) | BIT(EV_ABS);
-- warrior->dev.keybit[LONG(BTN_TRIGGER)] = BIT(BTN_TRIGGER) | BIT(BTN_THUMB) | BIT(BTN_TOP) | BIT(BTN_TOP2);
-- warrior->dev.relbit[0] = BIT(REL_DIAL);
-- warrior->dev.absbit[0] = BIT(ABS_X) | BIT(ABS_Y) | BIT(ABS_THROTTLE) | BIT(ABS_HAT0X) | BIT(ABS_HAT0Y);
-+ warrior = kzalloc(sizeof(struct warrior), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!warrior || !input_dev)
-+ goto fail;
-
-+ warrior->dev = input_dev;
- sprintf(warrior->phys, "%s/input0", serio->phys);
-
-- init_input_dev(&warrior->dev);
-- warrior->dev.name = warrior_name;
-- warrior->dev.phys = warrior->phys;
-- warrior->dev.id.bustype = BUS_RS232;
-- warrior->dev.id.vendor = SERIO_WARRIOR;
-- warrior->dev.id.product = 0x0001;
-- warrior->dev.id.version = 0x0100;
-- warrior->dev.dev = &serio->dev;
--
-- for (i = 0; i < 2; i++) {
-- warrior->dev.absmax[ABS_X+i] = -64;
-- warrior->dev.absmin[ABS_X+i] = 64;
-- warrior->dev.absflat[ABS_X+i] = 8;
-- }
--
-- warrior->dev.absmax[ABS_THROTTLE] = -112;
-- warrior->dev.absmin[ABS_THROTTLE] = 112;
--
-- for (i = 0; i < 2; i++) {
-- warrior->dev.absmax[ABS_HAT0X+i] = -1;
-- warrior->dev.absmin[ABS_HAT0X+i] = 1;
-- }
--
-- warrior->dev.private = warrior;
-+ input_dev->name = "Logitech WingMan Warrior";
-+ input_dev->phys = warrior->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_WARRIOR;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = warrior;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_TRIGGER)] = BIT(BTN_TRIGGER) | BIT(BTN_THUMB) | BIT(BTN_TOP) | BIT(BTN_TOP2);
-+ input_dev->relbit[0] = BIT(REL_DIAL);
-+ input_set_abs_params(input_dev, ABS_X, -64, 64, 0, 8);
-+ input_set_abs_params(input_dev, ABS_Y, -64, 64, 0, 8);
-+ input_set_abs_params(input_dev, ABS_THROTTLE, -112, 112, 0, 0);
-+ input_set_abs_params(input_dev, ABS_HAT0X, -1, 1, 0, 0);
-+ input_set_abs_params(input_dev, ABS_HAT0X, -1, 1, 0, 0);
-
- serio_set_drvdata(serio, warrior);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(warrior);
-- return err;
-- }
--
-- input_register_device(&warrior->dev);
--
-- printk(KERN_INFO "input: Logitech WingMan Warrior on %s\n", serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(warrior->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(warrior);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/joystick/spaceorb.c
-+++ gregkh-2.6/drivers/input/joystick/spaceorb.c
-@@ -52,15 +52,13 @@ MODULE_LICENSE("GPL");
-
- static int spaceorb_buttons[] = { BTN_TL, BTN_TR, BTN_Y, BTN_X, BTN_B, BTN_A };
- static int spaceorb_axes[] = { ABS_X, ABS_Y, ABS_Z, ABS_RX, ABS_RY, ABS_RZ };
--static char *spaceorb_name = "SpaceTec SpaceOrb 360 / Avenger";
-
- /*
- * Per-Orb data.
- */
-
- struct spaceorb {
-- struct input_dev dev;
-- struct serio *serio;
-+ struct input_dev *dev;
- int idx;
- unsigned char data[SPACEORB_MAX_LENGTH];
- char phys[32];
-@@ -78,7 +76,7 @@ static unsigned char *spaceorb_errors[]
-
- static void spaceorb_process_packet(struct spaceorb *spaceorb, struct pt_regs *regs)
- {
-- struct input_dev *dev = &spaceorb->dev;
-+ struct input_dev *dev = spaceorb->dev;
- unsigned char *data = spaceorb->data;
- unsigned char c = 0;
- int axes[6];
-@@ -95,8 +93,8 @@ static void spaceorb_process_packet(stru
- case 'R': /* Reset packet */
- spaceorb->data[spaceorb->idx - 1] = 0;
- for (i = 1; i < spaceorb->idx && spaceorb->data[i] == ' '; i++);
-- printk(KERN_INFO "input: %s [%s] on %s\n",
-- spaceorb_name, spaceorb->data + i, spaceorb->serio->phys);
-+ printk(KERN_INFO "input: %s [%s] is %s\n",
-+ dev->name, spaceorb->data + i, spaceorb->phys);
- break;
-
- case 'D': /* Ball + button data */
-@@ -123,7 +121,7 @@ static void spaceorb_process_packet(stru
-
- case 'E': /* Error packet */
- if (spaceorb->idx != 4) return;
-- printk(KERN_ERR "joy-spaceorb: Device error. [ ");
-+ printk(KERN_ERR "spaceorb: Device error. [ ");
- for (i = 0; i < 7; i++) if (data[1] & (1 << i)) printk("%s ", spaceorb_errors[i]);
- printk("]\n");
- break;
-@@ -154,9 +152,9 @@ static void spaceorb_disconnect(struct s
- {
- struct spaceorb* spaceorb = serio_get_drvdata(serio);
-
-- input_unregister_device(&spaceorb->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(spaceorb->dev);
- kfree(spaceorb);
- }
-
-@@ -169,52 +167,48 @@ static void spaceorb_disconnect(struct s
- static int spaceorb_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct spaceorb *spaceorb;
-- int i, t;
-- int err;
--
-- if (!(spaceorb = kmalloc(sizeof(struct spaceorb), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(spaceorb, 0, sizeof(struct spaceorb));
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-+ int i;
-
-- spaceorb->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ spaceorb = kzalloc(sizeof(struct spaceorb), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!spaceorb || !input_dev)
-+ goto fail;
-
-- for (i = 0; i < 6; i++)
-- set_bit(spaceorb_buttons[i], spaceorb->dev.keybit);
-+ spaceorb->dev = input_dev;
-+ sprintf(spaceorb->phys, "%s/input0", serio->phys);
-
-- for (i = 0; i < 6; i++) {
-- t = spaceorb_axes[i];
-- set_bit(t, spaceorb->dev.absbit);
-- spaceorb->dev.absmin[t] = -508;
-- spaceorb->dev.absmax[t] = 508;
-- }
-+ input_dev->name = "SpaceTec SpaceOrb 360 / Avenger";
-+ input_dev->phys = spaceorb->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_SPACEORB;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = spaceorb;
-
-- spaceorb->serio = serio;
-- spaceorb->dev.private = spaceorb;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
-- sprintf(spaceorb->phys, "%s/input0", serio->phys);
-+ for (i = 0; i < 6; i++)
-+ set_bit(spaceorb_buttons[i], input_dev->keybit);
-
-- init_input_dev(&spaceorb->dev);
-- spaceorb->dev.name = spaceorb_name;
-- spaceorb->dev.phys = spaceorb->phys;
-- spaceorb->dev.id.bustype = BUS_RS232;
-- spaceorb->dev.id.vendor = SERIO_SPACEORB;
-- spaceorb->dev.id.product = 0x0001;
-- spaceorb->dev.id.version = 0x0100;
-- spaceorb->dev.dev = &serio->dev;
-+ for (i = 0; i < 6; i++)
-+ input_set_abs_params(input_dev, spaceorb_axes[i], -508, 508, 0, 0);
-
- serio_set_drvdata(serio, spaceorb);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(spaceorb);
-- return err;
-- }
--
-- input_register_device(&spaceorb->dev);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(spaceorb->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(spaceorb);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/joystick/magellan.c
-+++ gregkh-2.6/drivers/input/joystick/magellan.c
-@@ -49,14 +49,13 @@ MODULE_LICENSE("GPL");
-
- static int magellan_buttons[] = { BTN_0, BTN_1, BTN_2, BTN_3, BTN_4, BTN_5, BTN_6, BTN_7, BTN_8 };
- static int magellan_axes[] = { ABS_X, ABS_Y, ABS_Z, ABS_RX, ABS_RY, ABS_RZ };
--static char *magellan_name = "LogiCad3D Magellan / SpaceMouse";
-
- /*
- * Per-Magellan data.
- */
-
- struct magellan {
-- struct input_dev dev;
-+ struct input_dev *dev;
- int idx;
- unsigned char data[MAGELLAN_MAX_LENGTH];
- char phys[32];
-@@ -85,7 +84,7 @@ static int magellan_crunch_nibbles(unsig
-
- static void magellan_process_packet(struct magellan* magellan, struct pt_regs *regs)
- {
-- struct input_dev *dev = &magellan->dev;
-+ struct input_dev *dev = magellan->dev;
- unsigned char *data = magellan->data;
- int i, t;
-
-@@ -138,9 +137,9 @@ static void magellan_disconnect(struct s
- {
- struct magellan* magellan = serio_get_drvdata(serio);
-
-- input_unregister_device(&magellan->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(magellan->dev);
- kfree(magellan);
- }
-
-@@ -153,52 +152,48 @@ static void magellan_disconnect(struct s
- static int magellan_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct magellan *magellan;
-- int i, t;
-- int err;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-+ int i;
-+
-+ magellan = kzalloc(sizeof(struct magellan), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!magellan || !input_dev)
-+ goto fail;
-
-- if (!(magellan = kmalloc(sizeof(struct magellan), GFP_KERNEL)))
-- return -ENOMEM;
-+ magellan->dev = input_dev;
-+ sprintf(magellan->phys, "%s/input0", serio->phys);
-
-- memset(magellan, 0, sizeof(struct magellan));
-+ input_dev->name = "LogiCad3D Magellan / SpaceMouse";
-+ input_dev->phys = magellan->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_MAGELLAN;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = magellan;
-
-- magellan->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (i = 0; i < 9; i++)
-- set_bit(magellan_buttons[i], magellan->dev.keybit);
--
-- for (i = 0; i < 6; i++) {
-- t = magellan_axes[i];
-- set_bit(t, magellan->dev.absbit);
-- magellan->dev.absmin[t] = -360;
-- magellan->dev.absmax[t] = 360;
-- }
--
-- sprintf(magellan->phys, "%s/input0", serio->phys);
-+ set_bit(magellan_buttons[i], input_dev->keybit);
-
-- init_input_dev(&magellan->dev);
-- magellan->dev.private = magellan;
-- magellan->dev.name = magellan_name;
-- magellan->dev.phys = magellan->phys;
-- magellan->dev.id.bustype = BUS_RS232;
-- magellan->dev.id.vendor = SERIO_MAGELLAN;
-- magellan->dev.id.product = 0x0001;
-- magellan->dev.id.version = 0x0100;
-- magellan->dev.dev = &serio->dev;
-+ for (i = 0; i < 6; i++)
-+ input_set_abs_params(input_dev, magellan_axes[i], -360, 360, 0, 0);
-
- serio_set_drvdata(serio, magellan);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(magellan);
-- return err;
-- }
--
-- input_register_device(&magellan->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", magellan_name, serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(magellan->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(magellan);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/joystick/stinger.c
-+++ gregkh-2.6/drivers/input/joystick/stinger.c
-@@ -48,14 +48,12 @@ MODULE_LICENSE("GPL");
-
- #define STINGER_MAX_LENGTH 8
-
--static char *stinger_name = "Gravis Stinger";
--
- /*
- * Per-Stinger data.
- */
-
- struct stinger {
-- struct input_dev dev;
-+ struct input_dev *dev;
- int idx;
- unsigned char data[STINGER_MAX_LENGTH];
- char phys[32];
-@@ -68,7 +66,7 @@ struct stinger {
-
- static void stinger_process_packet(struct stinger *stinger, struct pt_regs *regs)
- {
-- struct input_dev *dev = &stinger->dev;
-+ struct input_dev *dev = stinger->dev;
- unsigned char *data = stinger->data;
-
- if (!stinger->idx) return;
-@@ -126,9 +124,9 @@ static void stinger_disconnect(struct se
- {
- struct stinger *stinger = serio_get_drvdata(serio);
-
-- input_unregister_device(&stinger->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(stinger->dev);
- kfree(stinger);
- }
-
-@@ -141,53 +139,46 @@ static void stinger_disconnect(struct se
- static int stinger_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct stinger *stinger;
-- int i;
-- int err;
--
-- if (!(stinger = kmalloc(sizeof(struct stinger), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(stinger, 0, sizeof(struct stinger));
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-
-- stinger->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- stinger->dev.keybit[LONG(BTN_A)] = BIT(BTN_A) | BIT(BTN_B) | BIT(BTN_C) | BIT(BTN_X) | \
-- BIT(BTN_Y) | BIT(BTN_Z) | BIT(BTN_TL) | BIT(BTN_TR) | \
-- BIT(BTN_START) | BIT(BTN_SELECT);
-- stinger->dev.absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-+ stinger = kmalloc(sizeof(struct stinger), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!stinger || !input_dev)
-+ goto fail;
-
-+ stinger->dev = input_dev;
- sprintf(stinger->phys, "%s/serio0", serio->phys);
-
-- init_input_dev(&stinger->dev);
-- stinger->dev.name = stinger_name;
-- stinger->dev.phys = stinger->phys;
-- stinger->dev.id.bustype = BUS_RS232;
-- stinger->dev.id.vendor = SERIO_STINGER;
-- stinger->dev.id.product = 0x0001;
-- stinger->dev.id.version = 0x0100;
-- stinger->dev.dev = &serio->dev;
--
-- for (i = 0; i < 2; i++) {
-- stinger->dev.absmax[ABS_X+i] = 64;
-- stinger->dev.absmin[ABS_X+i] = -64;
-- stinger->dev.absflat[ABS_X+i] = 4;
-- }
--
-- stinger->dev.private = stinger;
-+ input_dev->name = "Gravis Stinger";
-+ input_dev->phys = stinger->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_STINGER;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = stinger;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_A)] = BIT(BTN_A) | BIT(BTN_B) | BIT(BTN_C) | BIT(BTN_X) |
-+ BIT(BTN_Y) | BIT(BTN_Z) | BIT(BTN_TL) | BIT(BTN_TR) |
-+ BIT(BTN_START) | BIT(BTN_SELECT);
-+ input_set_abs_params(input_dev, ABS_X, -64, 64, 0, 4);
-+ input_set_abs_params(input_dev, ABS_Y, -64, 64, 0, 4);
-
- serio_set_drvdata(serio, stinger);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(stinger);
-- return err;
-- }
--
-- input_register_device(&stinger->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", stinger_name, serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(stinger->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(stinger);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/joystick/adi.c
-+++ gregkh-2.6/drivers/input/joystick/adi.c
-@@ -54,7 +54,7 @@ MODULE_LICENSE("GPL");
- #define ADI_MIN_LENGTH 8
- #define ADI_MIN_LEN_LENGTH 10
- #define ADI_MIN_ID_LENGTH 66
--#define ADI_MAX_NAME_LENGTH 48
-+#define ADI_MAX_NAME_LENGTH 64
- #define ADI_MAX_CNAME_LENGTH 16
- #define ADI_MAX_PHYS_LENGTH 64
-
-@@ -106,7 +106,7 @@ static struct {
- */
-
- struct adi {
-- struct input_dev dev;
-+ struct input_dev *dev;
- int length;
- int ret;
- int idx;
-@@ -215,7 +215,7 @@ static inline int adi_get_bits(struct ad
-
- static int adi_decode(struct adi *adi)
- {
-- struct input_dev *dev = &adi->dev;
-+ struct input_dev *dev = adi->dev;
- char *abs = adi->abs;
- short *key = adi->key;
- int i, t;
-@@ -318,7 +318,8 @@ static void adi_init_digital(struct game
-
- for (i = 0; seq[i]; i++) {
- gameport_trigger(gameport);
-- if (seq[i] > 0) msleep(seq[i]);
-+ if (seq[i] > 0)
-+ msleep(seq[i]);
- if (seq[i] < 0) {
- mdelay(-seq[i]);
- udelay(-seq[i]*14); /* It looks like mdelay() is off by approx 1.4% */
-@@ -397,42 +398,46 @@ static void adi_id_decode(struct adi *ad
- }
- }
-
--static void adi_init_input(struct adi *adi, struct adi_port *port, int half)
-+static int adi_init_input(struct adi *adi, struct adi_port *port, int half)
- {
-- int i, t;
-+ struct input_dev *input_dev;
- char buf[ADI_MAX_NAME_LENGTH];
-+ int i, t;
-
-- if (!adi->length) return;
--
-- init_input_dev(&adi->dev);
-+ adi->dev = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-
- t = adi->id < ADI_ID_MAX ? adi->id : ADI_ID_MAX;
-
- snprintf(buf, ADI_MAX_PHYS_LENGTH, adi_names[t], adi->id);
-- snprintf(adi->name, ADI_MAX_NAME_LENGTH, "Logitech %s", buf);
-+ snprintf(adi->name, ADI_MAX_NAME_LENGTH, "Logitech %s [%s]", buf, adi->cname);
- snprintf(adi->phys, ADI_MAX_PHYS_LENGTH, "%s/input%d", port->gameport->phys, half);
-
- adi->abs = adi_abs[t];
- adi->key = adi_key[t];
-
-- adi->dev.open = adi_open;
-- adi->dev.close = adi_close;
-+ input_dev->name = adi->name;
-+ input_dev->phys = adi->phys;
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_LOGITECH;
-+ input_dev->id.product = adi->id;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &port->gameport->dev;
-+ input_dev->private = port;
-
-- adi->dev.name = adi->name;
-- adi->dev.phys = adi->phys;
-- adi->dev.id.bustype = BUS_GAMEPORT;
-- adi->dev.id.vendor = GAMEPORT_ID_VENDOR_LOGITECH;
-- adi->dev.id.product = adi->id;
-- adi->dev.id.version = 0x0100;
-+ input_dev->open = adi_open;
-+ input_dev->close = adi_close;
-
-- adi->dev.private = port;
-- adi->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (i = 0; i < adi->axes10 + adi->axes8 + (adi->hats + (adi->pad != -1)) * 2; i++)
-- set_bit(adi->abs[i], adi->dev.absbit);
-+ set_bit(adi->abs[i], input_dev->absbit);
-
- for (i = 0; i < adi->buttons; i++)
-- set_bit(adi->key[i], adi->dev.keybit);
-+ set_bit(adi->key[i], input_dev->keybit);
-+
-+ return 0;
- }
-
- static void adi_init_center(struct adi *adi)
-@@ -445,17 +450,17 @@ static void adi_init_center(struct adi *
- for (i = 0; i < adi->axes10 + adi->axes8 + (adi->hats + (adi->pad != -1)) * 2; i++) {
-
- t = adi->abs[i];
-- x = adi->dev.abs[t];
-+ x = adi->dev->abs[t];
-
- if (t == ABS_THROTTLE || t == ABS_RUDDER || adi->id == ADI_ID_WGPE)
- x = i < adi->axes10 ? 512 : 128;
-
- if (i < adi->axes10)
-- input_set_abs_params(&adi->dev, t, 64, x * 2 - 64, 2, 16);
-+ input_set_abs_params(adi->dev, t, 64, x * 2 - 64, 2, 16);
- else if (i < adi->axes10 + adi->axes8)
-- input_set_abs_params(&adi->dev, t, 48, x * 2 - 48, 1, 16);
-+ input_set_abs_params(adi->dev, t, 48, x * 2 - 48, 1, 16);
- else
-- input_set_abs_params(&adi->dev, t, -1, 1, 0, 0);
-+ input_set_abs_params(adi->dev, t, -1, 1, 0, 0);
- }
- }
-
-@@ -469,7 +474,8 @@ static int adi_connect(struct gameport *
- int i;
- int err;
-
-- if (!(port = kzalloc(sizeof(struct adi_port), GFP_KERNEL)))
-+ port = kzalloc(sizeof(struct adi_port), GFP_KERNEL);
-+ if (!port)
- return -ENOMEM;
-
- port->gameport = gameport;
-@@ -477,10 +483,8 @@ static int adi_connect(struct gameport *
- gameport_set_drvdata(gameport, port);
-
- err = gameport_open(gameport, drv, GAMEPORT_MODE_RAW);
-- if (err) {
-- kfree(port);
-- return err;
-- }
-+ if (err)
-+ goto fail1;
-
- adi_init_digital(gameport);
- adi_read_packet(port);
-@@ -490,13 +494,18 @@ static int adi_connect(struct gameport *
-
- for (i = 0; i < 2; i++) {
- adi_id_decode(port->adi + i, port);
-- adi_init_input(port->adi + i, port, i);
-+
-+ if (!port->adi[i].length)
-+ continue;
-+
-+ err = adi_init_input(port->adi + i, port, i);
-+ if (err)
-+ goto fail2;
- }
-
- if (!port->adi[0].length && !port->adi[1].length) {
-- gameport_close(gameport);
-- kfree(port);
-- return -ENODEV;
-+ err = -ENODEV;
-+ goto fail2;
- }
-
- gameport_set_poll_handler(gameport, adi_poll);
-@@ -511,12 +520,18 @@ static int adi_connect(struct gameport *
- for (i = 0; i < 2; i++)
- if (port->adi[i].length > 0) {
- adi_init_center(port->adi + i);
-- input_register_device(&port->adi[i].dev);
-- printk(KERN_INFO "input: %s [%s] on %s\n",
-- port->adi[i].name, port->adi[i].cname, gameport->phys);
-+ input_register_device(port->adi[i].dev);
- }
-
- return 0;
-+
-+ fail2: for (i = 0; i < 2; i++)
-+ if (port->adi[i].dev)
-+ input_free_device(port->adi[i].dev);
-+ gameport_close(gameport);
-+ fail1: gameport_set_drvdata(gameport, NULL);
-+ kfree(port);
-+ return err;
- }
-
- static void adi_disconnect(struct gameport *gameport)
-@@ -526,7 +541,7 @@ static void adi_disconnect(struct gamepo
-
- for (i = 0; i < 2; i++)
- if (port->adi[i].length > 0)
-- input_unregister_device(&port->adi[i].dev);
-+ input_unregister_device(port->adi[i].dev);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(port);
---- gregkh-2.6.orig/drivers/input/joystick/amijoy.c
-+++ gregkh-2.6/drivers/input/joystick/amijoy.c
-@@ -53,11 +53,9 @@ __obsolete_setup("amijoy=");
-
- static int amijoy_used;
- static DECLARE_MUTEX(amijoy_sem);
--static struct input_dev amijoy_dev[2];
-+static struct input_dev *amijoy_dev[2];
- static char *amijoy_phys[2] = { "amijoy/input0", "amijoy/input1" };
-
--static char *amijoy_name = "Amiga joystick";
--
- static irqreturn_t amijoy_interrupt(int irq, void *dummy, struct pt_regs *fp)
- {
- int i, data = 0, button = 0;
-@@ -70,15 +68,15 @@ static irqreturn_t amijoy_interrupt(int
- case 1: data = ~custom.joy1dat; button = (~ciaa.pra >> 7) & 1; break;
- }
-
-- input_regs(amijoy_dev + i, fp);
-+ input_regs(amijoy_dev[i], fp);
-
-- input_report_key(amijoy_dev + i, BTN_TRIGGER, button);
-+ input_report_key(amijoy_dev[i], BTN_TRIGGER, button);
-
-- input_report_abs(amijoy_dev + i, ABS_X, ((data >> 1) & 1) - ((data >> 9) & 1));
-+ input_report_abs(amijoy_dev[i], ABS_X, ((data >> 1) & 1) - ((data >> 9) & 1));
- data = ~(data ^ (data << 1));
-- input_report_abs(amijoy_dev + i, ABS_Y, ((data >> 1) & 1) - ((data >> 9) & 1));
-+ input_report_abs(amijoy_dev[i], ABS_Y, ((data >> 1) & 1) - ((data >> 9) & 1));
-
-- input_sync(amijoy_dev + i);
-+ input_sync(amijoy_dev[i]);
- }
- return IRQ_HANDLED;
- }
-@@ -114,39 +112,52 @@ static void amijoy_close(struct input_de
- static int __init amijoy_init(void)
- {
- int i, j;
-+ int err;
-
-- for (i = 0; i < 2; i++)
-- if (amijoy[i]) {
-- if (!request_mem_region(CUSTOM_PHYSADDR+10+i*2, 2,
-- "amijoy [Denise]")) {
-- if (i == 1 && amijoy[0]) {
-- input_unregister_device(amijoy_dev);
-- release_mem_region(CUSTOM_PHYSADDR+10, 2);
-- }
-- return -EBUSY;
-- }
--
-- amijoy_dev[i].open = amijoy_open;
-- amijoy_dev[i].close = amijoy_close;
-- amijoy_dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- amijoy_dev[i].absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-- amijoy_dev[i].keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-- for (j = 0; j < 2; j++) {
-- amijoy_dev[i].absmin[ABS_X + j] = -1;
-- amijoy_dev[i].absmax[ABS_X + j] = 1;
-- }
-+ for (i = 0; i < 2; i++) {
-+ if (!amijoy[i])
-+ continue;
-+
-+ amijoy_dev[i] = input_allocate_device();
-+ if (!amijoy_dev[i]) {
-+ err = -ENOMEM;
-+ goto fail;
-+ }
-
-- amijoy_dev[i].name = amijoy_name;
-- amijoy_dev[i].phys = amijoy_phys[i];
-- amijoy_dev[i].id.bustype = BUS_AMIGA;
-- amijoy_dev[i].id.vendor = 0x0001;
-- amijoy_dev[i].id.product = 0x0003;
-- amijoy_dev[i].id.version = 0x0100;
-+ if (!request_mem_region(CUSTOM_PHYSADDR + 10 + i * 2, 2, "amijoy [Denise]")) {
-+ input_free_device(amijoy_dev[i]);
-+ err = -EBUSY;
-+ goto fail;
-+ }
-
-- input_register_device(amijoy_dev + i);
-- printk(KERN_INFO "input: %s at joy%ddat\n", amijoy_name, i);
-+ amijoy_dev[i]->name = "Amiga joystick";
-+ amijoy_dev[i]->phys = amijoy_phys[i];
-+ amijoy_dev[i]->id.bustype = BUS_AMIGA;
-+ amijoy_dev[i]->id.vendor = 0x0001;
-+ amijoy_dev[i]->id.product = 0x0003;
-+ amijoy_dev[i]->id.version = 0x0100;
-+
-+ amijoy_dev[i]->open = amijoy_open;
-+ amijoy_dev[i]->close = amijoy_close;
-+
-+ amijoy_dev[i]->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ amijoy_dev[i]->absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-+ amijoy_dev[i]->keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ for (j = 0; j < 2; j++) {
-+ amijoy_dev[i]->absmin[ABS_X + j] = -1;
-+ amijoy_dev[i]->absmax[ABS_X + j] = 1;
- }
-+
-+ input_register_device(amijoy_dev[i]);
-+ }
- return 0;
-+
-+ fail: while (--i >= 0)
-+ if (amijoy[i]) {
-+ input_unregister_device(amijoy_dev[i]);
-+ release_mem_region(CUSTOM_PHYSADDR + 10 + i * 2, 2);
-+ }
-+ return err;
- }
-
- static void __exit amijoy_exit(void)
-@@ -155,8 +166,8 @@ static void __exit amijoy_exit(void)
-
- for (i = 0; i < 2; i++)
- if (amijoy[i]) {
-- input_unregister_device(amijoy_dev + i);
-- release_mem_region(CUSTOM_PHYSADDR+10+i*2, 2);
-+ input_unregister_device(amijoy_dev[i]);
-+ release_mem_region(CUSTOM_PHYSADDR + 10 + i * 2, 2);
- }
- }
-
---- gregkh-2.6.orig/drivers/input/joystick/analog.c
-+++ gregkh-2.6/drivers/input/joystick/analog.c
-@@ -111,7 +111,7 @@ static short analog_joy_btn[] = { BTN_TR
- static unsigned char analog_chf[] = { 0xf, 0x0, 0x1, 0x9, 0x2, 0x4, 0xc, 0x8, 0x3, 0x5, 0xb, 0x7, 0xd, 0xe, 0xa, 0x6 };
-
- struct analog {
-- struct input_dev dev;
-+ struct input_dev *dev;
- int mask;
- short *buttons;
- char name[ANALOG_MAX_NAME_LENGTH];
-@@ -182,7 +182,7 @@ static unsigned long analog_faketime = 0
-
- static void analog_decode(struct analog *analog, int *axes, int *initial, int buttons)
- {
-- struct input_dev *dev = &analog->dev;
-+ struct input_dev *dev = analog->dev;
- int i, j;
-
- if (analog->mask & ANALOG_HAT_FCS)
-@@ -428,27 +428,30 @@ static void analog_name(struct analog *a
- * analog_init_device()
- */
-
--static void analog_init_device(struct analog_port *port, struct analog *analog, int index)
-+static int analog_init_device(struct analog_port *port, struct analog *analog, int index)
- {
-+ struct input_dev *input_dev;
- int i, j, t, v, w, x, y, z;
-
- analog_name(analog);
- sprintf(analog->phys, "%s/input%d", port->gameport->phys, index);
- analog->buttons = (analog->mask & ANALOG_GAMEPAD) ? analog_pad_btn : analog_joy_btn;
-
-- init_input_dev(&analog->dev);
--
-- analog->dev.name = analog->name;
-- analog->dev.phys = analog->phys;
-- analog->dev.id.bustype = BUS_GAMEPORT;
-- analog->dev.id.vendor = GAMEPORT_ID_VENDOR_ANALOG;
-- analog->dev.id.product = analog->mask >> 4;
-- analog->dev.id.version = 0x0100;
--
-- analog->dev.open = analog_open;
-- analog->dev.close = analog_close;
-- analog->dev.private = port;
-- analog->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ analog->dev = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-+
-+ input_dev->name = analog->name;
-+ input_dev->phys = analog->phys;
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_ANALOG;
-+ input_dev->id.product = analog->mask >> 4;
-+ input_dev->id.version = 0x0100;
-+
-+ input_dev->open = analog_open;
-+ input_dev->close = analog_close;
-+ input_dev->private = port;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (i = j = 0; i < 4; i++)
- if (analog->mask & (1 << i)) {
-@@ -461,8 +464,6 @@ static void analog_init_device(struct an
- v = (x >> 3);
- w = (x >> 3);
-
-- set_bit(t, analog->dev.absbit);
--
- if ((i == 2 || i == 3) && (j == 2 || j == 3) && (z > (y >> 3)))
- x = y;
-
-@@ -472,11 +473,7 @@ static void analog_init_device(struct an
- w = (x >> 4);
- }
-
-- analog->dev.absmax[t] = (x << 1) - v;
-- analog->dev.absmin[t] = v;
-- analog->dev.absfuzz[t] = port->fuzz;
-- analog->dev.absflat[t] = w;
--
-+ input_set_abs_params(input_dev, t, v, (x << 1) - v, port->fuzz, w);
- j++;
- }
-
-@@ -484,41 +481,30 @@ static void analog_init_device(struct an
- if (analog->mask & analog_exts[i])
- for (x = 0; x < 2; x++) {
- t = analog_hats[j++];
-- set_bit(t, analog->dev.absbit);
-- analog->dev.absmax[t] = 1;
-- analog->dev.absmin[t] = -1;
-+ input_set_abs_params(input_dev, t, -1, 1, 0, 0);
- }
-
- for (i = j = 0; i < 4; i++)
- if (analog->mask & (0x10 << i))
-- set_bit(analog->buttons[j++], analog->dev.keybit);
-+ set_bit(analog->buttons[j++], input_dev->keybit);
-
- if (analog->mask & ANALOG_BTNS_CHF)
- for (i = 0; i < 2; i++)
-- set_bit(analog->buttons[j++], analog->dev.keybit);
-+ set_bit(analog->buttons[j++], input_dev->keybit);
-
- if (analog->mask & ANALOG_HBTN_CHF)
- for (i = 0; i < 4; i++)
-- set_bit(analog->buttons[j++], analog->dev.keybit);
-+ set_bit(analog->buttons[j++], input_dev->keybit);
-
- for (i = 0; i < 4; i++)
- if (analog->mask & (ANALOG_BTN_TL << i))
-- set_bit(analog_pads[i], analog->dev.keybit);
-+ set_bit(analog_pads[i], input_dev->keybit);
-
- analog_decode(analog, port->axes, port->initial, port->buttons);
-
-- input_register_device(&analog->dev);
--
-- printk(KERN_INFO "input: %s at %s", analog->name, port->gameport->phys);
-+ input_register_device(analog->dev);
-
-- if (port->cooked)
-- printk(" [ADC port]\n");
-- else
-- printk(" [%s timer, %d %sHz clock, %d ns res]\n", TIME_NAME,
-- port->speed > 10000 ? (port->speed + 800) / 1000 : port->speed,
-- port->speed > 10000 ? "M" : "k",
-- port->speed > 10000 ? (port->loop * 1000) / (port->speed / 1000)
-- : (port->loop * 1000000) / port->speed);
-+ return 0;
- }
-
- /*
-@@ -659,37 +645,41 @@ static int analog_connect(struct gamepor
- return - ENOMEM;
-
- err = analog_init_port(gameport, drv, port);
-- if (err) {
-- kfree(port);
-- return err;
-- }
-+ if (err)
-+ goto fail1;
-
- err = analog_init_masks(port);
-- if (err) {
-- gameport_close(gameport);
-- gameport_set_drvdata(gameport, NULL);
-- kfree(port);
-- return err;
-- }
-+ if (err)
-+ goto fail2;
-
- gameport_set_poll_handler(gameport, analog_poll);
- gameport_set_poll_interval(gameport, 10);
-
- for (i = 0; i < 2; i++)
-- if (port->analog[i].mask)
-- analog_init_device(port, port->analog + i, i);
-+ if (port->analog[i].mask) {
-+ err = analog_init_device(port, port->analog + i, i);
-+ if (err)
-+ goto fail3;
-+ }
-
- return 0;
-+
-+ fail3: while (--i >= 0)
-+ input_unregister_device(port->analog[i].dev);
-+ fail2: gameport_close(gameport);
-+ fail1: gameport_set_drvdata(gameport, NULL);
-+ kfree(port);
-+ return err;
- }
-
- static void analog_disconnect(struct gameport *gameport)
- {
-- int i;
- struct analog_port *port = gameport_get_drvdata(gameport);
-+ int i;
-
- for (i = 0; i < 2; i++)
- if (port->analog[i].mask)
-- input_unregister_device(&port->analog[i].dev);
-+ input_unregister_device(port->analog[i].dev);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- printk(KERN_INFO "analog.c: %d out of %d reads (%d%%) on %s failed\n",
---- gregkh-2.6.orig/drivers/input/joystick/cobra.c
-+++ gregkh-2.6/drivers/input/joystick/cobra.c
-@@ -44,13 +44,11 @@ MODULE_LICENSE("GPL");
- #define COBRA_MAX_STROBE 45 /* 45 us max wait for first strobe */
- #define COBRA_LENGTH 36
-
--static char* cobra_name = "Creative Labs Blaster GamePad Cobra";
--
- static int cobra_btn[] = { BTN_START, BTN_SELECT, BTN_TL, BTN_TR, BTN_X, BTN_Y, BTN_Z, BTN_A, BTN_B, BTN_C, BTN_TL2, BTN_TR2, 0 };
-
- struct cobra {
- struct gameport *gameport;
-- struct input_dev dev[2];
-+ struct input_dev *dev[2];
- int reads;
- int bads;
- unsigned char exists;
-@@ -128,7 +126,7 @@ static void cobra_poll(struct gameport *
- for (i = 0; i < 2; i++)
- if (cobra->exists & r & (1 << i)) {
-
-- dev = cobra->dev + i;
-+ dev = cobra->dev[i];
-
- input_report_abs(dev, ABS_X, ((data[i] >> 4) & 1) - ((data[i] >> 3) & 1));
- input_report_abs(dev, ABS_Y, ((data[i] >> 2) & 1) - ((data[i] >> 1) & 1));
-@@ -159,11 +157,13 @@ static void cobra_close(struct input_dev
- static int cobra_connect(struct gameport *gameport, struct gameport_driver *drv)
- {
- struct cobra *cobra;
-+ struct input_dev *input_dev;
- unsigned int data[2];
- int i, j;
- int err;
-
-- if (!(cobra = kzalloc(sizeof(struct cobra), GFP_KERNEL)))
-+ cobra = kzalloc(sizeof(struct cobra), GFP_KERNEL);
-+ if (!cobra)
- return -ENOMEM;
-
- cobra->gameport = gameport;
-@@ -191,38 +191,46 @@ static int cobra_connect(struct gameport
- gameport_set_poll_handler(gameport, cobra_poll);
- gameport_set_poll_interval(gameport, 20);
-
-- for (i = 0; i < 2; i++)
-- if ((cobra->exists >> i) & 1) {
--
-- sprintf(cobra->phys[i], "%s/input%d", gameport->phys, i);
--
-- cobra->dev[i].private = cobra;
-- cobra->dev[i].open = cobra_open;
-- cobra->dev[i].close = cobra_close;
--
-- cobra->dev[i].name = cobra_name;
-- cobra->dev[i].phys = cobra->phys[i];
-- cobra->dev[i].id.bustype = BUS_GAMEPORT;
-- cobra->dev[i].id.vendor = GAMEPORT_ID_VENDOR_CREATIVE;
-- cobra->dev[i].id.product = 0x0008;
-- cobra->dev[i].id.version = 0x0100;
-+ for (i = 0; i < 2; i++) {
-+ if (~(cobra->exists >> i) & 1)
-+ continue;
-
-- cobra->dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ cobra->dev[i] = input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ err = -ENOMEM;
-+ goto fail3;
-+ }
-
-- input_set_abs_params(&cobra->dev[i], ABS_X, -1, 1, 0, 0);
-- input_set_abs_params(&cobra->dev[i], ABS_Y, -1, 1, 0, 0);
-+ sprintf(cobra->phys[i], "%s/input%d", gameport->phys, i);
-
-- for (j = 0; cobra_btn[j]; j++)
-- set_bit(cobra_btn[j], cobra->dev[i].keybit);
-+ input_dev->name = "Creative Labs Blaster GamePad Cobra";
-+ input_dev->phys = cobra->phys[i];
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_CREATIVE;
-+ input_dev->id.product = 0x0008;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &gameport->dev;
-+ input_dev->private = cobra;
-+
-+ input_dev->open = cobra_open;
-+ input_dev->close = cobra_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_set_abs_params(input_dev, ABS_X, -1, 1, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, -1, 1, 0, 0);
-+ for (j = 0; cobra_btn[j]; j++)
-+ set_bit(cobra_btn[j], input_dev->keybit);
-
-- input_register_device(&cobra->dev[i]);
-- printk(KERN_INFO "input: %s on %s\n", cobra_name, gameport->phys);
-- }
-+ input_register_device(cobra->dev[i]);
-+ }
-
- return 0;
-
--fail2: gameport_close(gameport);
--fail1: gameport_set_drvdata(gameport, NULL);
-+ fail3: for (i = 0; i < 2; i++)
-+ if (cobra->dev[i])
-+ input_unregister_device(cobra->dev[i]);
-+ fail2: gameport_close(gameport);
-+ fail1: gameport_set_drvdata(gameport, NULL);
- kfree(cobra);
- return err;
- }
-@@ -234,7 +242,7 @@ static void cobra_disconnect(struct game
-
- for (i = 0; i < 2; i++)
- if ((cobra->exists >> i) & 1)
-- input_unregister_device(cobra->dev + i);
-+ input_unregister_device(cobra->dev[i]);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(cobra);
---- gregkh-2.6.orig/drivers/input/joystick/db9.c
-+++ gregkh-2.6/drivers/input/joystick/db9.c
-@@ -43,25 +43,28 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@u
- MODULE_DESCRIPTION("Atari, Amstrad, Commodore, Amiga, Sega, etc. joystick driver");
- MODULE_LICENSE("GPL");
-
--static int db9[] __initdata = { -1, 0 };
--static int db9_nargs __initdata = 0;
--module_param_array_named(dev, db9, int, &db9_nargs, 0);
--MODULE_PARM_DESC(dev, "Describes first attached device (<parport#>,<type>)");
-+struct db9_config {
-+ int args[2];
-+ int nargs;
-+};
-
--static int db9_2[] __initdata = { -1, 0 };
--static int db9_nargs_2 __initdata = 0;
--module_param_array_named(dev2, db9_2, int, &db9_nargs_2, 0);
--MODULE_PARM_DESC(dev2, "Describes second attached device (<parport#>,<type>)");
-+#define DB9_MAX_PORTS 3
-+static struct db9_config db9[DB9_MAX_PORTS] __initdata;
-
--static int db9_3[] __initdata = { -1, 0 };
--static int db9_nargs_3 __initdata = 0;
--module_param_array_named(dev3, db9_3, int, &db9_nargs_3, 0);
-+module_param_array_named(dev, db9[0].args, int, &db9[0].nargs, 0);
-+MODULE_PARM_DESC(dev, "Describes first attached device (<parport#>,<type>)");
-+module_param_array_named(dev2, db9[1].args, int, &db9[0].nargs, 0);
-+MODULE_PARM_DESC(dev2, "Describes second attached device (<parport#>,<type>)");
-+module_param_array_named(dev3, db9[2].args, int, &db9[2].nargs, 0);
- MODULE_PARM_DESC(dev3, "Describes third attached device (<parport#>,<type>)");
-
- __obsolete_setup("db9=");
- __obsolete_setup("db9_2=");
- __obsolete_setup("db9_3=");
-
-+#define DB9_ARG_PARPORT 0
-+#define DB9_ARG_MODE 1
-+
- #define DB9_MULTI_STICK 0x01
- #define DB9_MULTI2_STICK 0x02
- #define DB9_GENESIS_PAD 0x03
-@@ -87,40 +90,53 @@ __obsolete_setup("db9_3=");
- #define DB9_NORMAL 0x0a
- #define DB9_NOSELECT 0x08
-
--#define DB9_MAX_DEVICES 2
--
- #define DB9_GENESIS6_DELAY 14
- #define DB9_REFRESH_TIME HZ/100
-
-+#define DB9_MAX_DEVICES 2
-+
-+struct db9_mode_data {
-+ const char *name;
-+ const short *buttons;
-+ int n_buttons;
-+ int n_pads;
-+ int n_axis;
-+ int bidirectional;
-+ int reverse;
-+};
-+
- struct db9 {
-- struct input_dev dev[DB9_MAX_DEVICES];
-+ struct input_dev *dev[DB9_MAX_DEVICES];
- struct timer_list timer;
- struct pardevice *pd;
- int mode;
- int used;
- struct semaphore sem;
-- char phys[2][32];
-+ char phys[DB9_MAX_DEVICES][32];
- };
-
- static struct db9 *db9_base[3];
-
--static short db9_multi_btn[] = { BTN_TRIGGER, BTN_THUMB };
--static short db9_genesis_btn[] = { BTN_START, BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z, BTN_MODE };
--static short db9_cd32_btn[] = { BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z, BTN_TL, BTN_TR, BTN_START };
--
--static char db9_buttons[DB9_MAX_PAD] = { 0, 1, 2, 4, 0, 6, 8, 9, 1, 1, 7, 9, 9 };
--static short *db9_btn[DB9_MAX_PAD] = { NULL, db9_multi_btn, db9_multi_btn, db9_genesis_btn, NULL, db9_genesis_btn,
-- db9_genesis_btn, db9_cd32_btn, db9_multi_btn, db9_multi_btn, db9_cd32_btn,
-- db9_cd32_btn, db9_cd32_btn };
--static char *db9_name[DB9_MAX_PAD] = { NULL, "Multisystem joystick", "Multisystem joystick (2 fire)", "Genesis pad",
-- NULL, "Genesis 5 pad", "Genesis 6 pad", "Saturn pad", "Multisystem (0.8.0.2) joystick",
-- "Multisystem (0.8.0.2-dual) joystick", "Amiga CD-32 pad", "Saturn dpp", "Saturn dpp dual" };
--
--static const int db9_max_pads[DB9_MAX_PAD] = { 0, 1, 1, 1, 0, 1, 1, 6, 1, 2, 1, 6, 12 };
--static const int db9_num_axis[DB9_MAX_PAD] = { 0, 2, 2, 2, 0, 2, 2, 7, 2, 2, 2 ,7, 7 };
-+static const short db9_multi_btn[] = { BTN_TRIGGER, BTN_THUMB };
-+static const short db9_genesis_btn[] = { BTN_START, BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z, BTN_MODE };
-+static const short db9_cd32_btn[] = { BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z, BTN_TL, BTN_TR, BTN_START };
- static const short db9_abs[] = { ABS_X, ABS_Y, ABS_RX, ABS_RY, ABS_RZ, ABS_Z, ABS_HAT0X, ABS_HAT0Y, ABS_HAT1X, ABS_HAT1Y };
--static const int db9_bidirectional[DB9_MAX_PAD] = { 0, 1, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0 };
--static const int db9_reverse[DB9_MAX_PAD] = { 0, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0, 0 };
-+
-+static const struct db9_mode_data db9_modes[] = {
-+ { NULL, NULL, 0, 0, 0, 0, 0 },
-+ { "Multisystem joystick", db9_multi_btn, 1, 1, 2, 1, 1 },
-+ { "Multisystem joystick (2 fire)", db9_multi_btn, 2, 1, 2, 1, 1 },
-+ { "Genesis pad", db9_genesis_btn, 4, 1, 2, 1, 1 },
-+ { NULL, NULL, 0, 0, 0, 0, 0 },
-+ { "Genesis 5 pad", db9_genesis_btn, 6, 1, 2, 1, 1 },
-+ { "Genesis 6 pad", db9_genesis_btn, 8, 1, 2, 1, 1 },
-+ { "Saturn pad", db9_cd32_btn, 9, 6, 7, 0, 1 },
-+ { "Multisystem (0.8.0.2) joystick", db9_multi_btn, 1, 1, 2, 1, 1 },
-+ { "Multisystem (0.8.0.2-dual) joystick", db9_multi_btn, 1, 2, 2, 1, 1 },
-+ { "Amiga CD-32 pad", db9_cd32_btn, 7, 1, 2, 1, 1 },
-+ { "Saturn dpp", db9_cd32_btn, 9, 6, 7, 0, 0 },
-+ { "Saturn dpp dual", db9_cd32_btn, 9, 12, 7, 0, 0 },
-+};
-
- /*
- * Saturn controllers
-@@ -342,7 +358,7 @@ static int db9_saturn(int mode, struct p
- default:
- return -1;
- }
-- max_pads = min(db9_max_pads[mode], DB9_MAX_DEVICES);
-+ max_pads = min(db9_modes[mode].n_pads, DB9_MAX_DEVICES);
- for (tmp = 0, i = 0; i < n; i++) {
- id = db9_saturn_read_packet(port, data, type + i, 1);
- tmp = db9_saturn_report(id, data, dev, tmp, max_pads);
-@@ -354,17 +370,18 @@ static void db9_timer(unsigned long priv
- {
- struct db9 *db9 = (void *) private;
- struct parport *port = db9->pd->port;
-- struct input_dev *dev = db9->dev;
-+ struct input_dev *dev = db9->dev[0];
-+ struct input_dev *dev2 = db9->dev[1];
- int data, i;
-
-- switch(db9->mode) {
-+ switch (db9->mode) {
- case DB9_MULTI_0802_2:
-
- data = parport_read_data(port) >> 3;
-
-- input_report_abs(dev + 1, ABS_X, (data & DB9_RIGHT ? 0 : 1) - (data & DB9_LEFT ? 0 : 1));
-- input_report_abs(dev + 1, ABS_Y, (data & DB9_DOWN ? 0 : 1) - (data & DB9_UP ? 0 : 1));
-- input_report_key(dev + 1, BTN_TRIGGER, ~data & DB9_FIRE1);
-+ input_report_abs(dev2, ABS_X, (data & DB9_RIGHT ? 0 : 1) - (data & DB9_LEFT ? 0 : 1));
-+ input_report_abs(dev2, ABS_Y, (data & DB9_DOWN ? 0 : 1) - (data & DB9_UP ? 0 : 1));
-+ input_report_key(dev2, BTN_TRIGGER, ~data & DB9_FIRE1);
-
- case DB9_MULTI_0802:
-
-@@ -405,7 +422,7 @@ static void db9_timer(unsigned long priv
- input_report_key(dev, BTN_C, ~data & DB9_FIRE2);
-
- parport_write_control(port, DB9_NORMAL);
-- data=parport_read_data(port);
-+ data = parport_read_data(port);
-
- input_report_key(dev, BTN_A, ~data & DB9_FIRE1);
- input_report_key(dev, BTN_START, ~data & DB9_FIRE2);
-@@ -414,7 +431,7 @@ static void db9_timer(unsigned long priv
- case DB9_GENESIS5_PAD:
-
- parport_write_control(port, DB9_NOSELECT);
-- data=parport_read_data(port);
-+ data = parport_read_data(port);
-
- input_report_abs(dev, ABS_X, (data & DB9_RIGHT ? 0 : 1) - (data & DB9_LEFT ? 0 : 1));
- input_report_abs(dev, ABS_Y, (data & DB9_DOWN ? 0 : 1) - (data & DB9_UP ? 0 : 1));
-@@ -422,7 +439,7 @@ static void db9_timer(unsigned long priv
- input_report_key(dev, BTN_C, ~data & DB9_FIRE2);
-
- parport_write_control(port, DB9_NORMAL);
-- data=parport_read_data(port);
-+ data = parport_read_data(port);
-
- input_report_key(dev, BTN_A, ~data & DB9_FIRE1);
- input_report_key(dev, BTN_X, ~data & DB9_FIRE2);
-@@ -434,7 +451,7 @@ static void db9_timer(unsigned long priv
-
- parport_write_control(port, DB9_NOSELECT); /* 1 */
- udelay(DB9_GENESIS6_DELAY);
-- data=parport_read_data(port);
-+ data = parport_read_data(port);
-
- input_report_abs(dev, ABS_X, (data & DB9_RIGHT ? 0 : 1) - (data & DB9_LEFT ? 0 : 1));
- input_report_abs(dev, ABS_Y, (data & DB9_DOWN ? 0 : 1) - (data & DB9_UP ? 0 : 1));
-@@ -443,7 +460,7 @@ static void db9_timer(unsigned long priv
-
- parport_write_control(port, DB9_NORMAL);
- udelay(DB9_GENESIS6_DELAY);
-- data=parport_read_data(port);
-+ data = parport_read_data(port);
-
- input_report_key(dev, BTN_A, ~data & DB9_FIRE1);
- input_report_key(dev, BTN_START, ~data & DB9_FIRE2);
-@@ -477,7 +494,7 @@ static void db9_timer(unsigned long priv
-
- case DB9_CD32_PAD:
-
-- data=parport_read_data(port);
-+ data = parport_read_data(port);
-
- input_report_abs(dev, ABS_X, (data & DB9_RIGHT ? 0 : 1) - (data & DB9_LEFT ? 0 : 1));
- input_report_abs(dev, ABS_Y, (data & DB9_DOWN ? 0 : 1) - (data & DB9_UP ? 0 : 1));
-@@ -489,7 +506,7 @@ static void db9_timer(unsigned long priv
- parport_write_control(port, 0x02);
- parport_write_control(port, 0x0a);
- input_report_key(dev, db9_cd32_btn[i], ~data & DB9_FIRE2);
-- }
-+ }
-
- parport_write_control(port, 0x00);
- break;
-@@ -513,7 +530,7 @@ static int db9_open(struct input_dev *de
- if (!db9->used++) {
- parport_claim(db9->pd);
- parport_write_data(port, 0xff);
-- if (db9_reverse[db9->mode]) {
-+ if (db9_modes[db9->mode].reverse) {
- parport_data_reverse(port);
- parport_write_control(port, DB9_NORMAL);
- }
-@@ -539,117 +556,160 @@ static void db9_close(struct input_dev *
- up(&db9->sem);
- }
-
--static struct db9 __init *db9_probe(int *config, int nargs)
-+static struct db9 __init *db9_probe(int parport, int mode)
- {
- struct db9 *db9;
-+ const struct db9_mode_data *db9_mode;
- struct parport *pp;
-+ struct pardevice *pd;
-+ struct input_dev *input_dev;
- int i, j;
-+ int err;
-
-- if (config[0] < 0)
-- return NULL;
--
-- if (nargs < 2) {
-- printk(KERN_ERR "db9.c: Device type must be specified.\n");
-- return NULL;
-+ if (mode < 1 || mode >= DB9_MAX_PAD || !db9_modes[mode].n_buttons) {
-+ printk(KERN_ERR "db9.c: Bad device type %d\n", mode);
-+ err = -EINVAL;
-+ goto err_out;
- }
-
-- if (config[1] < 1 || config[1] >= DB9_MAX_PAD || !db9_buttons[config[1]]) {
-- printk(KERN_ERR "db9.c: bad config\n");
-- return NULL;
-- }
-+ db9_mode = &db9_modes[mode];
-
-- pp = parport_find_number(config[0]);
-+ pp = parport_find_number(parport);
- if (!pp) {
- printk(KERN_ERR "db9.c: no such parport\n");
-- return NULL;
-+ err = -ENODEV;
-+ goto err_out;
- }
-
-- if (db9_bidirectional[config[1]]) {
-- if (!(pp->modes & PARPORT_MODE_TRISTATE)) {
-- printk(KERN_ERR "db9.c: specified parport is not bidirectional\n");
-- parport_put_port(pp);
-- return NULL;
-- }
-+ if (db9_mode[mode].bidirectional && !(pp->modes & PARPORT_MODE_TRISTATE)) {
-+ printk(KERN_ERR "db9.c: specified parport is not bidirectional\n");
-+ err = -EINVAL;
-+ goto err_put_pp;
-+ }
-+
-+ pd = parport_register_device(pp, "db9", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
-+ if (!pd) {
-+ printk(KERN_ERR "db9.c: parport busy already - lp.o loaded?\n");
-+ err = -EBUSY;
-+ goto err_put_pp;
- }
-
-- if (!(db9 = kzalloc(sizeof(struct db9), GFP_KERNEL))) {
-- parport_put_port(pp);
-- return NULL;
-+ db9 = kzalloc(sizeof(struct db9), GFP_KERNEL);
-+ if (!db9) {
-+ printk(KERN_ERR "db9.c: Not enough memory\n");
-+ err = -ENOMEM;
-+ goto err_unreg_pardev;
- }
-
- init_MUTEX(&db9->sem);
-- db9->mode = config[1];
-+ db9->pd = pd;
-+ db9->mode = mode;
- init_timer(&db9->timer);
- db9->timer.data = (long) db9;
- db9->timer.function = db9_timer;
-
-- db9->pd = parport_register_device(pp, "db9", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
-- parport_put_port(pp);
-+ for (i = 0; i < (min(db9_mode->n_pads, DB9_MAX_DEVICES)); i++) {
-
-- if (!db9->pd) {
-- printk(KERN_ERR "db9.c: parport busy already - lp.o loaded?\n");
-- kfree(db9);
-- return NULL;
-- }
--
-- for (i = 0; i < (min(db9_max_pads[db9->mode], DB9_MAX_DEVICES)); i++) {
-+ db9->dev[i] = input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ printk(KERN_ERR "db9.c: Not enough memory for input device\n");
-+ err = -ENOMEM;
-+ goto err_free_devs;
-+ }
-
- sprintf(db9->phys[i], "%s/input%d", db9->pd->port->name, i);
-
-- db9->dev[i].private = db9;
-- db9->dev[i].open = db9_open;
-- db9->dev[i].close = db9_close;
--
-- db9->dev[i].name = db9_name[db9->mode];
-- db9->dev[i].phys = db9->phys[i];
-- db9->dev[i].id.bustype = BUS_PARPORT;
-- db9->dev[i].id.vendor = 0x0002;
-- db9->dev[i].id.product = config[1];
-- db9->dev[i].id.version = 0x0100;
--
-- db9->dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- for (j = 0; j < db9_buttons[db9->mode]; j++)
-- set_bit(db9_btn[db9->mode][j], db9->dev[i].keybit);
-- for (j = 0; j < db9_num_axis[db9->mode]; j++) {
-- set_bit(db9_abs[j], db9->dev[i].absbit);
-- if (j < 2) {
-- db9->dev[i].absmin[db9_abs[j]] = -1;
-- db9->dev[i].absmax[db9_abs[j]] = 1;
-- } else {
-- db9->dev[i].absmin[db9_abs[j]] = 1;
-- db9->dev[i].absmax[db9_abs[j]] = 255;
-- db9->dev[i].absflat[db9_abs[j]] = 0;
-- }
-+ input_dev->name = db9_mode->name;
-+ input_dev->phys = db9->phys[i];
-+ input_dev->id.bustype = BUS_PARPORT;
-+ input_dev->id.vendor = 0x0002;
-+ input_dev->id.product = mode;
-+ input_dev->id.version = 0x0100;
-+ input_dev->private = db9;
-+
-+ input_dev->open = db9_open;
-+ input_dev->close = db9_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ for (j = 0; j < db9_mode->n_buttons; j++)
-+ set_bit(db9_mode->buttons[j], input_dev->keybit);
-+ for (j = 0; j < db9_mode->n_axis; j++) {
-+ if (j < 2)
-+ input_set_abs_params(input_dev, db9_abs[j], -1, 1, 0, 0);
-+ else
-+ input_set_abs_params(input_dev, db9_abs[j], 1, 255, 0, 0);
- }
-- input_register_device(db9->dev + i);
-- printk(KERN_INFO "input: %s on %s\n", db9->dev[i].name, db9->pd->port->name);
-+
-+ input_register_device(input_dev);
- }
-
-+ parport_put_port(pp);
- return db9;
-+
-+ err_free_devs:
-+ while (--i >= 0)
-+ input_unregister_device(db9->dev[i]);
-+ kfree(db9);
-+ err_unreg_pardev:
-+ parport_unregister_device(pd);
-+ err_put_pp:
-+ parport_put_port(pp);
-+ err_out:
-+ return ERR_PTR(err);
-+}
-+
-+static void __exit db9_remove(struct db9 *db9)
-+{
-+ int i;
-+
-+ for (i = 0; i < min(db9_modes[db9->mode].n_pads, DB9_MAX_DEVICES); i++)
-+ input_unregister_device(db9->dev[i]);
-+ parport_unregister_device(db9->pd);
-+ kfree(db9);
- }
-
- static int __init db9_init(void)
- {
-- db9_base[0] = db9_probe(db9, db9_nargs);
-- db9_base[1] = db9_probe(db9_2, db9_nargs_2);
-- db9_base[2] = db9_probe(db9_3, db9_nargs_3);
-+ int i;
-+ int have_dev = 0;
-+ int err = 0;
-+
-+ for (i = 0; i < DB9_MAX_PORTS; i++) {
-+ if (db9[i].nargs == 0 || db9[i].args[DB9_ARG_PARPORT] < 0)
-+ continue;
-+
-+ if (db9[i].nargs < 2) {
-+ printk(KERN_ERR "db9.c: Device type must be specified.\n");
-+ err = -EINVAL;
-+ break;
-+ }
-
-- if (db9_base[0] || db9_base[1] || db9_base[2])
-- return 0;
-+ db9_base[i] = db9_probe(db9[i].args[DB9_ARG_PARPORT],
-+ db9[i].args[DB9_ARG_MODE]);
-+ if (IS_ERR(db9_base[i])) {
-+ err = PTR_ERR(db9_base[i]);
-+ break;
-+ }
-
-- return -ENODEV;
-+ have_dev = 1;
-+ }
-+
-+ if (err) {
-+ while (--i >= 0)
-+ db9_remove(db9_base[i]);
-+ return err;
-+ }
-+
-+ return have_dev ? 0 : -ENODEV;
- }
-
- static void __exit db9_exit(void)
- {
-- int i, j;
-+ int i;
-
-- for (i = 0; i < 3; i++)
-- if (db9_base[i]) {
-- for (j = 0; j < min(db9_max_pads[db9_base[i]->mode], DB9_MAX_DEVICES); j++)
-- input_unregister_device(db9_base[i]->dev + j);
-- parport_unregister_device(db9_base[i]->pd);
-- }
-+ for (i = 0; i < DB9_MAX_PORTS; i++)
-+ if (db9_base[i])
-+ db9_remove(db9_base[i]);
- }
-
- module_init(db9_init);
---- gregkh-2.6.orig/drivers/input/joystick/gamecon.c
-+++ gregkh-2.6/drivers/input/joystick/gamecon.c
-@@ -41,20 +41,22 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@u
- MODULE_DESCRIPTION("NES, SNES, N64, MultiSystem, PSX gamepad driver");
- MODULE_LICENSE("GPL");
-
--static int gc[] __initdata = { -1, 0, 0, 0, 0, 0 };
--static int gc_nargs __initdata = 0;
--module_param_array_named(map, gc, int, &gc_nargs, 0);
--MODULE_PARM_DESC(map, "Describers first set of devices (<parport#>,<pad1>,<pad2>,..<pad5>)");
--
--static int gc_2[] __initdata = { -1, 0, 0, 0, 0, 0 };
--static int gc_nargs_2 __initdata = 0;
--module_param_array_named(map2, gc_2, int, &gc_nargs_2, 0);
--MODULE_PARM_DESC(map2, "Describers second set of devices");
--
--static int gc_3[] __initdata = { -1, 0, 0, 0, 0, 0 };
--static int gc_nargs_3 __initdata = 0;
--module_param_array_named(map3, gc_3, int, &gc_nargs_3, 0);
--MODULE_PARM_DESC(map3, "Describers third set of devices");
-+#define GC_MAX_PORTS 3
-+#define GC_MAX_DEVICES 5
-+
-+struct gc_config {
-+ int args[GC_MAX_DEVICES + 1];
-+ int nargs;
-+};
-+
-+static struct gc_config gc[GC_MAX_PORTS] __initdata;
-+
-+module_param_array_named(map, gc[0].args, int, &gc[0].nargs, 0);
-+MODULE_PARM_DESC(map, "Describes first set of devices (<parport#>,<pad1>,<pad2>,..<pad5>)");
-+module_param_array_named(map2, gc[1].args, int, &gc[1].nargs, 0);
-+MODULE_PARM_DESC(map2, "Describes second set of devices");
-+module_param_array_named(map3, gc[2].args, int, &gc[2].nargs, 0);
-+MODULE_PARM_DESC(map3, "Describes third set of devices");
-
- __obsolete_setup("gc=");
- __obsolete_setup("gc_2=");
-@@ -77,12 +79,12 @@ __obsolete_setup("gc_3=");
-
- struct gc {
- struct pardevice *pd;
-- struct input_dev dev[5];
-+ struct input_dev *dev[GC_MAX_DEVICES];
- struct timer_list timer;
- unsigned char pads[GC_MAX + 1];
- int used;
- struct semaphore sem;
-- char phys[5][32];
-+ char phys[GC_MAX_DEVICES][32];
- };
-
- static struct gc *gc_base[3];
-@@ -330,7 +332,6 @@ static void gc_psx_read_packet(struct gc
- static void gc_timer(unsigned long private)
- {
- struct gc *gc = (void *) private;
-- struct input_dev *dev = gc->dev;
- unsigned char data[GC_MAX_LENGTH];
- unsigned char data_psx[5][GC_PSX_BYTES];
- int i, j, s;
-@@ -357,16 +358,16 @@ static void gc_timer(unsigned long priva
- if (data[31 - j] & s) axes[1] |= 1 << j;
- }
-
-- input_report_abs(dev + i, ABS_X, axes[0]);
-- input_report_abs(dev + i, ABS_Y, -axes[1]);
-+ input_report_abs(gc->dev[i], ABS_X, axes[0]);
-+ input_report_abs(gc->dev[i], ABS_Y, -axes[1]);
-
-- input_report_abs(dev + i, ABS_HAT0X, !(s & data[6]) - !(s & data[7]));
-- input_report_abs(dev + i, ABS_HAT0Y, !(s & data[4]) - !(s & data[5]));
-+ input_report_abs(gc->dev[i], ABS_HAT0X, !(s & data[6]) - !(s & data[7]));
-+ input_report_abs(gc->dev[i], ABS_HAT0Y, !(s & data[4]) - !(s & data[5]));
-
- for (j = 0; j < 10; j++)
-- input_report_key(dev + i, gc_n64_btn[j], s & data[gc_n64_bytes[j]]);
-+ input_report_key(gc->dev[i], gc_n64_btn[j], s & data[gc_n64_bytes[j]]);
-
-- input_sync(dev + i);
-+ input_sync(gc->dev[i]);
- }
- }
- }
-@@ -384,19 +385,19 @@ static void gc_timer(unsigned long priva
- s = gc_status_bit[i];
-
- if (s & (gc->pads[GC_NES] | gc->pads[GC_SNES])) {
-- input_report_abs(dev + i, ABS_X, !(s & data[6]) - !(s & data[7]));
-- input_report_abs(dev + i, ABS_Y, !(s & data[4]) - !(s & data[5]));
-+ input_report_abs(gc->dev[i], ABS_X, !(s & data[6]) - !(s & data[7]));
-+ input_report_abs(gc->dev[i], ABS_Y, !(s & data[4]) - !(s & data[5]));
- }
-
- if (s & gc->pads[GC_NES])
- for (j = 0; j < 4; j++)
-- input_report_key(dev + i, gc_snes_btn[j], s & data[gc_nes_bytes[j]]);
-+ input_report_key(gc->dev[i], gc_snes_btn[j], s & data[gc_nes_bytes[j]]);
-
- if (s & gc->pads[GC_SNES])
- for (j = 0; j < 8; j++)
-- input_report_key(dev + i, gc_snes_btn[j], s & data[gc_snes_bytes[j]]);
-+ input_report_key(gc->dev[i], gc_snes_btn[j], s & data[gc_snes_bytes[j]]);
-
-- input_sync(dev + i);
-+ input_sync(gc->dev[i]);
- }
- }
-
-@@ -413,15 +414,15 @@ static void gc_timer(unsigned long priva
- s = gc_status_bit[i];
-
- if (s & (gc->pads[GC_MULTI] | gc->pads[GC_MULTI2])) {
-- input_report_abs(dev + i, ABS_X, !(s & data[2]) - !(s & data[3]));
-- input_report_abs(dev + i, ABS_Y, !(s & data[0]) - !(s & data[1]));
-- input_report_key(dev + i, BTN_TRIGGER, s & data[4]);
-+ input_report_abs(gc->dev[i], ABS_X, !(s & data[2]) - !(s & data[3]));
-+ input_report_abs(gc->dev[i], ABS_Y, !(s & data[0]) - !(s & data[1]));
-+ input_report_key(gc->dev[i], BTN_TRIGGER, s & data[4]);
- }
-
- if (s & gc->pads[GC_MULTI2])
-- input_report_key(dev + i, BTN_THUMB, s & data[5]);
-+ input_report_key(gc->dev[i], BTN_THUMB, s & data[5]);
-
-- input_sync(dev + i);
-+ input_sync(gc->dev[i]);
- }
- }
-
-@@ -438,44 +439,44 @@ static void gc_timer(unsigned long priva
-
- case GC_PSX_RUMBLE:
-
-- input_report_key(dev + i, BTN_THUMBL, ~data_psx[i][0] & 0x04);
-- input_report_key(dev + i, BTN_THUMBR, ~data_psx[i][0] & 0x02);
-+ input_report_key(gc->dev[i], BTN_THUMBL, ~data_psx[i][0] & 0x04);
-+ input_report_key(gc->dev[i], BTN_THUMBR, ~data_psx[i][0] & 0x02);
-
- case GC_PSX_NEGCON:
- case GC_PSX_ANALOG:
-
-- if(gc->pads[GC_DDR] & gc_status_bit[i]) {
-+ if (gc->pads[GC_DDR] & gc_status_bit[i]) {
- for(j = 0; j < 4; j++)
-- input_report_key(dev + i, gc_psx_ddr_btn[j], ~data_psx[i][0] & (0x10 << j));
-+ input_report_key(gc->dev[i], gc_psx_ddr_btn[j], ~data_psx[i][0] & (0x10 << j));
- } else {
- for (j = 0; j < 4; j++)
-- input_report_abs(dev + i, gc_psx_abs[j+2], data_psx[i][j + 2]);
-+ input_report_abs(gc->dev[i], gc_psx_abs[j+2], data_psx[i][j + 2]);
-
-- input_report_abs(dev + i, ABS_X, 128 + !(data_psx[i][0] & 0x20) * 127 - !(data_psx[i][0] & 0x80) * 128);
-- input_report_abs(dev + i, ABS_Y, 128 + !(data_psx[i][0] & 0x40) * 127 - !(data_psx[i][0] & 0x10) * 128);
-+ input_report_abs(gc->dev[i], ABS_X, 128 + !(data_psx[i][0] & 0x20) * 127 - !(data_psx[i][0] & 0x80) * 128);
-+ input_report_abs(gc->dev[i], ABS_Y, 128 + !(data_psx[i][0] & 0x40) * 127 - !(data_psx[i][0] & 0x10) * 128);
- }
-
- for (j = 0; j < 8; j++)
-- input_report_key(dev + i, gc_psx_btn[j], ~data_psx[i][1] & (1 << j));
-+ input_report_key(gc->dev[i], gc_psx_btn[j], ~data_psx[i][1] & (1 << j));
-
-- input_report_key(dev + i, BTN_START, ~data_psx[i][0] & 0x08);
-- input_report_key(dev + i, BTN_SELECT, ~data_psx[i][0] & 0x01);
-+ input_report_key(gc->dev[i], BTN_START, ~data_psx[i][0] & 0x08);
-+ input_report_key(gc->dev[i], BTN_SELECT, ~data_psx[i][0] & 0x01);
-
-- input_sync(dev + i);
-+ input_sync(gc->dev[i]);
-
- break;
-
- case GC_PSX_NORMAL:
-- if(gc->pads[GC_DDR] & gc_status_bit[i]) {
-+ if (gc->pads[GC_DDR] & gc_status_bit[i]) {
- for(j = 0; j < 4; j++)
-- input_report_key(dev + i, gc_psx_ddr_btn[j], ~data_psx[i][0] & (0x10 << j));
-+ input_report_key(gc->dev[i], gc_psx_ddr_btn[j], ~data_psx[i][0] & (0x10 << j));
- } else {
-- input_report_abs(dev + i, ABS_X, 128 + !(data_psx[i][0] & 0x20) * 127 - !(data_psx[i][0] & 0x80) * 128);
-- input_report_abs(dev + i, ABS_Y, 128 + !(data_psx[i][0] & 0x40) * 127 - !(data_psx[i][0] & 0x10) * 128);
-+ input_report_abs(gc->dev[i], ABS_X, 128 + !(data_psx[i][0] & 0x20) * 127 - !(data_psx[i][0] & 0x80) * 128);
-+ input_report_abs(gc->dev[i], ABS_Y, 128 + !(data_psx[i][0] & 0x40) * 127 - !(data_psx[i][0] & 0x10) * 128);
-
- /* for some reason if the extra axes are left unset they drift */
- /* for (j = 0; j < 4; j++)
-- input_report_abs(dev + i, gc_psx_abs[j+2], 128);
-+ input_report_abs(gc->dev[i], gc_psx_abs[j+2], 128);
- * This needs to be debugged properly,
- * maybe fuzz processing needs to be done in input_sync()
- * --vojtech
-@@ -483,12 +484,12 @@ static void gc_timer(unsigned long priva
- }
-
- for (j = 0; j < 8; j++)
-- input_report_key(dev + i, gc_psx_btn[j], ~data_psx[i][1] & (1 << j));
-+ input_report_key(gc->dev[i], gc_psx_btn[j], ~data_psx[i][1] & (1 << j));
-
-- input_report_key(dev + i, BTN_START, ~data_psx[i][0] & 0x08);
-- input_report_key(dev + i, BTN_SELECT, ~data_psx[i][0] & 0x01);
-+ input_report_key(gc->dev[i], BTN_START, ~data_psx[i][0] & 0x08);
-+ input_report_key(gc->dev[i], BTN_SELECT, ~data_psx[i][0] & 0x01);
-
-- input_sync(dev + i);
-+ input_sync(gc->dev[i]);
-
- break;
-
-@@ -533,177 +534,212 @@ static void gc_close(struct input_dev *d
- up(&gc->sem);
- }
-
--static struct gc __init *gc_probe(int *config, int nargs)
-+static int __init gc_setup_pad(struct gc *gc, int idx, int pad_type)
- {
-- struct gc *gc;
-- struct parport *pp;
-- int i, j;
--
-- if (config[0] < 0)
-- return NULL;
--
-- if (nargs < 2) {
-- printk(KERN_ERR "gamecon.c: at least one device must be specified\n");
-- return NULL;
-- }
-+ struct input_dev *input_dev;
-+ int i;
-
-- pp = parport_find_number(config[0]);
-+ if (!pad_type)
-+ return 0;
-
-- if (!pp) {
-- printk(KERN_ERR "gamecon.c: no such parport\n");
-- return NULL;
-+ if (pad_type < 1 || pad_type > GC_MAX) {
-+ printk(KERN_WARNING "gamecon.c: Pad type %d unknown\n", pad_type);
-+ return -EINVAL;
- }
-
-- if (!(gc = kzalloc(sizeof(struct gc), GFP_KERNEL))) {
-- parport_put_port(pp);
-- return NULL;
-+ gc->dev[idx] = input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ printk(KERN_ERR "gamecon.c: Not enough memory for input device\n");
-+ return -ENOMEM;
- }
-
-- init_MUTEX(&gc->sem);
-+ input_dev->name = gc_names[pad_type];
-+ input_dev->phys = gc->phys[idx];
-+ input_dev->id.bustype = BUS_PARPORT;
-+ input_dev->id.vendor = 0x0001;
-+ input_dev->id.product = pad_type;
-+ input_dev->id.version = 0x0100;
-+ input_dev->private = gc;
-
-- gc->pd = parport_register_device(pp, "gamecon", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
-+ input_dev->open = gc_open;
-+ input_dev->close = gc_close;
-
-- parport_put_port(pp);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
-- if (!gc->pd) {
-- printk(KERN_ERR "gamecon.c: parport busy already - lp.o loaded?\n");
-- kfree(gc);
-- return NULL;
-- }
-+ for (i = 0; i < 2; i++)
-+ input_set_abs_params(input_dev, ABS_X + i, -1, 1, 0, 0);
-
-- parport_claim(gc->pd);
-+ gc->pads[0] |= gc_status_bit[idx];
-+ gc->pads[pad_type] |= gc_status_bit[idx];
-
-- init_timer(&gc->timer);
-- gc->timer.data = (long) gc;
-- gc->timer.function = gc_timer;
-+ switch (pad_type) {
-
-- for (i = 0; i < nargs - 1; i++) {
-+ case GC_N64:
-+ for (i = 0; i < 10; i++)
-+ set_bit(gc_n64_btn[i], input_dev->keybit);
-
-- if (!config[i + 1])
-- continue;
--
-- if (config[i + 1] < 1 || config[i + 1] > GC_MAX) {
-- printk(KERN_WARNING "gamecon.c: Pad type %d unknown\n", config[i + 1]);
-- continue;
-- }
-+ for (i = 0; i < 2; i++) {
-+ input_set_abs_params(input_dev, ABS_X + i, -127, 126, 0, 2);
-+ input_set_abs_params(input_dev, ABS_HAT0X + i, -1, 1, 0, 0);
-+ }
-
-- gc->dev[i].private = gc;
-- gc->dev[i].open = gc_open;
-- gc->dev[i].close = gc_close;
--
-- gc->dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
--
-- for (j = 0; j < 2; j++) {
-- set_bit(ABS_X + j, gc->dev[i].absbit);
-- gc->dev[i].absmin[ABS_X + j] = -1;
-- gc->dev[i].absmax[ABS_X + j] = 1;
-- }
-+ break;
-
-- gc->pads[0] |= gc_status_bit[i];
-- gc->pads[config[i + 1]] |= gc_status_bit[i];
-+ case GC_SNES:
-+ for (i = 4; i < 8; i++)
-+ set_bit(gc_snes_btn[i], input_dev->keybit);
-+ case GC_NES:
-+ for (i = 0; i < 4; i++)
-+ set_bit(gc_snes_btn[i], input_dev->keybit);
-+ break;
-+
-+ case GC_MULTI2:
-+ set_bit(BTN_THUMB, input_dev->keybit);
-+ case GC_MULTI:
-+ set_bit(BTN_TRIGGER, input_dev->keybit);
-+ break;
-+
-+ case GC_PSX:
-+ for (i = 0; i < 6; i++)
-+ input_set_abs_params(input_dev, gc_psx_abs[i], 4, 252, 0, 2);
-+ for (i = 0; i < 12; i++)
-+ set_bit(gc_psx_btn[i], input_dev->keybit);
-+
-+ break;
-+
-+ case GC_DDR:
-+ for (i = 0; i < 4; i++)
-+ set_bit(gc_psx_ddr_btn[i], input_dev->keybit);
-+ for (i = 0; i < 12; i++)
-+ set_bit(gc_psx_btn[i], input_dev->keybit);
-
-- switch(config[i + 1]) {
-+ break;
-+ }
-
-- case GC_N64:
-- for (j = 0; j < 10; j++)
-- set_bit(gc_n64_btn[j], gc->dev[i].keybit);
-+ return 0;
-+}
-
-- for (j = 0; j < 2; j++) {
-- set_bit(ABS_X + j, gc->dev[i].absbit);
-- gc->dev[i].absmin[ABS_X + j] = -127;
-- gc->dev[i].absmax[ABS_X + j] = 126;
-- gc->dev[i].absflat[ABS_X + j] = 2;
-- set_bit(ABS_HAT0X + j, gc->dev[i].absbit);
-- gc->dev[i].absmin[ABS_HAT0X + j] = -1;
-- gc->dev[i].absmax[ABS_HAT0X + j] = 1;
-- }
-+static struct gc __init *gc_probe(int parport, int *pads, int n_pads)
-+{
-+ struct gc *gc;
-+ struct parport *pp;
-+ struct pardevice *pd;
-+ int i;
-+ int err;
-
-- break;
-+ pp = parport_find_number(parport);
-+ if (!pp) {
-+ printk(KERN_ERR "gamecon.c: no such parport\n");
-+ err = -EINVAL;
-+ goto err_out;
-+ }
-
-- case GC_SNES:
-- for (j = 4; j < 8; j++)
-- set_bit(gc_snes_btn[j], gc->dev[i].keybit);
-- case GC_NES:
-- for (j = 0; j < 4; j++)
-- set_bit(gc_snes_btn[j], gc->dev[i].keybit);
-- break;
-+ pd = parport_register_device(pp, "gamecon", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
-+ if (!pd) {
-+ printk(KERN_ERR "gamecon.c: parport busy already - lp.o loaded?\n");
-+ err = -EBUSY;
-+ goto err_put_pp;
-+ }
-
-- case GC_MULTI2:
-- set_bit(BTN_THUMB, gc->dev[i].keybit);
-- case GC_MULTI:
-- set_bit(BTN_TRIGGER, gc->dev[i].keybit);
-- break;
--
-- case GC_PSX:
-- case GC_DDR:
-- if(config[i + 1] == GC_DDR) {
-- for (j = 0; j < 4; j++)
-- set_bit(gc_psx_ddr_btn[j], gc->dev[i].keybit);
-- } else {
-- for (j = 0; j < 6; j++) {
-- set_bit(gc_psx_abs[j], gc->dev[i].absbit);
-- gc->dev[i].absmin[gc_psx_abs[j]] = 4;
-- gc->dev[i].absmax[gc_psx_abs[j]] = 252;
-- gc->dev[i].absflat[gc_psx_abs[j]] = 2;
-- }
-- }
-+ gc = kzalloc(sizeof(struct gc), GFP_KERNEL);
-+ if (!gc) {
-+ printk(KERN_ERR "gamecon.c: Not enough memory\n");
-+ err = -ENOMEM;
-+ goto err_unreg_pardev;
-+ }
-
-- for (j = 0; j < 12; j++)
-- set_bit(gc_psx_btn[j], gc->dev[i].keybit);
-+ init_MUTEX(&gc->sem);
-+ gc->pd = pd;
-+ init_timer(&gc->timer);
-+ gc->timer.data = (long) gc;
-+ gc->timer.function = gc_timer;
-
-- break;
-- }
-+ for (i = 0; i < n_pads; i++) {
-+ if (!pads[i])
-+ continue;
-
- sprintf(gc->phys[i], "%s/input%d", gc->pd->port->name, i);
-+ err = gc_setup_pad(gc, i, pads[i]);
-+ if (err)
-+ goto err_free_devs;
-
-- gc->dev[i].name = gc_names[config[i + 1]];
-- gc->dev[i].phys = gc->phys[i];
-- gc->dev[i].id.bustype = BUS_PARPORT;
-- gc->dev[i].id.vendor = 0x0001;
-- gc->dev[i].id.product = config[i + 1];
-- gc->dev[i].id.version = 0x0100;
-+ input_register_device(gc->dev[i]);
- }
-
-- parport_release(gc->pd);
--
- if (!gc->pads[0]) {
-- parport_unregister_device(gc->pd);
-- kfree(gc);
-- return NULL;
-+ printk(KERN_ERR "gamecon.c: No valid devices specified\n");
-+ err = -EINVAL;
-+ goto err_free_gc;
- }
-
-- for (i = 0; i < 5; i++)
-- if (gc->pads[0] & gc_status_bit[i]) {
-- input_register_device(gc->dev + i);
-- printk(KERN_INFO "input: %s on %s\n", gc->dev[i].name, gc->pd->port->name);
-- }
--
-+ parport_put_port(pp);
- return gc;
-+
-+ err_free_devs:
-+ while (--i >= 0)
-+ input_unregister_device(gc->dev[i]);
-+ err_free_gc:
-+ kfree(gc);
-+ err_unreg_pardev:
-+ parport_unregister_device(pd);
-+ err_put_pp:
-+ parport_put_port(pp);
-+ err_out:
-+ return ERR_PTR(err);
-+}
-+
-+static void __exit gc_remove(struct gc *gc)
-+{
-+ int i;
-+
-+ for (i = 0; i < GC_MAX_DEVICES; i++)
-+ if (gc->dev[i])
-+ input_unregister_device(gc->dev[i]);
-+ parport_unregister_device(gc->pd);
-+ kfree(gc);
- }
-
- static int __init gc_init(void)
- {
-- gc_base[0] = gc_probe(gc, gc_nargs);
-- gc_base[1] = gc_probe(gc_2, gc_nargs_2);
-- gc_base[2] = gc_probe(gc_3, gc_nargs_3);
-+ int i;
-+ int have_dev = 0;
-+ int err = 0;
-
-- if (gc_base[0] || gc_base[1] || gc_base[2])
-- return 0;
-+ for (i = 0; i < GC_MAX_PORTS; i++) {
-+ if (gc[i].nargs == 0 || gc[i].args[0] < 0)
-+ continue;
-+
-+ if (gc[i].nargs < 2) {
-+ printk(KERN_ERR "gamecon.c: at least one device must be specified\n");
-+ err = -EINVAL;
-+ break;
-+ }
-
-- return -ENODEV;
-+ gc_base[i] = gc_probe(gc[i].args[0], gc[i].args + 1, gc[i].nargs - 1);
-+ if (IS_ERR(gc_base[i])) {
-+ err = PTR_ERR(gc_base[i]);
-+ break;
-+ }
-+
-+ have_dev = 1;
-+ }
-+
-+ if (err) {
-+ while (--i >= 0)
-+ gc_remove(gc_base[i]);
-+ return err;
-+ }
-+
-+ return have_dev ? 0 : -ENODEV;
- }
-
- static void __exit gc_exit(void)
- {
-- int i, j;
-+ int i;
-
-- for (i = 0; i < 3; i++)
-- if (gc_base[i]) {
-- for (j = 0; j < 5; j++)
-- if (gc_base[i]->pads[0] & gc_status_bit[j])
-- input_unregister_device(gc_base[i]->dev + j);
-- parport_unregister_device(gc_base[i]->pd);
-- }
-+ for (i = 0; i < GC_MAX_PORTS; i++)
-+ if (gc_base[i])
-+ gc_remove(gc_base[i]);
- }
-
- module_init(gc_init);
---- gregkh-2.6.orig/drivers/input/joystick/gf2k.c
-+++ gregkh-2.6/drivers/input/joystick/gf2k.c
-@@ -81,7 +81,7 @@ static short gf2k_seq_digital[] = { 590,
-
- struct gf2k {
- struct gameport *gameport;
-- struct input_dev dev;
-+ struct input_dev *dev;
- int reads;
- int bads;
- unsigned char id;
-@@ -175,7 +175,7 @@ static int gf2k_get_bits(unsigned char *
-
- static void gf2k_read(struct gf2k *gf2k, unsigned char *data)
- {
-- struct input_dev *dev = &gf2k->dev;
-+ struct input_dev *dev = gf2k->dev;
- int i, t;
-
- for (i = 0; i < 4 && i < gf2k_axes[gf2k->id]; i++)
-@@ -239,13 +239,19 @@ static void gf2k_close(struct input_dev
- static int gf2k_connect(struct gameport *gameport, struct gameport_driver *drv)
- {
- struct gf2k *gf2k;
-+ struct input_dev *input_dev;
- unsigned char data[GF2K_LENGTH];
- int i, err;
-
-- if (!(gf2k = kzalloc(sizeof(struct gf2k), GFP_KERNEL)))
-- return -ENOMEM;
-+ gf2k = kzalloc(sizeof(struct gf2k), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!gf2k || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail1;
-+ }
-
- gf2k->gameport = gameport;
-+ gf2k->dev = input_dev;
-
- gameport_set_drvdata(gameport, gf2k);
-
-@@ -295,53 +301,52 @@ static int gf2k_connect(struct gameport
-
- gf2k->length = gf2k_lens[gf2k->id];
-
-- init_input_dev(&gf2k->dev);
--
-- gf2k->dev.private = gf2k;
-- gf2k->dev.open = gf2k_open;
-- gf2k->dev.close = gf2k_close;
-- gf2k->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
--
-- gf2k->dev.name = gf2k_names[gf2k->id];
-- gf2k->dev.phys = gf2k->phys;
-- gf2k->dev.id.bustype = BUS_GAMEPORT;
-- gf2k->dev.id.vendor = GAMEPORT_ID_VENDOR_GENIUS;
-- gf2k->dev.id.product = gf2k->id;
-- gf2k->dev.id.version = 0x0100;
-+ input_dev->name = gf2k_names[gf2k->id];
-+ input_dev->phys = gf2k->phys;
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_GENIUS;
-+ input_dev->id.product = gf2k->id;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &gameport->dev;
-+ input_dev->private = gf2k;
-+
-+ input_dev->open = gf2k_open;
-+ input_dev->close = gf2k_close;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (i = 0; i < gf2k_axes[gf2k->id]; i++)
-- set_bit(gf2k_abs[i], gf2k->dev.absbit);
-+ set_bit(gf2k_abs[i], input_dev->absbit);
-
- for (i = 0; i < gf2k_hats[gf2k->id]; i++) {
-- set_bit(ABS_HAT0X + i, gf2k->dev.absbit);
-- gf2k->dev.absmin[ABS_HAT0X + i] = -1;
-- gf2k->dev.absmax[ABS_HAT0X + i] = 1;
-+ set_bit(ABS_HAT0X + i, input_dev->absbit);
-+ input_dev->absmin[ABS_HAT0X + i] = -1;
-+ input_dev->absmax[ABS_HAT0X + i] = 1;
- }
-
- for (i = 0; i < gf2k_joys[gf2k->id]; i++)
-- set_bit(gf2k_btn_joy[i], gf2k->dev.keybit);
-+ set_bit(gf2k_btn_joy[i], input_dev->keybit);
-
- for (i = 0; i < gf2k_pads[gf2k->id]; i++)
-- set_bit(gf2k_btn_pad[i], gf2k->dev.keybit);
-+ set_bit(gf2k_btn_pad[i], input_dev->keybit);
-
- gf2k_read_packet(gameport, gf2k->length, data);
- gf2k_read(gf2k, data);
-
- for (i = 0; i < gf2k_axes[gf2k->id]; i++) {
-- gf2k->dev.absmax[gf2k_abs[i]] = (i < 2) ? gf2k->dev.abs[gf2k_abs[i]] * 2 - 32 :
-- gf2k->dev.abs[gf2k_abs[0]] + gf2k->dev.abs[gf2k_abs[1]] - 32;
-- gf2k->dev.absmin[gf2k_abs[i]] = 32;
-- gf2k->dev.absfuzz[gf2k_abs[i]] = 8;
-- gf2k->dev.absflat[gf2k_abs[i]] = (i < 2) ? 24 : 0;
-+ input_dev->absmax[gf2k_abs[i]] = (i < 2) ? input_dev->abs[gf2k_abs[i]] * 2 - 32 :
-+ input_dev->abs[gf2k_abs[0]] + input_dev->abs[gf2k_abs[1]] - 32;
-+ input_dev->absmin[gf2k_abs[i]] = 32;
-+ input_dev->absfuzz[gf2k_abs[i]] = 8;
-+ input_dev->absflat[gf2k_abs[i]] = (i < 2) ? 24 : 0;
- }
-
-- input_register_device(&gf2k->dev);
-- printk(KERN_INFO "input: %s on %s\n", gf2k_names[gf2k->id], gameport->phys);
-+ input_register_device(gf2k->dev);
-
- return 0;
-
--fail2: gameport_close(gameport);
--fail1: gameport_set_drvdata(gameport, NULL);
-+ fail2: gameport_close(gameport);
-+ fail1: gameport_set_drvdata(gameport, NULL);
-+ input_free_device(input_dev);
- kfree(gf2k);
- return err;
- }
-@@ -350,7 +355,7 @@ static void gf2k_disconnect(struct gamep
- {
- struct gf2k *gf2k = gameport_get_drvdata(gameport);
-
-- input_unregister_device(&gf2k->dev);
-+ input_unregister_device(gf2k->dev);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(gf2k);
---- gregkh-2.6.orig/drivers/input/joystick/grip.c
-+++ gregkh-2.6/drivers/input/joystick/grip.c
-@@ -55,7 +55,7 @@ MODULE_LICENSE("GPL");
-
- struct grip {
- struct gameport *gameport;
-- struct input_dev dev[2];
-+ struct input_dev *dev[2];
- unsigned char mode[2];
- int reads;
- int bads;
-@@ -190,7 +190,7 @@ static void grip_poll(struct gameport *g
-
- for (i = 0; i < 2; i++) {
-
-- dev = grip->dev + i;
-+ dev = grip->dev[i];
- grip->reads++;
-
- switch (grip->mode[i]) {
-@@ -297,6 +297,7 @@ static void grip_close(struct input_dev
- static int grip_connect(struct gameport *gameport, struct gameport_driver *drv)
- {
- struct grip *grip;
-+ struct input_dev *input_dev;
- unsigned int data[GRIP_LENGTH_XT];
- int i, j, t;
- int err;
-@@ -339,48 +340,56 @@ static int grip_connect(struct gameport
- gameport_set_poll_handler(gameport, grip_poll);
- gameport_set_poll_interval(gameport, 20);
-
-- for (i = 0; i < 2; i++)
-- if (grip->mode[i]) {
--
-- sprintf(grip->phys[i], "%s/input%d", gameport->phys, i);
--
-- grip->dev[i].private = grip;
--
-- grip->dev[i].open = grip_open;
-- grip->dev[i].close = grip_close;
-+ for (i = 0; i < 2; i++) {
-+ if (!grip->mode[i])
-+ continue;
-
-- grip->dev[i].name = grip_name[grip->mode[i]];
-- grip->dev[i].phys = grip->phys[i];
-- grip->dev[i].id.bustype = BUS_GAMEPORT;
-- grip->dev[i].id.vendor = GAMEPORT_ID_VENDOR_GRAVIS;
-- grip->dev[i].id.product = grip->mode[i];
-- grip->dev[i].id.version = 0x0100;
-+ grip->dev[i] = input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ err = -ENOMEM;
-+ goto fail3;
-+ }
-
-- grip->dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ sprintf(grip->phys[i], "%s/input%d", gameport->phys, i);
-
-- for (j = 0; (t = grip_abs[grip->mode[i]][j]) >= 0; j++) {
-+ input_dev->name = grip_name[grip->mode[i]];
-+ input_dev->phys = grip->phys[i];
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_GRAVIS;
-+ input_dev->id.product = grip->mode[i];
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &gameport->dev;
-+ input_dev->private = grip;
-+
-+ input_dev->open = grip_open;
-+ input_dev->close = grip_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+
-+ for (j = 0; (t = grip_abs[grip->mode[i]][j]) >= 0; j++) {
-+
-+ if (j < grip_cen[grip->mode[i]])
-+ input_set_abs_params(input_dev, t, 14, 52, 1, 2);
-+ else if (j < grip_anx[grip->mode[i]])
-+ input_set_abs_params(input_dev, t, 3, 57, 1, 0);
-+ else
-+ input_set_abs_params(input_dev, t, -1, 1, 0, 0);
-+ }
-
-- if (j < grip_cen[grip->mode[i]])
-- input_set_abs_params(&grip->dev[i], t, 14, 52, 1, 2);
-- else if (j < grip_anx[grip->mode[i]])
-- input_set_abs_params(&grip->dev[i], t, 3, 57, 1, 0);
-- else
-- input_set_abs_params(&grip->dev[i], t, -1, 1, 0, 0);
-- }
-+ for (j = 0; (t = grip_btn[grip->mode[i]][j]) >= 0; j++)
-+ if (t > 0)
-+ set_bit(t, input_dev->keybit);
-
-- for (j = 0; (t = grip_btn[grip->mode[i]][j]) >= 0; j++)
-- if (t > 0)
-- set_bit(t, grip->dev[i].keybit);
--
-- printk(KERN_INFO "input: %s on %s\n",
-- grip_name[grip->mode[i]], gameport->phys);
-- input_register_device(grip->dev + i);
-- }
-+ input_register_device(grip->dev[i]);
-+ }
-
- return 0;
-
--fail2: gameport_close(gameport);
--fail1: gameport_set_drvdata(gameport, NULL);
-+ fail3: for (i = 0; i < 2; i++)
-+ if (grip->dev[i])
-+ input_unregister_device(grip->dev[i]);
-+ fail2: gameport_close(gameport);
-+ fail1: gameport_set_drvdata(gameport, NULL);
- kfree(grip);
- return err;
- }
-@@ -391,8 +400,8 @@ static void grip_disconnect(struct gamep
- int i;
-
- for (i = 0; i < 2; i++)
-- if (grip->mode[i])
-- input_unregister_device(grip->dev + i);
-+ if (grip->dev[i])
-+ input_unregister_device(grip->dev[i]);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(grip);
---- gregkh-2.6.orig/drivers/input/joystick/grip_mp.c
-+++ gregkh-2.6/drivers/input/joystick/grip_mp.c
-@@ -32,23 +32,37 @@ MODULE_LICENSE("GPL");
- #define dbg(format, arg...) do {} while (0)
- #endif
-
-+#define GRIP_MAX_PORTS 4
- /*
- * Grip multiport state
- */
-
-+struct grip_port {
-+ struct input_dev *dev;
-+ int mode;
-+ int registered;
-+
-+ /* individual gamepad states */
-+ int buttons;
-+ int xaxes;
-+ int yaxes;
-+ int dirty; /* has the state been updated? */
-+};
-+
- struct grip_mp {
- struct gameport *gameport;
-- struct input_dev dev[4];
-- int mode[4];
-- int registered[4];
-+ struct grip_port *port[GRIP_MAX_PORTS];
-+// struct input_dev *dev[4];
-+// int mode[4];
-+// int registered[4];
- int reads;
- int bads;
-
- /* individual gamepad states */
-- int buttons[4];
-- int xaxes[4];
-- int yaxes[4];
-- int dirty[4]; /* has the state been updated? */
-+// int buttons[4];
-+// int xaxes[4];
-+// int yaxes[4];
-+// int dirty[4]; /* has the state been updated? */
- };
-
- /*
-@@ -85,16 +99,16 @@ struct grip_mp {
- #define GRIP_MODE_GP 2
- #define GRIP_MODE_C64 3
-
--static int grip_btn_gp[] = { BTN_TR, BTN_TL, BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z, -1 };
--static int grip_btn_c64[] = { BTN_JOYSTICK, -1 };
-+static const int grip_btn_gp[] = { BTN_TR, BTN_TL, BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z, -1 };
-+static const int grip_btn_c64[] = { BTN_JOYSTICK, -1 };
-
--static int grip_abs_gp[] = { ABS_X, ABS_Y, -1 };
--static int grip_abs_c64[] = { ABS_X, ABS_Y, -1 };
-+static const int grip_abs_gp[] = { ABS_X, ABS_Y, -1 };
-+static const int grip_abs_c64[] = { ABS_X, ABS_Y, -1 };
-
--static int *grip_abs[] = { NULL, NULL, grip_abs_gp, grip_abs_c64 };
--static int *grip_btn[] = { NULL, NULL, grip_btn_gp, grip_btn_c64 };
-+static const int *grip_abs[] = { NULL, NULL, grip_abs_gp, grip_abs_c64 };
-+static const int *grip_btn[] = { NULL, NULL, grip_btn_gp, grip_btn_c64 };
-
--static char *grip_name[] = { NULL, NULL, "Gravis Grip Pad", "Commodore 64 Joystick" };
-+static const char *grip_name[] = { NULL, NULL, "Gravis Grip Pad", "Commodore 64 Joystick" };
-
- static const int init_seq[] = {
- 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1,
-@@ -104,9 +118,9 @@ static const int init_seq[] = {
-
- /* Maps multiport directional values to X,Y axis values (each axis encoded in 3 bits) */
-
--static int axis_map[] = { 5, 9, 1, 5, 6, 10, 2, 6, 4, 8, 0, 4, 5, 9, 1, 5 };
-+static const int axis_map[] = { 5, 9, 1, 5, 6, 10, 2, 6, 4, 8, 0, 4, 5, 9, 1, 5 };
-
--static void register_slot(int i, struct grip_mp *grip);
-+static int register_slot(int i, struct grip_mp *grip);
-
- /*
- * Returns whether an odd or even number of bits are on in pkt.
-@@ -353,9 +367,10 @@ static int dig_mode_start(struct gamepor
-
- static int get_and_decode_packet(struct grip_mp *grip, int flags)
- {
-+ struct grip_port *port;
- u32 packet;
- int joytype = 0;
-- int slot = 0;
-+ int slot;
-
- /* Get a packet and check for validity */
-
-@@ -377,6 +392,8 @@ static int get_and_decode_packet(struct
- if ((slot < 0) || (slot > 3))
- return flags;
-
-+ port = grip->port[slot];
-+
- /*
- * Handle "reset" packets, which occur at startup, and when gamepads
- * are removed or plugged in. May contain configuration of a new gamepad.
-@@ -385,14 +402,14 @@ static int get_and_decode_packet(struct
- joytype = (packet >> 16) & 0x1f;
- if (!joytype) {
-
-- if (grip->registered[slot]) {
-+ if (port->registered) {
- printk(KERN_INFO "grip_mp: removing %s, slot %d\n",
-- grip_name[grip->mode[slot]], slot);
-- input_unregister_device(grip->dev + slot);
-- grip->registered[slot] = 0;
-+ grip_name[port->mode], slot);
-+ input_unregister_device(port->dev);
-+ port->registered = 0;
- }
- dbg("Reset: grip multiport slot %d\n", slot);
-- grip->mode[slot] = GRIP_MODE_RESET;
-+ port->mode = GRIP_MODE_RESET;
- flags |= IO_SLOT_CHANGE;
- return flags;
- }
-@@ -402,17 +419,17 @@ static int get_and_decode_packet(struct
- if (joytype == 0x1f) {
-
- int dir = (packet >> 8) & 0xf; /* eight way directional value */
-- grip->buttons[slot] = (~packet) & 0xff;
-- grip->yaxes[slot] = ((axis_map[dir] >> 2) & 3) - 1;
-- grip->xaxes[slot] = (axis_map[dir] & 3) - 1;
-- grip->dirty[slot] = 1;
-+ port->buttons = (~packet) & 0xff;
-+ port->yaxes = ((axis_map[dir] >> 2) & 3) - 1;
-+ port->xaxes = (axis_map[dir] & 3) - 1;
-+ port->dirty = 1;
-
-- if (grip->mode[slot] == GRIP_MODE_RESET)
-+ if (port->mode == GRIP_MODE_RESET)
- flags |= IO_SLOT_CHANGE;
-
-- grip->mode[slot] = GRIP_MODE_GP;
-+ port->mode = GRIP_MODE_GP;
-
-- if (!grip->registered[slot]) {
-+ if (!port->registered) {
- dbg("New Grip pad in multiport slot %d.\n", slot);
- register_slot(slot, grip);
- }
-@@ -445,9 +462,9 @@ static int slots_valid(struct grip_mp *g
- return 0;
-
- for (slot = 0; slot < 4; slot++) {
-- if (grip->mode[slot] == GRIP_MODE_RESET)
-+ if (grip->port[slot]->mode == GRIP_MODE_RESET)
- invalid = 1;
-- if (grip->mode[slot] != GRIP_MODE_NONE)
-+ if (grip->port[slot]->mode != GRIP_MODE_NONE)
- active = 1;
- }
-
-@@ -484,7 +501,7 @@ static int multiport_init(struct grip_mp
-
- /* Get packets, store multiport state, and check state's validity */
- for (tries = 0; tries < 4096; tries++) {
-- if ( slots_valid(grip) ) {
-+ if (slots_valid(grip)) {
- initialized = 1;
- break;
- }
-@@ -499,24 +516,24 @@ static int multiport_init(struct grip_mp
-
- static void report_slot(struct grip_mp *grip, int slot)
- {
-- struct input_dev *dev = &(grip->dev[slot]);
-- int i, buttons = grip->buttons[slot];
-+ struct grip_port *port = grip->port[slot];
-+ int i;
-
- /* Store button states with linux input driver */
-
- for (i = 0; i < 8; i++)
-- input_report_key(dev, grip_btn_gp[i], (buttons >> i) & 1);
-+ input_report_key(port->dev, grip_btn_gp[i], (port->buttons >> i) & 1);
-
- /* Store axis states with linux driver */
-
-- input_report_abs(dev, ABS_X, grip->xaxes[slot]);
-- input_report_abs(dev, ABS_Y, grip->yaxes[slot]);
-+ input_report_abs(port->dev, ABS_X, port->xaxes);
-+ input_report_abs(port->dev, ABS_Y, port->yaxes);
-
- /* Tell the receiver of the events to process them */
-
-- input_sync(dev);
-+ input_sync(port->dev);
-
-- grip->dirty[slot] = 0;
-+ port->dirty = 0;
- }
-
- /*
-@@ -540,7 +557,7 @@ static void grip_poll(struct gameport *g
- }
-
- for (i = 0; i < 4; i++)
-- if (grip->dirty[i])
-+ if (grip->port[i]->dirty)
- report_slot(grip, i);
- }
-
-@@ -571,35 +588,43 @@ static void grip_close(struct input_dev
- * Tell the linux input layer about a newly plugged-in gamepad.
- */
-
--static void register_slot(int slot, struct grip_mp *grip)
-+static int register_slot(int slot, struct grip_mp *grip)
- {
-+ struct grip_port *port = grip->port[slot];
-+ struct input_dev *input_dev;
- int j, t;
-
-- grip->dev[slot].private = grip;
-- grip->dev[slot].open = grip_open;
-- grip->dev[slot].close = grip_close;
-- grip->dev[slot].name = grip_name[grip->mode[slot]];
-- grip->dev[slot].id.bustype = BUS_GAMEPORT;
-- grip->dev[slot].id.vendor = GAMEPORT_ID_VENDOR_GRAVIS;
-- grip->dev[slot].id.product = 0x0100 + grip->mode[slot];
-- grip->dev[slot].id.version = 0x0100;
-- grip->dev[slot].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ port->dev = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-+
-+ input_dev->name = grip_name[port->mode];
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_GRAVIS;
-+ input_dev->id.product = 0x0100 + port->mode;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &grip->gameport->dev;
-+ input_dev->private = grip;
-+
-+ input_dev->open = grip_open;
-+ input_dev->close = grip_close;
-
-- for (j = 0; (t = grip_abs[grip->mode[slot]][j]) >= 0; j++)
-- input_set_abs_params(&grip->dev[slot], t, -1, 1, 0, 0);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
-- for (j = 0; (t = grip_btn[grip->mode[slot]][j]) >= 0; j++)
-+ for (j = 0; (t = grip_abs[port->mode][j]) >= 0; j++)
-+ input_set_abs_params(input_dev, t, -1, 1, 0, 0);
-+
-+ for (j = 0; (t = grip_btn[port->mode][j]) >= 0; j++)
- if (t > 0)
-- set_bit(t, grip->dev[slot].keybit);
-+ set_bit(t, input_dev->keybit);
-
-- input_register_device(grip->dev + slot);
-- grip->registered[slot] = 1;
-+ input_register_device(port->dev);
-+ port->registered = 1;
-
-- if (grip->dirty[slot]) /* report initial state, if any */
-+ if (port->dirty) /* report initial state, if any */
- report_slot(grip, slot);
-
-- printk(KERN_INFO "grip_mp: added %s, slot %d\n",
-- grip_name[grip->mode[slot]], slot);
-+ return 0;
- }
-
- static int grip_connect(struct gameport *gameport, struct gameport_driver *drv)
-@@ -626,7 +651,7 @@ static int grip_connect(struct gameport
- goto fail2;
- }
-
-- if (!grip->mode[0] && !grip->mode[1] && !grip->mode[2] && !grip->mode[3]) {
-+ if (!grip->port[0]->mode && !grip->port[1]->mode && !grip->port[2]->mode && !grip->port[3]->mode) {
- /* nothing plugged in */
- err = -ENODEV;
- goto fail2;
-@@ -646,8 +671,8 @@ static void grip_disconnect(struct gamep
- int i;
-
- for (i = 0; i < 4; i++)
-- if (grip->registered[i])
-- input_unregister_device(grip->dev + i);
-+ if (grip->port[i]->registered)
-+ input_unregister_device(grip->port[i]->dev);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(grip);
---- gregkh-2.6.orig/drivers/input/joystick/guillemot.c
-+++ gregkh-2.6/drivers/input/joystick/guillemot.c
-@@ -67,7 +67,7 @@ struct guillemot_type {
-
- struct guillemot {
- struct gameport *gameport;
-- struct input_dev dev;
-+ struct input_dev *dev;
- int bads;
- int reads;
- struct guillemot_type *type;
-@@ -123,7 +123,7 @@ static int guillemot_read_packet(struct
- static void guillemot_poll(struct gameport *gameport)
- {
- struct guillemot *guillemot = gameport_get_drvdata(gameport);
-- struct input_dev *dev = &guillemot->dev;
-+ struct input_dev *dev = guillemot->dev;
- u8 data[GUILLEMOT_MAX_LENGTH];
- int i;
-
-@@ -179,14 +179,20 @@ static void guillemot_close(struct input
- static int guillemot_connect(struct gameport *gameport, struct gameport_driver *drv)
- {
- struct guillemot *guillemot;
-+ struct input_dev *input_dev;
- u8 data[GUILLEMOT_MAX_LENGTH];
- int i, t;
- int err;
-
-- if (!(guillemot = kzalloc(sizeof(struct guillemot), GFP_KERNEL)))
-- return -ENOMEM;
-+ guillemot = kzalloc(sizeof(struct guillemot), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!guillemot || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail1;
-+ }
-
- guillemot->gameport = gameport;
-+ guillemot->dev = input_dev;
-
- gameport_set_drvdata(gameport, guillemot);
-
-@@ -216,41 +222,40 @@ static int guillemot_connect(struct game
- gameport_set_poll_interval(gameport, 20);
-
- sprintf(guillemot->phys, "%s/input0", gameport->phys);
--
- guillemot->type = guillemot_type + i;
-
-- guillemot->dev.private = guillemot;
-- guillemot->dev.open = guillemot_open;
-- guillemot->dev.close = guillemot_close;
--
-- guillemot->dev.name = guillemot_type[i].name;
-- guillemot->dev.phys = guillemot->phys;
-- guillemot->dev.id.bustype = BUS_GAMEPORT;
-- guillemot->dev.id.vendor = GAMEPORT_ID_VENDOR_GUILLEMOT;
-- guillemot->dev.id.product = guillemot_type[i].id;
-- guillemot->dev.id.version = (int)data[14] << 8 | data[15];
-+ input_dev->name = guillemot_type[i].name;
-+ input_dev->phys = guillemot->phys;
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_GUILLEMOT;
-+ input_dev->id.product = guillemot_type[i].id;
-+ input_dev->id.version = (int)data[14] << 8 | data[15];
-+ input_dev->cdev.dev = &gameport->dev;
-+ input_dev->private = guillemot;
-+
-+ input_dev->open = guillemot_open;
-+ input_dev->close = guillemot_close;
-
-- guillemot->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (i = 0; (t = guillemot->type->abs[i]) >= 0; i++)
-- input_set_abs_params(&guillemot->dev, t, 0, 255, 0, 0);
-+ input_set_abs_params(input_dev, t, 0, 255, 0, 0);
-
- if (guillemot->type->hat) {
-- input_set_abs_params(&guillemot->dev, ABS_HAT0X, -1, 1, 0, 0);
-- input_set_abs_params(&guillemot->dev, ABS_HAT0Y, -1, 1, 0, 0);
-+ input_set_abs_params(input_dev, ABS_HAT0X, -1, 1, 0, 0);
-+ input_set_abs_params(input_dev, ABS_HAT0Y, -1, 1, 0, 0);
- }
-
- for (i = 0; (t = guillemot->type->btn[i]) >= 0; i++)
-- set_bit(t, guillemot->dev.keybit);
-+ set_bit(t, input_dev->keybit);
-
-- input_register_device(&guillemot->dev);
-- printk(KERN_INFO "input: %s ver %d.%02d on %s\n",
-- guillemot->type->name, data[14], data[15], gameport->phys);
-+ input_register_device(guillemot->dev);
-
- return 0;
-
- fail2: gameport_close(gameport);
- fail1: gameport_set_drvdata(gameport, NULL);
-+ input_free_device(input_dev);
- kfree(guillemot);
- return err;
- }
-@@ -260,7 +265,7 @@ static void guillemot_disconnect(struct
- struct guillemot *guillemot = gameport_get_drvdata(gameport);
-
- printk(KERN_INFO "guillemot.c: Failed %d reads out of %d on %s\n", guillemot->reads, guillemot->bads, guillemot->phys);
-- input_unregister_device(&guillemot->dev);
-+ input_unregister_device(guillemot->dev);
- gameport_close(gameport);
- kfree(guillemot);
- }
---- gregkh-2.6.orig/drivers/input/joystick/interact.c
-+++ gregkh-2.6/drivers/input/joystick/interact.c
-@@ -54,7 +54,7 @@ MODULE_LICENSE("GPL");
-
- struct interact {
- struct gameport *gameport;
-- struct input_dev dev;
-+ struct input_dev *dev;
- int bads;
- int reads;
- unsigned char type;
-@@ -130,7 +130,7 @@ static int interact_read_packet(struct g
- static void interact_poll(struct gameport *gameport)
- {
- struct interact *interact = gameport_get_drvdata(gameport);
-- struct input_dev *dev = &interact->dev;
-+ struct input_dev *dev = interact->dev;
- u32 data[3];
- int i;
-
-@@ -208,14 +208,20 @@ static void interact_close(struct input_
- static int interact_connect(struct gameport *gameport, struct gameport_driver *drv)
- {
- struct interact *interact;
-+ struct input_dev *input_dev;
- __u32 data[3];
- int i, t;
- int err;
-
-- if (!(interact = kzalloc(sizeof(struct interact), GFP_KERNEL)))
-- return -ENOMEM;
-+ interact = kzalloc(sizeof(struct interact), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!interact || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail1;
-+ }
-
- interact->gameport = gameport;
-+ interact->dev = input_dev;
-
- gameport_set_drvdata(gameport, interact);
-
-@@ -249,41 +255,40 @@ static int interact_connect(struct gamep
- interact->type = i;
- interact->length = interact_type[i].length;
-
-- interact->dev.private = interact;
-- interact->dev.open = interact_open;
-- interact->dev.close = interact_close;
--
-- interact->dev.name = interact_type[i].name;
-- interact->dev.phys = interact->phys;
-- interact->dev.id.bustype = BUS_GAMEPORT;
-- interact->dev.id.vendor = GAMEPORT_ID_VENDOR_INTERACT;
-- interact->dev.id.product = interact_type[i].id;
-- interact->dev.id.version = 0x0100;
-+ input_dev->name = interact_type[i].name;
-+ input_dev->phys = interact->phys;
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_INTERACT;
-+ input_dev->id.product = interact_type[i].id;
-+ input_dev->id.version = 0x0100;
-+ input_dev->private = interact;
-+
-+ input_dev->open = interact_open;
-+ input_dev->close = interact_close;
-
-- interact->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (i = 0; (t = interact_type[interact->type].abs[i]) >= 0; i++) {
-- set_bit(t, interact->dev.absbit);
-+ set_bit(t, input_dev->absbit);
- if (i < interact_type[interact->type].b8) {
-- interact->dev.absmin[t] = 0;
-- interact->dev.absmax[t] = 255;
-+ input_dev->absmin[t] = 0;
-+ input_dev->absmax[t] = 255;
- } else {
-- interact->dev.absmin[t] = -1;
-- interact->dev.absmax[t] = 1;
-+ input_dev->absmin[t] = -1;
-+ input_dev->absmax[t] = 1;
- }
- }
-
- for (i = 0; (t = interact_type[interact->type].btn[i]) >= 0; i++)
-- set_bit(t, interact->dev.keybit);
-+ set_bit(t, input_dev->keybit);
-
-- input_register_device(&interact->dev);
-- printk(KERN_INFO "input: %s on %s\n",
-- interact_type[interact->type].name, gameport->phys);
-+ input_register_device(interact->dev);
-
- return 0;
-
- fail2: gameport_close(gameport);
- fail1: gameport_set_drvdata(gameport, NULL);
-+ input_free_device(input_dev);
- kfree(interact);
- return err;
- }
-@@ -292,7 +297,7 @@ static void interact_disconnect(struct g
- {
- struct interact *interact = gameport_get_drvdata(gameport);
-
-- input_unregister_device(&interact->dev);
-+ input_unregister_device(interact->dev);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(interact);
---- gregkh-2.6.orig/drivers/input/joystick/sidewinder.c
-+++ gregkh-2.6/drivers/input/joystick/sidewinder.c
-@@ -113,7 +113,7 @@ static struct {
-
- struct sw {
- struct gameport *gameport;
-- struct input_dev dev[4];
-+ struct input_dev *dev[4];
- char name[64];
- char phys[4][32];
- int length;
-@@ -301,7 +301,7 @@ static int sw_check(__u64 t)
- static int sw_parse(unsigned char *buf, struct sw *sw)
- {
- int hat, i, j;
-- struct input_dev *dev = sw->dev;
-+ struct input_dev *dev;
-
- switch (sw->type) {
-
-@@ -310,6 +310,8 @@ static int sw_parse(unsigned char *buf,
- if (sw_check(GB(0,64)) || (hat = (GB(6,1) << 3) | GB(60,3)) > 8)
- return -1;
-
-+ dev = sw->dev[0];
-+
- input_report_abs(dev, ABS_X, (GB( 3,3) << 7) | GB(16,7));
- input_report_abs(dev, ABS_Y, (GB( 0,3) << 7) | GB(24,7));
- input_report_abs(dev, ABS_RZ, (GB(35,2) << 7) | GB(40,7));
-@@ -335,13 +337,13 @@ static int sw_parse(unsigned char *buf,
- if (sw_parity(GB(i*15,15)))
- return -1;
-
-- input_report_abs(dev + i, ABS_X, GB(i*15+3,1) - GB(i*15+2,1));
-- input_report_abs(dev + i, ABS_Y, GB(i*15+0,1) - GB(i*15+1,1));
-+ input_report_abs(sw->dev[i], ABS_X, GB(i*15+3,1) - GB(i*15+2,1));
-+ input_report_abs(sw->dev[i], ABS_Y, GB(i*15+0,1) - GB(i*15+1,1));
-
- for (j = 0; j < 10; j++)
-- input_report_key(dev + i, sw_btn[SW_ID_GP][j], !GB(i*15+j+4,1));
-+ input_report_key(sw->dev[i], sw_btn[SW_ID_GP][j], !GB(i*15+j+4,1));
-
-- input_sync(dev + i);
-+ input_sync(sw->dev[i]);
- }
-
- return 0;
-@@ -352,6 +354,7 @@ static int sw_parse(unsigned char *buf,
- if (!sw_parity(GB(0,48)) || (hat = GB(42,4)) > 8)
- return -1;
-
-+ dev = sw->dev[0];
- input_report_abs(dev, ABS_X, GB( 9,10));
- input_report_abs(dev, ABS_Y, GB(19,10));
- input_report_abs(dev, ABS_RZ, GB(36, 6));
-@@ -372,6 +375,7 @@ static int sw_parse(unsigned char *buf,
- if (!sw_parity(GB(0,43)) || (hat = GB(28,4)) > 8)
- return -1;
-
-+ dev = sw->dev[0];
- input_report_abs(dev, ABS_X, GB( 0,10));
- input_report_abs(dev, ABS_Y, GB(16,10));
- input_report_abs(dev, ABS_THROTTLE, GB(32, 6));
-@@ -396,6 +400,7 @@ static int sw_parse(unsigned char *buf,
- if (!sw_parity(GB(0,33)))
- return -1;
-
-+ dev = sw->dev[0];
- input_report_abs(dev, ABS_RX, GB( 0,10));
- input_report_abs(dev, ABS_RUDDER, GB(10, 6));
- input_report_abs(dev, ABS_THROTTLE, GB(16, 6));
-@@ -581,6 +586,7 @@ static int sw_guess_mode(unsigned char *
- static int sw_connect(struct gameport *gameport, struct gameport_driver *drv)
- {
- struct sw *sw;
-+ struct input_dev *input_dev;
- int i, j, k, l;
- int err;
- unsigned char *buf = NULL; /* [SW_LENGTH] */
-@@ -729,42 +735,50 @@ static int sw_connect(struct gameport *g
- sprintf(sw->name, "Microsoft SideWinder %s", sw_name[sw->type]);
- sprintf(sw->phys[i], "%s/input%d", gameport->phys, i);
-
-- sw->dev[i].private = sw;
--
-- sw->dev[i].open = sw_open;
-- sw->dev[i].close = sw_close;
-+ input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ err = -ENOMEM;
-+ goto fail3;
-+ }
-+
-+ input_dev->name = sw->name;
-+ input_dev->phys = sw->phys[i];
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_MICROSOFT;
-+ input_dev->id.product = sw->type;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &gameport->dev;
-+ input_dev->private = sw;
-
-- sw->dev[i].name = sw->name;
-- sw->dev[i].phys = sw->phys[i];
-- sw->dev[i].id.bustype = BUS_GAMEPORT;
-- sw->dev[i].id.vendor = GAMEPORT_ID_VENDOR_MICROSOFT;
-- sw->dev[i].id.product = sw->type;
-- sw->dev[i].id.version = 0x0100;
-+ input_dev->open = sw_open;
-+ input_dev->close = sw_close;
-
-- sw->dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (j = 0; (bits = sw_bit[sw->type][j]); j++) {
- code = sw_abs[sw->type][j];
-- set_bit(code, sw->dev[i].absbit);
-- sw->dev[i].absmax[code] = (1 << bits) - 1;
-- sw->dev[i].absmin[code] = (bits == 1) ? -1 : 0;
-- sw->dev[i].absfuzz[code] = ((bits >> 1) >= 2) ? (1 << ((bits >> 1) - 2)) : 0;
-+ set_bit(code, input_dev->absbit);
-+ input_dev->absmax[code] = (1 << bits) - 1;
-+ input_dev->absmin[code] = (bits == 1) ? -1 : 0;
-+ input_dev->absfuzz[code] = ((bits >> 1) >= 2) ? (1 << ((bits >> 1) - 2)) : 0;
- if (code != ABS_THROTTLE)
-- sw->dev[i].absflat[code] = (bits >= 5) ? (1 << (bits - 5)) : 0;
-+ input_dev->absflat[code] = (bits >= 5) ? (1 << (bits - 5)) : 0;
- }
-
- for (j = 0; (code = sw_btn[sw->type][j]); j++)
-- set_bit(code, sw->dev[i].keybit);
-+ set_bit(code, input_dev->keybit);
-+
-+ dbg("%s%s [%d-bit id %d data %d]\n", sw->name, comment, m, l, k);
-
-- input_register_device(sw->dev + i);
-- printk(KERN_INFO "input: %s%s on %s [%d-bit id %d data %d]\n",
-- sw->name, comment, gameport->phys, m, l, k);
-+ input_register_device(sw->dev[i]);
- }
-
- return 0;
-
--fail2: gameport_close(gameport);
--fail1: gameport_set_drvdata(gameport, NULL);
-+ fail3: while (--i >= 0)
-+ input_unregister_device(sw->dev[i]);
-+ fail2: gameport_close(gameport);
-+ fail1: gameport_set_drvdata(gameport, NULL);
- kfree(sw);
- kfree(buf);
- kfree(idbuf);
-@@ -777,7 +791,7 @@ static void sw_disconnect(struct gamepor
- int i;
-
- for (i = 0; i < sw->number; i++)
-- input_unregister_device(sw->dev + i);
-+ input_unregister_device(sw->dev[i]);
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(sw);
---- gregkh-2.6.orig/drivers/input/joystick/tmdc.c
-+++ gregkh-2.6/drivers/input/joystick/tmdc.c
-@@ -63,37 +63,70 @@ MODULE_LICENSE("GPL");
- #define TMDC_ABS_HAT 4
- #define TMDC_BTN 16
-
--static unsigned char tmdc_byte_a[16] = { 0, 1, 3, 4, 6, 7 };
--static unsigned char tmdc_byte_d[16] = { 2, 5, 8, 9 };
-+static const unsigned char tmdc_byte_a[16] = { 0, 1, 3, 4, 6, 7 };
-+static const unsigned char tmdc_byte_d[16] = { 2, 5, 8, 9 };
-
--static signed char tmdc_abs[TMDC_ABS] =
-+static const signed char tmdc_abs[TMDC_ABS] =
- { ABS_X, ABS_Y, ABS_RUDDER, ABS_THROTTLE, ABS_RX, ABS_RY, ABS_RZ };
--static signed char tmdc_abs_hat[TMDC_ABS_HAT] =
-+static const signed char tmdc_abs_hat[TMDC_ABS_HAT] =
- { ABS_HAT0X, ABS_HAT0Y, ABS_HAT1X, ABS_HAT1Y };
--static signed char tmdc_abs_at[TMDC_ABS] =
-+static const signed char tmdc_abs_at[TMDC_ABS] =
- { ABS_X, ABS_Y, ABS_RUDDER, -1, ABS_THROTTLE };
--static signed char tmdc_abs_fm[TMDC_ABS] =
-+static const signed char tmdc_abs_fm[TMDC_ABS] =
- { ABS_RX, ABS_RY, ABS_X, ABS_Y };
-
--static short tmdc_btn_pad[TMDC_BTN] =
-+static const short tmdc_btn_pad[TMDC_BTN] =
- { BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z, BTN_START, BTN_SELECT, BTN_TL, BTN_TR };
--static short tmdc_btn_joy[TMDC_BTN] =
-+static const short tmdc_btn_joy[TMDC_BTN] =
- { BTN_TRIGGER, BTN_THUMB, BTN_TOP, BTN_TOP2, BTN_BASE, BTN_BASE2, BTN_THUMB2, BTN_PINKIE,
- BTN_BASE3, BTN_BASE4, BTN_A, BTN_B, BTN_C, BTN_X, BTN_Y, BTN_Z };
--static short tmdc_btn_fm[TMDC_BTN] =
-+static const short tmdc_btn_fm[TMDC_BTN] =
- { BTN_TRIGGER, BTN_C, BTN_B, BTN_A, BTN_THUMB, BTN_X, BTN_Y, BTN_Z, BTN_TOP, BTN_TOP2 };
--static short tmdc_btn_at[TMDC_BTN] =
-+static const short tmdc_btn_at[TMDC_BTN] =
- { BTN_TRIGGER, BTN_THUMB2, BTN_PINKIE, BTN_THUMB, BTN_BASE6, BTN_BASE5, BTN_BASE4,
- BTN_BASE3, BTN_BASE2, BTN_BASE };
-
--static struct {
-+static const struct {
- int x;
- int y;
- } tmdc_hat_to_axis[] = {{ 0, 0}, { 1, 0}, { 0,-1}, {-1, 0}, { 0, 1}};
-
-+static const struct tmdc_model {
-+ unsigned char id;
-+ const char *name;
-+ char abs;
-+ char hats;
-+ char btnc[4];
-+ char btno[4];
-+ const signed char *axes;
-+ const short *buttons;
-+} tmdc_models[] = {
-+ { 1, "ThrustMaster Millenium 3D Inceptor", 6, 2, { 4, 2 }, { 4, 6 }, tmdc_abs, tmdc_btn_joy },
-+ { 3, "ThrustMaster Rage 3D Gamepad", 2, 0, { 8, 2 }, { 0, 0 }, tmdc_abs, tmdc_btn_pad },
-+ { 4, "ThrustMaster Attack Throttle", 5, 2, { 4, 6 }, { 4, 2 }, tmdc_abs_at, tmdc_btn_at },
-+ { 8, "ThrustMaster FragMaster", 4, 0, { 8, 2 }, { 0, 0 }, tmdc_abs_fm, tmdc_btn_fm },
-+ { 163, "Thrustmaster Fusion GamePad", 2, 0, { 8, 2 }, { 0, 0 }, tmdc_abs, tmdc_btn_pad },
-+ { 0, "Unknown %d-axis, %d-button TM device %d", 0, 0, { 0, 0 }, { 0, 0 }, tmdc_abs, tmdc_btn_joy }
-+};
-+
-+
-+struct tmdc_port {
-+ struct input_dev *dev;
-+ char name[64];
-+ char phys[32];
-+ int mode;
-+ const signed char *abs;
-+ const short *btn;
-+ unsigned char absc;
-+ unsigned char btnc[4];
-+ unsigned char btno[4];
-+};
-+
- struct tmdc {
- struct gameport *gameport;
-- struct input_dev dev[2];
-+ struct tmdc_port *port[2];
-+#if 0
-+ struct input_dev *dev[2];
- char name[2][64];
- char phys[2][32];
- int mode[2];
-@@ -102,6 +135,7 @@ struct tmdc {
- unsigned char absc[2];
- unsigned char btnc[2][4];
- unsigned char btno[2][4];
-+#endif
- int reads;
- int bads;
- unsigned char exists;
-@@ -156,6 +190,50 @@ static int tmdc_read_packet(struct gamep
- return (i[0] == TMDC_MAX_LENGTH) | ((i[1] == TMDC_MAX_LENGTH) << 1);
- }
-
-+static int tmdc_parse_packet(struct tmdc_port *port, unsigned char *data)
-+{
-+ int i, k, l;
-+
-+ if (data[TMDC_BYTE_ID] != port->mode)
-+ return -1;
-+
-+ for (i = 0; i < port->absc; i++) {
-+ if (port->abs[i] < 0)
-+ return 0;
-+
-+ input_report_abs(port->dev, port->abs[i], data[tmdc_byte_a[i]]);
-+ }
-+
-+ switch (port->mode) {
-+
-+ case TMDC_MODE_M3DI:
-+
-+ i = tmdc_byte_d[0];
-+ input_report_abs(port->dev, ABS_HAT0X, ((data[i] >> 3) & 1) - ((data[i] >> 1) & 1));
-+ input_report_abs(port->dev, ABS_HAT0Y, ((data[i] >> 2) & 1) - ( data[i] & 1));
-+ break;
-+
-+ case TMDC_MODE_AT:
-+
-+ i = tmdc_byte_a[3];
-+ input_report_abs(port->dev, ABS_HAT0X, tmdc_hat_to_axis[(data[i] - 141) / 25].x);
-+ input_report_abs(port->dev, ABS_HAT0Y, tmdc_hat_to_axis[(data[i] - 141) / 25].y);
-+ break;
-+
-+ }
-+
-+ for (k = l = 0; k < 4; k++) {
-+ for (i = 0; i < port->btnc[k]; i++)
-+ input_report_key(port->dev, port->btn[i + l],
-+ ((data[tmdc_byte_d[k]] >> (i + port->btno[k])) & 1));
-+ l += port->btnc[k];
-+ }
-+
-+ input_sync(port->dev);
-+
-+ return 0;
-+}
-+
- /*
- * tmdc_poll() reads and analyzes ThrustMaster joystick data.
- */
-@@ -164,57 +242,21 @@ static void tmdc_poll(struct gameport *g
- {
- unsigned char data[2][TMDC_MAX_LENGTH];
- struct tmdc *tmdc = gameport_get_drvdata(gameport);
-- struct input_dev *dev;
- unsigned char r, bad = 0;
-- int i, j, k, l;
-+ int i;
-
- tmdc->reads++;
-
- if ((r = tmdc_read_packet(tmdc->gameport, data)) != tmdc->exists)
- bad = 1;
-- else
--
-- for (j = 0; j < 2; j++)
-- if (r & (1 << j) & tmdc->exists) {
--
-- if (data[j][TMDC_BYTE_ID] != tmdc->mode[j]) {
-- bad = 1;
-- continue;
-- }
--
-- dev = tmdc->dev + j;
-+ else {
-+ for (i = 0; i < 2; i++) {
-+ if (r & (1 << i) & tmdc->exists) {
-
-- for (i = 0; i < tmdc->absc[j]; i++) {
-- if (tmdc->abs[j][i] < 0) continue;
-- input_report_abs(dev, tmdc->abs[j][i], data[j][tmdc_byte_a[i]]);
-+ if (tmdc_parse_packet(tmdc->port[i], data[i]))
-+ bad = 1;
- }
--
-- switch (tmdc->mode[j]) {
--
-- case TMDC_MODE_M3DI:
--
-- i = tmdc_byte_d[0];
-- input_report_abs(dev, ABS_HAT0X, ((data[j][i] >> 3) & 1) - ((data[j][i] >> 1) & 1));
-- input_report_abs(dev, ABS_HAT0Y, ((data[j][i] >> 2) & 1) - ( data[j][i] & 1));
-- break;
--
-- case TMDC_MODE_AT:
--
-- i = tmdc_byte_a[3];
-- input_report_abs(dev, ABS_HAT0X, tmdc_hat_to_axis[(data[j][i] - 141) / 25].x);
-- input_report_abs(dev, ABS_HAT0Y, tmdc_hat_to_axis[(data[j][i] - 141) / 25].y);
-- break;
--
-- }
--
-- for (k = l = 0; k < 4; k++) {
-- for (i = 0; i < tmdc->btnc[j][k]; i++)
-- input_report_key(dev, tmdc->btn[j][i + l],
-- ((data[j][tmdc_byte_d[k]] >> (i + tmdc->btno[j][k])) & 1));
-- l += tmdc->btnc[j][k];
-- }
--
-- input_sync(dev);
-+ }
- }
-
- tmdc->bads += bad;
-@@ -235,31 +277,89 @@ static void tmdc_close(struct input_dev
- gameport_stop_polling(tmdc->gameport);
- }
-
-+static int tmdc_setup_port(struct tmdc *tmdc, int idx, unsigned char *data)
-+{
-+ const struct tmdc_model *model;
-+ struct tmdc_port *port;
-+ struct input_dev *input_dev;
-+ int i, j, b = 0;
-+
-+ tmdc->port[idx] = port = kzalloc(sizeof (struct tmdc_port), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!port || !input_dev) {
-+ kfree(port);
-+ input_free_device(input_dev);
-+ return -ENOMEM;
-+ }
-+
-+ port->mode = data[TMDC_BYTE_ID];
-+
-+ for (model = tmdc_models; model->id && model->id != port->mode; model++)
-+ /* empty */;
-+
-+ port->abs = model->axes;
-+ port->btn = model->buttons;
-+
-+ if (!model->id) {
-+ port->absc = data[TMDC_BYTE_DEF] >> 4;
-+ for (i = 0; i < 4; i++)
-+ port->btnc[i] = i < (data[TMDC_BYTE_DEF] & 0xf) ? 8 : 0;
-+ } else {
-+ port->absc = model->abs;
-+ for (i = 0; i < 4; i++)
-+ port->btnc[i] = model->btnc[i];
-+ }
-+
-+ for (i = 0; i < 4; i++)
-+ port->btno[i] = model->btno[i];
-+
-+ snprintf(port->name, sizeof(port->name), model->name,
-+ port->absc, (data[TMDC_BYTE_DEF] & 0xf) << 3, port->mode);
-+ snprintf(port->phys, sizeof(port->phys), "%s/input%d", tmdc->gameport->phys, i);
-+
-+ port->dev = input_dev;
-+
-+ input_dev->name = port->name;
-+ input_dev->phys = port->phys;
-+ input_dev->id.bustype = BUS_GAMEPORT;
-+ input_dev->id.vendor = GAMEPORT_ID_VENDOR_THRUSTMASTER;
-+ input_dev->id.product = model->id;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &tmdc->gameport->dev;
-+ input_dev->private = tmdc;
-+
-+ input_dev->open = tmdc_open;
-+ input_dev->close = tmdc_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+
-+ for (i = 0; i < port->absc && i < TMDC_ABS; i++)
-+ if (port->abs[i] >= 0)
-+ input_set_abs_params(input_dev, port->abs[i], 8, 248, 2, 4);
-+
-+ for (i = 0; i < model->hats && i < TMDC_ABS_HAT; i++)
-+ input_set_abs_params(input_dev, tmdc_abs_hat[i], -1, 1, 0, 0);
-+
-+ for (i = 0; i < 4; i++) {
-+ for (j = 0; j < port->btnc[i] && j < TMDC_BTN; j++)
-+ set_bit(port->btn[j + b], input_dev->keybit);
-+ b += port->btnc[i];
-+ }
-+
-+ input_register_device(port->dev);
-+
-+ return 0;
-+}
-+
- /*
- * tmdc_probe() probes for ThrustMaster type joysticks.
- */
-
- static int tmdc_connect(struct gameport *gameport, struct gameport_driver *drv)
- {
-- static struct models {
-- unsigned char id;
-- char *name;
-- char abs;
-- char hats;
-- char btnc[4];
-- char btno[4];
-- signed char *axes;
-- short *buttons;
-- } models[] = { { 1, "ThrustMaster Millenium 3D Inceptor", 6, 2, { 4, 2 }, { 4, 6 }, tmdc_abs, tmdc_btn_joy },
-- { 3, "ThrustMaster Rage 3D Gamepad", 2, 0, { 8, 2 }, { 0, 0 }, tmdc_abs, tmdc_btn_pad },
-- { 4, "ThrustMaster Attack Throttle", 5, 2, { 4, 6 }, { 4, 2 }, tmdc_abs_at, tmdc_btn_at },
-- { 8, "ThrustMaster FragMaster", 4, 0, { 8, 2 }, { 0, 0 }, tmdc_abs_fm, tmdc_btn_fm },
-- { 163, "Thrustmaster Fusion GamePad", 2, 0, { 8, 2 }, { 0, 0 }, tmdc_abs, tmdc_btn_pad },
-- { 0, "Unknown %d-axis, %d-button TM device %d", 0, 0, { 0, 0 }, { 0, 0 }, tmdc_abs, tmdc_btn_joy }};
--
- unsigned char data[2][TMDC_MAX_LENGTH];
- struct tmdc *tmdc;
-- int i, j, k, l, m;
-+ int i;
- int err;
-
- if (!(tmdc = kzalloc(sizeof(struct tmdc), GFP_KERNEL)))
-@@ -281,68 +381,25 @@ static int tmdc_connect(struct gameport
- gameport_set_poll_handler(gameport, tmdc_poll);
- gameport_set_poll_interval(gameport, 20);
-
-- for (j = 0; j < 2; j++)
-- if (tmdc->exists & (1 << j)) {
--
-- tmdc->mode[j] = data[j][TMDC_BYTE_ID];
--
-- for (m = 0; models[m].id && models[m].id != tmdc->mode[j]; m++);
-+ for (i = 0; i < 2; i++) {
-+ if (tmdc->exists & (1 << i)) {
-
-- tmdc->abs[j] = models[m].axes;
-- tmdc->btn[j] = models[m].buttons;
--
-- if (!models[m].id) {
-- models[m].abs = data[j][TMDC_BYTE_DEF] >> 4;
-- for (k = 0; k < 4; k++)
-- models[m].btnc[k] = k < (data[j][TMDC_BYTE_DEF] & 0xf) ? 8 : 0;
-- }
--
-- tmdc->absc[j] = models[m].abs;
-- for (k = 0; k < 4; k++) {
-- tmdc->btnc[j][k] = models[m].btnc[k];
-- tmdc->btno[j][k] = models[m].btno[k];
-- }
--
-- sprintf(tmdc->name[j], models[m].name, models[m].abs,
-- (data[j][TMDC_BYTE_DEF] & 0xf) << 3, tmdc->mode[j]);
--
-- sprintf(tmdc->phys[j], "%s/input%d", gameport->phys, j);
--
-- tmdc->dev[j].private = tmdc;
-- tmdc->dev[j].open = tmdc_open;
-- tmdc->dev[j].close = tmdc_close;
--
-- tmdc->dev[j].name = tmdc->name[j];
-- tmdc->dev[j].phys = tmdc->phys[j];
-- tmdc->dev[j].id.bustype = BUS_GAMEPORT;
-- tmdc->dev[j].id.vendor = GAMEPORT_ID_VENDOR_THRUSTMASTER;
-- tmdc->dev[j].id.product = models[m].id;
-- tmdc->dev[j].id.version = 0x0100;
--
-- tmdc->dev[j].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
--
-- for (i = 0; i < models[m].abs && i < TMDC_ABS; i++)
-- if (tmdc->abs[j][i] >= 0)
-- input_set_abs_params(&tmdc->dev[j], tmdc->abs[j][i], 8, 248, 2, 4);
--
-- for (i = 0; i < models[m].hats && i < TMDC_ABS_HAT; i++)
-- input_set_abs_params(&tmdc->dev[j], tmdc_abs_hat[i], -1, 1, 0, 0);
--
--
-- for (k = l = 0; k < 4; k++) {
-- for (i = 0; i < models[m].btnc[k] && i < TMDC_BTN; i++)
-- set_bit(tmdc->btn[j][i + l], tmdc->dev[j].keybit);
-- l += models[m].btnc[k];
-- }
--
-- input_register_device(tmdc->dev + j);
-- printk(KERN_INFO "input: %s on %s\n", tmdc->name[j], gameport->phys);
-+ err = tmdc_setup_port(tmdc, i, data[i]);
-+ if (err)
-+ goto fail3;
- }
-+ }
-
- return 0;
-
--fail2: gameport_close(gameport);
--fail1: gameport_set_drvdata(gameport, NULL);
-+ fail3: while (--i >= 0) {
-+ if (tmdc->port[i]) {
-+ input_unregister_device(tmdc->port[i]->dev);
-+ kfree(tmdc->port[i]);
-+ }
-+ }
-+ fail2: gameport_close(gameport);
-+ fail1: gameport_set_drvdata(gameport, NULL);
- kfree(tmdc);
- return err;
- }
-@@ -352,9 +409,12 @@ static void tmdc_disconnect(struct gamep
- struct tmdc *tmdc = gameport_get_drvdata(gameport);
- int i;
-
-- for (i = 0; i < 2; i++)
-- if (tmdc->exists & (1 << i))
-- input_unregister_device(tmdc->dev + i);
-+ for (i = 0; i < 2; i++) {
-+ if (tmdc->port[i]) {
-+ input_unregister_device(tmdc->port[i]->dev);
-+ kfree(tmdc->port[i]);
-+ }
-+ }
- gameport_close(gameport);
- gameport_set_drvdata(gameport, NULL);
- kfree(tmdc);
---- gregkh-2.6.orig/drivers/input/joystick/turbografx.c
-+++ gregkh-2.6/drivers/input/joystick/turbografx.c
-@@ -42,19 +42,21 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@u
- MODULE_DESCRIPTION("TurboGraFX parallel port interface driver");
- MODULE_LICENSE("GPL");
-
--static int tgfx[] __initdata = { -1, 0, 0, 0, 0, 0, 0, 0 };
--static int tgfx_nargs __initdata = 0;
--module_param_array_named(map, tgfx, int, &tgfx_nargs, 0);
--MODULE_PARM_DESC(map, "Describes first set of devices (<parport#>,<js1>,<js2>,..<js7>");
-+#define TGFX_MAX_PORTS 3
-+#define TGFX_MAX_DEVICES 7
-
--static int tgfx_2[] __initdata = { -1, 0, 0, 0, 0, 0, 0, 0 };
--static int tgfx_nargs_2 __initdata = 0;
--module_param_array_named(map2, tgfx_2, int, &tgfx_nargs_2, 0);
--MODULE_PARM_DESC(map2, "Describes second set of devices");
-+struct tgfx_config {
-+ int args[TGFX_MAX_DEVICES + 1];
-+ int nargs;
-+};
-+
-+static struct tgfx_config tgfx[TGFX_MAX_PORTS] __initdata;
-
--static int tgfx_3[] __initdata = { -1, 0, 0, 0, 0, 0, 0, 0 };
--static int tgfx_nargs_3 __initdata = 0;
--module_param_array_named(map3, tgfx_3, int, &tgfx_nargs_3, 0);
-+module_param_array_named(map, tgfx[0].args, int, &tgfx[0].nargs, 0);
-+MODULE_PARM_DESC(map, "Describes first set of devices (<parport#>,<js1>,<js2>,..<js7>");
-+module_param_array_named(map2, tgfx[1].args, int, &tgfx[1].nargs, 0);
-+MODULE_PARM_DESC(map2, "Describes second set of devices");
-+module_param_array_named(map3, tgfx[2].args, int, &tgfx[2].nargs, 0);
- MODULE_PARM_DESC(map3, "Describes third set of devices");
-
- __obsolete_setup("tgfx=");
-@@ -75,17 +77,17 @@ __obsolete_setup("tgfx_3=");
- #define TGFX_TOP2 0x08
-
- static int tgfx_buttons[] = { BTN_TRIGGER, BTN_THUMB, BTN_THUMB2, BTN_TOP, BTN_TOP2 };
--static char *tgfx_name = "TurboGraFX Multisystem joystick";
-
- static struct tgfx {
- struct pardevice *pd;
- struct timer_list timer;
-- struct input_dev dev[7];
-- char phys[7][32];
-+ struct input_dev *dev[TGFX_MAX_DEVICES];
-+ char name[TGFX_MAX_DEVICES][64];
-+ char phys[TGFX_MAX_DEVICES][32];
- int sticks;
- int used;
- struct semaphore sem;
--} *tgfx_base[3];
-+} *tgfx_base[TGFX_MAX_PORTS];
-
- /*
- * tgfx_timer() reads and analyzes TurboGraFX joystick data.
-@@ -100,7 +102,7 @@ static void tgfx_timer(unsigned long pri
- for (i = 0; i < 7; i++)
- if (tgfx->sticks & (1 << i)) {
-
-- dev = tgfx->dev + i;
-+ dev = tgfx->dev[i];
-
- parport_write_data(tgfx->pd->port, ~(1 << i));
- data1 = parport_read_status(tgfx->pd->port) ^ 0x7f;
-@@ -153,118 +155,165 @@ static void tgfx_close(struct input_dev
- up(&tgfx->sem);
- }
-
-+
-+
- /*
- * tgfx_probe() probes for tg gamepads.
- */
-
--static struct tgfx __init *tgfx_probe(int *config, int nargs)
-+static struct tgfx __init *tgfx_probe(int parport, int *n_buttons, int n_devs)
- {
- struct tgfx *tgfx;
-+ struct input_dev *input_dev;
- struct parport *pp;
-+ struct pardevice *pd;
- int i, j;
-+ int err;
-
-- if (config[0] < 0)
-- return NULL;
--
-- if (nargs < 2) {
-- printk(KERN_ERR "turbografx.c: at least one joystick must be specified\n");
-- return NULL;
-- }
--
-- pp = parport_find_number(config[0]);
--
-+ pp = parport_find_number(parport);
- if (!pp) {
- printk(KERN_ERR "turbografx.c: no such parport\n");
-- return NULL;
-+ err = -EINVAL;
-+ goto err_out;
- }
-
-- if (!(tgfx = kzalloc(sizeof(struct tgfx), GFP_KERNEL))) {
-- parport_put_port(pp);
-- return NULL;
-+ pd = parport_register_device(pp, "turbografx", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
-+ if (!pd) {
-+ printk(KERN_ERR "turbografx.c: parport busy already - lp.o loaded?\n");
-+ err = -EBUSY;
-+ goto err_put_pp;
- }
-
-- init_MUTEX(&tgfx->sem);
--
-- tgfx->pd = parport_register_device(pp, "turbografx", NULL, NULL, NULL, PARPORT_DEV_EXCL, NULL);
--
-- parport_put_port(pp);
--
-- if (!tgfx->pd) {
-- printk(KERN_ERR "turbografx.c: parport busy already - lp.o loaded?\n");
-- kfree(tgfx);
-- return NULL;
-+ tgfx = kzalloc(sizeof(struct tgfx), GFP_KERNEL);
-+ if (!tgfx) {
-+ printk(KERN_ERR "turbografx.c: Not enough memory\n");
-+ err = -ENOMEM;
-+ goto err_unreg_pardev;
- }
-
-+ init_MUTEX(&tgfx->sem);
-+ tgfx->pd = pd;
- init_timer(&tgfx->timer);
- tgfx->timer.data = (long) tgfx;
- tgfx->timer.function = tgfx_timer;
-
-- tgfx->sticks = 0;
--
-- for (i = 0; i < nargs - 1; i++)
-- if (config[i+1] > 0 && config[i+1] < 6) {
--
-- tgfx->sticks |= (1 << i);
--
-- tgfx->dev[i].private = tgfx;
-- tgfx->dev[i].open = tgfx_open;
-- tgfx->dev[i].close = tgfx_close;
--
-- sprintf(tgfx->phys[i], "%s/input0", tgfx->pd->port->name);
--
-- tgfx->dev[i].name = tgfx_name;
-- tgfx->dev[i].phys = tgfx->phys[i];
-- tgfx->dev[i].id.bustype = BUS_PARPORT;
-- tgfx->dev[i].id.vendor = 0x0003;
-- tgfx->dev[i].id.product = config[i+1];
-- tgfx->dev[i].id.version = 0x0100;
-+ for (i = 0; i < n_devs; i++) {
-+ if (n_buttons[i] < 1)
-+ continue;
-+
-+ if (n_buttons[i] > 6) {
-+ printk(KERN_ERR "turbografx.c: Invalid number of buttons %d\n", n_buttons[i]);
-+ err = -EINVAL;
-+ goto err_free_devs;
-+ }
-
-- tgfx->dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- tgfx->dev[i].absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-+ tgfx->dev[i] = input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ printk(KERN_ERR "turbografx.c: Not enough memory for input device\n");
-+ err = -ENOMEM;
-+ goto err_free_devs;
-+ }
-
-- for (j = 0; j < config[i+1]; j++)
-- set_bit(tgfx_buttons[j], tgfx->dev[i].keybit);
-+ tgfx->sticks |= (1 << i);
-+ snprintf(tgfx->name[i], sizeof(tgfx->name[i]),
-+ "TurboGraFX %d-button Multisystem joystick", n_buttons[i]);
-+ snprintf(tgfx->phys[i], sizeof(tgfx->phys[i]),
-+ "%s/input%d", tgfx->pd->port->name, i);
-+
-+ input_dev->name = tgfx->name[i];
-+ input_dev->phys = tgfx->phys[i];
-+ input_dev->id.bustype = BUS_PARPORT;
-+ input_dev->id.vendor = 0x0003;
-+ input_dev->id.product = n_buttons[i];
-+ input_dev->id.version = 0x0100;
-+
-+ input_dev->private = tgfx;
-+ input_dev->open = tgfx_open;
-+ input_dev->close = tgfx_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_set_abs_params(input_dev, ABS_X, -1, 1, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, -1, 1, 0, 0);
-
-- tgfx->dev[i].absmin[ABS_X] = -1; tgfx->dev[i].absmax[ABS_X] = 1;
-- tgfx->dev[i].absmin[ABS_Y] = -1; tgfx->dev[i].absmax[ABS_Y] = 1;
-+ for (j = 0; j < n_buttons[i]; j++)
-+ set_bit(tgfx_buttons[j], input_dev->keybit);
-
-- input_register_device(tgfx->dev + i);
-- printk(KERN_INFO "input: %d-button Multisystem joystick on %s\n",
-- config[i+1], tgfx->pd->port->name);
-- }
-+ input_register_device(tgfx->dev[i]);
-+ }
-
- if (!tgfx->sticks) {
-- parport_unregister_device(tgfx->pd);
-- kfree(tgfx);
-- return NULL;
-+ printk(KERN_ERR "turbografx.c: No valid devices specified\n");
-+ err = -EINVAL;
-+ goto err_free_tgfx;
- }
-
- return tgfx;
-+
-+ err_free_devs:
-+ while (--i >= 0)
-+ input_unregister_device(tgfx->dev[i]);
-+ err_free_tgfx:
-+ kfree(tgfx);
-+ err_unreg_pardev:
-+ parport_unregister_device(pd);
-+ err_put_pp:
-+ parport_put_port(pp);
-+ err_out:
-+ return ERR_PTR(err);
-+}
-+
-+static void __exit tgfx_remove(struct tgfx *tgfx)
-+{
-+ int i;
-+
-+ for (i = 0; i < TGFX_MAX_DEVICES; i++)
-+ if (tgfx->dev[i])
-+ input_unregister_device(tgfx->dev[i]);
-+ parport_unregister_device(tgfx->pd);
-+ kfree(tgfx);
- }
-
- static int __init tgfx_init(void)
- {
-- tgfx_base[0] = tgfx_probe(tgfx, tgfx_nargs);
-- tgfx_base[1] = tgfx_probe(tgfx_2, tgfx_nargs_2);
-- tgfx_base[2] = tgfx_probe(tgfx_3, tgfx_nargs_3);
-+ int i;
-+ int have_dev = 0;
-+ int err = 0;
-+
-+ for (i = 0; i < TGFX_MAX_PORTS; i++) {
-+ if (tgfx[i].nargs == 0 || tgfx[i].args[0] < 0)
-+ continue;
-+
-+ if (tgfx[i].nargs < 2) {
-+ printk(KERN_ERR "turbografx.c: at least one joystick must be specified\n");
-+ err = -EINVAL;
-+ break;
-+ }
-
-- if (tgfx_base[0] || tgfx_base[1] || tgfx_base[2])
-- return 0;
-+ tgfx_base[i] = tgfx_probe(tgfx[i].args[0], tgfx[i].args + 1, tgfx[i].nargs - 1);
-+ if (IS_ERR(tgfx_base[i])) {
-+ err = PTR_ERR(tgfx_base[i]);
-+ break;
-+ }
-+
-+ have_dev = 1;
-+ }
-
-- return -ENODEV;
-+ if (err) {
-+ while (--i >= 0)
-+ tgfx_remove(tgfx_base[i]);
-+ return err;
-+ }
-+
-+ return have_dev ? 0 : -ENODEV;
- }
-
- static void __exit tgfx_exit(void)
- {
-- int i, j;
-+ int i;
-
-- for (i = 0; i < 3; i++)
-- if (tgfx_base[i]) {
-- for (j = 0; j < 7; j++)
-- if (tgfx_base[i]->sticks & (1 << j))
-- input_unregister_device(tgfx_base[i]->dev + j);
-- parport_unregister_device(tgfx_base[i]->pd);
-- }
-+ for (i = 0; i < TGFX_MAX_PORTS; i++)
-+ if (tgfx_base[i])
-+ tgfx_remove(tgfx_base[i]);
- }
-
- module_init(tgfx_init);
---- gregkh-2.6.orig/drivers/input/joystick/iforce/iforce-main.c
-+++ gregkh-2.6/drivers/input/joystick/iforce/iforce-main.c
-@@ -144,7 +144,7 @@ static int iforce_upload_effect(struct i
- int is_update;
-
- /* Check this effect type is supported by this device */
-- if (!test_bit(effect->type, iforce->dev.ffbit))
-+ if (!test_bit(effect->type, iforce->dev->ffbit))
- return -EINVAL;
-
- /*
-@@ -152,30 +152,31 @@ static int iforce_upload_effect(struct i
- */
- if (effect->id == -1) {
-
-- for (id=0; id < FF_EFFECTS_MAX; ++id)
-- if (!test_and_set_bit(FF_CORE_IS_USED, iforce->core_effects[id].flags)) break;
-+ for (id = 0; id < FF_EFFECTS_MAX; ++id)
-+ if (!test_and_set_bit(FF_CORE_IS_USED, iforce->core_effects[id].flags))
-+ break;
-
-- if ( id == FF_EFFECTS_MAX || id >= iforce->dev.ff_effects_max)
-+ if (id == FF_EFFECTS_MAX || id >= iforce->dev->ff_effects_max)
- return -ENOMEM;
-
- effect->id = id;
- iforce->core_effects[id].owner = current->pid;
-- iforce->core_effects[id].flags[0] = (1<<FF_CORE_IS_USED); /* Only IS_USED bit must be set */
-+ iforce->core_effects[id].flags[0] = (1 << FF_CORE_IS_USED); /* Only IS_USED bit must be set */
-
- is_update = FALSE;
- }
- else {
- /* We want to update an effect */
-- if (!CHECK_OWNERSHIP(effect->id, iforce)) return -EACCES;
-+ if (!CHECK_OWNERSHIP(effect->id, iforce))
-+ return -EACCES;
-
- /* Parameter type cannot be updated */
- if (effect->type != iforce->core_effects[effect->id].effect.type)
- return -EINVAL;
-
- /* Check the effect is not already being updated */
-- if (test_bit(FF_CORE_UPDATE, iforce->core_effects[effect->id].flags)) {
-+ if (test_bit(FF_CORE_UPDATE, iforce->core_effects[effect->id].flags))
- return -EAGAIN;
-- }
-
- is_update = TRUE;
- }
-@@ -339,15 +340,19 @@ void iforce_delete_device(struct iforce
-
- int iforce_init_device(struct iforce *iforce)
- {
-+ struct input_dev *input_dev;
- unsigned char c[] = "CEOV";
- int i;
-
-+ input_dev = input_allocate_device();
-+ if (input_dev)
-+ return -ENOMEM;
-+
- init_waitqueue_head(&iforce->wait);
- spin_lock_init(&iforce->xmit_lock);
- init_MUTEX(&iforce->mem_mutex);
- iforce->xmit.buf = iforce->xmit_data;
--
-- iforce->dev.ff_effects_max = 10;
-+ iforce->dev = input_dev;
-
- /*
- * Input device fields.
-@@ -356,26 +361,27 @@ int iforce_init_device(struct iforce *if
- switch (iforce->bus) {
- #ifdef CONFIG_JOYSTICK_IFORCE_USB
- case IFORCE_USB:
-- iforce->dev.id.bustype = BUS_USB;
-- iforce->dev.dev = &iforce->usbdev->dev;
-+ input_dev->id.bustype = BUS_USB;
-+ input_dev->cdev.dev = &iforce->usbdev->dev;
- break;
- #endif
- #ifdef CONFIG_JOYSTICK_IFORCE_232
- case IFORCE_232:
-- iforce->dev.id.bustype = BUS_RS232;
-- iforce->dev.dev = &iforce->serio->dev;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->cdev.dev = &iforce->serio->dev;
- break;
- #endif
- }
-
-- iforce->dev.private = iforce;
-- iforce->dev.name = "Unknown I-Force device";
-- iforce->dev.open = iforce_open;
-- iforce->dev.close = iforce_release;
-- iforce->dev.flush = iforce_flush;
-- iforce->dev.event = iforce_input_event;
-- iforce->dev.upload_effect = iforce_upload_effect;
-- iforce->dev.erase_effect = iforce_erase_effect;
-+ input_dev->private = iforce;
-+ input_dev->name = "Unknown I-Force device";
-+ input_dev->open = iforce_open;
-+ input_dev->close = iforce_release;
-+ input_dev->flush = iforce_flush;
-+ input_dev->event = iforce_input_event;
-+ input_dev->upload_effect = iforce_upload_effect;
-+ input_dev->erase_effect = iforce_erase_effect;
-+ input_dev->ff_effects_max = 10;
-
- /*
- * On-device memory allocation.
-@@ -399,7 +405,8 @@ int iforce_init_device(struct iforce *if
-
- if (i == 20) { /* 5 seconds */
- printk(KERN_ERR "iforce-main.c: Timeout waiting for response from device.\n");
-- return -1;
-+ input_free_device(input_dev);
-+ return -ENODEV;
- }
-
- /*
-@@ -407,12 +414,12 @@ int iforce_init_device(struct iforce *if
- */
-
- if (!iforce_get_id_packet(iforce, "M"))
-- iforce->dev.id.vendor = (iforce->edata[2] << 8) | iforce->edata[1];
-+ input_dev->id.vendor = (iforce->edata[2] << 8) | iforce->edata[1];
- else
- printk(KERN_WARNING "iforce-main.c: Device does not respond to id packet M\n");
-
- if (!iforce_get_id_packet(iforce, "P"))
-- iforce->dev.id.product = (iforce->edata[2] << 8) | iforce->edata[1];
-+ input_dev->id.product = (iforce->edata[2] << 8) | iforce->edata[1];
- else
- printk(KERN_WARNING "iforce-main.c: Device does not respond to id packet P\n");
-
-@@ -422,15 +429,15 @@ int iforce_init_device(struct iforce *if
- printk(KERN_WARNING "iforce-main.c: Device does not respond to id packet B\n");
-
- if (!iforce_get_id_packet(iforce, "N"))
-- iforce->dev.ff_effects_max = iforce->edata[1];
-+ iforce->dev->ff_effects_max = iforce->edata[1];
- else
- printk(KERN_WARNING "iforce-main.c: Device does not respond to id packet N\n");
-
- /* Check if the device can store more effects than the driver can really handle */
-- if (iforce->dev.ff_effects_max > FF_EFFECTS_MAX) {
-+ if (iforce->dev->ff_effects_max > FF_EFFECTS_MAX) {
- printk(KERN_WARNING "input??: Device can handle %d effects, but N_EFFECTS_MAX is set to %d in iforce.h\n",
-- iforce->dev.ff_effects_max, FF_EFFECTS_MAX);
-- iforce->dev.ff_effects_max = FF_EFFECTS_MAX;
-+ iforce->dev->ff_effects_max, FF_EFFECTS_MAX);
-+ iforce->dev->ff_effects_max = FF_EFFECTS_MAX;
- }
-
- /*
-@@ -453,29 +460,28 @@ int iforce_init_device(struct iforce *if
- */
-
- for (i = 0; iforce_device[i].idvendor; i++)
-- if (iforce_device[i].idvendor == iforce->dev.id.vendor &&
-- iforce_device[i].idproduct == iforce->dev.id.product)
-+ if (iforce_device[i].idvendor == input_dev->id.vendor &&
-+ iforce_device[i].idproduct == input_dev->id.product)
- break;
-
- iforce->type = iforce_device + i;
-- iforce->dev.name = iforce->type->name;
-+ input_dev->name = iforce->type->name;
-
- /*
- * Set input device bitfields and ranges.
- */
-
-- iforce->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS) | BIT(EV_FF) | BIT(EV_FF_STATUS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS) | BIT(EV_FF) | BIT(EV_FF_STATUS);
-
- for (i = 0; iforce->type->btn[i] >= 0; i++) {
- signed short t = iforce->type->btn[i];
-- set_bit(t, iforce->dev.keybit);
-+ set_bit(t, input_dev->keybit);
- }
-- set_bit(BTN_DEAD, iforce->dev.keybit);
-+ set_bit(BTN_DEAD, input_dev->keybit);
-
- for (i = 0; iforce->type->abs[i] >= 0; i++) {
-
- signed short t = iforce->type->abs[i];
-- set_bit(t, iforce->dev.absbit);
-
- switch (t) {
-
-@@ -483,52 +489,42 @@ int iforce_init_device(struct iforce *if
- case ABS_Y:
- case ABS_WHEEL:
-
-- iforce->dev.absmax[t] = 1920;
-- iforce->dev.absmin[t] = -1920;
-- iforce->dev.absflat[t] = 128;
-- iforce->dev.absfuzz[t] = 16;
--
-- set_bit(t, iforce->dev.ffbit);
-+ input_set_abs_params(input_dev, t, -1920, 1920, 16, 128);
-+ set_bit(t, input_dev->ffbit);
- break;
-
- case ABS_THROTTLE:
- case ABS_GAS:
- case ABS_BRAKE:
-
-- iforce->dev.absmax[t] = 255;
-- iforce->dev.absmin[t] = 0;
-+ input_set_abs_params(input_dev, t, 0, 255, 0, 0);
- break;
-
- case ABS_RUDDER:
-
-- iforce->dev.absmax[t] = 127;
-- iforce->dev.absmin[t] = -128;
-+ input_set_abs_params(input_dev, t, -128, 127, 0, 0);
- break;
-
- case ABS_HAT0X:
- case ABS_HAT0Y:
- case ABS_HAT1X:
- case ABS_HAT1Y:
-- iforce->dev.absmax[t] = 1;
-- iforce->dev.absmin[t] = -1;
-+
-+ input_set_abs_params(input_dev, t, -1, 1, 0, 0);
- break;
- }
- }
-
- for (i = 0; iforce->type->ff[i] >= 0; i++)
-- set_bit(iforce->type->ff[i], iforce->dev.ffbit);
-+ set_bit(iforce->type->ff[i], input_dev->ffbit);
-
- /*
- * Register input device.
- */
-
-- input_register_device(&iforce->dev);
--
-- printk(KERN_DEBUG "iforce->dev.open = %p\n", iforce->dev.open);
-+ input_register_device(iforce->dev);
-
-- printk(KERN_INFO "input: %s [%d effects, %ld bytes memory]\n",
-- iforce->dev.name, iforce->dev.ff_effects_max,
-- iforce->device_memory.end);
-+ printk(KERN_DEBUG "iforce->dev->open = %p\n", iforce->dev->open);
-
- return 0;
- }
---- gregkh-2.6.orig/drivers/input/joystick/iforce/iforce-packets.c
-+++ gregkh-2.6/drivers/input/joystick/iforce/iforce-packets.c
-@@ -139,7 +139,8 @@ printk(KERN_DEBUG "iforce-packets.c: con
- static int mark_core_as_ready(struct iforce *iforce, unsigned short addr)
- {
- int i;
-- for (i=0; i<iforce->dev.ff_effects_max; ++i) {
-+
-+ for (i = 0; i < iforce->dev->ff_effects_max; ++i) {
- if (test_bit(FF_CORE_IS_USED, iforce->core_effects[i].flags) &&
- (iforce->core_effects[i].mod1_chunk.start == addr ||
- iforce->core_effects[i].mod2_chunk.start == addr)) {
-@@ -153,7 +154,7 @@ static int mark_core_as_ready(struct ifo
-
- void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data, struct pt_regs *regs)
- {
-- struct input_dev *dev = &iforce->dev;
-+ struct input_dev *dev = iforce->dev;
- int i;
- static int being_used = 0;
-
---- gregkh-2.6.orig/drivers/input/joystick/iforce/iforce-serio.c
-+++ gregkh-2.6/drivers/input/joystick/iforce/iforce-serio.c
-@@ -131,11 +131,10 @@ static int iforce_serio_connect(struct s
- struct iforce *iforce;
- int err;
-
-- if (!(iforce = kmalloc(sizeof(struct iforce), GFP_KERNEL)))
-+ iforce = kzalloc(sizeof(struct iforce), GFP_KERNEL);
-+ if (!iforce)
- return -ENOMEM;
-
-- memset(iforce, 0, sizeof(struct iforce));
--
- iforce->bus = IFORCE_232;
- iforce->serio = serio;
-
-@@ -148,7 +147,8 @@ static int iforce_serio_connect(struct s
- return err;
- }
-
-- if (iforce_init_device(iforce)) {
-+ err = iforce_init_device(iforce);
-+ if (err) {
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
- kfree(iforce);
-@@ -162,7 +162,7 @@ static void iforce_serio_disconnect(stru
- {
- struct iforce *iforce = serio_get_drvdata(serio);
-
-- input_unregister_device(&iforce->dev);
-+ input_unregister_device(iforce->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
- kfree(iforce);
---- gregkh-2.6.orig/drivers/input/joystick/iforce/iforce-usb.c
-+++ gregkh-2.6/drivers/input/joystick/iforce/iforce-usb.c
-@@ -135,28 +135,24 @@ static int iforce_usb_probe(struct usb_i
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *epirq, *epout;
- struct iforce *iforce;
-+ int err = -ENOMEM;
-
- interface = intf->cur_altsetting;
-
- epirq = &interface->endpoint[0].desc;
- epout = &interface->endpoint[1].desc;
-
-- if (!(iforce = kmalloc(sizeof(struct iforce) + 32, GFP_KERNEL)))
-+ if (!(iforce = kzalloc(sizeof(struct iforce) + 32, GFP_KERNEL)))
- goto fail;
-
-- memset(iforce, 0, sizeof(struct iforce));
--
-- if (!(iforce->irq = usb_alloc_urb(0, GFP_KERNEL))) {
-+ if (!(iforce->irq = usb_alloc_urb(0, GFP_KERNEL)))
- goto fail;
-- }
-
-- if (!(iforce->out = usb_alloc_urb(0, GFP_KERNEL))) {
-+ if (!(iforce->out = usb_alloc_urb(0, GFP_KERNEL)))
- goto fail;
-- }
-
-- if (!(iforce->ctrl = usb_alloc_urb(0, GFP_KERNEL))) {
-+ if (!(iforce->ctrl = usb_alloc_urb(0, GFP_KERNEL)))
- goto fail;
-- }
-
- iforce->bus = IFORCE_USB;
- iforce->usbdev = dev;
-@@ -174,7 +170,9 @@ static int iforce_usb_probe(struct usb_i
- usb_fill_control_urb(iforce->ctrl, dev, usb_rcvctrlpipe(dev, 0),
- (void*) &iforce->cr, iforce->edata, 16, iforce_usb_ctrl, iforce);
-
-- if (iforce_init_device(iforce)) goto fail;
-+ err = iforce_init_device(iforce);
-+ if (err)
-+ goto fail;
-
- usb_set_intfdata(intf, iforce);
- return 0;
-@@ -187,7 +185,7 @@ fail:
- kfree(iforce);
- }
-
-- return -ENODEV;
-+ return err;
- }
-
- /* Called by iforce_delete() */
-@@ -211,7 +209,7 @@ static void iforce_usb_disconnect(struct
- usb_set_intfdata(intf, NULL);
- if (iforce) {
- iforce->usbdev = NULL;
-- input_unregister_device(&iforce->dev);
-+ input_unregister_device(iforce->dev);
-
- if (!open) {
- iforce_delete_device(iforce);
---- gregkh-2.6.orig/drivers/input/joystick/iforce/iforce.h
-+++ gregkh-2.6/drivers/input/joystick/iforce/iforce.h
-@@ -117,7 +117,7 @@ struct iforce_device {
- };
-
- struct iforce {
-- struct input_dev dev; /* Input device interface */
-+ struct input_dev *dev; /* Input device interface */
- struct iforce_device *type;
- int bus;
-
diff --git a/driver/input-convert-to-dynamic-keyboard.patch b/driver/input-convert-to-dynamic-keyboard.patch
deleted file mode 100644
index 29856241e104c..0000000000000
--- a/driver/input-convert-to-dynamic-keyboard.patch
+++ /dev/null
@@ -1,1669 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:38 2005
-Message-Id: <20050915070303.684452000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:45 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 14/28] drivers/input/keyboard: convert to dynamic input_dev allocation
-
-Input: convert drivers/input/keyboard to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/keyboard/amikbd.c | 59 +++++------
- drivers/input/keyboard/atkbd.c | 188 +++++++++++++++++++-----------------
- drivers/input/keyboard/corgikbd.c | 74 +++++++-------
- drivers/input/keyboard/lkkbd.c | 126 ++++++++++++------------
- drivers/input/keyboard/maple_keyb.c | 76 ++++++--------
- drivers/input/keyboard/newtonkbd.c | 83 +++++++--------
- drivers/input/keyboard/spitzkbd.c | 77 ++++++++------
- drivers/input/keyboard/sunkbd.c | 117 +++++++++++-----------
- drivers/input/keyboard/xtkbd.c | 82 +++++++--------
- 9 files changed, 450 insertions(+), 432 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/keyboard/atkbd.c
-+++ gregkh-2.6/drivers/input/keyboard/atkbd.c
-@@ -185,12 +185,12 @@ static struct {
-
- struct atkbd {
-
-- struct ps2dev ps2dev;
-+ struct ps2dev ps2dev;
-+ struct input_dev *dev;
-
- /* Written only during init */
- char name[64];
- char phys[32];
-- struct input_dev dev;
-
- unsigned short id;
- unsigned char keycode[512];
-@@ -290,7 +290,7 @@ static irqreturn_t atkbd_interrupt(struc
- if (!atkbd->enabled)
- goto out;
-
-- input_event(&atkbd->dev, EV_MSC, MSC_RAW, code);
-+ input_event(atkbd->dev, EV_MSC, MSC_RAW, code);
-
- if (atkbd->translated) {
-
-@@ -326,10 +326,10 @@ static irqreturn_t atkbd_interrupt(struc
- atkbd->release = 1;
- goto out;
- case ATKBD_RET_HANGUEL:
-- atkbd_report_key(&atkbd->dev, regs, KEY_HANGUEL, 3);
-+ atkbd_report_key(atkbd->dev, regs, KEY_HANGUEL, 3);
- goto out;
- case ATKBD_RET_HANJA:
-- atkbd_report_key(&atkbd->dev, regs, KEY_HANJA, 3);
-+ atkbd_report_key(atkbd->dev, regs, KEY_HANJA, 3);
- goto out;
- case ATKBD_RET_ERR:
- printk(KERN_DEBUG "atkbd.c: Keyboard on %s reports too many keys pressed.\n", serio->phys);
-@@ -345,7 +345,7 @@ static irqreturn_t atkbd_interrupt(struc
- }
-
- if (atkbd->keycode[code] != ATKBD_KEY_NULL)
-- input_event(&atkbd->dev, EV_MSC, MSC_SCAN, code);
-+ input_event(atkbd->dev, EV_MSC, MSC_SCAN, code);
-
- switch (atkbd->keycode[code]) {
- case ATKBD_KEY_NULL:
-@@ -365,7 +365,7 @@ static irqreturn_t atkbd_interrupt(struc
- "to make it known.\n",
- code & 0x80 ? "e0" : "", code & 0x7f);
- }
-- input_sync(&atkbd->dev);
-+ input_sync(atkbd->dev);
- break;
- case ATKBD_SCR_1:
- scroll = 1 - atkbd->release * 2;
-@@ -390,7 +390,7 @@ static irqreturn_t atkbd_interrupt(struc
- break;
- default:
- value = atkbd->release ? 0 :
-- (1 + (!atkbd->softrepeat && test_bit(atkbd->keycode[code], atkbd->dev.key)));
-+ (1 + (!atkbd->softrepeat && test_bit(atkbd->keycode[code], atkbd->dev->key)));
-
- switch (value) { /* Workaround Toshiba laptop multiple keypress */
- case 0:
-@@ -398,7 +398,7 @@ static irqreturn_t atkbd_interrupt(struc
- break;
- case 1:
- atkbd->last = code;
-- atkbd->time = jiffies + msecs_to_jiffies(atkbd->dev.rep[REP_DELAY]) / 2;
-+ atkbd->time = jiffies + msecs_to_jiffies(atkbd->dev->rep[REP_DELAY]) / 2;
- break;
- case 2:
- if (!time_after(jiffies, atkbd->time) && atkbd->last == code)
-@@ -406,16 +406,16 @@ static irqreturn_t atkbd_interrupt(struc
- break;
- }
-
-- atkbd_report_key(&atkbd->dev, regs, atkbd->keycode[code], value);
-+ atkbd_report_key(atkbd->dev, regs, atkbd->keycode[code], value);
- }
-
- if (atkbd->scroll) {
-- input_regs(&atkbd->dev, regs);
-+ input_regs(atkbd->dev, regs);
- if (click != -1)
-- input_report_key(&atkbd->dev, BTN_MIDDLE, click);
-- input_report_rel(&atkbd->dev, REL_WHEEL, scroll);
-- input_report_rel(&atkbd->dev, REL_HWHEEL, hscroll);
-- input_sync(&atkbd->dev);
-+ input_report_key(atkbd->dev, BTN_MIDDLE, click);
-+ input_report_rel(atkbd->dev, REL_WHEEL, scroll);
-+ input_report_rel(atkbd->dev, REL_HWHEEL, hscroll);
-+ input_sync(atkbd->dev);
- }
-
- atkbd->release = 0;
-@@ -463,7 +463,6 @@ static int atkbd_event(struct input_dev
-
- return 0;
-
--
- case EV_REP:
-
- if (atkbd->softrepeat) return 0;
-@@ -693,7 +692,7 @@ static void atkbd_disconnect(struct seri
- device_remove_file(&serio->dev, &atkbd_attr_softrepeat);
- device_remove_file(&serio->dev, &atkbd_attr_softraw);
-
-- input_unregister_device(&atkbd->dev);
-+ input_unregister_device(atkbd->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
- kfree(atkbd);
-@@ -701,7 +700,7 @@ static void atkbd_disconnect(struct seri
-
-
- /*
-- * atkbd_set_device_attrs() initializes keyboard's keycode table
-+ * atkbd_set_keycode_table() initializes keyboard's keycode table
- * according to the selected scancode set
- */
-
-@@ -737,53 +736,58 @@ static void atkbd_set_keycode_table(stru
-
- static void atkbd_set_device_attrs(struct atkbd *atkbd)
- {
-+ struct input_dev *input_dev = atkbd->dev;
- int i;
-
-- memset(&atkbd->dev, 0, sizeof(struct input_dev));
-+ if (atkbd->extra)
-+ sprintf(atkbd->name, "AT Set 2 Extra keyboard");
-+ else
-+ sprintf(atkbd->name, "AT %s Set %d keyboard",
-+ atkbd->translated ? "Translated" : "Raw", atkbd->set);
-
-- init_input_dev(&atkbd->dev);
-+ sprintf(atkbd->phys, "%s/input0", atkbd->ps2dev.serio->phys);
-
-- atkbd->dev.name = atkbd->name;
-- atkbd->dev.phys = atkbd->phys;
-- atkbd->dev.id.bustype = BUS_I8042;
-- atkbd->dev.id.vendor = 0x0001;
-- atkbd->dev.id.product = atkbd->translated ? 1 : atkbd->set;
-- atkbd->dev.id.version = atkbd->id;
-- atkbd->dev.event = atkbd_event;
-- atkbd->dev.private = atkbd;
-- atkbd->dev.dev = &atkbd->ps2dev.serio->dev;
-+ input_dev->name = atkbd->name;
-+ input_dev->phys = atkbd->phys;
-+ input_dev->id.bustype = BUS_I8042;
-+ input_dev->id.vendor = 0x0001;
-+ input_dev->id.product = atkbd->translated ? 1 : atkbd->set;
-+ input_dev->id.version = atkbd->id;
-+ input_dev->event = atkbd_event;
-+ input_dev->private = atkbd;
-+ input_dev->cdev.dev = &atkbd->ps2dev.serio->dev;
-
-- atkbd->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REP) | BIT(EV_MSC);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP) | BIT(EV_MSC);
-
- if (atkbd->write) {
-- atkbd->dev.evbit[0] |= BIT(EV_LED);
-- atkbd->dev.ledbit[0] = BIT(LED_NUML) | BIT(LED_CAPSL) | BIT(LED_SCROLLL);
-+ input_dev->evbit[0] |= BIT(EV_LED);
-+ input_dev->ledbit[0] = BIT(LED_NUML) | BIT(LED_CAPSL) | BIT(LED_SCROLLL);
- }
-
- if (atkbd->extra)
-- atkbd->dev.ledbit[0] |= BIT(LED_COMPOSE) | BIT(LED_SUSPEND) |
-+ input_dev->ledbit[0] |= BIT(LED_COMPOSE) | BIT(LED_SUSPEND) |
- BIT(LED_SLEEP) | BIT(LED_MUTE) | BIT(LED_MISC);
-
- if (!atkbd->softrepeat) {
-- atkbd->dev.rep[REP_DELAY] = 250;
-- atkbd->dev.rep[REP_PERIOD] = 33;
-+ input_dev->rep[REP_DELAY] = 250;
-+ input_dev->rep[REP_PERIOD] = 33;
- }
-
-- atkbd->dev.mscbit[0] = atkbd->softraw ? BIT(MSC_SCAN) : BIT(MSC_RAW) | BIT(MSC_SCAN);
-+ input_dev->mscbit[0] = atkbd->softraw ? BIT(MSC_SCAN) : BIT(MSC_RAW) | BIT(MSC_SCAN);
-
- if (atkbd->scroll) {
-- atkbd->dev.evbit[0] |= BIT(EV_REL);
-- atkbd->dev.relbit[0] = BIT(REL_WHEEL) | BIT(REL_HWHEEL);
-- set_bit(BTN_MIDDLE, atkbd->dev.keybit);
-+ input_dev->evbit[0] |= BIT(EV_REL);
-+ input_dev->relbit[0] = BIT(REL_WHEEL) | BIT(REL_HWHEEL);
-+ set_bit(BTN_MIDDLE, input_dev->keybit);
- }
-
-- atkbd->dev.keycode = atkbd->keycode;
-- atkbd->dev.keycodesize = sizeof(unsigned char);
-- atkbd->dev.keycodemax = ARRAY_SIZE(atkbd_set2_keycode);
-+ input_dev->keycode = atkbd->keycode;
-+ input_dev->keycodesize = sizeof(unsigned char);
-+ input_dev->keycodemax = ARRAY_SIZE(atkbd_set2_keycode);
-
- for (i = 0; i < 512; i++)
- if (atkbd->keycode[i] && atkbd->keycode[i] < ATKBD_SPECIAL)
-- set_bit(atkbd->keycode[i], atkbd->dev.keybit);
-+ set_bit(atkbd->keycode[i], input_dev->keybit);
- }
-
- /*
-@@ -796,13 +800,15 @@ static void atkbd_set_device_attrs(struc
- static int atkbd_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct atkbd *atkbd;
-- int err;
--
-- if (!(atkbd = kmalloc(sizeof(struct atkbd), GFP_KERNEL)))
-- return - ENOMEM;
-+ struct input_dev *dev;
-+ int err = -ENOMEM;
-
-- memset(atkbd, 0, sizeof(struct atkbd));
-+ atkbd = kzalloc(sizeof(struct atkbd), GFP_KERNEL);
-+ dev = input_allocate_device();
-+ if (!atkbd || !dev)
-+ goto fail;
-
-+ atkbd->dev = dev;
- ps2_init(&atkbd->ps2dev, serio);
-
- switch (serio->id.type) {
-@@ -828,19 +834,15 @@ static int atkbd_connect(struct serio *s
- serio_set_drvdata(serio, atkbd);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(atkbd);
-- return err;
-- }
-+ if (err)
-+ goto fail;
-
- if (atkbd->write) {
-
- if (atkbd_probe(atkbd)) {
- serio_close(serio);
-- serio_set_drvdata(serio, NULL);
-- kfree(atkbd);
-- return -ENODEV;
-+ err = -ENODEV;
-+ goto fail;
- }
-
- atkbd->set = atkbd_select_set(atkbd, atkbd_set, atkbd_extra);
-@@ -851,19 +853,9 @@ static int atkbd_connect(struct serio *s
- atkbd->id = 0xab00;
- }
-
-- if (atkbd->extra)
-- sprintf(atkbd->name, "AT Set 2 Extra keyboard");
-- else
-- sprintf(atkbd->name, "AT %s Set %d keyboard",
-- atkbd->translated ? "Translated" : "Raw", atkbd->set);
--
-- sprintf(atkbd->phys, "%s/input0", serio->phys);
--
- atkbd_set_keycode_table(atkbd);
- atkbd_set_device_attrs(atkbd);
-
-- input_register_device(&atkbd->dev);
--
- device_create_file(&serio->dev, &atkbd_attr_extra);
- device_create_file(&serio->dev, &atkbd_attr_scroll);
- device_create_file(&serio->dev, &atkbd_attr_set);
-@@ -872,9 +864,14 @@ static int atkbd_connect(struct serio *s
-
- atkbd_enable(atkbd);
-
-- printk(KERN_INFO "input: %s on %s\n", atkbd->name, serio->phys);
-+ input_register_device(atkbd->dev);
-
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(dev);
-+ kfree(atkbd);
-+ return err;
- }
-
- /*
-@@ -896,9 +893,9 @@ static int atkbd_reconnect(struct serio
- atkbd_disable(atkbd);
-
- if (atkbd->write) {
-- param[0] = (test_bit(LED_SCROLLL, atkbd->dev.led) ? 1 : 0)
-- | (test_bit(LED_NUML, atkbd->dev.led) ? 2 : 0)
-- | (test_bit(LED_CAPSL, atkbd->dev.led) ? 4 : 0);
-+ param[0] = (test_bit(LED_SCROLLL, atkbd->dev->led) ? 1 : 0)
-+ | (test_bit(LED_NUML, atkbd->dev->led) ? 2 : 0)
-+ | (test_bit(LED_CAPSL, atkbd->dev->led) ? 4 : 0);
-
- if (atkbd_probe(atkbd))
- return -1;
-@@ -1008,6 +1005,7 @@ static ssize_t atkbd_show_extra(struct a
-
- static ssize_t atkbd_set_extra(struct atkbd *atkbd, const char *buf, size_t count)
- {
-+ struct input_dev *new_dev;
- unsigned long value;
- char *rest;
-
-@@ -1019,12 +1017,19 @@ static ssize_t atkbd_set_extra(struct at
- return -EINVAL;
-
- if (atkbd->extra != value) {
-- /* unregister device as it's properties will change */
-- input_unregister_device(&atkbd->dev);
-+ /*
-+ * Since device's properties will change we need to
-+ * unregister old device. But allocate new one first
-+ * to make sure we have it.
-+ */
-+ if (!(new_dev = input_allocate_device()))
-+ return -ENOMEM;
-+ input_unregister_device(atkbd->dev);
-+ atkbd->dev = new_dev;
- atkbd->set = atkbd_select_set(atkbd, atkbd->set, value);
- atkbd_activate(atkbd);
- atkbd_set_device_attrs(atkbd);
-- input_register_device(&atkbd->dev);
-+ input_register_device(atkbd->dev);
- }
- return count;
- }
-@@ -1036,6 +1041,7 @@ static ssize_t atkbd_show_scroll(struct
-
- static ssize_t atkbd_set_scroll(struct atkbd *atkbd, const char *buf, size_t count)
- {
-+ struct input_dev *new_dev;
- unsigned long value;
- char *rest;
-
-@@ -1044,12 +1050,14 @@ static ssize_t atkbd_set_scroll(struct a
- return -EINVAL;
-
- if (atkbd->scroll != value) {
-- /* unregister device as it's properties will change */
-- input_unregister_device(&atkbd->dev);
-+ if (!(new_dev = input_allocate_device()))
-+ return -ENOMEM;
-+ input_unregister_device(atkbd->dev);
-+ atkbd->dev = new_dev;
- atkbd->scroll = value;
- atkbd_set_keycode_table(atkbd);
- atkbd_set_device_attrs(atkbd);
-- input_register_device(&atkbd->dev);
-+ input_register_device(atkbd->dev);
- }
- return count;
- }
-@@ -1061,6 +1069,7 @@ static ssize_t atkbd_show_set(struct atk
-
- static ssize_t atkbd_set_set(struct atkbd *atkbd, const char *buf, size_t count)
- {
-+ struct input_dev *new_dev;
- unsigned long value;
- char *rest;
-
-@@ -1072,13 +1081,15 @@ static ssize_t atkbd_set_set(struct atkb
- return -EINVAL;
-
- if (atkbd->set != value) {
-- /* unregister device as it's properties will change */
-- input_unregister_device(&atkbd->dev);
-+ if (!(new_dev = input_allocate_device()))
-+ return -ENOMEM;
-+ input_unregister_device(atkbd->dev);
-+ atkbd->dev = new_dev;
- atkbd->set = atkbd_select_set(atkbd, value, atkbd->extra);
- atkbd_activate(atkbd);
- atkbd_set_keycode_table(atkbd);
- atkbd_set_device_attrs(atkbd);
-- input_register_device(&atkbd->dev);
-+ input_register_device(atkbd->dev);
- }
- return count;
- }
-@@ -1090,6 +1101,7 @@ static ssize_t atkbd_show_softrepeat(str
-
- static ssize_t atkbd_set_softrepeat(struct atkbd *atkbd, const char *buf, size_t count)
- {
-+ struct input_dev *new_dev;
- unsigned long value;
- char *rest;
-
-@@ -1101,15 +1113,16 @@ static ssize_t atkbd_set_softrepeat(stru
- return -EINVAL;
-
- if (atkbd->softrepeat != value) {
-- /* unregister device as it's properties will change */
-- input_unregister_device(&atkbd->dev);
-+ if (!(new_dev = input_allocate_device()))
-+ return -ENOMEM;
-+ input_unregister_device(atkbd->dev);
-+ atkbd->dev = new_dev;
- atkbd->softrepeat = value;
- if (atkbd->softrepeat)
- atkbd->softraw = 1;
- atkbd_set_device_attrs(atkbd);
-- input_register_device(&atkbd->dev);
-+ input_register_device(atkbd->dev);
- }
--
- return count;
- }
-
-@@ -1121,6 +1134,7 @@ static ssize_t atkbd_show_softraw(struct
-
- static ssize_t atkbd_set_softraw(struct atkbd *atkbd, const char *buf, size_t count)
- {
-+ struct input_dev *new_dev;
- unsigned long value;
- char *rest;
-
-@@ -1129,11 +1143,13 @@ static ssize_t atkbd_set_softraw(struct
- return -EINVAL;
-
- if (atkbd->softraw != value) {
-- /* unregister device as it's properties will change */
-- input_unregister_device(&atkbd->dev);
-+ if (!(new_dev = input_allocate_device()))
-+ return -ENOMEM;
-+ input_unregister_device(atkbd->dev);
-+ atkbd->dev = new_dev;
- atkbd->softraw = value;
- atkbd_set_device_attrs(atkbd);
-- input_register_device(&atkbd->dev);
-+ input_register_device(atkbd->dev);
- }
- return count;
- }
---- gregkh-2.6.orig/drivers/input/keyboard/amikbd.c
-+++ gregkh-2.6/drivers/input/keyboard/amikbd.c
-@@ -155,10 +155,7 @@ static const char *amikbd_messages[8] =
- [7] = KERN_WARNING "amikbd: keyboard interrupt\n"
- };
-
--static struct input_dev amikbd_dev;
--
--static char *amikbd_name = "Amiga keyboard";
--static char *amikbd_phys = "amikbd/input0";
-+static struct input_dev *amikbd_dev;
-
- static irqreturn_t amikbd_interrupt(int irq, void *dummy, struct pt_regs *fp)
- {
-@@ -176,16 +173,16 @@ static irqreturn_t amikbd_interrupt(int
-
- scancode = amikbd_keycode[scancode];
-
-- input_regs(&amikbd_dev, fp);
-+ input_regs(amikbd_dev, fp);
-
- if (scancode == KEY_CAPSLOCK) { /* CapsLock is a toggle switch key on Amiga */
-- input_report_key(&amikbd_dev, scancode, 1);
-- input_report_key(&amikbd_dev, scancode, 0);
-- input_sync(&amikbd_dev);
-+ input_report_key(amikbd_dev, scancode, 1);
-+ input_report_key(amikbd_dev, scancode, 0);
- } else {
-- input_report_key(&amikbd_dev, scancode, down);
-- input_sync(&amikbd_dev);
-+ input_report_key(amikbd_dev, scancode, down);
- }
-+
-+ input_sync(amikbd_dev);
- } else /* scancodes >= 0x78 are error codes */
- printk(amikbd_messages[scancode - 0x78]);
-
-@@ -202,39 +199,41 @@ static int __init amikbd_init(void)
- if (!request_mem_region(CIAA_PHYSADDR-1+0xb00, 0x100, "amikeyb"))
- return -EBUSY;
-
-- init_input_dev(&amikbd_dev);
--
-- amikbd_dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-- amikbd_dev.keycode = amikbd_keycode;
-- amikbd_dev.keycodesize = sizeof(unsigned char);
-- amikbd_dev.keycodemax = ARRAY_SIZE(amikbd_keycode);
-+ amikbd_dev = input_dev_allocate();
-+ if (!amikbd_dev) {
-+ printk(KERN_ERR "amikbd: not enough memory for input device\n");
-+ release_mem_region(CIAA_PHYSADDR - 1 + 0xb00, 0x100);
-+ return -ENOMEM;
-+ }
-+
-+ amikbd_dev->name = "Amiga Keyboard";
-+ amikbd_dev->phys = "amikbd/input0";
-+ amikbd_dev->id.bustype = BUS_AMIGA;
-+ amikbd_dev->id.vendor = 0x0001;
-+ amikbd_dev->id.product = 0x0001;
-+ amikbd_dev->id.version = 0x0100;
-+
-+ amikbd_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ amikbd_dev->keycode = amikbd_keycode;
-+ amikbd_dev->keycodesize = sizeof(unsigned char);
-+ amikbd_dev->keycodemax = ARRAY_SIZE(amikbd_keycode);
-
- for (i = 0; i < 0x78; i++)
- if (amikbd_keycode[i])
-- set_bit(amikbd_keycode[i], amikbd_dev.keybit);
-+ set_bit(amikbd_keycode[i], amikbd_dev->keybit);
-
- ciaa.cra &= ~0x41; /* serial data in, turn off TA */
- request_irq(IRQ_AMIGA_CIAA_SP, amikbd_interrupt, 0, "amikbd", amikbd_interrupt);
-
-- amikbd_dev.name = amikbd_name;
-- amikbd_dev.phys = amikbd_phys;
-- amikbd_dev.id.bustype = BUS_AMIGA;
-- amikbd_dev.id.vendor = 0x0001;
-- amikbd_dev.id.product = 0x0001;
-- amikbd_dev.id.version = 0x0100;
--
-- input_register_device(&amikbd_dev);
--
-- printk(KERN_INFO "input: %s\n", amikbd_name);
--
-+ input_register_device(amikbd_dev);
- return 0;
- }
-
- static void __exit amikbd_exit(void)
- {
-- input_unregister_device(&amikbd_dev);
- free_irq(IRQ_AMIGA_CIAA_SP, amikbd_interrupt);
-- release_mem_region(CIAA_PHYSADDR-1+0xb00, 0x100);
-+ input_unregister_device(amikbd_dev);
-+ release_mem_region(CIAA_PHYSADDR - 1 + 0xb00, 0x100);
- }
-
- module_init(amikbd_init);
---- gregkh-2.6.orig/drivers/input/keyboard/lkkbd.c
-+++ gregkh-2.6/drivers/input/keyboard/lkkbd.c
-@@ -102,7 +102,7 @@ static int ctrlclick_volume = 100; /* %
- module_param (ctrlclick_volume, int, 0);
- MODULE_PARM_DESC (ctrlclick_volume, "Ctrlclick volume (in %), default is 100%");
-
--static int lk201_compose_is_alt = 0;
-+static int lk201_compose_is_alt;
- module_param (lk201_compose_is_alt, int, 0);
- MODULE_PARM_DESC (lk201_compose_is_alt, "If set non-zero, LK201' Compose key "
- "will act as an Alt key");
-@@ -274,7 +274,7 @@ static lk_keycode_t lkkbd_keycode[LK_NUM
- };
-
- #define CHECK_LED(LED, BITS) do { \
-- if (test_bit (LED, lk->dev.led)) \
-+ if (test_bit (LED, lk->dev->led)) \
- leds_on |= BITS; \
- else \
- leds_off |= BITS; \
-@@ -287,7 +287,7 @@ struct lkkbd {
- lk_keycode_t keycode[LK_NUM_KEYCODES];
- int ignore_bytes;
- unsigned char id[LK_NUM_IGNORE_BYTES];
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- struct work_struct tq;
- char name[64];
-@@ -423,8 +423,7 @@ lkkbd_interrupt (struct serio *serio, un
- DBG (KERN_INFO "Got byte 0x%02x\n", data);
-
- if (lk->ignore_bytes > 0) {
-- DBG (KERN_INFO "Ignoring a byte on %s\n",
-- lk->name);
-+ DBG (KERN_INFO "Ignoring a byte on %s\n", lk->name);
- lk->id[LK_NUM_IGNORE_BYTES - lk->ignore_bytes--] = data;
-
- if (lk->ignore_bytes == 0)
-@@ -435,14 +434,14 @@ lkkbd_interrupt (struct serio *serio, un
-
- switch (data) {
- case LK_ALL_KEYS_UP:
-- input_regs (&lk->dev, regs);
-+ input_regs (lk->dev, regs);
- for (i = 0; i < ARRAY_SIZE (lkkbd_keycode); i++)
- if (lk->keycode[i] != KEY_RESERVED)
-- input_report_key (&lk->dev, lk->keycode[i], 0);
-- input_sync (&lk->dev);
-+ input_report_key (lk->dev, lk->keycode[i], 0);
-+ input_sync (lk->dev);
- break;
- case LK_METRONOME:
-- DBG (KERN_INFO "Got LK_METRONOME and don't "
-+ DBG (KERN_INFO "Got %#d and don't "
- "know how to handle...\n");
- break;
- case LK_OUTPUT_ERROR:
-@@ -482,12 +481,12 @@ lkkbd_interrupt (struct serio *serio, un
-
- default:
- if (lk->keycode[data] != KEY_RESERVED) {
-- input_regs (&lk->dev, regs);
-- if (!test_bit (lk->keycode[data], lk->dev.key))
-- input_report_key (&lk->dev, lk->keycode[data], 1);
-+ input_regs (lk->dev, regs);
-+ if (!test_bit (lk->keycode[data], lk->dev->key))
-+ input_report_key (lk->dev, lk->keycode[data], 1);
- else
-- input_report_key (&lk->dev, lk->keycode[data], 0);
-- input_sync (&lk->dev);
-+ input_report_key (lk->dev, lk->keycode[data], 0);
-+ input_sync (lk->dev);
- } else
- printk (KERN_WARNING "%s: Unknown key with "
- "scancode 0x%02x on %s.\n",
-@@ -605,7 +604,7 @@ lkkbd_reinit (void *data)
- lk->serio->write (lk->serio, volume_to_hw (lk->bell_volume));
-
- /* Enable/disable keyclick (and possibly set volume) */
-- if (test_bit (SND_CLICK, lk->dev.snd)) {
-+ if (test_bit (SND_CLICK, lk->dev->snd)) {
- lk->serio->write (lk->serio, LK_CMD_ENABLE_KEYCLICK);
- lk->serio->write (lk->serio, volume_to_hw (lk->keyclick_volume));
- lk->serio->write (lk->serio, LK_CMD_ENABLE_CTRCLICK);
-@@ -616,7 +615,7 @@ lkkbd_reinit (void *data)
- }
-
- /* Sound the bell if needed */
-- if (test_bit (SND_BELL, lk->dev.snd))
-+ if (test_bit (SND_BELL, lk->dev->snd))
- lk->serio->write (lk->serio, LK_CMD_SOUND_BELL);
- }
-
-@@ -627,71 +626,70 @@ static int
- lkkbd_connect (struct serio *serio, struct serio_driver *drv)
- {
- struct lkkbd *lk;
-+ struct input_dev *input_dev;
- int i;
- int err;
-
-- if (!(lk = kmalloc (sizeof (struct lkkbd), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset (lk, 0, sizeof (struct lkkbd));
--
-- init_input_dev (&lk->dev);
-- set_bit (EV_KEY, lk->dev.evbit);
-- set_bit (EV_LED, lk->dev.evbit);
-- set_bit (EV_SND, lk->dev.evbit);
-- set_bit (EV_REP, lk->dev.evbit);
-- set_bit (LED_CAPSL, lk->dev.ledbit);
-- set_bit (LED_SLEEP, lk->dev.ledbit);
-- set_bit (LED_COMPOSE, lk->dev.ledbit);
-- set_bit (LED_SCROLLL, lk->dev.ledbit);
-- set_bit (SND_BELL, lk->dev.sndbit);
-- set_bit (SND_CLICK, lk->dev.sndbit);
-+ lk = kzalloc (sizeof (struct lkkbd), GFP_KERNEL);
-+ input_dev = input_allocate_device ();
-+ if (!lk || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail;
-+ }
-
- lk->serio = serio;
--
-+ lk->dev = input_dev;
- INIT_WORK (&lk->tq, lkkbd_reinit, lk);
--
- lk->bell_volume = bell_volume;
- lk->keyclick_volume = keyclick_volume;
- lk->ctrlclick_volume = ctrlclick_volume;
-+ memcpy (lk->keycode, lkkbd_keycode, sizeof (lk_keycode_t) * LK_NUM_KEYCODES);
-
-- lk->dev.keycode = lk->keycode;
-- lk->dev.keycodesize = sizeof (lk_keycode_t);
-- lk->dev.keycodemax = LK_NUM_KEYCODES;
-+ strlcpy (lk->name, "DEC LK keyboard", sizeof(lk->name));
-+ snprintf (lk->phys, sizeof(lk->phys), "%s/input0", serio->phys);
-
-- lk->dev.event = lkkbd_event;
-- lk->dev.private = lk;
-+ input_dev->name = lk->name;
-+ input_dev->phys = lk->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_LKKBD;
-+ input_dev->id.product = 0;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->event = lkkbd_event;
-+ input_dev->private = lk;
-+
-+ set_bit (EV_KEY, input_dev->evbit);
-+ set_bit (EV_LED, input_dev->evbit);
-+ set_bit (EV_SND, input_dev->evbit);
-+ set_bit (EV_REP, input_dev->evbit);
-+ set_bit (LED_CAPSL, input_dev->ledbit);
-+ set_bit (LED_SLEEP, input_dev->ledbit);
-+ set_bit (LED_COMPOSE, input_dev->ledbit);
-+ set_bit (LED_SCROLLL, input_dev->ledbit);
-+ set_bit (SND_BELL, input_dev->sndbit);
-+ set_bit (SND_CLICK, input_dev->sndbit);
-+
-+ input_dev->keycode = lk->keycode;
-+ input_dev->keycodesize = sizeof (lk_keycode_t);
-+ input_dev->keycodemax = LK_NUM_KEYCODES;
-+ for (i = 0; i < LK_NUM_KEYCODES; i++)
-+ set_bit (lk->keycode[i], input_dev->keybit);
-
- serio_set_drvdata (serio, lk);
-
- err = serio_open (serio, drv);
-- if (err) {
-- serio_set_drvdata (serio, NULL);
-- kfree (lk);
-- return err;
-- }
-+ if (err)
-+ goto fail;
-
-- sprintf (lk->name, "DEC LK keyboard");
-- sprintf (lk->phys, "%s/input0", serio->phys);
--
-- memcpy (lk->keycode, lkkbd_keycode, sizeof (lk_keycode_t) * LK_NUM_KEYCODES);
-- for (i = 0; i < LK_NUM_KEYCODES; i++)
-- set_bit (lk->keycode[i], lk->dev.keybit);
--
-- lk->dev.name = lk->name;
-- lk->dev.phys = lk->phys;
-- lk->dev.id.bustype = BUS_RS232;
-- lk->dev.id.vendor = SERIO_LKKBD;
-- lk->dev.id.product = 0;
-- lk->dev.id.version = 0x0100;
-- lk->dev.dev = &serio->dev;
--
-- input_register_device (&lk->dev);
--
-- printk (KERN_INFO "input: %s on %s, initiating reset\n", lk->name, serio->phys);
-+ input_register_device (lk->dev);
- lk->serio->write (lk->serio, LK_CMD_POWERCYCLE_RESET);
-
- return 0;
-+
-+ fail: serio_set_drvdata (serio, NULL);
-+ input_free_device (input_dev);
-+ kfree (lk);
-+ return err;
- }
-
- /*
-@@ -702,9 +700,11 @@ lkkbd_disconnect (struct serio *serio)
- {
- struct lkkbd *lk = serio_get_drvdata (serio);
-
-- input_unregister_device (&lk->dev);
-+ input_get_device (lk->dev);
-+ input_unregister_device (lk->dev);
- serio_close (serio);
- serio_set_drvdata (serio, NULL);
-+ input_put_device (lk->dev);
- kfree (lk);
- }
-
---- gregkh-2.6.orig/drivers/input/keyboard/corgikbd.c
-+++ gregkh-2.6/drivers/input/keyboard/corgikbd.c
-@@ -70,8 +70,7 @@ static unsigned char corgikbd_keycode[NR
-
- struct corgikbd {
- unsigned char keycode[ARRAY_SIZE(corgikbd_keycode)];
-- struct input_dev input;
-- char phys[32];
-+ struct input_dev *input;
-
- spinlock_t lock;
- struct timer_list timer;
-@@ -147,7 +146,7 @@ static void corgikbd_scankeyboard(struct
- spin_lock_irqsave(&corgikbd_data->lock, flags);
-
- if (regs)
-- input_regs(&corgikbd_data->input, regs);
-+ input_regs(corgikbd_data->input, regs);
-
- num_pressed = 0;
- for (col = 0; col < KB_COLS; col++) {
-@@ -169,14 +168,14 @@ static void corgikbd_scankeyboard(struct
- scancode = SCANCODE(row, col);
- pressed = rowd & KB_ROWMASK(row);
-
-- input_report_key(&corgikbd_data->input, corgikbd_data->keycode[scancode], pressed);
-+ input_report_key(corgikbd_data->input, corgikbd_data->keycode[scancode], pressed);
-
- if (pressed)
- num_pressed++;
-
- if (pressed && (corgikbd_data->keycode[scancode] == CORGI_KEY_OFF)
- && time_after(jiffies, corgikbd_data->suspend_jiffies + HZ)) {
-- input_event(&corgikbd_data->input, EV_PWR, CORGI_KEY_OFF, 1);
-+ input_event(corgikbd_data->input, EV_PWR, CORGI_KEY_OFF, 1);
- corgikbd_data->suspend_jiffies=jiffies;
- }
- }
-@@ -185,7 +184,7 @@ static void corgikbd_scankeyboard(struct
-
- corgikbd_activate_all();
-
-- input_sync(&corgikbd_data->input);
-+ input_sync(corgikbd_data->input);
-
- /* if any keys are pressed, enable the timer */
- if (num_pressed)
-@@ -249,9 +248,9 @@ static void corgikbd_hinge_timer(unsigne
- if (hinge_count >= HINGE_STABLE_COUNT) {
- spin_lock_irqsave(&corgikbd_data->lock, flags);
-
-- input_report_switch(&corgikbd_data->input, SW_0, ((sharpsl_hinge_state & CORGI_SCP_SWA) != 0));
-- input_report_switch(&corgikbd_data->input, SW_1, ((sharpsl_hinge_state & CORGI_SCP_SWB) != 0));
-- input_sync(&corgikbd_data->input);
-+ input_report_switch(corgikbd_data->input, SW_0, ((sharpsl_hinge_state & CORGI_SCP_SWA) != 0));
-+ input_report_switch(corgikbd_data->input, SW_1, ((sharpsl_hinge_state & CORGI_SCP_SWB) != 0));
-+ input_sync(corgikbd_data->input);
-
- spin_unlock_irqrestore(&corgikbd_data->lock, flags);
- }
-@@ -287,16 +286,21 @@ static int corgikbd_resume(struct device
-
- static int __init corgikbd_probe(struct device *dev)
- {
-- int i;
- struct corgikbd *corgikbd;
-+ struct input_dev *input_dev;
-+ int i;
-
- corgikbd = kzalloc(sizeof(struct corgikbd), GFP_KERNEL);
-- if (!corgikbd)
-+ input_dev = input_allocate_device();
-+ if (!corgikbd || !input_dev) {
-+ kfree(corgikbd);
-+ input_free_device(input_dev);
- return -ENOMEM;
-+ }
-
-- dev_set_drvdata(dev,corgikbd);
-- strcpy(corgikbd->phys, "corgikbd/input0");
-+ dev_set_drvdata(dev, corgikbd);
-
-+ corgikbd->input = input_dev;
- spin_lock_init(&corgikbd->lock);
-
- /* Init Keyboard rescan timer */
-@@ -311,28 +315,30 @@ static int __init corgikbd_probe(struct
-
- corgikbd->suspend_jiffies=jiffies;
-
-- init_input_dev(&corgikbd->input);
-- corgikbd->input.private = corgikbd;
-- corgikbd->input.name = "Corgi Keyboard";
-- corgikbd->input.dev = dev;
-- corgikbd->input.phys = corgikbd->phys;
-- corgikbd->input.id.bustype = BUS_HOST;
-- corgikbd->input.id.vendor = 0x0001;
-- corgikbd->input.id.product = 0x0001;
-- corgikbd->input.id.version = 0x0100;
-- corgikbd->input.evbit[0] = BIT(EV_KEY) | BIT(EV_REP) | BIT(EV_PWR) | BIT(EV_SW);
-- corgikbd->input.keycode = corgikbd->keycode;
-- corgikbd->input.keycodesize = sizeof(unsigned char);
-- corgikbd->input.keycodemax = ARRAY_SIZE(corgikbd_keycode);
--
- memcpy(corgikbd->keycode, corgikbd_keycode, sizeof(corgikbd->keycode));
-+
-+ input_dev->name = "Corgi Keyboard";
-+ input_dev->phys = "corgikbd/input0";
-+ input_dev->id.bustype = BUS_HOST;
-+ input_dev->id.vendor = 0x0001;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = dev;
-+ input_dev->private = corgikbd;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP) | BIT(EV_PWR) | BIT(EV_SW);
-+ input_dev->keycode = corgikbd->keycode;
-+ input_dev->keycodesize = sizeof(unsigned char);
-+ input_dev->keycodemax = ARRAY_SIZE(corgikbd_keycode);
-+
- for (i = 0; i < ARRAY_SIZE(corgikbd_keycode); i++)
-- set_bit(corgikbd->keycode[i], corgikbd->input.keybit);
-- clear_bit(0, corgikbd->input.keybit);
-- set_bit(SW_0, corgikbd->input.swbit);
-- set_bit(SW_1, corgikbd->input.swbit);
-+ set_bit(corgikbd->keycode[i], input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-+ set_bit(SW_0, input_dev->swbit);
-+ set_bit(SW_1, input_dev->swbit);
-+
-+ input_register_device(corgikbd->input);
-
-- input_register_device(&corgikbd->input);
- mod_timer(&corgikbd->htimer, jiffies + HINGE_SCAN_INTERVAL);
-
- /* Setup sense interrupts - RisingEdge Detect, sense lines as inputs */
-@@ -349,8 +355,6 @@ static int __init corgikbd_probe(struct
- for (i = 0; i < CORGI_KEY_STROBE_NUM; i++)
- pxa_gpio_mode(CORGI_GPIO_KEY_STROBE(i) | GPIO_OUT | GPIO_DFLT_HIGH);
-
-- printk(KERN_INFO "input: Corgi Keyboard Registered\n");
--
- return 0;
- }
-
-@@ -365,7 +369,7 @@ static int corgikbd_remove(struct device
- del_timer_sync(&corgikbd->htimer);
- del_timer_sync(&corgikbd->timer);
-
-- input_unregister_device(&corgikbd->input);
-+ input_unregister_device(corgikbd->input);
-
- kfree(corgikbd);
-
---- gregkh-2.6.orig/drivers/input/keyboard/xtkbd.c
-+++ gregkh-2.6/drivers/input/keyboard/xtkbd.c
-@@ -56,11 +56,9 @@ static unsigned char xtkbd_keycode[256]
- 106
- };
-
--static char *xtkbd_name = "XT Keyboard";
--
- struct xtkbd {
- unsigned char keycode[256];
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- char phys[32];
- };
-@@ -77,9 +75,9 @@ static irqreturn_t xtkbd_interrupt(struc
- default:
-
- if (xtkbd->keycode[data & XTKBD_KEY]) {
-- input_regs(&xtkbd->dev, regs);
-- input_report_key(&xtkbd->dev, xtkbd->keycode[data & XTKBD_KEY], !(data & XTKBD_RELEASE));
-- input_sync(&xtkbd->dev);
-+ input_regs(xtkbd->dev, regs);
-+ input_report_key(xtkbd->dev, xtkbd->keycode[data & XTKBD_KEY], !(data & XTKBD_RELEASE));
-+ input_sync(xtkbd->dev);
- } else {
- printk(KERN_WARNING "xtkbd.c: Unknown key (scancode %#x) %s.\n",
- data & XTKBD_KEY, data & XTKBD_RELEASE ? "released" : "pressed");
-@@ -91,62 +89,60 @@ static irqreturn_t xtkbd_interrupt(struc
- static int xtkbd_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct xtkbd *xtkbd;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
- int i;
-- int err;
--
-- if (!(xtkbd = kmalloc(sizeof(struct xtkbd), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(xtkbd, 0, sizeof(struct xtkbd));
-
-- xtkbd->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ xtkbd = kmalloc(sizeof(struct xtkbd), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!xtkbd || !input_dev)
-+ goto fail;
-
- xtkbd->serio = serio;
--
-- init_input_dev(&xtkbd->dev);
-- xtkbd->dev.keycode = xtkbd->keycode;
-- xtkbd->dev.keycodesize = sizeof(unsigned char);
-- xtkbd->dev.keycodemax = ARRAY_SIZE(xtkbd_keycode);
-- xtkbd->dev.private = xtkbd;
--
-- serio_set_drvdata(serio, xtkbd);
--
-- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(xtkbd);
-- return err;
-- }
--
-+ xtkbd->dev = input_dev;
-+ sprintf(xtkbd->phys, "%s/input0", serio->phys);
- memcpy(xtkbd->keycode, xtkbd_keycode, sizeof(xtkbd->keycode));
-- for (i = 0; i < 255; i++)
-- set_bit(xtkbd->keycode[i], xtkbd->dev.keybit);
-- clear_bit(0, xtkbd->dev.keybit);
-
-- sprintf(xtkbd->phys, "%s/input0", serio->phys);
-+ input_dev->name = "XT Keyboard";
-+ input_dev->phys = xtkbd->phys;
-+ input_dev->id.bustype = BUS_XTKBD;
-+ input_dev->id.vendor = 0x0001;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = xtkbd;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ input_dev->keycode = xtkbd->keycode;
-+ input_dev->keycodesize = sizeof(unsigned char);
-+ input_dev->keycodemax = ARRAY_SIZE(xtkbd_keycode);
-
-- xtkbd->dev.name = xtkbd_name;
-- xtkbd->dev.phys = xtkbd->phys;
-- xtkbd->dev.id.bustype = BUS_XTKBD;
-- xtkbd->dev.id.vendor = 0x0001;
-- xtkbd->dev.id.product = 0x0001;
-- xtkbd->dev.id.version = 0x0100;
-- xtkbd->dev.dev = &serio->dev;
-+ for (i = 0; i < 255; i++)
-+ set_bit(xtkbd->keycode[i], input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-
-- input_register_device(&xtkbd->dev);
-+ serio_set_drvdata(serio, xtkbd);
-
-- printk(KERN_INFO "input: %s on %s\n", xtkbd_name, serio->phys);
-+ err = serio_open(serio, drv);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(xtkbd->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(xtkbd);
-+ return err;
- }
-
- static void xtkbd_disconnect(struct serio *serio)
- {
- struct xtkbd *xtkbd = serio_get_drvdata(serio);
-
-- input_unregister_device(&xtkbd->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(xtkbd->dev);
- kfree(xtkbd);
- }
-
---- gregkh-2.6.orig/drivers/input/keyboard/newtonkbd.c
-+++ gregkh-2.6/drivers/input/keyboard/newtonkbd.c
-@@ -57,11 +57,9 @@ static unsigned char nkbd_keycode[128] =
- KEY_LEFT, KEY_RIGHT, KEY_DOWN, KEY_UP, 0
- };
-
--static char *nkbd_name = "Newton Keyboard";
--
- struct nkbd {
- unsigned char keycode[128];
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- char phys[32];
- };
-@@ -73,13 +71,13 @@ static irqreturn_t nkbd_interrupt(struct
-
- /* invalid scan codes are probably the init sequence, so we ignore them */
- if (nkbd->keycode[data & NKBD_KEY]) {
-- input_regs(&nkbd->dev, regs);
-- input_report_key(&nkbd->dev, nkbd->keycode[data & NKBD_KEY], data & NKBD_PRESS);
-- input_sync(&nkbd->dev);
-+ input_regs(nkbd->dev, regs);
-+ input_report_key(nkbd->dev, nkbd->keycode[data & NKBD_KEY], data & NKBD_PRESS);
-+ input_sync(nkbd->dev);
- }
-
- else if (data == 0xe7) /* end of init sequence */
-- printk(KERN_INFO "input: %s on %s\n", nkbd_name, serio->phys);
-+ printk(KERN_INFO "input: %s on %s\n", nkbd->dev->name, serio->phys);
- return IRQ_HANDLED;
-
- }
-@@ -87,62 +85,59 @@ static irqreturn_t nkbd_interrupt(struct
- static int nkbd_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct nkbd *nkbd;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
- int i;
-- int err;
--
-- if (!(nkbd = kmalloc(sizeof(struct nkbd), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(nkbd, 0, sizeof(struct nkbd));
-
-- nkbd->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ nkbd = kzalloc(sizeof(struct nkbd), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!nkbd || !input_dev)
-+ goto fail;
-
- nkbd->serio = serio;
-+ nkbd->dev = input_dev;
-+ sprintf(nkbd->phys, "%s/input0", serio->phys);
-+ memcpy(nkbd->keycode, nkbd_keycode, sizeof(nkbd->keycode));
-
-- init_input_dev(&nkbd->dev);
-- nkbd->dev.keycode = nkbd->keycode;
-- nkbd->dev.keycodesize = sizeof(unsigned char);
-- nkbd->dev.keycodemax = ARRAY_SIZE(nkbd_keycode);
-- nkbd->dev.private = nkbd;
-+ input_dev->name = "Newton Keyboard";
-+ input_dev->phys = nkbd->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_NEWTON;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = nkbd;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ input_dev->keycode = nkbd->keycode;
-+ input_dev->keycodesize = sizeof(unsigned char);
-+ input_dev->keycodemax = ARRAY_SIZE(nkbd_keycode);
-+ for (i = 0; i < 128; i++)
-+ set_bit(nkbd->keycode[i], input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-
- serio_set_drvdata(serio, nkbd);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(nkbd);
-- return err;
-- }
--
-- memcpy(nkbd->keycode, nkbd_keycode, sizeof(nkbd->keycode));
-- for (i = 0; i < 128; i++)
-- set_bit(nkbd->keycode[i], nkbd->dev.keybit);
-- clear_bit(0, nkbd->dev.keybit);
--
-- sprintf(nkbd->phys, "%s/input0", serio->phys);
--
-- nkbd->dev.name = nkbd_name;
-- nkbd->dev.phys = nkbd->phys;
-- nkbd->dev.id.bustype = BUS_RS232;
-- nkbd->dev.id.vendor = SERIO_NEWTON;
-- nkbd->dev.id.product = 0x0001;
-- nkbd->dev.id.version = 0x0100;
-- nkbd->dev.dev = &serio->dev;
--
-- input_register_device(&nkbd->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", nkbd_name, serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(nkbd->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(nkbd);
-+ return err;
- }
-
- static void nkbd_disconnect(struct serio *serio)
- {
- struct nkbd *nkbd = serio_get_drvdata(serio);
-
-- input_unregister_device(&nkbd->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(nkbd->dev);
- kfree(nkbd);
- }
-
---- gregkh-2.6.orig/drivers/input/keyboard/sunkbd.c
-+++ gregkh-2.6/drivers/input/keyboard/sunkbd.c
-@@ -76,13 +76,14 @@ static unsigned char sunkbd_keycode[128]
-
- struct sunkbd {
- unsigned char keycode[128];
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- struct work_struct tq;
- wait_queue_head_t wait;
- char name[64];
- char phys[32];
- char type;
-+ unsigned char enabled;
- volatile s8 reset;
- volatile s8 layout;
- };
-@@ -124,10 +125,13 @@ static irqreturn_t sunkbd_interrupt(stru
- break;
-
- default:
-+ if (!sunkbd->enabled)
-+ break;
-+
- if (sunkbd->keycode[data & SUNKBD_KEY]) {
-- input_regs(&sunkbd->dev, regs);
-- input_report_key(&sunkbd->dev, sunkbd->keycode[data & SUNKBD_KEY], !(data & SUNKBD_RELEASE));
-- input_sync(&sunkbd->dev);
-+ input_regs(sunkbd->dev, regs);
-+ input_report_key(sunkbd->dev, sunkbd->keycode[data & SUNKBD_KEY], !(data & SUNKBD_RELEASE));
-+ input_sync(sunkbd->dev);
- } else {
- printk(KERN_WARNING "sunkbd.c: Unknown key (scancode %#x) %s.\n",
- data & SUNKBD_KEY, data & SUNKBD_RELEASE ? "released" : "pressed");
-@@ -184,7 +188,7 @@ static int sunkbd_initialize(struct sunk
- sunkbd->reset = -2;
- sunkbd->serio->write(sunkbd->serio, SUNKBD_CMD_RESET);
- wait_event_interruptible_timeout(sunkbd->wait, sunkbd->reset >= 0, HZ);
-- if (sunkbd->reset <0)
-+ if (sunkbd->reset < 0)
- return -1;
-
- sunkbd->type = sunkbd->reset;
-@@ -213,10 +217,17 @@ static void sunkbd_reinit(void *data)
-
- sunkbd->serio->write(sunkbd->serio, SUNKBD_CMD_SETLED);
- sunkbd->serio->write(sunkbd->serio,
-- (!!test_bit(LED_CAPSL, sunkbd->dev.led) << 3) | (!!test_bit(LED_SCROLLL, sunkbd->dev.led) << 2) |
-- (!!test_bit(LED_COMPOSE, sunkbd->dev.led) << 1) | !!test_bit(LED_NUML, sunkbd->dev.led));
-- sunkbd->serio->write(sunkbd->serio, SUNKBD_CMD_NOCLICK - !!test_bit(SND_CLICK, sunkbd->dev.snd));
-- sunkbd->serio->write(sunkbd->serio, SUNKBD_CMD_BELLOFF - !!test_bit(SND_BELL, sunkbd->dev.snd));
-+ (!!test_bit(LED_CAPSL, sunkbd->dev->led) << 3) | (!!test_bit(LED_SCROLLL, sunkbd->dev->led) << 2) |
-+ (!!test_bit(LED_COMPOSE, sunkbd->dev->led) << 1) | !!test_bit(LED_NUML, sunkbd->dev->led));
-+ sunkbd->serio->write(sunkbd->serio, SUNKBD_CMD_NOCLICK - !!test_bit(SND_CLICK, sunkbd->dev->snd));
-+ sunkbd->serio->write(sunkbd->serio, SUNKBD_CMD_BELLOFF - !!test_bit(SND_BELL, sunkbd->dev->snd));
-+}
-+
-+static void sunkbd_enable(struct sunkbd *sunkbd, int enable)
-+{
-+ serio_pause_rx(sunkbd->serio);
-+ sunkbd->enabled = 1;
-+ serio_continue_rx(sunkbd->serio);
- }
-
- /*
-@@ -226,70 +237,64 @@ static void sunkbd_reinit(void *data)
- static int sunkbd_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct sunkbd *sunkbd;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
- int i;
-- int err;
--
-- if (!(sunkbd = kmalloc(sizeof(struct sunkbd), GFP_KERNEL)))
-- return -ENOMEM;
-
-- memset(sunkbd, 0, sizeof(struct sunkbd));
--
-- init_input_dev(&sunkbd->dev);
-- init_waitqueue_head(&sunkbd->wait);
--
-- sunkbd->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_LED) | BIT(EV_SND) | BIT(EV_REP);
-- sunkbd->dev.ledbit[0] = BIT(LED_CAPSL) | BIT(LED_COMPOSE) | BIT(LED_SCROLLL) | BIT(LED_NUML);
-- sunkbd->dev.sndbit[0] = BIT(SND_CLICK) | BIT(SND_BELL);
-+ sunkbd = kzalloc(sizeof(struct sunkbd), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!sunkbd || !input_dev)
-+ goto fail;
-
- sunkbd->serio = serio;
--
-+ sunkbd->dev = input_dev;
-+ init_waitqueue_head(&sunkbd->wait);
- INIT_WORK(&sunkbd->tq, sunkbd_reinit, sunkbd);
--
-- sunkbd->dev.keycode = sunkbd->keycode;
-- sunkbd->dev.keycodesize = sizeof(unsigned char);
-- sunkbd->dev.keycodemax = ARRAY_SIZE(sunkbd_keycode);
--
-- sunkbd->dev.event = sunkbd_event;
-- sunkbd->dev.private = sunkbd;
-+ snprintf(sunkbd->phys, sizeof(sunkbd->phys), "%s/input0", serio->phys);
-
- serio_set_drvdata(serio, sunkbd);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(sunkbd);
-- return err;
-- }
-+ if (err)
-+ goto fail;
-
- if (sunkbd_initialize(sunkbd) < 0) {
- serio_close(serio);
-- serio_set_drvdata(serio, NULL);
-- kfree(sunkbd);
-- return -ENODEV;
-+ goto fail;
- }
-
- sprintf(sunkbd->name, "Sun Type %d keyboard", sunkbd->type);
--
- memcpy(sunkbd->keycode, sunkbd_keycode, sizeof(sunkbd->keycode));
-- for (i = 0; i < 128; i++)
-- set_bit(sunkbd->keycode[i], sunkbd->dev.keybit);
-- clear_bit(0, sunkbd->dev.keybit);
--
-- sprintf(sunkbd->phys, "%s/input0", serio->phys);
--
-- sunkbd->dev.name = sunkbd->name;
-- sunkbd->dev.phys = sunkbd->phys;
-- sunkbd->dev.id.bustype = BUS_RS232;
-- sunkbd->dev.id.vendor = SERIO_SUNKBD;
-- sunkbd->dev.id.product = sunkbd->type;
-- sunkbd->dev.id.version = 0x0100;
-- sunkbd->dev.dev = &serio->dev;
-
-- input_register_device(&sunkbd->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", sunkbd->name, serio->phys);
-+ input_dev->name = sunkbd->name;
-+ input_dev->phys = sunkbd->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_SUNKBD;
-+ input_dev->id.product = sunkbd->type;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = sunkbd;
-+ input_dev->event = sunkbd_event;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_LED) | BIT(EV_SND) | BIT(EV_REP);
-+ input_dev->ledbit[0] = BIT(LED_CAPSL) | BIT(LED_COMPOSE) | BIT(LED_SCROLLL) | BIT(LED_NUML);
-+ input_dev->sndbit[0] = BIT(SND_CLICK) | BIT(SND_BELL);
-+
-+ input_dev->keycode = sunkbd->keycode;
-+ input_dev->keycodesize = sizeof(unsigned char);
-+ input_dev->keycodemax = ARRAY_SIZE(sunkbd_keycode);
-+ for (i = 0; i < 128; i++)
-+ set_bit(sunkbd->keycode[i], input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-
-+ sunkbd_enable(sunkbd, 1);
-+ input_register_device(sunkbd->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(sunkbd);
-+ return err;
- }
-
- /*
-@@ -299,7 +304,9 @@ static int sunkbd_connect(struct serio *
- static void sunkbd_disconnect(struct serio *serio)
- {
- struct sunkbd *sunkbd = serio_get_drvdata(serio);
-- input_unregister_device(&sunkbd->dev);
-+
-+ sunkbd_enable(sunkbd, 0);
-+ input_unregister_device(sunkbd->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
- kfree(sunkbd);
---- gregkh-2.6.orig/drivers/input/keyboard/maple_keyb.c
-+++ gregkh-2.6/drivers/input/keyboard/maple_keyb.c
-@@ -37,7 +37,7 @@ static unsigned char dc_kbd_keycode[256]
-
-
- struct dc_kbd {
-- struct input_dev dev;
-+ struct input_dev *dev;
- unsigned char new[8];
- unsigned char old[8];
- };
-@@ -46,30 +46,24 @@ struct dc_kbd {
- static void dc_scan_kbd(struct dc_kbd *kbd)
- {
- int i;
-- struct input_dev *dev = &kbd->dev;
-+ struct input_dev *dev = kbd->dev;
-
-- for(i=0; i<8; i++)
-- input_report_key(dev,
-- dc_kbd_keycode[i+224],
-- (kbd->new[0]>>i)&1);
--
-- for(i=2; i<8; i++) {
--
-- if(kbd->old[i]>3&&memscan(kbd->new+2, kbd->old[i], 6)==NULL) {
-- if(dc_kbd_keycode[kbd->old[i]])
-- input_report_key(dev,
-- dc_kbd_keycode[kbd->old[i]],
-- 0);
-+ for (i = 0; i < 8; i++)
-+ input_report_key(dev, dc_kbd_keycode[i + 224], (kbd->new[0] >> i) & 1);
-+
-+ for (i = 2; i < 8; i++) {
-+
-+ if (kbd->old[i] > 3 && memscan(kbd->new + 2, kbd->old[i], 6) == NULL) {
-+ if (dc_kbd_keycode[kbd->old[i]])
-+ input_report_key(dev, dc_kbd_keycode[kbd->old[i]], 0);
- else
- printk("Unknown key (scancode %#x) released.",
- kbd->old[i]);
- }
-
-- if(kbd->new[i]>3&&memscan(kbd->old+2, kbd->new[i], 6)!=NULL) {
-+ if (kbd->new[i] > 3 && memscan(kbd->old + 2, kbd->new[i], 6) != NULL) {
- if(dc_kbd_keycode[kbd->new[i]])
-- input_report_key(dev,
-- dc_kbd_keycode[kbd->new[i]],
-- 1);
-+ input_report_key(dev, dc_kbd_keycode[kbd->new[i]], 1);
- else
- printk("Unknown key (scancode %#x) pressed.",
- kbd->new[i]);
-@@ -89,43 +83,39 @@ static void dc_kbd_callback(struct maple
- unsigned long *buf = mq->recvbuf;
-
- if (buf[1] == mapledev->function) {
-- memcpy(kbd->new, buf+2, 8);
-+ memcpy(kbd->new, buf + 2, 8);
- dc_scan_kbd(kbd);
- }
- }
-
- static int dc_kbd_connect(struct maple_device *dev)
- {
-- int i;
-- unsigned long data = be32_to_cpu(dev->devinfo.function_data[0]);
- struct dc_kbd *kbd;
-+ struct input_dev *input_dev;
-+ unsigned long data = be32_to_cpu(dev->devinfo.function_data[0]);
-+ int i;
-
-- if (!(kbd = kmalloc(sizeof(struct dc_kbd), GFP_KERNEL)))
-- return -1;
-- memset(kbd, 0, sizeof(struct dc_kbd));
--
-- dev->private_data = kbd;
--
-- kbd->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
--
-- init_input_dev(&kbd->dev);
--
-- for (i=0; i<255; i++)
-- set_bit(dc_kbd_keycode[i], kbd->dev.keybit);
--
-- clear_bit(0, kbd->dev.keybit);
-+ dev->private_data = kbd = kzalloc(sizeof(struct dc_kbd), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!kbd || !input_dev) {
-+ kfree(kbd);
-+ input_free_device(input_dev);
-+ return -ENOMEM;
-+ }
-
-- kbd->dev.private = kbd;
-+ kbd->dev = input_dev;
-
-- kbd->dev.name = dev->product_name;
-- kbd->dev.id.bustype = BUS_MAPLE;
-+ input_dev->name = dev->product_name;
-+ input_dev->id.bustype = BUS_MAPLE;
-+ input_dev->private = kbd;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ for (i = 0; i < 255; i++)
-+ set_bit(dc_kbd_keycode[i], input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-
-- input_register_device(&kbd->dev);
-+ input_register_device(kbd->dev);
-
- maple_getcond_callback(dev, dc_kbd_callback, 1, MAPLE_FUNC_KEYBOARD);
--
-- printk(KERN_INFO "input: keyboard(0x%lx): %s\n", data, kbd->dev.name);
--
- return 0;
- }
-
-@@ -134,7 +124,7 @@ static void dc_kbd_disconnect(struct map
- {
- struct dc_kbd *kbd = dev->private_data;
-
-- input_unregister_device(&kbd->dev);
-+ input_unregister_device(kbd->dev);
- kfree(kbd);
- }
-
---- gregkh-2.6.orig/drivers/input/keyboard/spitzkbd.c
-+++ gregkh-2.6/drivers/input/keyboard/spitzkbd.c
-@@ -85,7 +85,7 @@ static int spitz_senses[] = {
-
- struct spitzkbd {
- unsigned char keycode[ARRAY_SIZE(spitzkbd_keycode)];
-- struct input_dev input;
-+ struct input_dev *input;
- char phys[32];
-
- spinlock_t lock;
-@@ -187,8 +187,7 @@ static void spitzkbd_scankeyboard(struct
-
- spin_lock_irqsave(&spitzkbd_data->lock, flags);
-
-- if (regs)
-- input_regs(&spitzkbd_data->input, regs);
-+ input_regs(spitzkbd_data->input, regs);
-
- num_pressed = 0;
- for (col = 0; col < KB_COLS; col++) {
-@@ -210,7 +209,7 @@ static void spitzkbd_scankeyboard(struct
- scancode = SCANCODE(row, col);
- pressed = rowd & KB_ROWMASK(row);
-
-- input_report_key(&spitzkbd_data->input, spitzkbd_data->keycode[scancode], pressed);
-+ input_report_key(spitzkbd_data->input, spitzkbd_data->keycode[scancode], pressed);
-
- if (pressed)
- num_pressed++;
-@@ -220,15 +219,15 @@ static void spitzkbd_scankeyboard(struct
-
- spitzkbd_activate_all();
-
-- input_report_key(&spitzkbd_data->input, SPITZ_KEY_SYNC, (GPLR(SPITZ_GPIO_SYNC) & GPIO_bit(SPITZ_GPIO_SYNC)) != 0 );
-- input_report_key(&spitzkbd_data->input, KEY_SUSPEND, pwrkey);
-+ input_report_key(spitzkbd_data->input, SPITZ_KEY_SYNC, (GPLR(SPITZ_GPIO_SYNC) & GPIO_bit(SPITZ_GPIO_SYNC)) != 0 );
-+ input_report_key(spitzkbd_data->input, KEY_SUSPEND, pwrkey);
-
- if (pwrkey && time_after(jiffies, spitzkbd_data->suspend_jiffies + msecs_to_jiffies(1000))) {
-- input_event(&spitzkbd_data->input, EV_PWR, KEY_SUSPEND, 1);
-+ input_event(spitzkbd_data->input, EV_PWR, KEY_SUSPEND, 1);
- spitzkbd_data->suspend_jiffies = jiffies;
- }
-
-- input_sync(&spitzkbd_data->input);
-+ input_sync(spitzkbd_data->input);
-
- /* if any keys are pressed, enable the timer */
- if (num_pressed)
-@@ -259,6 +258,7 @@ static irqreturn_t spitzkbd_interrupt(in
- static void spitzkbd_timer_callback(unsigned long data)
- {
- struct spitzkbd *spitzkbd_data = (struct spitzkbd *) data;
-+
- spitzkbd_scankeyboard(spitzkbd_data, NULL);
- }
-
-@@ -298,9 +298,9 @@ static void spitzkbd_hinge_timer(unsigne
- if (hinge_count >= HINGE_STABLE_COUNT) {
- spin_lock_irqsave(&spitzkbd_data->lock, flags);
-
-- input_report_switch(&spitzkbd_data->input, SW_0, ((GPLR(SPITZ_GPIO_SWA) & GPIO_bit(SPITZ_GPIO_SWA)) != 0));
-- input_report_switch(&spitzkbd_data->input, SW_1, ((GPLR(SPITZ_GPIO_SWB) & GPIO_bit(SPITZ_GPIO_SWB)) != 0));
-- input_sync(&spitzkbd_data->input);
-+ input_report_switch(spitzkbd_data->input, SW_0, ((GPLR(SPITZ_GPIO_SWA) & GPIO_bit(SPITZ_GPIO_SWA)) != 0));
-+ input_report_switch(spitzkbd_data->input, SW_1, ((GPLR(SPITZ_GPIO_SWB) & GPIO_bit(SPITZ_GPIO_SWB)) != 0));
-+ input_sync(spitzkbd_data->input);
-
- spin_unlock_irqrestore(&spitzkbd_data->lock, flags);
- } else {
-@@ -346,14 +346,21 @@ static int spitzkbd_resume(struct device
-
- static int __init spitzkbd_probe(struct device *dev)
- {
-- int i;
- struct spitzkbd *spitzkbd;
-+ struct input_dev *input_dev;
-+ int i;
-
- spitzkbd = kzalloc(sizeof(struct spitzkbd), GFP_KERNEL);
- if (!spitzkbd)
- return -ENOMEM;
-
-- dev_set_drvdata(dev,spitzkbd);
-+ input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ kfree(spitzkbd);
-+ return -ENOMEM;
-+ }
-+
-+ dev_set_drvdata(dev, spitzkbd);
- strcpy(spitzkbd->phys, "spitzkbd/input0");
-
- spin_lock_init(&spitzkbd->lock);
-@@ -368,30 +375,34 @@ static int __init spitzkbd_probe(struct
- spitzkbd->htimer.function = spitzkbd_hinge_timer;
- spitzkbd->htimer.data = (unsigned long) spitzkbd;
-
-- spitzkbd->suspend_jiffies=jiffies;
-+ spitzkbd->suspend_jiffies = jiffies;
-
-- init_input_dev(&spitzkbd->input);
-- spitzkbd->input.private = spitzkbd;
-- spitzkbd->input.name = "Spitz Keyboard";
-- spitzkbd->input.dev = dev;
-- spitzkbd->input.phys = spitzkbd->phys;
-- spitzkbd->input.id.bustype = BUS_HOST;
-- spitzkbd->input.id.vendor = 0x0001;
-- spitzkbd->input.id.product = 0x0001;
-- spitzkbd->input.id.version = 0x0100;
-- spitzkbd->input.evbit[0] = BIT(EV_KEY) | BIT(EV_REP) | BIT(EV_PWR) | BIT(EV_SW);
-- spitzkbd->input.keycode = spitzkbd->keycode;
-- spitzkbd->input.keycodesize = sizeof(unsigned char);
-- spitzkbd->input.keycodemax = ARRAY_SIZE(spitzkbd_keycode);
-+ spitzkbd->input = input_dev;
-+
-+ input_dev->private = spitzkbd;
-+ input_dev->name = "Spitz Keyboard";
-+ input_dev->phys = spitzkbd->phys;
-+ input_dev->cdev.dev = dev;
-+
-+ input_dev->id.bustype = BUS_HOST;
-+ input_dev->id.vendor = 0x0001;
-+ input_dev->id.product = 0x0001;
-+ input_dev->id.version = 0x0100;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP) | BIT(EV_PWR) | BIT(EV_SW);
-+ input_dev->keycode = spitzkbd->keycode;
-+ input_dev->keycodesize = sizeof(unsigned char);
-+ input_dev->keycodemax = ARRAY_SIZE(spitzkbd_keycode);
-
- memcpy(spitzkbd->keycode, spitzkbd_keycode, sizeof(spitzkbd->keycode));
- for (i = 0; i < ARRAY_SIZE(spitzkbd_keycode); i++)
-- set_bit(spitzkbd->keycode[i], spitzkbd->input.keybit);
-- clear_bit(0, spitzkbd->input.keybit);
-- set_bit(SW_0, spitzkbd->input.swbit);
-- set_bit(SW_1, spitzkbd->input.swbit);
-+ set_bit(spitzkbd->keycode[i], input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-+ set_bit(SW_0, input_dev->swbit);
-+ set_bit(SW_1, input_dev->swbit);
-+
-+ input_register_device(input_dev);
-
-- input_register_device(&spitzkbd->input);
- mod_timer(&spitzkbd->htimer, jiffies + msecs_to_jiffies(HINGE_SCAN_INTERVAL));
-
- /* Setup sense interrupts - RisingEdge Detect, sense lines as inputs */
-@@ -444,7 +455,7 @@ static int spitzkbd_remove(struct device
- del_timer_sync(&spitzkbd->htimer);
- del_timer_sync(&spitzkbd->timer);
-
-- input_unregister_device(&spitzkbd->input);
-+ input_unregister_device(spitzkbd->input);
-
- kfree(spitzkbd);
-
diff --git a/driver/input-convert-to-dynamic-konicawc.patch b/driver/input-convert-to-dynamic-konicawc.patch
deleted file mode 100644
index 8a9400ac4b9ab..0000000000000
--- a/driver/input-convert-to-dynamic-konicawc.patch
+++ /dev/null
@@ -1,157 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:17 2005
-Message-Id: <20050915070303.236124000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:42 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 11/28] Input: convert konicawc to dynamic input_dev allocation
-
-Input: convert konicawc to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/usb/media/konicawc.c | 89 +++++++++++++++++++++++++++++--------------
- 1 file changed, 61 insertions(+), 28 deletions(-)
-
---- gregkh-2.6.orig/drivers/usb/media/konicawc.c
-+++ gregkh-2.6/drivers/usb/media/konicawc.c
-@@ -119,7 +119,7 @@ struct konicawc {
- int yplanesz; /* Number of bytes in the Y plane */
- unsigned int buttonsts:1;
- #ifdef CONFIG_INPUT
-- struct input_dev input;
-+ struct input_dev *input;
- char input_physname[64];
- #endif
- };
-@@ -218,6 +218,57 @@ static void konicawc_adjust_picture(stru
- konicawc_camera_on(uvd);
- }
-
-+#ifdef CONFIG_INPUT
-+
-+static void konicawc_register_input(struct konicawc *cam, struct usb_device *dev)
-+{
-+ struct input_dev *input_dev;
-+
-+ usb_make_path(dev, cam->input_physname, sizeof(cam->input_physname));
-+ strncat(cam->input_physname, "/input0", sizeof(cam->input_physname));
-+
-+ cam->input = input_dev = input_allocate_device();
-+ if (!input_dev) {
-+ warn("Not enough memory for camera's input device\n");
-+ return;
-+ }
-+
-+ input_dev->name = "Konicawc snapshot button";
-+ input_dev->phys = cam->input_physname;
-+ usb_to_input_id(dev, &input_dev->id);
-+ input_dev->cdev.dev = &dev->dev;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY);
-+ input_dev->keybit[LONG(BTN_0)] = BIT(BTN_0);
-+
-+ input_dev->private = cam;
-+
-+ input_register_device(cam->input);
-+}
-+
-+static void konicawc_unregister_input(struct konicawc *cam)
-+{
-+ if (cam->input) {
-+ input_unregister_device(cam->input);
-+ cam->input = NULL;
-+ }
-+}
-+
-+static void konicawc_report_buttonstat(struct konicawc *cam)
-+{
-+ if (cam->input) {
-+ input_report_key(cam->input, BTN_0, cam->buttonsts);
-+ input_sync(cam->input);
-+ }
-+}
-+
-+#else
-+
-+static inline void konicawc_register_input(struct konicawc *cam, struct usb_device *dev) { }
-+static inline void konicawc_unregister_input(struct konicawc *cam) { }
-+static inline void konicawc_report_buttonstat(struct konicawc *cam) { }
-+
-+#endif /* CONFIG_INPUT */
-
- static int konicawc_compress_iso(struct uvd *uvd, struct urb *dataurb, struct urb *stsurb)
- {
-@@ -273,10 +324,7 @@ static int konicawc_compress_iso(struct
- if(button != cam->buttonsts) {
- DEBUG(2, "button: %sclicked", button ? "" : "un");
- cam->buttonsts = button;
--#ifdef CONFIG_INPUT
-- input_report_key(&cam->input, BTN_0, cam->buttonsts);
-- input_sync(&cam->input);
--#endif
-+ konicawc_report_buttonstat(cam);
- }
-
- if(sts == 0x01) { /* drop frame */
-@@ -645,9 +693,9 @@ static int konicawc_set_video_mode(struc
- RingQueue_Flush(&uvd->dp);
- cam->lastframe = -2;
- if(uvd->curframe != -1) {
-- uvd->frame[uvd->curframe].curline = 0;
-- uvd->frame[uvd->curframe].seqRead_Length = 0;
-- uvd->frame[uvd->curframe].seqRead_Index = 0;
-+ uvd->frame[uvd->curframe].curline = 0;
-+ uvd->frame[uvd->curframe].seqRead_Length = 0;
-+ uvd->frame[uvd->curframe].seqRead_Index = 0;
- }
-
- konicawc_start_data(uvd);
-@@ -718,7 +766,6 @@ static void konicawc_configure_video(str
- DEBUG(1, "setting initial values");
- }
-
--
- static int konicawc_probe(struct usb_interface *intf, const struct usb_device_id *devid)
- {
- struct usb_device *dev = interface_to_usbdev(intf);
-@@ -839,21 +886,8 @@ static int konicawc_probe(struct usb_int
- err("usbvideo_RegisterVideoDevice() failed.");
- uvd = NULL;
- }
--#ifdef CONFIG_INPUT
-- /* Register input device for button */
-- memset(&cam->input, 0, sizeof(struct input_dev));
-- cam->input.name = "Konicawc snapshot button";
-- cam->input.private = cam;
-- cam->input.evbit[0] = BIT(EV_KEY);
-- cam->input.keybit[LONG(BTN_0)] = BIT(BTN_0);
-- usb_to_input_id(dev, &cam->input.id);
-- input_register_device(&cam->input);
--
-- usb_make_path(dev, cam->input_physname, 56);
-- strcat(cam->input_physname, "/input0");
-- cam->input.phys = cam->input_physname;
-- info("konicawc: %s on %s\n", cam->input.name, cam->input.phys);
--#endif
-+
-+ konicawc_register_input(cam, dev);
- }
-
- if (uvd) {
-@@ -869,10 +903,9 @@ static void konicawc_free_uvd(struct uvd
- int i;
- struct konicawc *cam = (struct konicawc *)uvd->user_data;
-
--#ifdef CONFIG_INPUT
-- input_unregister_device(&cam->input);
--#endif
-- for (i=0; i < USBVIDEO_NUMSBUF; i++) {
-+ konicawc_unregister_input(cam);
-+
-+ for (i = 0; i < USBVIDEO_NUMSBUF; i++) {
- usb_free_urb(cam->sts_urb[i]);
- cam->sts_urb[i] = NULL;
- }
diff --git a/driver/input-convert-to-dynamic-macintosh.patch b/driver/input-convert-to-dynamic-macintosh.patch
deleted file mode 100644
index 0bae607942f1a..0000000000000
--- a/driver/input-convert-to-dynamic-macintosh.patch
+++ /dev/null
@@ -1,525 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:05 2005
-Message-Id: <20050915070303.064107000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:41 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 10/28] Input: convert drivers/macintosh to dynamic input_dev allocation
-
-Input: convert drivers/macntosh to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/macintosh/adbhid.c | 220 +++++++++++++++++++++++---------------------
- drivers/macintosh/mac_hid.c | 44 ++++----
- 2 files changed, 139 insertions(+), 125 deletions(-)
-
---- gregkh-2.6.orig/drivers/macintosh/adbhid.c
-+++ gregkh-2.6/drivers/macintosh/adbhid.c
-@@ -206,7 +206,7 @@ u8 adb_to_linux_keycodes[128] = {
- };
-
- struct adbhid {
-- struct input_dev input;
-+ struct input_dev *input;
- int id;
- int default_id;
- int original_handler_id;
-@@ -291,10 +291,10 @@ adbhid_input_keycode(int id, int keycode
-
- switch (keycode) {
- case ADB_KEY_CAPSLOCK: /* Generate down/up events for CapsLock everytime. */
-- input_regs(&ahid->input, regs);
-- input_report_key(&ahid->input, KEY_CAPSLOCK, 1);
-- input_report_key(&ahid->input, KEY_CAPSLOCK, 0);
-- input_sync(&ahid->input);
-+ input_regs(ahid->input, regs);
-+ input_report_key(ahid->input, KEY_CAPSLOCK, 1);
-+ input_report_key(ahid->input, KEY_CAPSLOCK, 0);
-+ input_sync(ahid->input);
- return;
- #ifdef CONFIG_PPC_PMAC
- case ADB_KEY_POWER_OLD: /* Power key on PBook 3400 needs remapping */
-@@ -347,10 +347,10 @@ adbhid_input_keycode(int id, int keycode
- }
-
- if (adbhid[id]->keycode[keycode]) {
-- input_regs(&adbhid[id]->input, regs);
-- input_report_key(&adbhid[id]->input,
-+ input_regs(adbhid[id]->input, regs);
-+ input_report_key(adbhid[id]->input,
- adbhid[id]->keycode[keycode], !up_flag);
-- input_sync(&adbhid[id]->input);
-+ input_sync(adbhid[id]->input);
- } else
- printk(KERN_INFO "Unhandled ADB key (scancode %#02x) %s.\n", keycode,
- up_flag ? "released" : "pressed");
-@@ -441,20 +441,20 @@ adbhid_mouse_input(unsigned char *data,
- break;
- }
-
-- input_regs(&adbhid[id]->input, regs);
-+ input_regs(adbhid[id]->input, regs);
-
-- input_report_key(&adbhid[id]->input, BTN_LEFT, !((data[1] >> 7) & 1));
-- input_report_key(&adbhid[id]->input, BTN_MIDDLE, !((data[2] >> 7) & 1));
-+ input_report_key(adbhid[id]->input, BTN_LEFT, !((data[1] >> 7) & 1));
-+ input_report_key(adbhid[id]->input, BTN_MIDDLE, !((data[2] >> 7) & 1));
-
- if (nb >= 4 && adbhid[id]->mouse_kind != ADBMOUSE_TRACKPAD)
-- input_report_key(&adbhid[id]->input, BTN_RIGHT, !((data[3] >> 7) & 1));
-+ input_report_key(adbhid[id]->input, BTN_RIGHT, !((data[3] >> 7) & 1));
-
-- input_report_rel(&adbhid[id]->input, REL_X,
-+ input_report_rel(adbhid[id]->input, REL_X,
- ((data[2]&0x7f) < 64 ? (data[2]&0x7f) : (data[2]&0x7f)-128 ));
-- input_report_rel(&adbhid[id]->input, REL_Y,
-+ input_report_rel(adbhid[id]->input, REL_Y,
- ((data[1]&0x7f) < 64 ? (data[1]&0x7f) : (data[1]&0x7f)-128 ));
-
-- input_sync(&adbhid[id]->input);
-+ input_sync(adbhid[id]->input);
- }
-
- static void
-@@ -467,7 +467,7 @@ adbhid_buttons_input(unsigned char *data
- return;
- }
-
-- input_regs(&adbhid[id]->input, regs);
-+ input_regs(adbhid[id]->input, regs);
-
- switch (adbhid[id]->original_handler_id) {
- default:
-@@ -477,19 +477,19 @@ adbhid_buttons_input(unsigned char *data
-
- switch (data[1] & 0x0f) {
- case 0x0: /* microphone */
-- input_report_key(&adbhid[id]->input, KEY_SOUND, down);
-+ input_report_key(adbhid[id]->input, KEY_SOUND, down);
- break;
-
- case 0x1: /* mute */
-- input_report_key(&adbhid[id]->input, KEY_MUTE, down);
-+ input_report_key(adbhid[id]->input, KEY_MUTE, down);
- break;
-
- case 0x2: /* volume decrease */
-- input_report_key(&adbhid[id]->input, KEY_VOLUMEDOWN, down);
-+ input_report_key(adbhid[id]->input, KEY_VOLUMEDOWN, down);
- break;
-
- case 0x3: /* volume increase */
-- input_report_key(&adbhid[id]->input, KEY_VOLUMEUP, down);
-+ input_report_key(adbhid[id]->input, KEY_VOLUMEUP, down);
- break;
-
- default:
-@@ -513,19 +513,19 @@ adbhid_buttons_input(unsigned char *data
-
- switch (data[1] & 0x0f) {
- case 0x8: /* mute */
-- input_report_key(&adbhid[id]->input, KEY_MUTE, down);
-+ input_report_key(adbhid[id]->input, KEY_MUTE, down);
- break;
-
- case 0x7: /* volume decrease */
-- input_report_key(&adbhid[id]->input, KEY_VOLUMEDOWN, down);
-+ input_report_key(adbhid[id]->input, KEY_VOLUMEDOWN, down);
- break;
-
- case 0x6: /* volume increase */
-- input_report_key(&adbhid[id]->input, KEY_VOLUMEUP, down);
-+ input_report_key(adbhid[id]->input, KEY_VOLUMEUP, down);
- break;
-
- case 0xb: /* eject */
-- input_report_key(&adbhid[id]->input, KEY_EJECTCD, down);
-+ input_report_key(adbhid[id]->input, KEY_EJECTCD, down);
- break;
-
- case 0xa: /* brightness decrease */
-@@ -539,7 +539,7 @@ adbhid_buttons_input(unsigned char *data
- }
- }
- #endif /* CONFIG_PMAC_BACKLIGHT */
-- input_report_key(&adbhid[id]->input, KEY_BRIGHTNESSDOWN, down);
-+ input_report_key(adbhid[id]->input, KEY_BRIGHTNESSDOWN, down);
- break;
-
- case 0x9: /* brightness increase */
-@@ -553,19 +553,19 @@ adbhid_buttons_input(unsigned char *data
- }
- }
- #endif /* CONFIG_PMAC_BACKLIGHT */
-- input_report_key(&adbhid[id]->input, KEY_BRIGHTNESSUP, down);
-+ input_report_key(adbhid[id]->input, KEY_BRIGHTNESSUP, down);
- break;
-
- case 0xc: /* videomode switch */
-- input_report_key(&adbhid[id]->input, KEY_SWITCHVIDEOMODE, down);
-+ input_report_key(adbhid[id]->input, KEY_SWITCHVIDEOMODE, down);
- break;
-
- case 0xd: /* keyboard illumination toggle */
-- input_report_key(&adbhid[id]->input, KEY_KBDILLUMTOGGLE, down);
-+ input_report_key(adbhid[id]->input, KEY_KBDILLUMTOGGLE, down);
- break;
-
- case 0xe: /* keyboard illumination decrease */
-- input_report_key(&adbhid[id]->input, KEY_KBDILLUMDOWN, down);
-+ input_report_key(adbhid[id]->input, KEY_KBDILLUMDOWN, down);
- break;
-
- case 0xf:
-@@ -573,7 +573,7 @@ adbhid_buttons_input(unsigned char *data
- case 0x8f:
- case 0x0f:
- /* keyboard illumination increase */
-- input_report_key(&adbhid[id]->input, KEY_KBDILLUMUP, down);
-+ input_report_key(adbhid[id]->input, KEY_KBDILLUMUP, down);
- break;
-
- case 0x7f:
-@@ -596,7 +596,7 @@ adbhid_buttons_input(unsigned char *data
- break;
- }
-
-- input_sync(&adbhid[id]->input);
-+ input_sync(adbhid[id]->input);
- }
-
- static struct adb_request led_request;
-@@ -683,7 +683,7 @@ adb_message_handler(struct notifier_bloc
- int i;
- for (i = 1; i < 16; i++) {
- if (adbhid[i])
-- del_timer_sync(&adbhid[i]->input.timer);
-+ del_timer_sync(&adbhid[i]->input->timer);
- }
- }
-
-@@ -699,153 +699,163 @@ adb_message_handler(struct notifier_bloc
- return NOTIFY_DONE;
- }
-
--static void
-+static int
- adbhid_input_register(int id, int default_id, int original_handler_id,
- int current_handler_id, int mouse_kind)
- {
-+ struct adbhid *hid;
-+ struct input_dev *input_dev;
-+ int err;
- int i;
-
- if (adbhid[id]) {
- printk(KERN_ERR "Trying to reregister ADB HID on ID %d\n", id);
-- return;
-+ return -EEXIST;
- }
-
-- if (!(adbhid[id] = kmalloc(sizeof(struct adbhid), GFP_KERNEL)))
-- return;
--
-- memset(adbhid[id], 0, sizeof(struct adbhid));
-- sprintf(adbhid[id]->phys, "adb%d:%d.%02x/input", id, default_id, original_handler_id);
-+ adbhid[id] = hid = kzalloc(sizeof(struct adbhid), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!hid || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail;
-
-- init_input_dev(&adbhid[id]->input);
-+ }
-
-- adbhid[id]->id = default_id;
-- adbhid[id]->original_handler_id = original_handler_id;
-- adbhid[id]->current_handler_id = current_handler_id;
-- adbhid[id]->mouse_kind = mouse_kind;
-- adbhid[id]->flags = 0;
-- adbhid[id]->input.private = adbhid[id];
-- adbhid[id]->input.name = adbhid[id]->name;
-- adbhid[id]->input.phys = adbhid[id]->phys;
-- adbhid[id]->input.id.bustype = BUS_ADB;
-- adbhid[id]->input.id.vendor = 0x0001;
-- adbhid[id]->input.id.product = (id << 12) | (default_id << 8) | original_handler_id;
-- adbhid[id]->input.id.version = 0x0100;
-+ sprintf(hid->phys, "adb%d:%d.%02x/input", id, default_id, original_handler_id);
-+
-+ hid->id = default_id;
-+ hid->original_handler_id = original_handler_id;
-+ hid->current_handler_id = current_handler_id;
-+ hid->mouse_kind = mouse_kind;
-+ hid->flags = 0;
-+ input_dev->private = hid;
-+ input_dev->name = hid->name;
-+ input_dev->phys = hid->phys;
-+ input_dev->id.bustype = BUS_ADB;
-+ input_dev->id.vendor = 0x0001;
-+ input_dev->id.product = (id << 12) | (default_id << 8) | original_handler_id;
-+ input_dev->id.version = 0x0100;
-
- switch (default_id) {
- case ADB_KEYBOARD:
-- if (!(adbhid[id]->keycode = kmalloc(sizeof(adb_to_linux_keycodes), GFP_KERNEL))) {
-- kfree(adbhid[id]);
-- return;
-+ hid->keycode = kmalloc(sizeof(adb_to_linux_keycodes), GFP_KERNEL);
-+ if (!hid->keycode) {
-+ err = -ENOMEM;
-+ goto fail;
- }
-
-- sprintf(adbhid[id]->name, "ADB keyboard");
-+ sprintf(hid->name, "ADB keyboard");
-
-- memcpy(adbhid[id]->keycode, adb_to_linux_keycodes, sizeof(adb_to_linux_keycodes));
-+ memcpy(hid->keycode, adb_to_linux_keycodes, sizeof(adb_to_linux_keycodes));
-
- printk(KERN_INFO "Detected ADB keyboard, type ");
- switch (original_handler_id) {
- default:
- printk("<unknown>.\n");
-- adbhid[id]->input.id.version = ADB_KEYBOARD_UNKNOWN;
-+ input_dev->id.version = ADB_KEYBOARD_UNKNOWN;
- break;
-
- case 0x01: case 0x02: case 0x03: case 0x06: case 0x08:
- case 0x0C: case 0x10: case 0x18: case 0x1B: case 0x1C:
- case 0xC0: case 0xC3: case 0xC6:
- printk("ANSI.\n");
-- adbhid[id]->input.id.version = ADB_KEYBOARD_ANSI;
-+ input_dev->id.version = ADB_KEYBOARD_ANSI;
- break;
-
- case 0x04: case 0x05: case 0x07: case 0x09: case 0x0D:
- case 0x11: case 0x14: case 0x19: case 0x1D: case 0xC1:
- case 0xC4: case 0xC7:
- printk("ISO, swapping keys.\n");
-- adbhid[id]->input.id.version = ADB_KEYBOARD_ISO;
-- i = adbhid[id]->keycode[10];
-- adbhid[id]->keycode[10] = adbhid[id]->keycode[50];
-- adbhid[id]->keycode[50] = i;
-+ input_dev->id.version = ADB_KEYBOARD_ISO;
-+ i = hid->keycode[10];
-+ hid->keycode[10] = hid->keycode[50];
-+ hid->keycode[50] = i;
- break;
-
- case 0x12: case 0x15: case 0x16: case 0x17: case 0x1A:
- case 0x1E: case 0xC2: case 0xC5: case 0xC8: case 0xC9:
- printk("JIS.\n");
-- adbhid[id]->input.id.version = ADB_KEYBOARD_JIS;
-+ input_dev->id.version = ADB_KEYBOARD_JIS;
- break;
- }
-
- for (i = 0; i < 128; i++)
-- if (adbhid[id]->keycode[i])
-- set_bit(adbhid[id]->keycode[i], adbhid[id]->input.keybit);
-+ if (hid->keycode[i])
-+ set_bit(hid->keycode[i], input_dev->keybit);
-
-- adbhid[id]->input.evbit[0] = BIT(EV_KEY) | BIT(EV_LED) | BIT(EV_REP);
-- adbhid[id]->input.ledbit[0] = BIT(LED_SCROLLL) | BIT(LED_CAPSL) | BIT(LED_NUML);
-- adbhid[id]->input.event = adbhid_kbd_event;
-- adbhid[id]->input.keycodemax = 127;
-- adbhid[id]->input.keycodesize = 1;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_LED) | BIT(EV_REP);
-+ input_dev->ledbit[0] = BIT(LED_SCROLLL) | BIT(LED_CAPSL) | BIT(LED_NUML);
-+ input_dev->event = adbhid_kbd_event;
-+ input_dev->keycodemax = 127;
-+ input_dev->keycodesize = 1;
- break;
-
- case ADB_MOUSE:
-- sprintf(adbhid[id]->name, "ADB mouse");
-+ sprintf(hid->name, "ADB mouse");
-
-- adbhid[id]->input.evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-- adbhid[id]->input.keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-- adbhid[id]->input.relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ input_dev->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ input_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
- break;
-
- case ADB_MISC:
- switch (original_handler_id) {
- case 0x02: /* Adjustable keyboard button device */
-- sprintf(adbhid[id]->name, "ADB adjustable keyboard buttons");
-- adbhid[id]->input.evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-- set_bit(KEY_SOUND, adbhid[id]->input.keybit);
-- set_bit(KEY_MUTE, adbhid[id]->input.keybit);
-- set_bit(KEY_VOLUMEUP, adbhid[id]->input.keybit);
-- set_bit(KEY_VOLUMEDOWN, adbhid[id]->input.keybit);
-+ sprintf(hid->name, "ADB adjustable keyboard buttons");
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ set_bit(KEY_SOUND, input_dev->keybit);
-+ set_bit(KEY_MUTE, input_dev->keybit);
-+ set_bit(KEY_VOLUMEUP, input_dev->keybit);
-+ set_bit(KEY_VOLUMEDOWN, input_dev->keybit);
- break;
- case 0x1f: /* Powerbook button device */
-- sprintf(adbhid[id]->name, "ADB Powerbook buttons");
-- adbhid[id]->input.evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-- set_bit(KEY_MUTE, adbhid[id]->input.keybit);
-- set_bit(KEY_VOLUMEUP, adbhid[id]->input.keybit);
-- set_bit(KEY_VOLUMEDOWN, adbhid[id]->input.keybit);
-- set_bit(KEY_BRIGHTNESSUP, adbhid[id]->input.keybit);
-- set_bit(KEY_BRIGHTNESSDOWN, adbhid[id]->input.keybit);
-- set_bit(KEY_EJECTCD, adbhid[id]->input.keybit);
-- set_bit(KEY_SWITCHVIDEOMODE, adbhid[id]->input.keybit);
-- set_bit(KEY_KBDILLUMTOGGLE, adbhid[id]->input.keybit);
-- set_bit(KEY_KBDILLUMDOWN, adbhid[id]->input.keybit);
-- set_bit(KEY_KBDILLUMUP, adbhid[id]->input.keybit);
-+ sprintf(hid->name, "ADB Powerbook buttons");
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ set_bit(KEY_MUTE, input_dev->keybit);
-+ set_bit(KEY_VOLUMEUP, input_dev->keybit);
-+ set_bit(KEY_VOLUMEDOWN, input_dev->keybit);
-+ set_bit(KEY_BRIGHTNESSUP, input_dev->keybit);
-+ set_bit(KEY_BRIGHTNESSDOWN, input_dev->keybit);
-+ set_bit(KEY_EJECTCD, input_dev->keybit);
-+ set_bit(KEY_SWITCHVIDEOMODE, input_dev->keybit);
-+ set_bit(KEY_KBDILLUMTOGGLE, input_dev->keybit);
-+ set_bit(KEY_KBDILLUMDOWN, input_dev->keybit);
-+ set_bit(KEY_KBDILLUMUP, input_dev->keybit);
- break;
- }
-- if (adbhid[id]->name[0])
-+ if (hid->name[0])
- break;
- /* else fall through */
-
- default:
- printk(KERN_INFO "Trying to register unknown ADB device to input layer.\n");
-- kfree(adbhid[id]);
-- return;
-+ err = -ENODEV;
-+ goto fail;
- }
-
-- adbhid[id]->input.keycode = adbhid[id]->keycode;
--
-- input_register_device(&adbhid[id]->input);
-+ input_dev->keycode = hid->keycode;
-
-- printk(KERN_INFO "input: %s on %s\n",
-- adbhid[id]->name, adbhid[id]->phys);
-+ input_register_device(input_dev);
-
- if (default_id == ADB_KEYBOARD) {
- /* HACK WARNING!! This should go away as soon there is an utility
- * to control that for event devices.
- */
-- adbhid[id]->input.rep[REP_DELAY] = 500; /* input layer default: 250 */
-- adbhid[id]->input.rep[REP_PERIOD] = 66; /* input layer default: 33 */
-+ input_dev->rep[REP_DELAY] = 500; /* input layer default: 250 */
-+ input_dev->rep[REP_PERIOD] = 66; /* input layer default: 33 */
- }
-+
-+ return 0;
-+
-+ fail: input_free_device(input_dev);
-+ kfree(hid);
-+ adbhid[id] = NULL;
-+ return err;
- }
-
- static void adbhid_input_unregister(int id)
- {
-- input_unregister_device(&adbhid[id]->input);
-+ input_unregister_device(adbhid[id]->input);
- if (adbhid[id]->keycode)
- kfree(adbhid[id]->keycode);
- kfree(adbhid[id]);
-@@ -858,7 +868,7 @@ adbhid_input_reregister(int id, int defa
- int cur_handler_id, int mk)
- {
- if (adbhid[id]) {
-- if (adbhid[id]->input.id.product !=
-+ if (adbhid[id]->input->id.product !=
- ((id << 12)|(default_id << 8)|org_handler_id)) {
- adbhid_input_unregister(id);
- adbhid_input_register(id, default_id, org_handler_id,
---- gregkh-2.6.orig/drivers/macintosh/mac_hid.c
-+++ gregkh-2.6/drivers/macintosh/mac_hid.c
-@@ -16,8 +16,8 @@
- #include <linux/module.h>
-
-
--static struct input_dev emumousebtn;
--static void emumousebtn_input_register(void);
-+static struct input_dev *emumousebtn;
-+static int emumousebtn_input_register(void);
- static int mouse_emulate_buttons = 0;
- static int mouse_button2_keycode = KEY_RIGHTCTRL; /* right control key */
- static int mouse_button3_keycode = KEY_RIGHTALT; /* right option key */
-@@ -90,10 +90,10 @@ int mac_hid_mouse_emulate_buttons(int ca
- && (keycode == mouse_button2_keycode
- || keycode == mouse_button3_keycode)) {
- if (mouse_emulate_buttons == 1) {
-- input_report_key(&emumousebtn,
-+ input_report_key(emumousebtn,
- keycode == mouse_button2_keycode ? BTN_MIDDLE : BTN_RIGHT,
- down);
-- input_sync(&emumousebtn);
-+ input_sync(emumousebtn);
- return 1;
- }
- mouse_last_keycode = down ? keycode : 0;
-@@ -105,30 +105,34 @@ int mac_hid_mouse_emulate_buttons(int ca
-
- EXPORT_SYMBOL(mac_hid_mouse_emulate_buttons);
-
--static void emumousebtn_input_register(void)
-+static int emumousebtn_input_register(void)
- {
-- emumousebtn.name = "Macintosh mouse button emulation";
-+ emumousebtn = input_allocate_device();
-+ if (!emumousebtn)
-+ return -ENOMEM;
-+
-+ emumousebtn->name = "Macintosh mouse button emulation";
-+ emumousebtn->id.bustype = BUS_ADB;
-+ emumousebtn->id.vendor = 0x0001;
-+ emumousebtn->id.product = 0x0001;
-+ emumousebtn->id.version = 0x0100;
-+
-+ emumousebtn->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ emumousebtn->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ emumousebtn->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-
-- init_input_dev(&emumousebtn);
-+ input_register_device(emumousebtn);
-
-- emumousebtn.evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-- emumousebtn.keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-- emumousebtn.relbit[0] = BIT(REL_X) | BIT(REL_Y);
--
-- emumousebtn.id.bustype = BUS_ADB;
-- emumousebtn.id.vendor = 0x0001;
-- emumousebtn.id.product = 0x0001;
-- emumousebtn.id.version = 0x0100;
--
-- input_register_device(&emumousebtn);
--
-- printk(KERN_INFO "input: Macintosh mouse button emulation\n");
-+ return 0;
- }
-
- int __init mac_hid_init(void)
- {
-+ int err;
-
-- emumousebtn_input_register();
-+ err = emumousebtn_input_register();
-+ if (err)
-+ return err;
-
- #if defined(CONFIG_SYSCTL)
- mac_hid_sysctl_header = register_sysctl_table(mac_hid_root_dir, 1);
diff --git a/driver/input-convert-to-dynamic-media.patch b/driver/input-convert-to-dynamic-media.patch
deleted file mode 100644
index 5228ccd43f17b..0000000000000
--- a/driver/input-convert-to-dynamic-media.patch
+++ /dev/null
@@ -1,1081 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:10 2005
-Message-Id: <20050915070305.039413000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:53 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 22/28] drivers/media: convert to dynamic input_dev allocation
-
-Input: convert drivers/media to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/media/common/ir-common.c | 1
- drivers/media/dvb/cinergyT2/cinergyT2.c | 108 ++++++++++++++++++----------
- drivers/media/dvb/dvb-usb/dvb-usb-remote.c | 50 +++++++-----
- drivers/media/dvb/dvb-usb/dvb-usb.h | 3
- drivers/media/dvb/ttpci/av7110_ir.c | 37 +++++----
- drivers/media/dvb/ttpci/budget-ci.c | 24 +++---
- drivers/media/dvb/ttusb-dec/ttusb_dec.c | 51 ++++++++-----
- drivers/media/video/bttvp.h | 2
- drivers/media/video/cx88/cx88-input.c | 58 ++++++++-------
- drivers/media/video/ir-kbd-gpio.c | 52 +++++++------
- drivers/media/video/ir-kbd-i2c.c | 33 ++++----
- drivers/media/video/saa7134/saa7134-input.c | 39 +++++-----
- drivers/media/video/saa7134/saa7134.h | 2
- 13 files changed, 268 insertions(+), 192 deletions(-)
-
---- gregkh-2.6.orig/drivers/media/video/ir-kbd-i2c.c
-+++ gregkh-2.6/drivers/media/video/ir-kbd-i2c.c
-@@ -121,10 +121,9 @@ static IR_KEYTAB_TYPE ir_codes_purpletv[
-
- };
-
--struct IR;
- struct IR {
- struct i2c_client c;
-- struct input_dev input;
-+ struct input_dev *input;
- struct ir_input_state ir;
-
- struct work_struct work;
-@@ -271,9 +270,9 @@ static void ir_key_poll(struct IR *ir)
- }
-
- if (0 == rc) {
-- ir_input_nokey(&ir->input,&ir->ir);
-+ ir_input_nokey(ir->input, &ir->ir);
- } else {
-- ir_input_keydown(&ir->input,&ir->ir, ir_key, ir_raw);
-+ ir_input_keydown(ir->input, &ir->ir, ir_key, ir_raw);
- }
- }
-
-@@ -318,11 +317,18 @@ static int ir_attach(struct i2c_adapter
- char *name;
- int ir_type;
- struct IR *ir;
-+ struct input_dev *input_dev;
-
-- if (NULL == (ir = kmalloc(sizeof(struct IR),GFP_KERNEL)))
-+ ir = kzalloc(sizeof(struct IR), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!ir || !input_dev) {
-+ kfree(ir);
-+ input_free_device(input_dev);
- return -ENOMEM;
-- memset(ir,0,sizeof(*ir));
-+ }
-+
- ir->c = client_template;
-+ ir->input = input_dev;
-
- i2c_set_clientdata(&ir->c, ir);
- ir->c.adapter = adap;
-@@ -375,13 +381,12 @@ static int ir_attach(struct i2c_adapter
- ir->c.dev.bus_id);
-
- /* init + register input device */
-- ir_input_init(&ir->input,&ir->ir,ir_type,ir_codes);
-- ir->input.id.bustype = BUS_I2C;
-- ir->input.name = ir->c.name;
-- ir->input.phys = ir->phys;
-- input_register_device(&ir->input);
-- printk(DEVNAME ": %s detected at %s [%s]\n",
-- ir->input.name,ir->input.phys,adap->name);
-+ ir_input_init(input_dev, &ir->ir, ir_type, ir_codes);
-+ input_dev->id.bustype = BUS_I2C;
-+ input_dev->name = ir->c.name;
-+ input_dev->phys = ir->phys;
-+
-+ input_register_device(ir->input);
-
- /* start polling via eventd */
- INIT_WORK(&ir->work, ir_work, ir);
-@@ -402,7 +407,7 @@ static int ir_detach(struct i2c_client *
- flush_scheduled_work();
-
- /* unregister devices */
-- input_unregister_device(&ir->input);
-+ input_unregister_device(ir->input);
- i2c_detach_client(&ir->c);
-
- /* free memory */
---- gregkh-2.6.orig/drivers/media/video/ir-kbd-gpio.c
-+++ gregkh-2.6/drivers/media/video/ir-kbd-gpio.c
-@@ -158,7 +158,7 @@ static IR_KEYTAB_TYPE ir_codes_apac_view
-
- struct IR {
- struct bttv_sub_device *sub;
-- struct input_dev input;
-+ struct input_dev *input;
- struct ir_input_state ir;
- char name[32];
- char phys[32];
-@@ -217,23 +217,23 @@ static void ir_handle_key(struct IR *ir)
- if (ir->mask_keydown) {
- /* bit set on keydown */
- if (gpio & ir->mask_keydown) {
-- ir_input_keydown(&ir->input,&ir->ir,data,data);
-+ ir_input_keydown(ir->input, &ir->ir, data, data);
- } else {
-- ir_input_nokey(&ir->input,&ir->ir);
-+ ir_input_nokey(ir->input, &ir->ir);
- }
-
- } else if (ir->mask_keyup) {
- /* bit cleared on keydown */
- if (0 == (gpio & ir->mask_keyup)) {
-- ir_input_keydown(&ir->input,&ir->ir,data,data);
-+ ir_input_keydown(ir->input, &ir->ir, data, data);
- } else {
-- ir_input_nokey(&ir->input,&ir->ir);
-+ ir_input_nokey(ir->input, &ir->ir);
- }
-
- } else {
- /* can't disturgissh keydown/up :-/ */
-- ir_input_keydown(&ir->input,&ir->ir,data,data);
-- ir_input_nokey(&ir->input,&ir->ir);
-+ ir_input_keydown(ir->input, &ir->ir, data, data);
-+ ir_input_nokey(ir->input, &ir->ir);
- }
- }
-
-@@ -268,13 +268,17 @@ static int ir_probe(struct device *dev)
- {
- struct bttv_sub_device *sub = to_bttv_sub_dev(dev);
- struct IR *ir;
-+ struct input_dev *input_dev;
- IR_KEYTAB_TYPE *ir_codes = NULL;
- int ir_type = IR_TYPE_OTHER;
-
-- ir = kmalloc(sizeof(*ir),GFP_KERNEL);
-- if (NULL == ir)
-+ ir = kzalloc(sizeof(*ir), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!ir || !input_dev) {
-+ kfree(ir);
-+ input_free_device(input_dev);
- return -ENOMEM;
-- memset(ir,0,sizeof(*ir));
-+ }
-
- /* detect & configure */
- switch (sub->core->type) {
-@@ -328,6 +332,7 @@ static int ir_probe(struct device *dev)
- }
- if (NULL == ir_codes) {
- kfree(ir);
-+ input_free_device(input_dev);
- return -ENODEV;
- }
-
-@@ -341,19 +346,19 @@ static int ir_probe(struct device *dev)
- snprintf(ir->phys, sizeof(ir->phys), "pci-%s/ir0",
- pci_name(sub->core->pci));
-
-- ir_input_init(&ir->input, &ir->ir, ir_type, ir_codes);
-- ir->input.name = ir->name;
-- ir->input.phys = ir->phys;
-- ir->input.id.bustype = BUS_PCI;
-- ir->input.id.version = 1;
-+ ir_input_init(input_dev, &ir->ir, ir_type, ir_codes);
-+ input_dev->name = ir->name;
-+ input_dev->phys = ir->phys;
-+ input_dev->id.bustype = BUS_PCI;
-+ input_dev->id.version = 1;
- if (sub->core->pci->subsystem_vendor) {
-- ir->input.id.vendor = sub->core->pci->subsystem_vendor;
-- ir->input.id.product = sub->core->pci->subsystem_device;
-+ input_dev->id.vendor = sub->core->pci->subsystem_vendor;
-+ input_dev->id.product = sub->core->pci->subsystem_device;
- } else {
-- ir->input.id.vendor = sub->core->pci->vendor;
-- ir->input.id.product = sub->core->pci->device;
-+ input_dev->id.vendor = sub->core->pci->vendor;
-+ input_dev->id.product = sub->core->pci->device;
- }
-- ir->input.dev = &sub->core->pci->dev;
-+ input_dev->cdev.dev = &sub->core->pci->dev;
-
- if (ir->polling) {
- INIT_WORK(&ir->work, ir_work, ir);
-@@ -364,9 +369,8 @@ static int ir_probe(struct device *dev)
- }
-
- /* all done */
-- dev_set_drvdata(dev,ir);
-- input_register_device(&ir->input);
-- printk(DEVNAME ": %s detected at %s\n",ir->input.name,ir->input.phys);
-+ dev_set_drvdata(dev, ir);
-+ input_register_device(ir->input);
-
- return 0;
- }
-@@ -380,7 +384,7 @@ static int ir_remove(struct device *dev)
- flush_scheduled_work();
- }
-
-- input_unregister_device(&ir->input);
-+ input_unregister_device(ir->input);
- kfree(ir);
- return 0;
- }
---- gregkh-2.6.orig/drivers/media/video/saa7134/saa7134.h
-+++ gregkh-2.6/drivers/media/video/saa7134/saa7134.h
-@@ -351,7 +351,7 @@ struct saa7134_oss {
-
- /* IR input */
- struct saa7134_ir {
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct ir_input_state ir;
- char name[32];
- char phys[32];
---- gregkh-2.6.orig/drivers/media/video/saa7134/saa7134-input.c
-+++ gregkh-2.6/drivers/media/video/saa7134/saa7134-input.c
-@@ -425,9 +425,9 @@ static int build_key(struct saa7134_dev
-
- if ((ir->mask_keydown && (0 != (gpio & ir->mask_keydown))) ||
- (ir->mask_keyup && (0 == (gpio & ir->mask_keyup)))) {
-- ir_input_keydown(&ir->dev,&ir->ir,data,data);
-+ ir_input_keydown(ir->dev, &ir->ir, data, data);
- } else {
-- ir_input_nokey(&ir->dev,&ir->ir);
-+ ir_input_nokey(ir->dev, &ir->ir);
- }
- return 0;
- }
-@@ -456,6 +456,7 @@ static void saa7134_input_timer(unsigned
- int saa7134_input_init1(struct saa7134_dev *dev)
- {
- struct saa7134_ir *ir;
-+ struct input_dev *input_dev;
- IR_KEYTAB_TYPE *ir_codes = NULL;
- u32 mask_keycode = 0;
- u32 mask_keydown = 0;
-@@ -535,10 +536,13 @@ int saa7134_input_init1(struct saa7134_d
- return -ENODEV;
- }
-
-- ir = kmalloc(sizeof(*ir),GFP_KERNEL);
-- if (NULL == ir)
-+ ir = kzalloc(sizeof(*ir), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!ir || !input_dev) {
-+ kfree(ir);
-+ input_free_device(input_dev);
- return -ENOMEM;
-- memset(ir,0,sizeof(*ir));
-+ }
-
- /* init hardware-specific stuff */
- ir->mask_keycode = mask_keycode;
-@@ -552,19 +556,19 @@ int saa7134_input_init1(struct saa7134_d
- snprintf(ir->phys, sizeof(ir->phys), "pci-%s/ir0",
- pci_name(dev->pci));
-
-- ir_input_init(&ir->dev, &ir->ir, ir_type, ir_codes);
-- ir->dev.name = ir->name;
-- ir->dev.phys = ir->phys;
-- ir->dev.id.bustype = BUS_PCI;
-- ir->dev.id.version = 1;
-+ ir_input_init(input_dev, &ir->ir, ir_type, ir_codes);
-+ input_dev->name = ir->name;
-+ input_dev->phys = ir->phys;
-+ input_dev->id.bustype = BUS_PCI;
-+ input_dev->id.version = 1;
- if (dev->pci->subsystem_vendor) {
-- ir->dev.id.vendor = dev->pci->subsystem_vendor;
-- ir->dev.id.product = dev->pci->subsystem_device;
-+ input_dev->id.vendor = dev->pci->subsystem_vendor;
-+ input_dev->id.product = dev->pci->subsystem_device;
- } else {
-- ir->dev.id.vendor = dev->pci->vendor;
-- ir->dev.id.product = dev->pci->device;
-+ input_dev->id.vendor = dev->pci->vendor;
-+ input_dev->id.product = dev->pci->device;
- }
-- ir->dev.dev = &dev->pci->dev;
-+ input_dev->cdev.dev = &dev->pci->dev;
-
- /* all done */
- dev->remote = ir;
-@@ -576,8 +580,7 @@ int saa7134_input_init1(struct saa7134_d
- add_timer(&ir->timer);
- }
-
-- input_register_device(&dev->remote->dev);
-- printk("%s: registered input device for IR\n",dev->name);
-+ input_register_device(ir->dev);
- return 0;
- }
-
-@@ -586,9 +589,9 @@ void saa7134_input_fini(struct saa7134_d
- if (NULL == dev->remote)
- return;
-
-- input_unregister_device(&dev->remote->dev);
- if (dev->remote->polling)
- del_timer_sync(&dev->remote->timer);
-+ input_unregister_device(dev->remote->dev);
- kfree(dev->remote);
- dev->remote = NULL;
- }
---- gregkh-2.6.orig/drivers/media/video/bttvp.h
-+++ gregkh-2.6/drivers/media/video/bttvp.h
-@@ -240,7 +240,7 @@ struct bttv_pll_info {
-
- /* for gpio-connected remote control */
- struct bttv_input {
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct ir_input_state ir;
- char name[32];
- char phys[32];
---- gregkh-2.6.orig/drivers/media/dvb/ttpci/budget-ci.c
-+++ gregkh-2.6/drivers/media/dvb/ttpci/budget-ci.c
-@@ -64,7 +64,7 @@
-
- struct budget_ci {
- struct budget budget;
-- struct input_dev input_dev;
-+ struct input_dev *input_dev;
- struct tasklet_struct msp430_irq_tasklet;
- struct tasklet_struct ciintf_irq_tasklet;
- int slot_status;
-@@ -145,7 +145,7 @@ static void msp430_ir_debounce(unsigned
- static void msp430_ir_interrupt(unsigned long data)
- {
- struct budget_ci *budget_ci = (struct budget_ci *) data;
-- struct input_dev *dev = &budget_ci->input_dev;
-+ struct input_dev *dev = budget_ci->input_dev;
- unsigned int code =
- ttpci_budget_debiread(&budget_ci->budget, DEBINOSWAP, DEBIADDR_IR, 2, 1, 0) >> 8;
-
-@@ -181,25 +181,27 @@ static void msp430_ir_interrupt(unsigned
- static int msp430_ir_init(struct budget_ci *budget_ci)
- {
- struct saa7146_dev *saa = budget_ci->budget.dev;
-+ struct input_dev *input_dev;
- int i;
-
-- memset(&budget_ci->input_dev, 0, sizeof(struct input_dev));
-+ budget_ci->input_dev = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-
- sprintf(budget_ci->ir_dev_name, "Budget-CI dvb ir receiver %s", saa->name);
-- budget_ci->input_dev.name = budget_ci->ir_dev_name;
-
-- set_bit(EV_KEY, budget_ci->input_dev.evbit);
-+ input_dev->name = budget_ci->ir_dev_name;
-
-- for (i = 0; i < sizeof(key_map) / sizeof(*key_map); i++)
-+ set_bit(EV_KEY, input_dev->evbit);
-+ for (i = 0; i < ARRAY_SIZE(key_map); i++)
- if (key_map[i])
-- set_bit(key_map[i], budget_ci->input_dev.keybit);
-+ set_bit(key_map[i], input_dev->keybit);
-
-- input_register_device(&budget_ci->input_dev);
-+ input_register_device(budget_ci->input_dev);
-
-- budget_ci->input_dev.timer.function = msp430_ir_debounce;
-+ input_dev->timer.function = msp430_ir_debounce;
-
- saa7146_write(saa, IER, saa7146_read(saa, IER) | MASK_06);
--
- saa7146_setgpio(saa, 3, SAA7146_GPIO_IRQHI);
-
- return 0;
-@@ -208,7 +210,7 @@ static int msp430_ir_init(struct budget_
- static void msp430_ir_deinit(struct budget_ci *budget_ci)
- {
- struct saa7146_dev *saa = budget_ci->budget.dev;
-- struct input_dev *dev = &budget_ci->input_dev;
-+ struct input_dev *dev = budget_ci->input_dev;
-
- saa7146_write(saa, IER, saa7146_read(saa, IER) & ~MASK_06);
- saa7146_setgpio(saa, 3, SAA7146_GPIO_INPUT);
---- gregkh-2.6.orig/drivers/media/dvb/cinergyT2/cinergyT2.c
-+++ gregkh-2.6/drivers/media/dvb/cinergyT2/cinergyT2.c
-@@ -137,7 +137,8 @@ struct cinergyt2 {
- struct urb *stream_urb [STREAM_URB_COUNT];
-
- #ifdef ENABLE_RC
-- struct input_dev rc_input_dev;
-+ struct input_dev *rc_input_dev;
-+ char phys[64];
- struct work_struct rc_query_work;
- int rc_input_event;
- u32 rc_last_code;
-@@ -683,6 +684,7 @@ static struct dvb_device cinergyt2_fe_te
- };
-
- #ifdef ENABLE_RC
-+
- static void cinergyt2_query_rc (void *data)
- {
- struct cinergyt2 *cinergyt2 = data;
-@@ -703,7 +705,7 @@ static void cinergyt2_query_rc (void *da
- /* stop key repeat */
- if (cinergyt2->rc_input_event != KEY_MAX) {
- dprintk(1, "rc_input_event=%d Up\n", cinergyt2->rc_input_event);
-- input_report_key(&cinergyt2->rc_input_dev,
-+ input_report_key(cinergyt2->rc_input_dev,
- cinergyt2->rc_input_event, 0);
- cinergyt2->rc_input_event = KEY_MAX;
- }
-@@ -722,7 +724,7 @@ static void cinergyt2_query_rc (void *da
- /* keyrepeat bit -> just repeat last rc_input_event */
- } else {
- cinergyt2->rc_input_event = KEY_MAX;
-- for (i = 0; i < sizeof(rc_keys) / sizeof(rc_keys[0]); i += 3) {
-+ for (i = 0; i < ARRAY_SIZE(rc_keys); i += 3) {
- if (rc_keys[i + 0] == rc_events[n].type &&
- rc_keys[i + 1] == le32_to_cpu(rc_events[n].value)) {
- cinergyt2->rc_input_event = rc_keys[i + 2];
-@@ -736,11 +738,11 @@ static void cinergyt2_query_rc (void *da
- cinergyt2->rc_last_code != ~0) {
- /* emit a key-up so the double event is recognized */
- dprintk(1, "rc_input_event=%d UP\n", cinergyt2->rc_input_event);
-- input_report_key(&cinergyt2->rc_input_dev,
-+ input_report_key(cinergyt2->rc_input_dev,
- cinergyt2->rc_input_event, 0);
- }
- dprintk(1, "rc_input_event=%d\n", cinergyt2->rc_input_event);
-- input_report_key(&cinergyt2->rc_input_dev,
-+ input_report_key(cinergyt2->rc_input_dev,
- cinergyt2->rc_input_event, 1);
- cinergyt2->rc_last_code = rc_events[n].value;
- }
-@@ -752,7 +754,59 @@ out:
-
- up(&cinergyt2->sem);
- }
--#endif
-+
-+static int cinergyt2_register_rc(struct cinergyt2 *cinergyt2)
-+{
-+ struct input_dev *input_dev;
-+ int i;
-+
-+ cinergyt2->rc_input_dev = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-+
-+ usb_make_path(cinergyt2->udev, cinergyt2->phys, sizeof(cinergyt2->phys));
-+ strlcat(cinergyt2->phys, "/input0", sizeof(cinergyt2->phys));
-+ cinergyt2->rc_input_event = KEY_MAX;
-+ cinergyt2->rc_last_code = ~0;
-+ INIT_WORK(&cinergyt2->rc_query_work, cinergyt2_query_rc, cinergyt2);
-+
-+ input_dev->name = DRIVER_NAME " remote control";
-+ input_dev->phys = cinergyt2->phys;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-+ for (i = 0; ARRAY_SIZE(rc_keys); i += 3)
-+ set_bit(rc_keys[i + 2], input_dev->keybit);
-+ input_dev->keycodesize = 0;
-+ input_dev->keycodemax = 0;
-+
-+ input_register_device(cinergyt2->rc_input_dev);
-+ schedule_delayed_work(&cinergyt2->rc_query_work, HZ/2);
-+}
-+
-+static void cinergyt2_unregister_rc(struct cinergyt2 *cinergyt2)
-+{
-+ cancel_delayed_work(&cinergyt2->rc_query_work);
-+ flush_scheduled_work();
-+ input_unregister_device(cinergyt2->rc_input_dev);
-+}
-+
-+static inline void cinergyt2_suspend_rc(struct cinergyt2 *cinergyt2)
-+{
-+ cancel_delayed_work(&cinergyt2->rc_query_work);
-+}
-+
-+static inline void cinergyt2_resume_rc(struct cinergyt2 *cinergyt2)
-+{
-+ schedule_delayed_work(&cinergyt2->rc_query_work, HZ/2);
-+}
-+
-+#else
-+
-+static inline int cinergyt2_register_rc(struct cinergyt2 *cinergyt2) { return 0; }
-+static inline void cinergyt2_unregister_rc(struct cinergyt2 *cinergyt2) { }
-+static inline void cinergyt2_suspend_rc(struct cinergyt2 *cinergyt2) { }
-+static inline void cinergyt2_resume_rc(struct cinergyt2 *cinergyt2) { }
-+
-+#endif /* ENABLE_RC */
-
- static void cinergyt2_query (void *data)
- {
-@@ -789,9 +843,6 @@ static int cinergyt2_probe (struct usb_i
- {
- struct cinergyt2 *cinergyt2;
- int err;
--#ifdef ENABLE_RC
-- int i;
--#endif
-
- if (!(cinergyt2 = kmalloc (sizeof(struct cinergyt2), GFP_KERNEL))) {
- dprintk(1, "out of memory?!?\n");
-@@ -846,30 +897,17 @@ static int cinergyt2_probe (struct usb_i
- &cinergyt2_fe_template, cinergyt2,
- DVB_DEVICE_FRONTEND);
-
--#ifdef ENABLE_RC
-- cinergyt2->rc_input_dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
-- cinergyt2->rc_input_dev.keycodesize = 0;
-- cinergyt2->rc_input_dev.keycodemax = 0;
-- cinergyt2->rc_input_dev.name = DRIVER_NAME " remote control";
--
-- for (i = 0; i < sizeof(rc_keys) / sizeof(rc_keys[0]); i += 3)
-- set_bit(rc_keys[i + 2], cinergyt2->rc_input_dev.keybit);
--
-- input_register_device(&cinergyt2->rc_input_dev);
--
-- cinergyt2->rc_input_event = KEY_MAX;
-- cinergyt2->rc_last_code = ~0;
-+ err = cinergyt2_register_rc(cinergyt2);
-+ if (err)
-+ goto bailout;
-
-- INIT_WORK(&cinergyt2->rc_query_work, cinergyt2_query_rc, cinergyt2);
-- schedule_delayed_work(&cinergyt2->rc_query_work, HZ/2);
--#endif
- return 0;
-
- bailout:
- dvb_dmxdev_release(&cinergyt2->dmxdev);
- dvb_dmx_release(&cinergyt2->demux);
-- dvb_unregister_adapter (&cinergyt2->adapter);
-- cinergyt2_free_stream_urbs (cinergyt2);
-+ dvb_unregister_adapter(&cinergyt2->adapter);
-+ cinergyt2_free_stream_urbs(cinergyt2);
- kfree(cinergyt2);
- return -ENOMEM;
- }
-@@ -881,11 +919,7 @@ static void cinergyt2_disconnect (struct
- if (down_interruptible(&cinergyt2->sem))
- return;
-
--#ifdef ENABLE_RC
-- cancel_delayed_work(&cinergyt2->rc_query_work);
-- flush_scheduled_work();
-- input_unregister_device(&cinergyt2->rc_input_dev);
--#endif
-+ cinergyt2_unregister_rc(cinergyt2);
-
- cinergyt2->demux.dmx.close(&cinergyt2->demux.dmx);
- dvb_net_release(&cinergyt2->dvbnet);
-@@ -908,9 +942,8 @@ static int cinergyt2_suspend (struct usb
-
- if (state.event > PM_EVENT_ON) {
- struct cinergyt2 *cinergyt2 = usb_get_intfdata (intf);
--#ifdef ENABLE_RC
-- cancel_delayed_work(&cinergyt2->rc_query_work);
--#endif
-+
-+ cinergyt2_suspend_rc(cinergyt2);
- cancel_delayed_work(&cinergyt2->query_work);
- if (cinergyt2->streaming)
- cinergyt2_stop_stream_xfer(cinergyt2);
-@@ -938,9 +971,8 @@ static int cinergyt2_resume (struct usb_
- schedule_delayed_work(&cinergyt2->query_work, HZ/2);
- }
-
--#ifdef ENABLE_RC
-- schedule_delayed_work(&cinergyt2->rc_query_work, HZ/2);
--#endif
-+ cinergyt2_resume_rc(cinergyt2);
-+
- up(&cinergyt2->sem);
- return 0;
- }
---- gregkh-2.6.orig/drivers/media/common/ir-common.c
-+++ gregkh-2.6/drivers/media/common/ir-common.c
-@@ -252,7 +252,6 @@ void ir_input_init(struct input_dev *dev
- if (ir_codes)
- memcpy(ir->ir_codes, ir_codes, sizeof(ir->ir_codes));
-
-- init_input_dev(dev);
- dev->keycode = ir->ir_codes;
- dev->keycodesize = sizeof(IR_KEYTAB_TYPE);
- dev->keycodemax = IR_KEYTAB_SIZE;
---- gregkh-2.6.orig/drivers/media/dvb/dvb-usb/dvb-usb-remote.c
-+++ gregkh-2.6/drivers/media/dvb/dvb-usb/dvb-usb-remote.c
-@@ -39,9 +39,9 @@ static void dvb_usb_read_remote_control(
- d->last_event = event;
- case REMOTE_KEY_REPEAT:
- deb_rc("key repeated\n");
-- input_event(&d->rc_input_dev, EV_KEY, d->last_event, 1);
-- input_event(&d->rc_input_dev, EV_KEY, d->last_event, 0);
-- input_sync(&d->rc_input_dev);
-+ input_event(d->rc_input_dev, EV_KEY, event, 1);
-+ input_event(d->rc_input_dev, EV_KEY, d->last_event, 0);
-+ input_sync(d->rc_input_dev);
- break;
- default:
- break;
-@@ -53,8 +53,8 @@ static void dvb_usb_read_remote_control(
- deb_rc("NO KEY PRESSED\n");
- if (d->last_state != REMOTE_NO_KEY_PRESSED) {
- deb_rc("releasing event %d\n",d->last_event);
-- input_event(&d->rc_input_dev, EV_KEY, d->last_event, 0);
-- input_sync(&d->rc_input_dev);
-+ input_event(d->rc_input_dev, EV_KEY, d->last_event, 0);
-+ input_sync(d->rc_input_dev);
- }
- d->last_state = REMOTE_NO_KEY_PRESSED;
- d->last_event = 0;
-@@ -63,8 +63,8 @@ static void dvb_usb_read_remote_control(
- deb_rc("KEY PRESSED\n");
- deb_rc("pressing event %d\n",event);
-
-- input_event(&d->rc_input_dev, EV_KEY, event, 1);
-- input_sync(&d->rc_input_dev);
-+ input_event(d->rc_input_dev, EV_KEY, event, 1);
-+ input_sync(d->rc_input_dev);
-
- d->last_event = event;
- d->last_state = REMOTE_KEY_PRESSED;
-@@ -73,8 +73,8 @@ static void dvb_usb_read_remote_control(
- deb_rc("KEY_REPEAT\n");
- if (d->last_state != REMOTE_NO_KEY_PRESSED) {
- deb_rc("repeating event %d\n",d->last_event);
-- input_event(&d->rc_input_dev, EV_KEY, d->last_event, 2);
-- input_sync(&d->rc_input_dev);
-+ input_event(d->rc_input_dev, EV_KEY, d->last_event, 2);
-+ input_sync(d->rc_input_dev);
- d->last_state = REMOTE_KEY_REPEAT;
- }
- default:
-@@ -89,24 +89,30 @@ schedule:
- int dvb_usb_remote_init(struct dvb_usb_device *d)
- {
- int i;
-+
- if (d->props.rc_key_map == NULL ||
- d->props.rc_query == NULL ||
- dvb_usb_disable_rc_polling)
- return 0;
-
-- /* Initialise the remote-control structures.*/
-- init_input_dev(&d->rc_input_dev);
-+ usb_make_path(d->udev, d->rc_phys, sizeof(d->rc_phys));
-+ strlcpy(d->rc_phys, "/ir0", sizeof(d->rc_phys));
-
-- d->rc_input_dev.evbit[0] = BIT(EV_KEY);
-- d->rc_input_dev.keycodesize = sizeof(unsigned char);
-- d->rc_input_dev.keycodemax = KEY_MAX;
-- d->rc_input_dev.name = "IR-receiver inside an USB DVB receiver";
-+ d->rc_input_dev = input_allocate_device();
-+ if (!d->rc_input_dev)
-+ return -ENOMEM;
-+
-+ d->rc_input_dev->evbit[0] = BIT(EV_KEY);
-+ d->rc_input_dev->keycodesize = sizeof(unsigned char);
-+ d->rc_input_dev->keycodemax = KEY_MAX;
-+ d->rc_input_dev->name = "IR-receiver inside an USB DVB receiver";
-+ d->rc_input_dev->phys = d->rc_phys;
-
- /* set the bits for the keys */
-- deb_rc("key map size: %d\n",d->props.rc_key_map_size);
-+ deb_rc("key map size: %d\n", d->props.rc_key_map_size);
- for (i = 0; i < d->props.rc_key_map_size; i++) {
- deb_rc("setting bit for event %d item %d\n",d->props.rc_key_map[i].event, i);
-- set_bit(d->props.rc_key_map[i].event, d->rc_input_dev.keybit);
-+ set_bit(d->props.rc_key_map[i].event, d->rc_input_dev->keybit);
- }
-
- /* Start the remote-control polling. */
-@@ -114,14 +120,14 @@ int dvb_usb_remote_init(struct dvb_usb_d
- d->props.rc_interval = 100; /* default */
-
- /* setting these two values to non-zero, we have to manage key repeats */
-- d->rc_input_dev.rep[REP_PERIOD] = d->props.rc_interval;
-- d->rc_input_dev.rep[REP_DELAY] = d->props.rc_interval + 150;
-+ d->rc_input_dev->rep[REP_PERIOD] = d->props.rc_interval;
-+ d->rc_input_dev->rep[REP_DELAY] = d->props.rc_interval + 150;
-
-- input_register_device(&d->rc_input_dev);
-+ input_register_device(d->rc_input_dev);
-
- INIT_WORK(&d->rc_query_work, dvb_usb_read_remote_control, d);
-
-- info("schedule remote query interval to %d msecs.",d->props.rc_interval);
-+ info("schedule remote query interval to %d msecs.", d->props.rc_interval);
- schedule_delayed_work(&d->rc_query_work,msecs_to_jiffies(d->props.rc_interval));
-
- d->state |= DVB_USB_STATE_REMOTE;
-@@ -134,7 +140,7 @@ int dvb_usb_remote_exit(struct dvb_usb_d
- if (d->state & DVB_USB_STATE_REMOTE) {
- cancel_delayed_work(&d->rc_query_work);
- flush_scheduled_work();
-- input_unregister_device(&d->rc_input_dev);
-+ input_unregister_device(d->rc_input_dev);
- }
- d->state &= ~DVB_USB_STATE_REMOTE;
- return 0;
---- gregkh-2.6.orig/drivers/media/dvb/dvb-usb/dvb-usb.h
-+++ gregkh-2.6/drivers/media/dvb/dvb-usb/dvb-usb.h
-@@ -300,7 +300,8 @@ struct dvb_usb_device {
- int (*fe_init) (struct dvb_frontend *);
-
- /* remote control */
-- struct input_dev rc_input_dev;
-+ struct input_dev *rc_input_dev;
-+ char rc_phys[64];
- struct work_struct rc_query_work;
- u32 last_event;
- int last_state;
---- gregkh-2.6.orig/drivers/media/dvb/ttpci/av7110_ir.c
-+++ gregkh-2.6/drivers/media/dvb/ttpci/av7110_ir.c
-@@ -15,7 +15,7 @@
-
- static int av_cnt;
- static struct av7110 *av_list[4];
--static struct input_dev input_dev;
-+static struct input_dev *input_dev;
-
- static u16 key_map [256] = {
- KEY_0, KEY_1, KEY_2, KEY_3, KEY_4, KEY_5, KEY_6, KEY_7,
-@@ -43,10 +43,10 @@ static u16 key_map [256] = {
-
- static void av7110_emit_keyup(unsigned long data)
- {
-- if (!data || !test_bit(data, input_dev.key))
-+ if (!data || !test_bit(data, input_dev->key))
- return;
-
-- input_event(&input_dev, EV_KEY, data, !!0);
-+ input_event(input_dev, EV_KEY, data, !!0);
- }
-
-
-@@ -112,13 +112,13 @@ static void av7110_emit_key(unsigned lon
- if (timer_pending(&keyup_timer)) {
- del_timer(&keyup_timer);
- if (keyup_timer.data != keycode || new_toggle != old_toggle) {
-- input_event(&input_dev, EV_KEY, keyup_timer.data, !!0);
-- input_event(&input_dev, EV_KEY, keycode, !0);
-+ input_event(input_dev, EV_KEY, keyup_timer.data, !!0);
-+ input_event(input_dev, EV_KEY, keycode, !0);
- } else
-- input_event(&input_dev, EV_KEY, keycode, 2);
-+ input_event(input_dev, EV_KEY, keycode, 2);
-
- } else
-- input_event(&input_dev, EV_KEY, keycode, !0);
-+ input_event(input_dev, EV_KEY, keycode, !0);
-
- keyup_timer.expires = jiffies + UP_TIMEOUT;
- keyup_timer.data = keycode;
-@@ -132,13 +132,13 @@ static void input_register_keys(void)
- {
- int i;
-
-- memset(input_dev.keybit, 0, sizeof(input_dev.keybit));
-+ memset(input_dev->keybit, 0, sizeof(input_dev->keybit));
-
-- for (i = 0; i < sizeof(key_map) / sizeof(key_map[0]); i++) {
-+ for (i = 0; i < ARRAY_SIZE(key_map); i++) {
- if (key_map[i] > KEY_MAX)
- key_map[i] = 0;
- else if (key_map[i] > KEY_RESERVED)
-- set_bit(key_map[i], input_dev.keybit);
-+ set_bit(key_map[i], input_dev->keybit);
- }
- }
-
-@@ -216,12 +216,17 @@ int __init av7110_ir_init(struct av7110
- init_timer(&keyup_timer);
- keyup_timer.data = 0;
-
-- input_dev.name = "DVB on-card IR receiver";
-- set_bit(EV_KEY, input_dev.evbit);
-- set_bit(EV_REP, input_dev.evbit);
-+ input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-+
-+ input_dev->name = "DVB on-card IR receiver";
-+
-+ set_bit(EV_KEY, input_dev->evbit);
-+ set_bit(EV_REP, input_dev->evbit);
- input_register_keys();
-- input_register_device(&input_dev);
-- input_dev.timer.function = input_repeat_key;
-+ input_register_device(input_dev);
-+ input_dev->timer.function = input_repeat_key;
-
- e = create_proc_entry("av7110_ir", S_IFREG | S_IRUGO | S_IWUSR, NULL);
- if (e) {
-@@ -256,7 +261,7 @@ void __exit av7110_ir_exit(struct av7110
- if (av_cnt == 1) {
- del_timer_sync(&keyup_timer);
- remove_proc_entry("av7110_ir", NULL);
-- input_unregister_device(&input_dev);
-+ input_unregister_device(input_dev);
- }
-
- av_cnt--;
---- gregkh-2.6.orig/drivers/media/dvb/ttusb-dec/ttusb_dec.c
-+++ gregkh-2.6/drivers/media/dvb/ttusb-dec/ttusb_dec.c
-@@ -152,7 +152,8 @@ struct ttusb_dec {
- struct list_head filter_info_list;
- spinlock_t filter_info_list_lock;
-
-- struct input_dev rc_input_dev;
-+ struct input_dev *rc_input_dev;
-+ char rc_phys[64];
-
- int active; /* Loaded successfully */
- };
-@@ -235,9 +236,9 @@ static void ttusb_dec_handle_irq( struct
- * this should/could be added later ...
- * for now lets report each signal as a key down and up*/
- dprintk("%s:rc signal:%d\n", __FUNCTION__, buffer[4]);
-- input_report_key(&dec->rc_input_dev,rc_keys[buffer[4]-1],1);
-- input_report_key(&dec->rc_input_dev,rc_keys[buffer[4]-1],0);
-- input_sync(&dec->rc_input_dev);
-+ input_report_key(dec->rc_input_dev, rc_keys[buffer[4] - 1], 1);
-+ input_report_key(dec->rc_input_dev, rc_keys[buffer[4] - 1], 0);
-+ input_sync(dec->rc_input_dev);
- }
-
- exit: retval = usb_submit_urb(urb, GFP_ATOMIC);
-@@ -1181,29 +1182,38 @@ static void ttusb_dec_init_tasklet(struc
- (unsigned long)dec);
- }
-
--static void ttusb_init_rc( struct ttusb_dec *dec)
-+static int ttusb_init_rc(struct ttusb_dec *dec)
- {
-+ struct input_dev *input_dev;
- u8 b[] = { 0x00, 0x01 };
- int i;
-
-- init_input_dev(&dec->rc_input_dev);
-+ usb_make_path(dec->udev, dec->rc_phys, sizeof(dec->rc_phys));
-+ strlcpy(dec->rc_phys, "/input0", sizeof(dec->rc_phys));
-
-- dec->rc_input_dev.name = "ttusb_dec remote control";
-- dec->rc_input_dev.evbit[0] = BIT(EV_KEY);
-- dec->rc_input_dev.keycodesize = sizeof(u16);
-- dec->rc_input_dev.keycodemax = 0x1a;
-- dec->rc_input_dev.keycode = rc_keys;
-+ dec->rc_input_dev = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-+
-+ input_dev->name = "ttusb_dec remote control";
-+ input_dev->phys = dec->rc_phys;
-+ input_dev->evbit[0] = BIT(EV_KEY);
-+ input_dev->keycodesize = sizeof(u16);
-+ input_dev->keycodemax = 0x1a;
-+ input_dev->keycode = rc_keys;
-
-- for (i = 0; i < sizeof(rc_keys)/sizeof(rc_keys[0]); i++)
-- set_bit(rc_keys[i], dec->rc_input_dev.keybit);
-+ for (i = 0; i < ARRAY_SIZE(rc_keys); i++)
-+ set_bit(rc_keys[i], input_dev->keybit);
-
-- input_register_device(&dec->rc_input_dev);
-+ input_register_device(input_dev);
-
-- if(usb_submit_urb(dec->irq_urb,GFP_KERNEL)) {
-+ if (usb_submit_urb(dec->irq_urb, GFP_KERNEL))
- printk("%s: usb_submit_urb failed\n",__FUNCTION__);
-- }
-+
- /* enable irq pipe */
- ttusb_dec_send_command(dec,0xb0,sizeof(b),b,NULL,NULL);
-+
-+ return 0;
- }
-
- static void ttusb_dec_init_v_pes(struct ttusb_dec *dec)
-@@ -1513,7 +1523,7 @@ static void ttusb_dec_exit_rc(struct ttu
- * As the irq is submitted after the interface is changed,
- * this is the best method i figured out.
- * Any others?*/
-- if(dec->interface == TTUSB_DEC_INTERFACE_IN)
-+ if (dec->interface == TTUSB_DEC_INTERFACE_IN)
- usb_kill_urb(dec->irq_urb);
-
- usb_free_urb(dec->irq_urb);
-@@ -1521,7 +1531,10 @@ static void ttusb_dec_exit_rc(struct ttu
- usb_buffer_free(dec->udev,IRQ_PACKET_SIZE,
- dec->irq_buffer, dec->irq_dma_handle);
-
-- input_unregister_device(&dec->rc_input_dev);
-+ if (dec->rc_input_dev) {
-+ input_unregister_device(dec->rc_input_dev);
-+ dec->rc_input_dev = NULL;
-+ }
- }
-
-
-@@ -1659,7 +1672,7 @@ static int ttusb_dec_probe(struct usb_in
-
- ttusb_dec_set_interface(dec, TTUSB_DEC_INTERFACE_IN);
-
-- if(enable_rc)
-+ if (enable_rc)
- ttusb_init_rc(dec);
-
- return 0;
---- gregkh-2.6.orig/drivers/media/video/cx88/cx88-input.c
-+++ gregkh-2.6/drivers/media/video/cx88/cx88-input.c
-@@ -260,7 +260,7 @@ static IR_KEYTAB_TYPE ir_codes_cinergy_1
-
- struct cx88_IR {
- struct cx88_core *core;
-- struct input_dev input;
-+ struct input_dev *input;
- struct ir_input_state ir;
- char name[32];
- char phys[32];
-@@ -315,23 +315,23 @@ static void cx88_ir_handle_key(struct cx
- if (ir->mask_keydown) {
- /* bit set on keydown */
- if (gpio & ir->mask_keydown) {
-- ir_input_keydown(&ir->input, &ir->ir, data, data);
-+ ir_input_keydown(ir->input, &ir->ir, data, data);
- } else {
-- ir_input_nokey(&ir->input, &ir->ir);
-+ ir_input_nokey(ir->input, &ir->ir);
- }
-
- } else if (ir->mask_keyup) {
- /* bit cleared on keydown */
- if (0 == (gpio & ir->mask_keyup)) {
-- ir_input_keydown(&ir->input, &ir->ir, data, data);
-+ ir_input_keydown(ir->input, &ir->ir, data, data);
- } else {
-- ir_input_nokey(&ir->input, &ir->ir);
-+ ir_input_nokey(ir->input, &ir->ir);
- }
-
- } else {
- /* can't distinguish keydown/up :-/ */
-- ir_input_keydown(&ir->input, &ir->ir, data, data);
-- ir_input_nokey(&ir->input, &ir->ir);
-+ ir_input_keydown(ir->input, &ir->ir, data, data);
-+ ir_input_nokey(ir->input, &ir->ir);
- }
- }
-
-@@ -357,13 +357,19 @@ static void cx88_ir_work(void *data)
- int cx88_ir_init(struct cx88_core *core, struct pci_dev *pci)
- {
- struct cx88_IR *ir;
-+ struct input_dev *input_dev;
- IR_KEYTAB_TYPE *ir_codes = NULL;
- int ir_type = IR_TYPE_OTHER;
-
-- ir = kmalloc(sizeof(*ir), GFP_KERNEL);
-- if (NULL == ir)
-+ ir = kzalloc(sizeof(*ir), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!ir || !input_dev) {
-+ kfree(ir);
-+ input_free_device(input_dev);
- return -ENOMEM;
-- memset(ir, 0, sizeof(*ir));
-+ }
-+
-+ ir->input = input_dev;
-
- /* detect & configure */
- switch (core->board) {
-@@ -425,6 +431,7 @@ int cx88_ir_init(struct cx88_core *core,
-
- if (NULL == ir_codes) {
- kfree(ir);
-+ input_free_device(input_dev);
- return -ENODEV;
- }
-
-@@ -433,19 +440,19 @@ int cx88_ir_init(struct cx88_core *core,
- cx88_boards[core->board].name);
- snprintf(ir->phys, sizeof(ir->phys), "pci-%s/ir0", pci_name(pci));
-
-- ir_input_init(&ir->input, &ir->ir, ir_type, ir_codes);
-- ir->input.name = ir->name;
-- ir->input.phys = ir->phys;
-- ir->input.id.bustype = BUS_PCI;
-- ir->input.id.version = 1;
-+ ir_input_init(input_dev, &ir->ir, ir_type, ir_codes);
-+ input_dev->name = ir->name;
-+ input_dev->phys = ir->phys;
-+ input_dev->id.bustype = BUS_PCI;
-+ input_dev->id.version = 1;
- if (pci->subsystem_vendor) {
-- ir->input.id.vendor = pci->subsystem_vendor;
-- ir->input.id.product = pci->subsystem_device;
-+ input_dev->id.vendor = pci->subsystem_vendor;
-+ input_dev->id.product = pci->subsystem_device;
- } else {
-- ir->input.id.vendor = pci->vendor;
-- ir->input.id.product = pci->device;
-+ input_dev->id.vendor = pci->vendor;
-+ input_dev->id.product = pci->device;
- }
-- ir->input.dev = &pci->dev;
-+ input_dev->cdev.dev = &pci->dev;
-
- /* record handles to ourself */
- ir->core = core;
-@@ -465,8 +472,7 @@ int cx88_ir_init(struct cx88_core *core,
- }
-
- /* all done */
-- input_register_device(&ir->input);
-- printk("%s: registered IR remote control\n", core->name);
-+ input_register_device(ir->input);
-
- return 0;
- }
-@@ -484,7 +490,7 @@ int cx88_ir_fini(struct cx88_core *core)
- flush_scheduled_work();
- }
-
-- input_unregister_device(&ir->input);
-+ input_unregister_device(ir->input);
- kfree(ir);
-
- /* done */
-@@ -515,7 +521,7 @@ void cx88_ir_irq(struct cx88_core *core)
- if (!ir->scount) {
- /* nothing to sample */
- if (ir->ir.keypressed && time_after(jiffies, ir->release))
-- ir_input_nokey(&ir->input, &ir->ir);
-+ ir_input_nokey(ir->input, &ir->ir);
- return;
- }
-
-@@ -557,7 +563,7 @@ void cx88_ir_irq(struct cx88_core *core)
-
- ir_dprintk("Key Code: %x\n", (ircode >> 16) & 0x7f);
-
-- ir_input_keydown(&ir->input, &ir->ir, (ircode >> 16) & 0x7f, (ircode >> 16) & 0xff);
-+ ir_input_keydown(ir->input, &ir->ir, (ircode >> 16) & 0x7f, (ircode >> 16) & 0xff);
- ir->release = jiffies + msecs_to_jiffies(120);
- break;
- case CX88_BOARD_HAUPPAUGE:
-@@ -566,7 +572,7 @@ void cx88_ir_irq(struct cx88_core *core)
- ir_dprintk("biphase decoded: %x\n", ircode);
- if ((ircode & 0xfffff000) != 0x3000)
- break;
-- ir_input_keydown(&ir->input, &ir->ir, ircode & 0x3f, ircode);
-+ ir_input_keydown(ir->input, &ir->ir, ircode & 0x3f, ircode);
- ir->release = jiffies + msecs_to_jiffies(120);
- break;
- }
diff --git a/driver/input-convert-to-dynamic-misc.patch b/driver/input-convert-to-dynamic-misc.patch
deleted file mode 100644
index 4dfba4dcc68b1..0000000000000
--- a/driver/input-convert-to-dynamic-misc.patch
+++ /dev/null
@@ -1,233 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:09 2005
-Message-Id: <20050915070304.621069000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:51 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 20/28] Input: convert driver/input/misc to dynamic input_dev allocation
-
-Input: convert driver/input/misc to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/misc/m68kspkr.c | 40 ++++++++++++++++++------------------
- drivers/input/misc/pcspkr.c | 34 +++++++++++++++---------------
- drivers/input/misc/sparcspkr.c | 45 ++++++++++++++++++++---------------------
- 3 files changed, 59 insertions(+), 60 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/misc/m68kspkr.c
-+++ gregkh-2.6/drivers/input/misc/m68kspkr.c
-@@ -24,9 +24,7 @@ MODULE_AUTHOR("Richard Zidlicky <rz@linu
- MODULE_DESCRIPTION("m68k beeper driver");
- MODULE_LICENSE("GPL");
-
--static char m68kspkr_name[] = "m68k beeper";
--static char m68kspkr_phys[] = "m68k/generic";
--static struct input_dev m68kspkr_dev;
-+static struct input_dev *m68kspkr_dev;
-
- static int m68kspkr_event(struct input_dev *dev, unsigned int type, unsigned int code, int value)
- {
-@@ -51,32 +49,34 @@ static int m68kspkr_event(struct input_d
-
- static int __init m68kspkr_init(void)
- {
-- if (!mach_beep){
-- printk("%s: no lowlevel beep support\n", m68kspkr_name);
-- return -1;
-+ if (!mach_beep) {
-+ printk(KERN_INFO "m68kspkr: no lowlevel beep support\n");
-+ return -ENODEV;
- }
-
-- m68kspkr_dev.evbit[0] = BIT(EV_SND);
-- m68kspkr_dev.sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-- m68kspkr_dev.event = m68kspkr_event;
--
-- m68kspkr_dev.name = m68kspkr_name;
-- m68kspkr_dev.phys = m68kspkr_phys;
-- m68kspkr_dev.id.bustype = BUS_HOST;
-- m68kspkr_dev.id.vendor = 0x001f;
-- m68kspkr_dev.id.product = 0x0001;
-- m68kspkr_dev.id.version = 0x0100;
--
-- input_register_device(&m68kspkr_dev);
-+ m68kspkr_dev = input_allocate_device();
-+ if (!m68kspkr_dev)
-+ return -ENOMEM;
-+
-+ m68kspkr_dev->name = "m68k beeper";
-+ m68kspkr_dev->phys = "m68k/generic";
-+ m68kspkr_dev->id.bustype = BUS_HOST;
-+ m68kspkr_dev->id.vendor = 0x001f;
-+ m68kspkr_dev->id.product = 0x0001;
-+ m68kspkr_dev->id.version = 0x0100;
-+
-+ m68kspkr_dev->evbit[0] = BIT(EV_SND);
-+ m68kspkr_dev->sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-+ m68kspkr_dev->event = m68kspkr_event;
-
-- printk(KERN_INFO "input: %s\n", m68kspkr_name);
-+ input_register_device(m68kspkr_dev);
-
- return 0;
- }
-
- static void __exit m68kspkr_exit(void)
- {
-- input_unregister_device(&m68kspkr_dev);
-+ input_unregister_device(m68kspkr_dev);
- }
-
- module_init(m68kspkr_init);
---- gregkh-2.6.orig/drivers/input/misc/pcspkr.c
-+++ gregkh-2.6/drivers/input/misc/pcspkr.c
-@@ -23,9 +23,7 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@u
- MODULE_DESCRIPTION("PC Speaker beeper driver");
- MODULE_LICENSE("GPL");
-
--static char pcspkr_name[] = "PC Speaker";
--static char pcspkr_phys[] = "isa0061/input0";
--static struct input_dev pcspkr_dev;
-+static struct input_dev *pcspkr_dev;
-
- static DEFINE_SPINLOCK(i8253_beep_lock);
-
-@@ -68,27 +66,29 @@ static int pcspkr_event(struct input_dev
-
- static int __init pcspkr_init(void)
- {
-- pcspkr_dev.evbit[0] = BIT(EV_SND);
-- pcspkr_dev.sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-- pcspkr_dev.event = pcspkr_event;
--
-- pcspkr_dev.name = pcspkr_name;
-- pcspkr_dev.phys = pcspkr_phys;
-- pcspkr_dev.id.bustype = BUS_ISA;
-- pcspkr_dev.id.vendor = 0x001f;
-- pcspkr_dev.id.product = 0x0001;
-- pcspkr_dev.id.version = 0x0100;
-+ pcspkr_dev = input_allocate_device();
-+ if (!pcspkr_dev)
-+ return -ENOMEM;
-+
-+ pcspkr_dev->name = "PC Speaker";
-+ pcspkr_dev->name = "isa0061/input0";
-+ pcspkr_dev->id.bustype = BUS_ISA;
-+ pcspkr_dev->id.vendor = 0x001f;
-+ pcspkr_dev->id.product = 0x0001;
-+ pcspkr_dev->id.version = 0x0100;
-+
-+ pcspkr_dev->evbit[0] = BIT(EV_SND);
-+ pcspkr_dev->sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-+ pcspkr_dev->event = pcspkr_event;
-
-- input_register_device(&pcspkr_dev);
--
-- printk(KERN_INFO "input: %s\n", pcspkr_name);
-+ input_register_device(pcspkr_dev);
-
- return 0;
- }
-
- static void __exit pcspkr_exit(void)
- {
-- input_unregister_device(&pcspkr_dev);
-+ input_unregister_device(pcspkr_dev);
- /* turn off the speaker */
- pcspkr_event(NULL, EV_SND, SND_BELL, 0);
- }
---- gregkh-2.6.orig/drivers/input/misc/sparcspkr.c
-+++ gregkh-2.6/drivers/input/misc/sparcspkr.c
-@@ -17,28 +17,24 @@
- #endif
-
- MODULE_AUTHOR("David S. Miller <davem@redhat.com>");
--MODULE_DESCRIPTION("PC Speaker beeper driver");
-+MODULE_DESCRIPTION("Sparc Speaker beeper driver");
- MODULE_LICENSE("GPL");
-
- static unsigned long beep_iobase;
--
--static char *sparcspkr_isa_name = "Sparc ISA Speaker";
--static char *sparcspkr_ebus_name = "Sparc EBUS Speaker";
--static char *sparcspkr_phys = "sparc/input0";
--static struct input_dev sparcspkr_dev;
-+static struct input_dev *sparcspkr_dev;
-
- DEFINE_SPINLOCK(beep_lock);
-
- static void __init init_sparcspkr_struct(void)
- {
-- sparcspkr_dev.evbit[0] = BIT(EV_SND);
-- sparcspkr_dev.sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-+ sparcspkr_dev->evbit[0] = BIT(EV_SND);
-+ sparcspkr_dev->sndbit[0] = BIT(SND_BELL) | BIT(SND_TONE);
-
-- sparcspkr_dev.phys = sparcspkr_phys;
-- sparcspkr_dev.id.bustype = BUS_ISA;
-- sparcspkr_dev.id.vendor = 0x001f;
-- sparcspkr_dev.id.product = 0x0001;
-- sparcspkr_dev.id.version = 0x0100;
-+ sparcspkr_dev->phys = "sparc/input0";
-+ sparcspkr_dev->id.bustype = BUS_ISA;
-+ sparcspkr_dev->id.vendor = 0x001f;
-+ sparcspkr_dev->id.product = 0x0001;
-+ sparcspkr_dev->id.version = 0x0100;
- }
-
- static int ebus_spkr_event(struct input_dev *dev, unsigned int type, unsigned int code, int value)
-@@ -84,14 +80,15 @@ static int __init init_ebus_beep(struct
- {
- beep_iobase = edev->resource[0].start;
-
-- init_sparcspkr_struct();
-+ sparcspkr_dev = input_allocate_device();
-+ if (!sparcspkr_dev)
-+ return -ENOMEM;
-
-- sparcspkr_dev.name = sparcspkr_ebus_name;
-- sparcspkr_dev.event = ebus_spkr_event;
-+ sparcspkr_dev->name = "Sparc EBUS Speaker";
-+ sparcspkr_dev->event = ebus_spkr_event;
-
-- input_register_device(&sparcspkr_dev);
-+ input_register_device(sparcspkr_dev);
-
-- printk(KERN_INFO "input: %s\n", sparcspkr_ebus_name);
- return 0;
- }
-
-@@ -137,15 +134,17 @@ static int __init init_isa_beep(struct s
- {
- beep_iobase = isa_dev->resource.start;
-
-+ sparcspkr_dev = input_allocate_device();
-+ if (!sparcspkr_dev)
-+ return -ENOMEM;
-+
- init_sparcspkr_struct();
-
-- sparcspkr_dev.name = sparcspkr_isa_name;
-- sparcspkr_dev.event = isa_spkr_event;
-- sparcspkr_dev.id.bustype = BUS_ISA;
-+ sparcspkr_dev->name = "Sparc ISA Speaker";
-+ sparcspkr_dev->event = isa_spkr_event;
-
- input_register_device(&sparcspkr_dev);
-
-- printk(KERN_INFO "input: %s\n", sparcspkr_isa_name);
- return 0;
- }
- #endif
-@@ -182,7 +181,7 @@ static int __init sparcspkr_init(void)
-
- static void __exit sparcspkr_exit(void)
- {
-- input_unregister_device(&sparcspkr_dev);
-+ input_unregister_device(sparcspkr_dev);
- }
-
- module_init(sparcspkr_init);
diff --git a/driver/input-convert-to-dynamic-mouse.patch b/driver/input-convert-to-dynamic-mouse.patch
deleted file mode 100644
index d899864200622..0000000000000
--- a/driver/input-convert-to-dynamic-mouse.patch
+++ /dev/null
@@ -1,1406 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:37 2005
-Message-Id: <20050915070303.511611000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:44 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 13/28] drivers/input/mouse: convert to dynamic input_dev allocation
-
-Input: convert drivers/input/mouse to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/mouse/alps.c | 67 +++++++++++++------------
- drivers/input/mouse/alps.h | 2
- drivers/input/mouse/amimouse.c | 51 +++++++++----------
- drivers/input/mouse/inport.c | 96 ++++++++++++++++++-----------------
- drivers/input/mouse/lifebook.c | 16 +++--
- drivers/input/mouse/logibm.c | 88 ++++++++++++++++----------------
- drivers/input/mouse/logips2pp.c | 20 ++++---
- drivers/input/mouse/maplemouse.c | 10 +--
- drivers/input/mouse/pc110pad.c | 70 ++++++++++++--------------
- drivers/input/mouse/psmouse-base.c | 99 +++++++++++++++++++------------------
- drivers/input/mouse/psmouse.h | 2
- drivers/input/mouse/rpcmouse.c | 43 +++++++---------
- drivers/input/mouse/sermouse.c | 84 ++++++++++++++-----------------
- drivers/input/mouse/synaptics.c | 6 +-
- drivers/input/mouse/vsxxxaa.c | 84 ++++++++++++++-----------------
- 15 files changed, 370 insertions(+), 368 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/mouse/amimouse.c
-+++ gregkh-2.6/drivers/input/mouse/amimouse.c
-@@ -34,10 +34,7 @@ MODULE_DESCRIPTION("Amiga mouse driver")
- MODULE_LICENSE("GPL");
-
- static int amimouse_lastx, amimouse_lasty;
--static struct input_dev amimouse_dev;
--
--static char *amimouse_name = "Amiga mouse";
--static char *amimouse_phys = "amimouse/input0";
-+static struct input_dev *amimouse_dev;
-
- static irqreturn_t amimouse_interrupt(int irq, void *dummy, struct pt_regs *fp)
- {
-@@ -62,16 +59,16 @@ static irqreturn_t amimouse_interrupt(in
-
- potgor = custom.potgor;
-
-- input_regs(&amimouse_dev, fp);
-+ input_regs(amimouse_dev, fp);
-
-- input_report_rel(&amimouse_dev, REL_X, dx);
-- input_report_rel(&amimouse_dev, REL_Y, dy);
-+ input_report_rel(amimouse_dev, REL_X, dx);
-+ input_report_rel(amimouse_dev, REL_Y, dy);
-
-- input_report_key(&amimouse_dev, BTN_LEFT, ciaa.pra & 0x40);
-- input_report_key(&amimouse_dev, BTN_MIDDLE, potgor & 0x0100);
-- input_report_key(&amimouse_dev, BTN_RIGHT, potgor & 0x0400);
-+ input_report_key(amimouse_dev, BTN_LEFT, ciaa.pra & 0x40);
-+ input_report_key(amimouse_dev, BTN_MIDDLE, potgor & 0x0100);
-+ input_report_key(amimouse_dev, BTN_RIGHT, potgor & 0x0400);
-
-- input_sync(&amimouse_dev);
-+ input_sync(amimouse_dev);
-
- return IRQ_HANDLED;
- }
-@@ -103,28 +100,30 @@ static int __init amimouse_init(void)
- if (!MACH_IS_AMIGA || !AMIGAHW_PRESENT(AMI_MOUSE))
- return -ENODEV;
-
-- amimouse_dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-- amimouse_dev.relbit[0] = BIT(REL_X) | BIT(REL_Y);
-- amimouse_dev.keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-- amimouse_dev.open = amimouse_open;
-- amimouse_dev.close = amimouse_close;
--
-- amimouse_dev.name = amimouse_name;
-- amimouse_dev.phys = amimouse_phys;
-- amimouse_dev.id.bustype = BUS_AMIGA;
-- amimouse_dev.id.vendor = 0x0001;
-- amimouse_dev.id.product = 0x0002;
-- amimouse_dev.id.version = 0x0100;
-+ if (!(amimouse_dev = input_allocate_device()))
-+ return -ENOMEM;
-+
-+ amimouse_dev->name = "Amiga mouse";
-+ amimouse_dev->phys = "amimouse/input0";
-+ amimouse_dev->id.bustype = BUS_AMIGA;
-+ amimouse_dev->id.vendor = 0x0001;
-+ amimouse_dev->id.product = 0x0002;
-+ amimouse_dev->id.version = 0x0100;
-+
-+ amimouse_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ amimouse_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+ amimouse_dev->keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ amimouse_dev->open = amimouse_open;
-+ amimouse_dev->close = amimouse_close;
-
-- input_register_device(&amimouse_dev);
-+ input_register_device(amimouse_dev);
-
-- printk(KERN_INFO "input: %s at joy0dat\n", amimouse_name);
- return 0;
- }
-
- static void __exit amimouse_exit(void)
- {
-- input_unregister_device(&amimouse_dev);
-+ input_unregister_device(amimouse_dev);
- }
-
- module_init(amimouse_init);
---- gregkh-2.6.orig/drivers/input/mouse/inport.c
-+++ gregkh-2.6/drivers/input/mouse/inport.c
-@@ -87,40 +87,7 @@ MODULE_PARM_DESC(irq, "IRQ number (5=def
-
- __obsolete_setup("inport_irq=");
-
--static irqreturn_t inport_interrupt(int irq, void *dev_id, struct pt_regs *regs);
--
--static int inport_open(struct input_dev *dev)
--{
-- if (request_irq(inport_irq, inport_interrupt, 0, "inport", NULL))
-- return -EBUSY;
-- outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
-- outb(INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT);
--
-- return 0;
--}
--
--static void inport_close(struct input_dev *dev)
--{
-- outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
-- outb(INPORT_MODE_BASE, INPORT_DATA_PORT);
-- free_irq(inport_irq, NULL);
--}
--
--static struct input_dev inport_dev = {
-- .evbit = { BIT(EV_KEY) | BIT(EV_REL) },
-- .keybit = { [LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT) },
-- .relbit = { BIT(REL_X) | BIT(REL_Y) },
-- .open = inport_open,
-- .close = inport_close,
-- .name = INPORT_NAME,
-- .phys = "isa023c/input0",
-- .id = {
-- .bustype = BUS_ISA,
-- .vendor = INPORT_VENDOR,
-- .product = 0x0001,
-- .version = 0x0100,
-- },
--};
-+static struct input_dev *inport_dev;
-
- static irqreturn_t inport_interrupt(int irq, void *dev_id, struct pt_regs *regs)
- {
-@@ -129,31 +96,48 @@ static irqreturn_t inport_interrupt(int
- outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
- outb(INPORT_MODE_HOLD | INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT);
-
-- input_regs(&inport_dev, regs);
-+ input_regs(inport_dev, regs);
-
- outb(INPORT_REG_X, INPORT_CONTROL_PORT);
-- input_report_rel(&inport_dev, REL_X, inb(INPORT_DATA_PORT));
-+ input_report_rel(inport_dev, REL_X, inb(INPORT_DATA_PORT));
-
- outb(INPORT_REG_Y, INPORT_CONTROL_PORT);
-- input_report_rel(&inport_dev, REL_Y, inb(INPORT_DATA_PORT));
-+ input_report_rel(inport_dev, REL_Y, inb(INPORT_DATA_PORT));
-
- outb(INPORT_REG_BTNS, INPORT_CONTROL_PORT);
- buttons = inb(INPORT_DATA_PORT);
-
-- input_report_key(&inport_dev, BTN_MIDDLE, buttons & 1);
-- input_report_key(&inport_dev, BTN_LEFT, buttons & 2);
-- input_report_key(&inport_dev, BTN_RIGHT, buttons & 4);
-+ input_report_key(inport_dev, BTN_MIDDLE, buttons & 1);
-+ input_report_key(inport_dev, BTN_LEFT, buttons & 2);
-+ input_report_key(inport_dev, BTN_RIGHT, buttons & 4);
-
- outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
- outb(INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT);
-
-- input_sync(&inport_dev);
-+ input_sync(inport_dev);
- return IRQ_HANDLED;
- }
-
-+static int inport_open(struct input_dev *dev)
-+{
-+ if (request_irq(inport_irq, inport_interrupt, 0, "inport", NULL))
-+ return -EBUSY;
-+ outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
-+ outb(INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT);
-+
-+ return 0;
-+}
-+
-+static void inport_close(struct input_dev *dev)
-+{
-+ outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
-+ outb(INPORT_MODE_BASE, INPORT_DATA_PORT);
-+ free_irq(inport_irq, NULL);
-+}
-+
- static int __init inport_init(void)
- {
-- unsigned char a,b,c;
-+ unsigned char a, b, c;
-
- if (!request_region(INPORT_BASE, INPORT_EXTENT, "inport")) {
- printk(KERN_ERR "inport.c: Can't allocate ports at %#x\n", INPORT_BASE);
-@@ -163,26 +147,44 @@ static int __init inport_init(void)
- a = inb(INPORT_SIGNATURE_PORT);
- b = inb(INPORT_SIGNATURE_PORT);
- c = inb(INPORT_SIGNATURE_PORT);
-- if (( a == b ) || ( a != c )) {
-+ if (a == b || a != c) {
- release_region(INPORT_BASE, INPORT_EXTENT);
- printk(KERN_ERR "inport.c: Didn't find InPort mouse at %#x\n", INPORT_BASE);
- return -ENODEV;
- }
-
-+ if (!(inport_dev = input_allocate_device())) {
-+ printk(KERN_ERR "inport.c: Not enough memory for input device\n");
-+ release_region(INPORT_BASE, INPORT_EXTENT);
-+ return -ENOMEM;
-+ }
-+
-+ inport_dev->name = INPORT_NAME;
-+ inport_dev->phys = "isa023c/input0";
-+ inport_dev->id.bustype = BUS_ISA;
-+ inport_dev->id.vendor = INPORT_VENDOR;
-+ inport_dev->id.product = 0x0001;
-+ inport_dev->id.version = 0x0100;
-+
-+ inport_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ inport_dev->keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ inport_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+
-+ inport_dev->open = inport_open;
-+ inport_dev->close = inport_close;
-+
- outb(INPORT_RESET, INPORT_CONTROL_PORT);
- outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
- outb(INPORT_MODE_BASE, INPORT_DATA_PORT);
-
-- input_register_device(&inport_dev);
--
-- printk(KERN_INFO "input: " INPORT_NAME " at %#x irq %d\n", INPORT_BASE, inport_irq);
-+ input_register_device(inport_dev);
-
- return 0;
- }
-
- static void __exit inport_exit(void)
- {
-- input_unregister_device(&inport_dev);
-+ input_unregister_device(inport_dev);
- release_region(INPORT_BASE, INPORT_EXTENT);
- }
-
---- gregkh-2.6.orig/drivers/input/mouse/logibm.c
-+++ gregkh-2.6/drivers/input/mouse/logibm.c
-@@ -77,39 +77,7 @@ MODULE_PARM_DESC(irq, "IRQ number (5=def
-
- __obsolete_setup("logibm_irq=");
-
--static irqreturn_t logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs);
--
--static int logibm_open(struct input_dev *dev)
--{
-- if (request_irq(logibm_irq, logibm_interrupt, 0, "logibm", NULL)) {
-- printk(KERN_ERR "logibm.c: Can't allocate irq %d\n", logibm_irq);
-- return -EBUSY;
-- }
-- outb(LOGIBM_ENABLE_IRQ, LOGIBM_CONTROL_PORT);
-- return 0;
--}
--
--static void logibm_close(struct input_dev *dev)
--{
-- outb(LOGIBM_DISABLE_IRQ, LOGIBM_CONTROL_PORT);
-- free_irq(logibm_irq, NULL);
--}
--
--static struct input_dev logibm_dev = {
-- .evbit = { BIT(EV_KEY) | BIT(EV_REL) },
-- .keybit = { [LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT) },
-- .relbit = { BIT(REL_X) | BIT(REL_Y) },
-- .open = logibm_open,
-- .close = logibm_close,
-- .name = "Logitech bus mouse",
-- .phys = "isa023c/input0",
-- .id = {
-- .bustype = BUS_ISA,
-- .vendor = 0x0003,
-- .product = 0x0001,
-- .version = 0x0100,
-- },
--};
-+static struct input_dev *logibm_dev;
-
- static irqreturn_t logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs)
- {
-@@ -127,18 +95,34 @@ static irqreturn_t logibm_interrupt(int
- dy |= (buttons & 0xf) << 4;
- buttons = ~buttons >> 5;
-
-- input_regs(&logibm_dev, regs);
-- input_report_rel(&logibm_dev, REL_X, dx);
-- input_report_rel(&logibm_dev, REL_Y, dy);
-- input_report_key(&logibm_dev, BTN_RIGHT, buttons & 1);
-- input_report_key(&logibm_dev, BTN_MIDDLE, buttons & 2);
-- input_report_key(&logibm_dev, BTN_LEFT, buttons & 4);
-- input_sync(&logibm_dev);
-+ input_regs(logibm_dev, regs);
-+ input_report_rel(logibm_dev, REL_X, dx);
-+ input_report_rel(logibm_dev, REL_Y, dy);
-+ input_report_key(logibm_dev, BTN_RIGHT, buttons & 1);
-+ input_report_key(logibm_dev, BTN_MIDDLE, buttons & 2);
-+ input_report_key(logibm_dev, BTN_LEFT, buttons & 4);
-+ input_sync(logibm_dev);
-
- outb(LOGIBM_ENABLE_IRQ, LOGIBM_CONTROL_PORT);
- return IRQ_HANDLED;
- }
-
-+static int logibm_open(struct input_dev *dev)
-+{
-+ if (request_irq(logibm_irq, logibm_interrupt, 0, "logibm", NULL)) {
-+ printk(KERN_ERR "logibm.c: Can't allocate irq %d\n", logibm_irq);
-+ return -EBUSY;
-+ }
-+ outb(LOGIBM_ENABLE_IRQ, LOGIBM_CONTROL_PORT);
-+ return 0;
-+}
-+
-+static void logibm_close(struct input_dev *dev)
-+{
-+ outb(LOGIBM_DISABLE_IRQ, LOGIBM_CONTROL_PORT);
-+ free_irq(logibm_irq, NULL);
-+}
-+
- static int __init logibm_init(void)
- {
- if (!request_region(LOGIBM_BASE, LOGIBM_EXTENT, "logibm")) {
-@@ -159,16 +143,34 @@ static int __init logibm_init(void)
- outb(LOGIBM_DEFAULT_MODE, LOGIBM_CONFIG_PORT);
- outb(LOGIBM_DISABLE_IRQ, LOGIBM_CONTROL_PORT);
-
-- input_register_device(&logibm_dev);
-+ if (!(logibm_dev = input_allocate_device())) {
-+ printk(KERN_ERR "logibm.c: Not enough memory for input device\n");
-+ release_region(LOGIBM_BASE, LOGIBM_EXTENT);
-+ return -ENOMEM;
-+ }
-+
-+ logibm_dev->name = "Logitech bus mouse";
-+ logibm_dev->phys = "isa023c/input0";
-+ logibm_dev->id.bustype = BUS_ISA;
-+ logibm_dev->id.vendor = 0x0003;
-+ logibm_dev->id.product = 0x0001;
-+ logibm_dev->id.version = 0x0100;
-+
-+ logibm_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ logibm_dev->keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ logibm_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+
-+ logibm_dev->open = logibm_open;
-+ logibm_dev->close = logibm_close;
-
-- printk(KERN_INFO "input: Logitech bus mouse at %#x irq %d\n", LOGIBM_BASE, logibm_irq);
-+ input_register_device(logibm_dev);
-
- return 0;
- }
-
- static void __exit logibm_exit(void)
- {
-- input_unregister_device(&logibm_dev);
-+ input_unregister_device(logibm_dev);
- release_region(LOGIBM_BASE, LOGIBM_EXTENT);
- }
-
---- gregkh-2.6.orig/drivers/input/mouse/maplemouse.c
-+++ gregkh-2.6/drivers/input/mouse/maplemouse.c
-@@ -41,13 +41,12 @@ static int dc_mouse_connect(struct maple
- unsigned long data = be32_to_cpu(dev->devinfo.function_data[0]);
- struct input_dev *input_dev;
-
-- if (!(input_dev = kmalloc(sizeof(struct input_dev), GFP_KERNEL)))
-- return -1;
-+ dev->private_data = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return -ENOMEM;
-
- dev->private_data = input_dev;
-
-- memset(input_dev, 0, sizeof(struct dc_mouse));
-- init_input_dev(input_dev);
- input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
- input_dev->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
- input_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y) | BIT(REL_WHEEL);
-@@ -59,8 +58,6 @@ static int dc_mouse_connect(struct maple
-
- maple_getcond_callback(dev, dc_mouse_callback, 1, MAPLE_FUNC_MOUSE);
-
-- printk(KERN_INFO "input: mouse(0x%lx): %s\n", data, input_dev->name);
--
- return 0;
- }
-
-@@ -70,7 +67,6 @@ static void dc_mouse_disconnect(struct m
- struct input_dev *input_dev = dev->private_data;
-
- input_unregister_device(input_dev);
-- kfree(input_dev);
- }
-
-
---- gregkh-2.6.orig/drivers/input/mouse/pc110pad.c
-+++ gregkh-2.6/drivers/input/mouse/pc110pad.c
-@@ -53,13 +53,10 @@ MODULE_LICENSE("GPL");
- static int pc110pad_irq = 10;
- static int pc110pad_io = 0x15e0;
-
--static struct input_dev pc110pad_dev;
-+static struct input_dev *pc110pad_dev;
- static int pc110pad_data[3];
- static int pc110pad_count;
-
--static char *pc110pad_name = "IBM PC110 TouchPad";
--static char *pc110pad_phys = "isa15e0/input0";
--
- static irqreturn_t pc110pad_interrupt(int irq, void *ptr, struct pt_regs *regs)
- {
- int value = inb_p(pc110pad_io);
-@@ -74,14 +71,14 @@ static irqreturn_t pc110pad_interrupt(in
- if (pc110pad_count < 3)
- return IRQ_HANDLED;
-
-- input_regs(&pc110pad_dev, regs);
-- input_report_key(&pc110pad_dev, BTN_TOUCH,
-+ input_regs(pc110pad_dev, regs);
-+ input_report_key(pc110pad_dev, BTN_TOUCH,
- pc110pad_data[0] & 0x01);
-- input_report_abs(&pc110pad_dev, ABS_X,
-+ input_report_abs(pc110pad_dev, ABS_X,
- pc110pad_data[1] | ((pc110pad_data[0] << 3) & 0x80) | ((pc110pad_data[0] << 1) & 0x100));
-- input_report_abs(&pc110pad_dev, ABS_Y,
-+ input_report_abs(pc110pad_dev, ABS_Y,
- pc110pad_data[2] | ((pc110pad_data[0] << 4) & 0x80));
-- input_sync(&pc110pad_dev);
-+ input_sync(pc110pad_dev);
-
- pc110pad_count = 0;
- return IRQ_HANDLED;
-@@ -94,9 +91,9 @@ static void pc110pad_close(struct input_
-
- static int pc110pad_open(struct input_dev *dev)
- {
-- pc110pad_interrupt(0,NULL,NULL);
-- pc110pad_interrupt(0,NULL,NULL);
-- pc110pad_interrupt(0,NULL,NULL);
-+ pc110pad_interrupt(0, NULL, NULL);
-+ pc110pad_interrupt(0, NULL, NULL);
-+ pc110pad_interrupt(0, NULL, NULL);
- outb(PC110PAD_ON, pc110pad_io + 2);
- pc110pad_count = 0;
-
-@@ -127,45 +124,46 @@ static int __init pc110pad_init(void)
-
- outb(PC110PAD_OFF, pc110pad_io + 2);
-
-- if (request_irq(pc110pad_irq, pc110pad_interrupt, 0, "pc110pad", NULL))
-- {
-+ if (request_irq(pc110pad_irq, pc110pad_interrupt, 0, "pc110pad", NULL)) {
- release_region(pc110pad_io, 4);
- printk(KERN_ERR "pc110pad: Unable to get irq %d.\n", pc110pad_irq);
- return -EBUSY;
- }
-
-- pc110pad_dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- pc110pad_dev.absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-- pc110pad_dev.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
--
-- pc110pad_dev.absmax[ABS_X] = 0x1ff;
-- pc110pad_dev.absmax[ABS_Y] = 0x0ff;
--
-- pc110pad_dev.open = pc110pad_open;
-- pc110pad_dev.close = pc110pad_close;
--
-- pc110pad_dev.name = pc110pad_name;
-- pc110pad_dev.phys = pc110pad_phys;
-- pc110pad_dev.id.bustype = BUS_ISA;
-- pc110pad_dev.id.vendor = 0x0003;
-- pc110pad_dev.id.product = 0x0001;
-- pc110pad_dev.id.version = 0x0100;
-+ if (!(pc110pad_dev = input_allocate_device())) {
-+ free_irq(pc110pad_irq, NULL);
-+ release_region(pc110pad_io, 4);
-+ printk(KERN_ERR "pc110pad: Not enough memory.\n");
-+ return -ENOMEM;
-+ }
-+
-+ pc110pad_dev->name = "IBM PC110 TouchPad";
-+ pc110pad_dev->phys = "isa15e0/input0";
-+ pc110pad_dev->id.bustype = BUS_ISA;
-+ pc110pad_dev->id.vendor = 0x0003;
-+ pc110pad_dev->id.product = 0x0001;
-+ pc110pad_dev->id.version = 0x0100;
-+
-+ pc110pad_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ pc110pad_dev->absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-+ pc110pad_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-
-- input_register_device(&pc110pad_dev);
-+ pc110pad_dev->absmax[ABS_X] = 0x1ff;
-+ pc110pad_dev->absmax[ABS_Y] = 0x0ff;
-
-- printk(KERN_INFO "input: %s at %#x irq %d\n",
-- pc110pad_name, pc110pad_io, pc110pad_irq);
-+ pc110pad_dev->open = pc110pad_open;
-+ pc110pad_dev->close = pc110pad_close;
-+
-+ input_register_device(pc110pad_dev);
-
- return 0;
- }
-
- static void __exit pc110pad_exit(void)
- {
-- input_unregister_device(&pc110pad_dev);
--
- outb(PC110PAD_OFF, pc110pad_io + 2);
--
- free_irq(pc110pad_irq, NULL);
-+ input_unregister_device(pc110pad_dev);
- release_region(pc110pad_io, 4);
- }
-
---- gregkh-2.6.orig/drivers/input/mouse/rpcmouse.c
-+++ gregkh-2.6/drivers/input/mouse/rpcmouse.c
-@@ -34,20 +34,7 @@ MODULE_DESCRIPTION("Acorn RiscPC mouse d
- MODULE_LICENSE("GPL");
-
- static short rpcmouse_lastx, rpcmouse_lasty;
--
--static struct input_dev rpcmouse_dev = {
-- .evbit = { BIT(EV_KEY) | BIT(EV_REL) },
-- .keybit = { [LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT) },
-- .relbit = { BIT(REL_X) | BIT(REL_Y) },
-- .name = "Acorn RiscPC Mouse",
-- .phys = "rpcmouse/input0",
-- .id = {
-- .bustype = BUS_HOST,
-- .vendor = 0x0005,
-- .product = 0x0001,
-- .version = 0x0100,
-- },
--};
-+static struct input_dev *rpcmouse_dev;
-
- static irqreturn_t rpcmouse_irq(int irq, void *dev_id, struct pt_regs *regs)
- {
-@@ -78,29 +65,41 @@ static irqreturn_t rpcmouse_irq(int irq,
- return IRQ_HANDLED;
- }
-
-+
- static int __init rpcmouse_init(void)
- {
-- init_input_dev(&rpcmouse_dev);
-+ if (!(rpcmouse_dev = input_allocate_device()))
-+ return -ENOMEM;
-+
-+ rpcmouse_dev->name = "Acorn RiscPC Mouse";
-+ rpcmouse_dev->phys = "rpcmouse/input0";
-+ rpcmouse_dev->id.bustype = BUS_HOST;
-+ rpcmouse_dev->id.vendor = 0x0005;
-+ rpcmouse_dev->id.product = 0x0001;
-+ rpcmouse_dev->id.version = 0x0100;
-+
-+ rpcmouse_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ rpcmouse_dev->keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ rpcmouse_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-
- rpcmouse_lastx = (short) iomd_readl(IOMD_MOUSEX);
- rpcmouse_lasty = (short) iomd_readl(IOMD_MOUSEY);
-
-- if (request_irq(IRQ_VSYNCPULSE, rpcmouse_irq, SA_SHIRQ, "rpcmouse", &rpcmouse_dev)) {
-+ if (request_irq(IRQ_VSYNCPULSE, rpcmouse_irq, SA_SHIRQ, "rpcmouse", rpcmouse_dev)) {
- printk(KERN_ERR "rpcmouse: unable to allocate VSYNC interrupt\n");
-- return -1;
-+ input_free_device(rpcmouse_dev);
-+ return -EBUSY;
- }
-
-- input_register_device(&rpcmouse_dev);
--
-- printk(KERN_INFO "input: Acorn RiscPC mouse\n");
-+ input_register_device(rpcmouse_dev);
-
- return 0;
- }
-
- static void __exit rpcmouse_exit(void)
- {
-- input_unregister_device(&rpcmouse_dev);
-- free_irq(IRQ_VSYNCPULSE, &rpcmouse_dev);
-+ free_irq(IRQ_VSYNCPULSE, rpcmouse_dev);
-+ input_unregister_device(rpcmouse_dev);
- }
-
- module_init(rpcmouse_init);
---- gregkh-2.6.orig/drivers/input/mouse/sermouse.c
-+++ gregkh-2.6/drivers/input/mouse/sermouse.c
-@@ -48,7 +48,7 @@ static char *sermouse_protocols[] = { "N
- "Logitech MZ++ Mouse"};
-
- struct sermouse {
-- struct input_dev dev;
-+ struct input_dev *dev;
- signed char buf[8];
- unsigned char count;
- unsigned char type;
-@@ -64,7 +64,7 @@ struct sermouse {
-
- static void sermouse_process_msc(struct sermouse *sermouse, signed char data, struct pt_regs *regs)
- {
-- struct input_dev *dev = &sermouse->dev;
-+ struct input_dev *dev = sermouse->dev;
- signed char *buf = sermouse->buf;
-
- input_regs(dev, regs);
-@@ -107,7 +107,7 @@ static void sermouse_process_msc(struct
-
- static void sermouse_process_ms(struct sermouse *sermouse, signed char data, struct pt_regs *regs)
- {
-- struct input_dev *dev = &sermouse->dev;
-+ struct input_dev *dev = sermouse->dev;
- signed char *buf = sermouse->buf;
-
- if (data & 0x40) sermouse->count = 0;
-@@ -230,9 +230,9 @@ static void sermouse_disconnect(struct s
- {
- struct sermouse *sermouse = serio_get_drvdata(serio);
-
-- input_unregister_device(&sermouse->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(sermouse->dev);
- kfree(sermouse);
- }
-
-@@ -244,56 +244,52 @@ static void sermouse_disconnect(struct s
- static int sermouse_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct sermouse *sermouse;
-- unsigned char c;
-- int err;
--
-- if (!serio->id.proto || serio->id.proto > SERIO_MZPP)
-- return -ENODEV;
--
-- if (!(sermouse = kmalloc(sizeof(struct sermouse), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(sermouse, 0, sizeof(struct sermouse));
--
-- init_input_dev(&sermouse->dev);
-- sermouse->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-- sermouse->dev.keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT);
-- sermouse->dev.relbit[0] = BIT(REL_X) | BIT(REL_Y);
-- sermouse->dev.private = sermouse;
--
-- sermouse->type = serio->id.proto;
-- c = serio->id.extra;
--
-- if (c & 0x01) set_bit(BTN_MIDDLE, sermouse->dev.keybit);
-- if (c & 0x02) set_bit(BTN_SIDE, sermouse->dev.keybit);
-- if (c & 0x04) set_bit(BTN_EXTRA, sermouse->dev.keybit);
-- if (c & 0x10) set_bit(REL_WHEEL, sermouse->dev.relbit);
-- if (c & 0x20) set_bit(REL_HWHEEL, sermouse->dev.relbit);
-+ struct input_dev *input_dev;
-+ unsigned char c = serio->id.extra;
-+ int err = -ENOMEM;
-+
-+ sermouse = kzalloc(sizeof(struct sermouse), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!sermouse || !input_dev)
-+ goto fail;
-
-+ sermouse->dev = input_dev;
- sprintf(sermouse->phys, "%s/input0", serio->phys);
-+ sermouse->type = serio->id.proto;
-
-- sermouse->dev.name = sermouse_protocols[sermouse->type];
-- sermouse->dev.phys = sermouse->phys;
-- sermouse->dev.id.bustype = BUS_RS232;
-- sermouse->dev.id.vendor = sermouse->type;
-- sermouse->dev.id.product = c;
-- sermouse->dev.id.version = 0x0100;
-- sermouse->dev.dev = &serio->dev;
-+ input_dev->name = sermouse_protocols[sermouse->type];
-+ input_dev->phys = sermouse->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = sermouse->type;
-+ input_dev->id.product = c;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ input_dev->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT);
-+ input_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+ input_dev->private = sermouse;
-+
-+ if (c & 0x01) set_bit(BTN_MIDDLE, input_dev->keybit);
-+ if (c & 0x02) set_bit(BTN_SIDE, input_dev->keybit);
-+ if (c & 0x04) set_bit(BTN_EXTRA, input_dev->keybit);
-+ if (c & 0x10) set_bit(REL_WHEEL, input_dev->relbit);
-+ if (c & 0x20) set_bit(REL_HWHEEL, input_dev->relbit);
-
- serio_set_drvdata(serio, sermouse);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(sermouse);
-- return err;
-- }
--
-- input_register_device(&sermouse->dev);
-+ if (err)
-+ goto fail;
-
-- printk(KERN_INFO "input: %s on %s\n", sermouse_protocols[sermouse->type], serio->phys);
-+ input_register_device(sermouse->dev);
-
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(sermouse);
-+ return err;
- }
-
- static struct serio_device_id sermouse_serio_ids[] = {
---- gregkh-2.6.orig/drivers/input/mouse/vsxxxaa.c
-+++ gregkh-2.6/drivers/input/mouse/vsxxxaa.c
-@@ -112,7 +112,7 @@ MODULE_LICENSE ("GPL");
-
-
- struct vsxxxaa {
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- #define BUFLEN 15 /* At least 5 is needed for a full tablet packet */
- unsigned char buf[BUFLEN];
-@@ -211,7 +211,7 @@ vsxxxaa_smells_like_packet (struct vsxxx
- static void
- vsxxxaa_handle_REL_packet (struct vsxxxaa *mouse, struct pt_regs *regs)
- {
-- struct input_dev *dev = &mouse->dev;
-+ struct input_dev *dev = mouse->dev;
- unsigned char *buf = mouse->buf;
- int left, middle, right;
- int dx, dy;
-@@ -269,7 +269,7 @@ vsxxxaa_handle_REL_packet (struct vsxxxa
- static void
- vsxxxaa_handle_ABS_packet (struct vsxxxaa *mouse, struct pt_regs *regs)
- {
-- struct input_dev *dev = &mouse->dev;
-+ struct input_dev *dev = mouse->dev;
- unsigned char *buf = mouse->buf;
- int left, middle, right, touch;
- int x, y;
-@@ -323,7 +323,7 @@ vsxxxaa_handle_ABS_packet (struct vsxxxa
- static void
- vsxxxaa_handle_POR_packet (struct vsxxxaa *mouse, struct pt_regs *regs)
- {
-- struct input_dev *dev = &mouse->dev;
-+ struct input_dev *dev = mouse->dev;
- unsigned char *buf = mouse->buf;
- int left, middle, right;
- unsigned char error;
-@@ -483,9 +483,9 @@ vsxxxaa_disconnect (struct serio *serio)
- {
- struct vsxxxaa *mouse = serio_get_drvdata (serio);
-
-- input_unregister_device (&mouse->dev);
- serio_close (serio);
- serio_set_drvdata (serio, NULL);
-+ input_unregister_device (mouse->dev);
- kfree (mouse);
- }
-
-@@ -493,61 +493,57 @@ static int
- vsxxxaa_connect (struct serio *serio, struct serio_driver *drv)
- {
- struct vsxxxaa *mouse;
-- int err;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-
-- if (!(mouse = kmalloc (sizeof (struct vsxxxaa), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset (mouse, 0, sizeof (struct vsxxxaa));
--
-- init_input_dev (&mouse->dev);
-- set_bit (EV_KEY, mouse->dev.evbit); /* We have buttons */
-- set_bit (EV_REL, mouse->dev.evbit);
-- set_bit (EV_ABS, mouse->dev.evbit);
-- set_bit (BTN_LEFT, mouse->dev.keybit); /* We have 3 buttons */
-- set_bit (BTN_MIDDLE, mouse->dev.keybit);
-- set_bit (BTN_RIGHT, mouse->dev.keybit);
-- set_bit (BTN_TOUCH, mouse->dev.keybit); /* ...and Tablet */
-- set_bit (REL_X, mouse->dev.relbit);
-- set_bit (REL_Y, mouse->dev.relbit);
-- set_bit (ABS_X, mouse->dev.absbit);
-- set_bit (ABS_Y, mouse->dev.absbit);
--
-- mouse->dev.absmin[ABS_X] = 0;
-- mouse->dev.absmax[ABS_X] = 1023;
-- mouse->dev.absmin[ABS_Y] = 0;
-- mouse->dev.absmax[ABS_Y] = 1023;
--
-- mouse->dev.private = mouse;
-+ mouse = kzalloc (sizeof (struct vsxxxaa), GFP_KERNEL);
-+ input_dev = input_allocate_device ();
-+ if (!mouse || !input_dev)
-+ goto fail;
-
-+ mouse->dev = input_dev;
-+ mouse->serio = serio;
- sprintf (mouse->name, "DEC VSXXX-AA/-GA mouse or VSXXX-AB digitizer");
- sprintf (mouse->phys, "%s/input0", serio->phys);
-- mouse->dev.name = mouse->name;
-- mouse->dev.phys = mouse->phys;
-- mouse->dev.id.bustype = BUS_RS232;
-- mouse->dev.dev = &serio->dev;
-- mouse->serio = serio;
-+
-+ input_dev->name = mouse->name;
-+ input_dev->phys = mouse->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = mouse;
-+
-+ set_bit (EV_KEY, input_dev->evbit); /* We have buttons */
-+ set_bit (EV_REL, input_dev->evbit);
-+ set_bit (EV_ABS, input_dev->evbit);
-+ set_bit (BTN_LEFT, input_dev->keybit); /* We have 3 buttons */
-+ set_bit (BTN_MIDDLE, input_dev->keybit);
-+ set_bit (BTN_RIGHT, input_dev->keybit);
-+ set_bit (BTN_TOUCH, input_dev->keybit); /* ...and Tablet */
-+ set_bit (REL_X, input_dev->relbit);
-+ set_bit (REL_Y, input_dev->relbit);
-+ input_set_abs_params (input_dev, ABS_X, 0, 1023, 0, 0);
-+ input_set_abs_params (input_dev, ABS_Y, 0, 1023, 0, 0);
-
- serio_set_drvdata (serio, mouse);
-
- err = serio_open (serio, drv);
-- if (err) {
-- serio_set_drvdata (serio, NULL);
-- kfree (mouse);
-- return err;
-- }
-+ if (err)
-+ goto fail;
-
- /*
- * Request selftest. Standard packet format and differential
- * mode will be requested after the device ID'ed successfully.
- */
-- mouse->serio->write (mouse->serio, 'T'); /* Test */
--
-- input_register_device (&mouse->dev);
-+ serio->write (serio, 'T'); /* Test */
-
-- printk (KERN_INFO "input: %s on %s\n", mouse->name, mouse->phys);
-+ input_register_device (input_dev);
-
- return 0;
-+
-+ fail: serio_set_drvdata (serio, NULL);
-+ input_free_device (input_dev);
-+ kfree (mouse);
-+ return err;
- }
-
- static struct serio_device_id vsxxaa_serio_ids[] = {
---- gregkh-2.6.orig/drivers/input/mouse/psmouse-base.c
-+++ gregkh-2.6/drivers/input/mouse/psmouse-base.c
-@@ -114,7 +114,7 @@ struct psmouse_protocol {
-
- static psmouse_ret_t psmouse_process_byte(struct psmouse *psmouse, struct pt_regs *regs)
- {
-- struct input_dev *dev = &psmouse->dev;
-+ struct input_dev *dev = psmouse->dev;
- unsigned char *packet = psmouse->packet;
-
- if (psmouse->pktcnt < psmouse->pktsize)
-@@ -333,12 +333,11 @@ static int genius_detect(struct psmouse
- return -1;
-
- if (set_properties) {
-- set_bit(BTN_EXTRA, psmouse->dev.keybit);
-- set_bit(BTN_SIDE, psmouse->dev.keybit);
-- set_bit(REL_WHEEL, psmouse->dev.relbit);
-+ set_bit(BTN_EXTRA, psmouse->dev->keybit);
-+ set_bit(BTN_SIDE, psmouse->dev->keybit);
-+ set_bit(REL_WHEEL, psmouse->dev->relbit);
-
- psmouse->vendor = "Genius";
-- psmouse->name = "Wheel Mouse";
- psmouse->pktsize = 4;
- }
-
-@@ -365,8 +364,8 @@ static int intellimouse_detect(struct ps
- return -1;
-
- if (set_properties) {
-- set_bit(BTN_MIDDLE, psmouse->dev.keybit);
-- set_bit(REL_WHEEL, psmouse->dev.relbit);
-+ set_bit(BTN_MIDDLE, psmouse->dev->keybit);
-+ set_bit(REL_WHEEL, psmouse->dev->relbit);
-
- if (!psmouse->vendor) psmouse->vendor = "Generic";
- if (!psmouse->name) psmouse->name = "Wheel Mouse";
-@@ -398,10 +397,10 @@ static int im_explorer_detect(struct psm
- return -1;
-
- if (set_properties) {
-- set_bit(BTN_MIDDLE, psmouse->dev.keybit);
-- set_bit(REL_WHEEL, psmouse->dev.relbit);
-- set_bit(BTN_SIDE, psmouse->dev.keybit);
-- set_bit(BTN_EXTRA, psmouse->dev.keybit);
-+ set_bit(BTN_MIDDLE, psmouse->dev->keybit);
-+ set_bit(REL_WHEEL, psmouse->dev->relbit);
-+ set_bit(BTN_SIDE, psmouse->dev->keybit);
-+ set_bit(BTN_EXTRA, psmouse->dev->keybit);
-
- if (!psmouse->vendor) psmouse->vendor = "Generic";
- if (!psmouse->name) psmouse->name = "Explorer Mouse";
-@@ -433,7 +432,7 @@ static int thinking_detect(struct psmous
- return -1;
-
- if (set_properties) {
-- set_bit(BTN_EXTRA, psmouse->dev.keybit);
-+ set_bit(BTN_EXTRA, psmouse->dev->keybit);
-
- psmouse->vendor = "Kensington";
- psmouse->name = "ThinkingMouse";
-@@ -839,9 +838,9 @@ static void psmouse_disconnect(struct se
-
- psmouse_set_state(psmouse, PSMOUSE_IGNORE);
-
-- input_unregister_device(&psmouse->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_unregister_device(psmouse->dev);
- kfree(psmouse);
-
- if (parent)
-@@ -852,16 +851,14 @@ static void psmouse_disconnect(struct se
-
- static int psmouse_switch_protocol(struct psmouse *psmouse, struct psmouse_protocol *proto)
- {
-- memset(&psmouse->dev, 0, sizeof(struct input_dev));
-+ struct input_dev *input_dev = psmouse->dev;
-
-- init_input_dev(&psmouse->dev);
-+ input_dev->private = psmouse;
-+ input_dev->cdev.dev = &psmouse->ps2dev.serio->dev;
-
-- psmouse->dev.private = psmouse;
-- psmouse->dev.dev = &psmouse->ps2dev.serio->dev;
--
-- psmouse->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-- psmouse->dev.keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-- psmouse->dev.relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ input_dev->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ input_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-
- psmouse->set_rate = psmouse_set_rate;
- psmouse->set_resolution = psmouse_set_resolution;
-@@ -883,12 +880,12 @@ static int psmouse_switch_protocol(struc
- sprintf(psmouse->devname, "%s %s %s",
- psmouse_protocol_by_type(psmouse->type)->name, psmouse->vendor, psmouse->name);
-
-- psmouse->dev.name = psmouse->devname;
-- psmouse->dev.phys = psmouse->phys;
-- psmouse->dev.id.bustype = BUS_I8042;
-- psmouse->dev.id.vendor = 0x0002;
-- psmouse->dev.id.product = psmouse->type;
-- psmouse->dev.id.version = psmouse->model;
-+ input_dev->name = psmouse->devname;
-+ input_dev->phys = psmouse->phys;
-+ input_dev->id.bustype = BUS_I8042;
-+ input_dev->id.vendor = 0x0002;
-+ input_dev->id.product = psmouse->type;
-+ input_dev->id.version = psmouse->model;
-
- return 0;
- }
-@@ -900,7 +897,8 @@ static int psmouse_switch_protocol(struc
- static int psmouse_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct psmouse *psmouse, *parent = NULL;
-- int retval;
-+ struct input_dev *input_dev;
-+ int retval = -ENOMEM;
-
- down(&psmouse_sem);
-
-@@ -913,12 +911,13 @@ static int psmouse_connect(struct serio
- psmouse_deactivate(parent);
- }
-
-- if (!(psmouse = kzalloc(sizeof(struct psmouse), GFP_KERNEL))) {
-- retval = -ENOMEM;
-+ psmouse = kzalloc(sizeof(struct psmouse), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!psmouse || !input_dev)
- goto out;
-- }
-
- ps2_init(&psmouse->ps2dev, serio);
-+ psmouse->dev = input_dev;
- sprintf(psmouse->phys, "%s/input0", serio->phys);
-
- psmouse_set_state(psmouse, PSMOUSE_INITIALIZING);
-@@ -926,16 +925,11 @@ static int psmouse_connect(struct serio
- serio_set_drvdata(serio, psmouse);
-
- retval = serio_open(serio, drv);
-- if (retval) {
-- serio_set_drvdata(serio, NULL);
-- kfree(psmouse);
-+ if (retval)
- goto out;
-- }
-
- if (psmouse_probe(psmouse) < 0) {
- serio_close(serio);
-- serio_set_drvdata(serio, NULL);
-- kfree(psmouse);
- retval = -ENODEV;
- goto out;
- }
-@@ -947,13 +941,11 @@ static int psmouse_connect(struct serio
-
- psmouse_switch_protocol(psmouse, NULL);
-
-- input_register_device(&psmouse->dev);
-- printk(KERN_INFO "input: %s on %s\n", psmouse->devname, serio->phys);
--
- psmouse_set_state(psmouse, PSMOUSE_CMD_MODE);
--
- psmouse_initialize(psmouse);
-
-+ input_register_device(psmouse->dev);
-+
- if (parent && parent->pt_activate)
- parent->pt_activate(parent);
-
-@@ -964,6 +956,12 @@ static int psmouse_connect(struct serio
- retval = 0;
-
- out:
-+ if (retval) {
-+ serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(psmouse);
-+ }
-+
- /* If this is a pass-through port the parent needs to be re-activated */
- if (parent)
- psmouse_activate(parent);
-@@ -1161,6 +1159,7 @@ static ssize_t psmouse_attr_set_protocol
- {
- struct serio *serio = psmouse->ps2dev.serio;
- struct psmouse *parent = NULL;
-+ struct input_dev *new_dev;
- struct psmouse_protocol *proto;
- int retry = 0;
-
-@@ -1170,9 +1169,13 @@ static ssize_t psmouse_attr_set_protocol
- if (psmouse->type == proto->type)
- return count;
-
-+ if (!(new_dev = input_allocate_device()))
-+ return -ENOMEM;
-+
- while (serio->child) {
- if (++retry > 3) {
- printk(KERN_WARNING "psmouse: failed to destroy child port, protocol change aborted.\n");
-+ input_free_device(new_dev);
- return -EIO;
- }
-
-@@ -1182,11 +1185,15 @@ static ssize_t psmouse_attr_set_protocol
- serio_pin_driver_uninterruptible(serio);
- down(&psmouse_sem);
-
-- if (serio->drv != &psmouse_drv)
-+ if (serio->drv != &psmouse_drv) {
-+ input_free_device(new_dev);
- return -ENODEV;
-+ }
-
-- if (psmouse->type == proto->type)
-+ if (psmouse->type == proto->type) {
-+ input_free_device(new_dev);
- return count; /* switched by other thread */
-+ }
- }
-
- if (serio->parent && serio->id.type == SERIO_PS_PSTHRU) {
-@@ -1199,8 +1206,9 @@ static ssize_t psmouse_attr_set_protocol
- psmouse->disconnect(psmouse);
-
- psmouse_set_state(psmouse, PSMOUSE_IGNORE);
-- input_unregister_device(&psmouse->dev);
-+ input_unregister_device(psmouse->dev);
-
-+ psmouse->dev = new_dev;
- psmouse_set_state(psmouse, PSMOUSE_INITIALIZING);
-
- if (psmouse_switch_protocol(psmouse, proto) < 0) {
-@@ -1212,8 +1220,7 @@ static ssize_t psmouse_attr_set_protocol
- psmouse_initialize(psmouse);
- psmouse_set_state(psmouse, PSMOUSE_CMD_MODE);
-
-- input_register_device(&psmouse->dev);
-- printk(KERN_INFO "input: %s on %s\n", psmouse->devname, serio->phys);
-+ input_register_device(psmouse->dev);
-
- if (parent && parent->pt_activate)
- parent->pt_activate(parent);
---- gregkh-2.6.orig/drivers/input/mouse/psmouse.h
-+++ gregkh-2.6/drivers/input/mouse/psmouse.h
-@@ -36,7 +36,7 @@ typedef enum {
-
- struct psmouse {
- void *private;
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct ps2dev ps2dev;
- char *vendor;
- char *name;
---- gregkh-2.6.orig/drivers/input/mouse/synaptics.c
-+++ gregkh-2.6/drivers/input/mouse/synaptics.c
-@@ -342,7 +342,7 @@ static void synaptics_parse_hw_state(uns
- */
- static void synaptics_process_packet(struct psmouse *psmouse)
- {
-- struct input_dev *dev = &psmouse->dev;
-+ struct input_dev *dev = psmouse->dev;
- struct synaptics_data *priv = psmouse->private;
- struct synaptics_hw_state hw;
- int num_fingers;
-@@ -473,7 +473,7 @@ static unsigned char synaptics_detect_pk
-
- static psmouse_ret_t synaptics_process_byte(struct psmouse *psmouse, struct pt_regs *regs)
- {
-- struct input_dev *dev = &psmouse->dev;
-+ struct input_dev *dev = psmouse->dev;
- struct synaptics_data *priv = psmouse->private;
-
- input_regs(dev, regs);
-@@ -645,7 +645,7 @@ int synaptics_init(struct psmouse *psmou
- SYN_ID_MAJOR(priv->identity), SYN_ID_MINOR(priv->identity),
- priv->model_id, priv->capabilities, priv->ext_cap);
-
-- set_input_params(&psmouse->dev, priv);
-+ set_input_params(psmouse->dev, priv);
-
- psmouse->protocol_handler = synaptics_process_byte;
- psmouse->set_rate = synaptics_set_rate;
---- gregkh-2.6.orig/drivers/input/mouse/alps.c
-+++ gregkh-2.6/drivers/input/mouse/alps.c
-@@ -79,8 +79,8 @@ static void alps_process_packet(struct p
- {
- struct alps_data *priv = psmouse->private;
- unsigned char *packet = psmouse->packet;
-- struct input_dev *dev = &psmouse->dev;
-- struct input_dev *dev2 = &priv->dev2;
-+ struct input_dev *dev = psmouse->dev;
-+ struct input_dev *dev2 = priv->dev2;
- int x, y, z, ges, fin, left, right, middle;
- int back = 0, forward = 0;
-
-@@ -379,20 +379,24 @@ static int alps_reconnect(struct psmouse
- static void alps_disconnect(struct psmouse *psmouse)
- {
- struct alps_data *priv = psmouse->private;
-+
- psmouse_reset(psmouse);
-- input_unregister_device(&priv->dev2);
-+ input_unregister_device(priv->dev2);
- kfree(priv);
- }
-
- int alps_init(struct psmouse *psmouse)
- {
- struct alps_data *priv;
-+ struct input_dev *dev1 = psmouse->dev, *dev2;
- int version;
-
-- psmouse->private = priv = kmalloc(sizeof(struct alps_data), GFP_KERNEL);
-- if (!priv)
-+ psmouse->private = priv = kzalloc(sizeof(struct alps_data), GFP_KERNEL);
-+ dev2 = input_allocate_device();
-+ if (!priv || !dev2)
- goto init_fail;
-- memset(priv, 0, sizeof(struct alps_data));
-+
-+ priv->dev2 = dev2;
-
- if (!(priv->i = alps_get_model(psmouse, &version)))
- goto init_fail;
-@@ -411,41 +415,39 @@ int alps_init(struct psmouse *psmouse)
- if ((priv->i->flags & ALPS_PASS) && alps_passthrough_mode(psmouse, 0))
- goto init_fail;
-
-- psmouse->dev.evbit[LONG(EV_KEY)] |= BIT(EV_KEY);
-- psmouse->dev.keybit[LONG(BTN_TOUCH)] |= BIT(BTN_TOUCH);
-- psmouse->dev.keybit[LONG(BTN_TOOL_FINGER)] |= BIT(BTN_TOOL_FINGER);
-- psmouse->dev.keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
--
-- psmouse->dev.evbit[LONG(EV_ABS)] |= BIT(EV_ABS);
-- input_set_abs_params(&psmouse->dev, ABS_X, 0, 1023, 0, 0);
-- input_set_abs_params(&psmouse->dev, ABS_Y, 0, 767, 0, 0);
-- input_set_abs_params(&psmouse->dev, ABS_PRESSURE, 0, 127, 0, 0);
-+ dev1->evbit[LONG(EV_KEY)] |= BIT(EV_KEY);
-+ dev1->keybit[LONG(BTN_TOUCH)] |= BIT(BTN_TOUCH);
-+ dev1->keybit[LONG(BTN_TOOL_FINGER)] |= BIT(BTN_TOOL_FINGER);
-+ dev1->keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+
-+ dev1->evbit[LONG(EV_ABS)] |= BIT(EV_ABS);
-+ input_set_abs_params(dev1, ABS_X, 0, 1023, 0, 0);
-+ input_set_abs_params(dev1, ABS_Y, 0, 767, 0, 0);
-+ input_set_abs_params(dev1, ABS_PRESSURE, 0, 127, 0, 0);
-
- if (priv->i->flags & ALPS_WHEEL) {
-- psmouse->dev.evbit[LONG(EV_REL)] |= BIT(EV_REL);
-- psmouse->dev.relbit[LONG(REL_WHEEL)] |= BIT(REL_WHEEL);
-+ dev1->evbit[LONG(EV_REL)] |= BIT(EV_REL);
-+ dev1->relbit[LONG(REL_WHEEL)] |= BIT(REL_WHEEL);
- }
-
- if (priv->i->flags & (ALPS_FW_BK_1 | ALPS_FW_BK_2)) {
-- psmouse->dev.keybit[LONG(BTN_FORWARD)] |= BIT(BTN_FORWARD);
-- psmouse->dev.keybit[LONG(BTN_BACK)] |= BIT(BTN_BACK);
-+ dev1->keybit[LONG(BTN_FORWARD)] |= BIT(BTN_FORWARD);
-+ dev1->keybit[LONG(BTN_BACK)] |= BIT(BTN_BACK);
- }
-
- sprintf(priv->phys, "%s/input1", psmouse->ps2dev.serio->phys);
-- priv->dev2.phys = priv->phys;
-- priv->dev2.name = (priv->i->flags & ALPS_DUALPOINT) ? "DualPoint Stick" : "PS/2 Mouse";
-- priv->dev2.id.bustype = BUS_I8042;
-- priv->dev2.id.vendor = 0x0002;
-- priv->dev2.id.product = PSMOUSE_ALPS;
-- priv->dev2.id.version = 0x0000;
--
-- priv->dev2.evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-- priv->dev2.relbit[LONG(REL_X)] |= BIT(REL_X) | BIT(REL_Y);
-- priv->dev2.keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
--
-- input_register_device(&priv->dev2);
-+ dev2->phys = priv->phys;
-+ dev2->name = (priv->i->flags & ALPS_DUALPOINT) ? "DualPoint Stick" : "PS/2 Mouse";
-+ dev2->id.bustype = BUS_I8042;
-+ dev2->id.vendor = 0x0002;
-+ dev2->id.product = PSMOUSE_ALPS;
-+ dev2->id.version = 0x0000;
-+
-+ dev2->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ dev2->relbit[LONG(REL_X)] |= BIT(REL_X) | BIT(REL_Y);
-+ dev2->keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-
-- printk(KERN_INFO "input: %s on %s\n", priv->dev2.name, psmouse->ps2dev.serio->phys);
-+ input_register_device(priv->dev2);
-
- psmouse->protocol_handler = alps_process_byte;
- psmouse->disconnect = alps_disconnect;
-@@ -455,6 +457,7 @@ int alps_init(struct psmouse *psmouse)
- return 0;
-
- init_fail:
-+ input_free_device(dev2);
- kfree(priv);
- return -1;
- }
---- gregkh-2.6.orig/drivers/input/mouse/logips2pp.c
-+++ gregkh-2.6/drivers/input/mouse/logips2pp.c
-@@ -40,7 +40,7 @@ struct ps2pp_info {
-
- static psmouse_ret_t ps2pp_process_byte(struct psmouse *psmouse, struct pt_regs *regs)
- {
-- struct input_dev *dev = &psmouse->dev;
-+ struct input_dev *dev = psmouse->dev;
- unsigned char *packet = psmouse->packet;
-
- if (psmouse->pktcnt < 3)
-@@ -257,25 +257,27 @@ static struct ps2pp_info *get_model_info
- static void ps2pp_set_model_properties(struct psmouse *psmouse, struct ps2pp_info *model_info,
- int using_ps2pp)
- {
-+ struct input_dev *input_dev = psmouse->dev;
-+
- if (model_info->features & PS2PP_SIDE_BTN)
-- set_bit(BTN_SIDE, psmouse->dev.keybit);
-+ set_bit(BTN_SIDE, input_dev->keybit);
-
- if (model_info->features & PS2PP_EXTRA_BTN)
-- set_bit(BTN_EXTRA, psmouse->dev.keybit);
-+ set_bit(BTN_EXTRA, input_dev->keybit);
-
- if (model_info->features & PS2PP_TASK_BTN)
-- set_bit(BTN_TASK, psmouse->dev.keybit);
-+ set_bit(BTN_TASK, input_dev->keybit);
-
- if (model_info->features & PS2PP_NAV_BTN) {
-- set_bit(BTN_FORWARD, psmouse->dev.keybit);
-- set_bit(BTN_BACK, psmouse->dev.keybit);
-+ set_bit(BTN_FORWARD, input_dev->keybit);
-+ set_bit(BTN_BACK, input_dev->keybit);
- }
-
- if (model_info->features & PS2PP_WHEEL)
-- set_bit(REL_WHEEL, psmouse->dev.relbit);
-+ set_bit(REL_WHEEL, input_dev->relbit);
-
- if (model_info->features & PS2PP_HWHEEL)
-- set_bit(REL_HWHEEL, psmouse->dev.relbit);
-+ set_bit(REL_HWHEEL, input_dev->relbit);
-
- switch (model_info->kind) {
- case PS2PP_KIND_WHEEL:
-@@ -387,7 +389,7 @@ int ps2pp_init(struct psmouse *psmouse,
- }
-
- if (buttons < 3)
-- clear_bit(BTN_MIDDLE, psmouse->dev.keybit);
-+ clear_bit(BTN_MIDDLE, psmouse->dev->keybit);
-
- if (model_info)
- ps2pp_set_model_properties(psmouse, model_info, use_ps2pp);
---- gregkh-2.6.orig/drivers/input/mouse/alps.h
-+++ gregkh-2.6/drivers/input/mouse/alps.h
-@@ -22,7 +22,7 @@ struct alps_model_info {
- };
-
- struct alps_data {
-- struct input_dev dev2; /* Relative device */
-+ struct input_dev *dev2; /* Relative device */
- char name[32]; /* Name */
- char phys[32]; /* Phys */
- struct alps_model_info *i; /* Info */
---- gregkh-2.6.orig/drivers/input/mouse/lifebook.c
-+++ gregkh-2.6/drivers/input/mouse/lifebook.c
-@@ -34,7 +34,7 @@ static struct dmi_system_id lifebook_dmi
- static psmouse_ret_t lifebook_process_byte(struct psmouse *psmouse, struct pt_regs *regs)
- {
- unsigned char *packet = psmouse->packet;
-- struct input_dev *dev = &psmouse->dev;
-+ struct input_dev *dev = psmouse->dev;
-
- if (psmouse->pktcnt != 3)
- return PSMOUSE_GOOD_DATA;
-@@ -113,15 +113,17 @@ int lifebook_detect(struct psmouse *psmo
-
- int lifebook_init(struct psmouse *psmouse)
- {
-+ struct input_dev *input_dev = psmouse->dev;
-+
- if (lifebook_absolute_mode(psmouse))
- return -1;
-
-- psmouse->dev.evbit[0] = BIT(EV_ABS) | BIT(EV_KEY) | BIT(EV_REL);
-- psmouse->dev.keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-- psmouse->dev.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-- psmouse->dev.relbit[0] = BIT(REL_X) | BIT(REL_Y);
-- input_set_abs_params(&psmouse->dev, ABS_X, 0, 1024, 0, 0);
-- input_set_abs_params(&psmouse->dev, ABS_Y, 0, 1024, 0, 0);
-+ input_dev->evbit[0] = BIT(EV_ABS) | BIT(EV_KEY) | BIT(EV_REL);
-+ input_dev->keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+ input_set_abs_params(input_dev, ABS_X, 0, 1024, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 0, 1024, 0, 0);
-
- psmouse->protocol_handler = lifebook_process_byte;
- psmouse->set_resolution = lifebook_set_resolution;
diff --git a/driver/input-convert-to-dynamic-onetouch.patch b/driver/input-convert-to-dynamic-onetouch.patch
deleted file mode 100644
index 5896c87098edd..0000000000000
--- a/driver/input-convert-to-dynamic-onetouch.patch
+++ /dev/null
@@ -1,203 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:17 2005
-Message-Id: <20050915070303.355810000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:43 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 12/28] Input: convert onetouch to dynamic input_dev allocation
-
-Input: convert onetouch to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/usb/storage/onetouch.c | 105 ++++++++++++++++++++---------------------
- 1 file changed, 53 insertions(+), 52 deletions(-)
-
---- gregkh-2.6.orig/drivers/usb/storage/onetouch.c
-+++ gregkh-2.6/drivers/usb/storage/onetouch.c
-@@ -5,7 +5,7 @@
- * Copyright (c) 2005 Nick Sillik <n.sillik@temple.edu>
- *
- * Initial work by:
-- * Copyright (c) 2003 Erik Thyren <erth7411@student.uu.se>
-+ * Copyright (c) 2003 Erik Thyren <erth7411@student.uu.se>
- *
- * Based on usbmouse.c (Vojtech Pavlik) and xpad.c (Marko Friedemann)
- *
-@@ -46,7 +46,7 @@ void onetouch_release_input(void *onetou
- struct usb_onetouch {
- char name[128];
- char phys[64];
-- struct input_dev dev; /* input device interface */
-+ struct input_dev *dev; /* input device interface */
- struct usb_device *udev; /* usb device */
-
- struct urb *irq; /* urb for interrupt in report */
-@@ -58,7 +58,7 @@ static void usb_onetouch_irq(struct urb
- {
- struct usb_onetouch *onetouch = urb->context;
- signed char *data = onetouch->data;
-- struct input_dev *dev = &onetouch->dev;
-+ struct input_dev *dev = onetouch->dev;
- int status;
-
- switch (urb->status) {
-@@ -74,11 +74,9 @@ static void usb_onetouch_irq(struct urb
- }
-
- input_regs(dev, regs);
--
-- input_report_key(&onetouch->dev, ONETOUCH_BUTTON,
-- data[0] & 0x02);
--
-+ input_report_key(dev, ONETOUCH_BUTTON, data[0] & 0x02);
- input_sync(dev);
-+
- resubmit:
- status = usb_submit_urb (urb, SLAB_ATOMIC);
- if (status)
-@@ -113,8 +111,8 @@ int onetouch_connect_input(struct us_dat
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct usb_onetouch *onetouch;
-+ struct input_dev *input_dev;
- int pipe, maxp;
-- char path[64];
-
- interface = ss->pusb_intf->cur_altsetting;
-
-@@ -122,62 +120,62 @@ int onetouch_connect_input(struct us_dat
- return -ENODEV;
-
- endpoint = &interface->endpoint[2].desc;
-- if(!(endpoint->bEndpointAddress & USB_DIR_IN))
-+ if (!(endpoint->bEndpointAddress & USB_DIR_IN))
- return -ENODEV;
-- if((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK)
-+ if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK)
- != USB_ENDPOINT_XFER_INT)
- return -ENODEV;
-
- pipe = usb_rcvintpipe(udev, endpoint->bEndpointAddress);
- maxp = usb_maxpacket(udev, pipe, usb_pipeout(pipe));
-
-- if (!(onetouch = kcalloc(1, sizeof(struct usb_onetouch), GFP_KERNEL)))
-- return -ENOMEM;
-+ onetouch = kzalloc(sizeof(struct usb_onetouch), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!onetouch || !input_dev)
-+ goto fail1;
-
- onetouch->data = usb_buffer_alloc(udev, ONETOUCH_PKT_LEN,
- SLAB_ATOMIC, &onetouch->data_dma);
-- if (!onetouch->data){
-- kfree(onetouch);
-- return -ENOMEM;
-- }
-+ if (!onetouch->data)
-+ goto fail1;
-
- onetouch->irq = usb_alloc_urb(0, GFP_KERNEL);
-- if (!onetouch->irq){
-- kfree(onetouch);
-- usb_buffer_free(udev, ONETOUCH_PKT_LEN,
-- onetouch->data, onetouch->data_dma);
-- return -ENODEV;
-- }
--
-+ if (!onetouch->irq)
-+ goto fail2;
-
- onetouch->udev = udev;
--
-- set_bit(EV_KEY, onetouch->dev.evbit);
-- set_bit(ONETOUCH_BUTTON, onetouch->dev.keybit);
-- clear_bit(0, onetouch->dev.keybit);
--
-- onetouch->dev.private = onetouch;
-- onetouch->dev.open = usb_onetouch_open;
-- onetouch->dev.close = usb_onetouch_close;
--
-- usb_make_path(udev, path, sizeof(path));
-- sprintf(onetouch->phys, "%s/input0", path);
--
-- onetouch->dev.name = onetouch->name;
-- onetouch->dev.phys = onetouch->phys;
--
-- usb_to_input_id(udev, &onetouch->dev.id);
--
-- onetouch->dev.dev = &udev->dev;
-+ onetouch->dev = input_dev;
-
- if (udev->manufacturer)
-- strcat(onetouch->name, udev->manufacturer);
-- if (udev->product)
-- sprintf(onetouch->name, "%s %s", onetouch->name,
-- udev->product);
-+ strlcpy(onetouch->name, udev->manufacturer,
-+ sizeof(onetouch->name));
-+ if (udev->product) {
-+ if (udev->manufacturer)
-+ strlcat(onetouch->name, " ", sizeof(onetouch->name));
-+ strlcat(onetouch->name, udev->product, sizeof(onetouch->name));
-+ }
-+
- if (!strlen(onetouch->name))
-- sprintf(onetouch->name, "Maxtor Onetouch %04x:%04x",
-- onetouch->dev.id.vendor, onetouch->dev.id.product);
-+ snprintf(onetouch->name, sizeof(onetouch->name),
-+ "Maxtor Onetouch %04x:%04x",
-+ le16_to_cpu(udev->descriptor.idVendor),
-+ le16_to_cpu(udev->descriptor.idProduct));
-+
-+ usb_make_path(udev, onetouch->phys, sizeof(onetouch->phys));
-+ strlcat(onetouch->phys, "/input0", sizeof(onetouch->phys));
-+
-+ input_dev->name = onetouch->name;
-+ input_dev->phys = onetouch->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &udev->dev;
-+
-+ set_bit(EV_KEY, input_dev->evbit);
-+ set_bit(ONETOUCH_BUTTON, input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-+
-+ input_dev->private = onetouch;
-+ input_dev->open = usb_onetouch_open;
-+ input_dev->close = usb_onetouch_close;
-
- usb_fill_int_urb(onetouch->irq, udev, pipe, onetouch->data,
- (maxp > 8 ? 8 : maxp),
-@@ -188,10 +186,15 @@ int onetouch_connect_input(struct us_dat
- ss->extra_destructor = onetouch_release_input;
- ss->extra = onetouch;
-
-- input_register_device(&onetouch->dev);
-- printk(KERN_INFO "usb-input: %s on %s\n", onetouch->dev.name, path);
-+ input_register_device(onetouch->dev);
-
- return 0;
-+
-+ fail2: usb_buffer_free(udev, ONETOUCH_PKT_LEN,
-+ onetouch->data, onetouch->data_dma);
-+ fail1: kfree(onetouch);
-+ input_free_device(input_dev);
-+ return -ENOMEM;
- }
-
- void onetouch_release_input(void *onetouch_)
-@@ -200,11 +203,9 @@ void onetouch_release_input(void *onetou
-
- if (onetouch) {
- usb_kill_urb(onetouch->irq);
-- input_unregister_device(&onetouch->dev);
-+ input_unregister_device(onetouch->dev);
- usb_free_urb(onetouch->irq);
- usb_buffer_free(onetouch->udev, ONETOUCH_PKT_LEN,
- onetouch->data, onetouch->data_dma);
-- printk(KERN_INFO "usb-input: deregistering %s\n",
-- onetouch->dev.name);
- }
- }
diff --git a/driver/input-convert-to-dynamic-sonypi.patch b/driver/input-convert-to-dynamic-sonypi.patch
deleted file mode 100644
index 947a49f258503..0000000000000
--- a/driver/input-convert-to-dynamic-sonypi.patch
+++ /dev/null
@@ -1,161 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:08 2005
-Message-Id: <20050915070304.495439000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:50 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 19/28] Input: convert sonypi to dynamic input_dev allocation
-
-Input: convert sonypi to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/char/sonypi.c | 92 ++++++++++++++++++++++++++++----------------------
- 1 file changed, 53 insertions(+), 39 deletions(-)
-
---- gregkh-2.6.orig/drivers/char/sonypi.c
-+++ gregkh-2.6/drivers/char/sonypi.c
-@@ -424,10 +424,6 @@ static struct sonypi_eventtypes {
-
- #define SONYPI_BUF_SIZE 128
-
--/* The name of the devices for the input device drivers */
--#define SONYPI_JOG_INPUTNAME "Sony Vaio Jogdial"
--#define SONYPI_KEY_INPUTNAME "Sony Vaio Keys"
--
- /* Correspondance table between sonypi events and input layer events */
- static struct {
- int sonypiev;
-@@ -490,8 +486,8 @@ static struct sonypi_device {
- struct fasync_struct *fifo_async;
- int open_count;
- int model;
-- struct input_dev input_jog_dev;
-- struct input_dev input_key_dev;
-+ struct input_dev *input_jog_dev;
-+ struct input_dev *input_key_dev;
- struct work_struct input_work;
- struct kfifo *input_fifo;
- spinlock_t input_fifo_lock;
-@@ -779,8 +775,8 @@ static void input_keyrelease(void *data)
-
- static void sonypi_report_input_event(u8 event)
- {
-- struct input_dev *jog_dev = &sonypi_device.input_jog_dev;
-- struct input_dev *key_dev = &sonypi_device.input_key_dev;
-+ struct input_dev *jog_dev = sonypi_device.input_jog_dev;
-+ struct input_dev *key_dev = sonypi_device.input_key_dev;
- struct sonypi_keypress kp = { NULL };
- int i;
-
-@@ -1203,6 +1199,47 @@ static struct device_driver sonypi_drive
- .shutdown = sonypi_shutdown,
- };
-
-+static int __devinit sonypi_create_input_devices(void)
-+{
-+ struct input_dev *jog_dev;
-+ struct input_dev *key_dev;
-+ int i;
-+
-+ sonypi_device.input_jog_dev = jog_dev = input_allocate_device();
-+ if (!jog_dev)
-+ return -ENOMEM;
-+
-+ jog_dev->name = "Sony Vaio Jogdial";
-+ jog_dev->id.bustype = BUS_ISA;
-+ jog_dev->id.vendor = PCI_VENDOR_ID_SONY;
-+
-+ jog_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ jog_dev->keybit[LONG(BTN_MOUSE)] = BIT(BTN_MIDDLE);
-+ jog_dev->relbit[0] = BIT(REL_WHEEL);
-+
-+ sonypi_device.input_key_dev = key_dev = input_allocate_device();
-+ if (!key_dev) {
-+ input_free_device(jog_dev);
-+ sonypi_device.input_jog_dev = NULL;
-+ return -ENOMEM;
-+ }
-+
-+ key_dev->name = "Sony Vaio Keys";
-+ key_dev->id.bustype = BUS_ISA;
-+ key_dev->id.vendor = PCI_VENDOR_ID_SONY;
-+
-+ /* Initialize the Input Drivers: special keys */
-+ key_dev->evbit[0] = BIT(EV_KEY);
-+ for (i = 0; sonypi_inputkeys[i].sonypiev; i++)
-+ if (sonypi_inputkeys[i].inputev)
-+ set_bit(sonypi_inputkeys[i].inputev, key_dev->keybit);
-+
-+ input_register_device(jog_dev);
-+ input_register_device(key_dev);
-+
-+ return 0;
-+}
-+
- static int __devinit sonypi_probe(void)
- {
- int i, ret;
-@@ -1298,34 +1335,10 @@ static int __devinit sonypi_probe(void)
- }
-
- if (useinput) {
-- /* Initialize the Input Drivers: jogdial */
-- int i;
-- sonypi_device.input_jog_dev.evbit[0] =
-- BIT(EV_KEY) | BIT(EV_REL);
-- sonypi_device.input_jog_dev.keybit[LONG(BTN_MOUSE)] =
-- BIT(BTN_MIDDLE);
-- sonypi_device.input_jog_dev.relbit[0] = BIT(REL_WHEEL);
-- sonypi_device.input_jog_dev.name = SONYPI_JOG_INPUTNAME;
-- sonypi_device.input_jog_dev.id.bustype = BUS_ISA;
-- sonypi_device.input_jog_dev.id.vendor = PCI_VENDOR_ID_SONY;
--
-- input_register_device(&sonypi_device.input_jog_dev);
-- printk(KERN_INFO "%s input method installed.\n",
-- sonypi_device.input_jog_dev.name);
-
-- /* Initialize the Input Drivers: special keys */
-- sonypi_device.input_key_dev.evbit[0] = BIT(EV_KEY);
-- for (i = 0; sonypi_inputkeys[i].sonypiev; i++)
-- if (sonypi_inputkeys[i].inputev)
-- set_bit(sonypi_inputkeys[i].inputev,
-- sonypi_device.input_key_dev.keybit);
-- sonypi_device.input_key_dev.name = SONYPI_KEY_INPUTNAME;
-- sonypi_device.input_key_dev.id.bustype = BUS_ISA;
-- sonypi_device.input_key_dev.id.vendor = PCI_VENDOR_ID_SONY;
--
-- input_register_device(&sonypi_device.input_key_dev);
-- printk(KERN_INFO "%s input method installed.\n",
-- sonypi_device.input_key_dev.name);
-+ ret = sonypi_create_input_devices();
-+ if (ret)
-+ goto out_inputdevices;
-
- spin_lock_init(&sonypi_device.input_fifo_lock);
- sonypi_device.input_fifo =
-@@ -1375,8 +1388,9 @@ static int __devinit sonypi_probe(void)
- out_platformdev:
- kfifo_free(sonypi_device.input_fifo);
- out_infifo:
-- input_unregister_device(&sonypi_device.input_key_dev);
-- input_unregister_device(&sonypi_device.input_jog_dev);
-+ input_unregister_device(sonypi_device.input_key_dev);
-+ input_unregister_device(sonypi_device.input_jog_dev);
-+out_inputdevices:
- free_irq(sonypi_device.irq, sonypi_irq);
- out_reqirq:
- release_region(sonypi_device.ioport1, sonypi_device.region_size);
-@@ -1402,8 +1416,8 @@ static void __devexit sonypi_remove(void
- platform_device_unregister(sonypi_device.pdev);
-
- if (useinput) {
-- input_unregister_device(&sonypi_device.input_key_dev);
-- input_unregister_device(&sonypi_device.input_jog_dev);
-+ input_unregister_device(sonypi_device.input_key_dev);
-+ input_unregister_device(sonypi_device.input_jog_dev);
- kfifo_free(sonypi_device.input_fifo);
- }
-
diff --git a/driver/input-convert-to-dynamic-touchscreen.patch b/driver/input-convert-to-dynamic-touchscreen.patch
deleted file mode 100644
index 8c2bff05c2785..0000000000000
--- a/driver/input-convert-to-dynamic-touchscreen.patch
+++ /dev/null
@@ -1,1054 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:07 2005
-Message-Id: <20050915070303.839306000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:46 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 15/28] drivers/input/touchscreen: convert to dynamic input_dev allocation
-
-Input: convert drivers/input/touchscreen to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/touchscreen/corgi_ts.c | 93 +++++++++---------
- drivers/input/touchscreen/elo.c | 89 ++++++++---------
- drivers/input/touchscreen/gunze.c | 66 ++++++------
- drivers/input/touchscreen/h3600_ts_input.c | 149 +++++++++++------------------
- drivers/input/touchscreen/hp680_ts_input.c | 58 +++++------
- drivers/input/touchscreen/mk712.c | 80 +++++++--------
- drivers/input/touchscreen/mtouch.c | 64 ++++++------
- 7 files changed, 285 insertions(+), 314 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/touchscreen/gunze.c
-+++ gregkh-2.6/drivers/input/touchscreen/gunze.c
-@@ -48,14 +48,12 @@ MODULE_LICENSE("GPL");
-
- #define GUNZE_MAX_LENGTH 10
-
--static char *gunze_name = "Gunze AHL-51S TouchScreen";
--
- /*
- * Per-touchscreen data.
- */
-
- struct gunze {
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- int idx;
- unsigned char data[GUNZE_MAX_LENGTH];
-@@ -64,7 +62,7 @@ struct gunze {
-
- static void gunze_process_packet(struct gunze* gunze, struct pt_regs *regs)
- {
-- struct input_dev *dev = &gunze->dev;
-+ struct input_dev *dev = gunze->dev;
-
- if (gunze->idx != GUNZE_MAX_LENGTH || gunze->data[5] != ',' ||
- (gunze->data[0] != 'T' && gunze->data[0] != 'R')) {
-@@ -100,11 +98,13 @@ static irqreturn_t gunze_interrupt(struc
-
- static void gunze_disconnect(struct serio *serio)
- {
-- struct gunze* gunze = serio_get_drvdata(serio);
-+ struct gunze *gunze = serio_get_drvdata(serio);
-
-- input_unregister_device(&gunze->dev);
-+ input_get_device(gunze->dev);
-+ input_unregister_device(gunze->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_put_device(gunze->dev);
- kfree(gunze);
- }
-
-@@ -117,45 +117,45 @@ static void gunze_disconnect(struct seri
- static int gunze_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct gunze *gunze;
-+ struct input_dev *input_dev;
- int err;
-
-- if (!(gunze = kmalloc(sizeof(struct gunze), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(gunze, 0, sizeof(struct gunze));
--
-- init_input_dev(&gunze->dev);
-- gunze->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- gunze->dev.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-- input_set_abs_params(&gunze->dev, ABS_X, 24, 1000, 0, 0);
-- input_set_abs_params(&gunze->dev, ABS_Y, 24, 1000, 0, 0);
-+ gunze = kzalloc(sizeof(struct gunze), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!gunze || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail;
-+ }
-
- gunze->serio = serio;
--
-+ gunze->dev = input_dev;
- sprintf(gunze->phys, "%s/input0", serio->phys);
-
-- gunze->dev.private = gunze;
-- gunze->dev.name = gunze_name;
-- gunze->dev.phys = gunze->phys;
-- gunze->dev.id.bustype = BUS_RS232;
-- gunze->dev.id.vendor = SERIO_GUNZE;
-- gunze->dev.id.product = 0x0051;
-- gunze->dev.id.version = 0x0100;
-+ input_dev->private = gunze;
-+ input_dev->name = "Gunze AHL-51S TouchScreen";
-+ input_dev->phys = gunze->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_GUNZE;
-+ input_dev->id.product = 0x0051;
-+ input_dev->id.version = 0x0100;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_set_abs_params(input_dev, ABS_X, 24, 1000, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 24, 1000, 0, 0);
-
- serio_set_drvdata(serio, gunze);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(gunze);
-- return err;
-- }
--
-- input_register_device(&gunze->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", gunze_name, serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(gunze->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(gunze);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/touchscreen/mk712.c
-+++ gregkh-2.6/drivers/input/touchscreen/mk712.c
-@@ -77,7 +77,7 @@ MODULE_PARM_DESC(irq, "IRQ of MK712 touc
- #define MK712_READ_ONE_POINT 0x20
- #define MK712_POWERUP 0x40
-
--static struct input_dev mk712_dev;
-+static struct input_dev *mk712_dev;
- static DEFINE_SPINLOCK(mk712_lock);
-
- static irqreturn_t mk712_interrupt(int irq, void *dev_id, struct pt_regs *regs)
-@@ -88,7 +88,7 @@ static irqreturn_t mk712_interrupt(int i
- static unsigned short last_y;
-
- spin_lock(&mk712_lock);
-- input_regs(&mk712_dev, regs);
-+ input_regs(mk712_dev, regs);
-
- status = inb(mk712_io + MK712_STATUS);
-
-@@ -100,7 +100,7 @@ static irqreturn_t mk712_interrupt(int i
- if (~status & MK712_STATUS_TOUCH)
- {
- debounce = 1;
-- input_report_key(&mk712_dev, BTN_TOUCH, 0);
-+ input_report_key(mk712_dev, BTN_TOUCH, 0);
- goto end;
- }
-
-@@ -110,15 +110,15 @@ static irqreturn_t mk712_interrupt(int i
- goto end;
- }
-
-- input_report_key(&mk712_dev, BTN_TOUCH, 1);
-- input_report_abs(&mk712_dev, ABS_X, last_x);
-- input_report_abs(&mk712_dev, ABS_Y, last_y);
-+ input_report_key(mk712_dev, BTN_TOUCH, 1);
-+ input_report_abs(mk712_dev, ABS_X, last_x);
-+ input_report_abs(mk712_dev, ABS_Y, last_y);
-
- end:
-
- last_x = inw(mk712_io + MK712_X) & 0x0fff;
- last_y = inw(mk712_io + MK712_Y) & 0x0fff;
-- input_sync(&mk712_dev);
-+ input_sync(mk712_dev);
- spin_unlock(&mk712_lock);
- return IRQ_HANDLED;
- }
-@@ -154,30 +154,11 @@ static void mk712_close(struct input_dev
- spin_unlock_irqrestore(&mk712_lock, flags);
- }
-
--static struct input_dev mk712_dev = {
-- .evbit = { BIT(EV_KEY) | BIT(EV_ABS) },
-- .keybit = { [LONG(BTN_TOUCH)] = BIT(BTN_TOUCH) },
-- .absbit = { BIT(ABS_X) | BIT(ABS_Y) },
-- .open = mk712_open,
-- .close = mk712_close,
-- .name = "ICS MicroClock MK712 TouchScreen",
-- .phys = "isa0260/input0",
-- .absmin = { [ABS_X] = 0, [ABS_Y] = 0 },
-- .absmax = { [ABS_X] = 0xfff, [ABS_Y] = 0xfff },
-- .absfuzz = { [ABS_X] = 88, [ABS_Y] = 88 },
-- .id = {
-- .bustype = BUS_ISA,
-- .vendor = 0x0005,
-- .product = 0x0001,
-- .version = 0x0100,
-- },
--};
--
- int __init mk712_init(void)
- {
-+ int err;
-
-- if(!request_region(mk712_io, 8, "mk712"))
-- {
-+ if (!request_region(mk712_io, 8, "mk712")) {
- printk(KERN_WARNING "mk712: unable to get IO region\n");
- return -ENODEV;
- }
-@@ -188,28 +169,49 @@ int __init mk712_init(void)
- (inw(mk712_io + MK712_Y) & 0xf000) ||
- (inw(mk712_io + MK712_STATUS) & 0xf333)) {
- printk(KERN_WARNING "mk712: device not present\n");
-- release_region(mk712_io, 8);
-- return -ENODEV;
-+ err = -ENODEV;
-+ goto fail;
- }
-
-- if(request_irq(mk712_irq, mk712_interrupt, 0, "mk712", &mk712_dev))
-- {
-- printk(KERN_WARNING "mk712: unable to get IRQ\n");
-- release_region(mk712_io, 8);
-- return -EBUSY;
-+ if (!(mk712_dev = input_allocate_device())) {
-+ printk(KERN_ERR "mk712: not enough memory\n");
-+ err = -ENOMEM;
-+ goto fail;
- }
-
-- input_register_device(&mk712_dev);
-+ mk712_dev->name = "ICS MicroClock MK712 TouchScreen";
-+ mk712_dev->phys = "isa0260/input0";
-+ mk712_dev->id.bustype = BUS_ISA;
-+ mk712_dev->id.vendor = 0x0005;
-+ mk712_dev->id.product = 0x0001;
-+ mk712_dev->id.version = 0x0100;
-+
-+ mk712_dev->open = mk712_open;
-+ mk712_dev->close = mk712_close;
-
-- printk(KERN_INFO "input: ICS MicroClock MK712 TouchScreen at %#x irq %d\n", mk712_io, mk712_irq);
-+ mk712_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ mk712_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_set_abs_params(mk712_dev, ABS_X, 0, 0xfff, 88, 0);
-+ input_set_abs_params(mk712_dev, ABS_Y, 0, 0xfff, 88, 0);
-
-+ if (request_irq(mk712_irq, mk712_interrupt, 0, "mk712", mk712_dev)) {
-+ printk(KERN_WARNING "mk712: unable to get IRQ\n");
-+ err = -EBUSY;
-+ goto fail;
-+ }
-+
-+ input_register_device(mk712_dev);
- return 0;
-+
-+ fail: input_free_device(mk712_dev);
-+ release_region(mk712_io, 8);
-+ return err;
- }
-
- static void __exit mk712_exit(void)
- {
-- input_unregister_device(&mk712_dev);
-- free_irq(mk712_irq, &mk712_dev);
-+ input_unregister_device(mk712_dev);
-+ free_irq(mk712_irq, mk712_dev);
- release_region(mk712_io, 8);
- }
-
---- gregkh-2.6.orig/drivers/input/touchscreen/h3600_ts_input.c
-+++ gregkh-2.6/drivers/input/touchscreen/h3600_ts_input.c
-@@ -39,7 +39,6 @@
- #include <linux/serio.h>
- #include <linux/init.h>
- #include <linux/delay.h>
--#include <linux/pm.h>
-
- /* SA1100 serial defines */
- #include <asm/arch/hardware.h>
-@@ -93,16 +92,12 @@ MODULE_LICENSE("GPL");
- #define H3600_SCANCODE_LEFT 8 /* 8 -> left */
- #define H3600_SCANCODE_DOWN 9 /* 9 -> down */
-
--static char *h3600_name = "H3600 TouchScreen";
--
- /*
- * Per-touchscreen data.
- */
- struct h3600_dev {
-- struct input_dev dev;
-- struct pm_dev *pm_dev;
-+ struct input_dev *dev;
- struct serio *serio;
-- struct pm_dev *pm_dev;
- unsigned char event; /* event ID from packet */
- unsigned char chksum;
- unsigned char len;
-@@ -163,33 +158,6 @@ unsigned int h3600_flite_power(struct in
- return 0;
- }
-
--static int suspended = 0;
--static int h3600ts_pm_callback(struct pm_dev *pm_dev, pm_request_t req,
-- void *data)
--{
-- struct input_dev *dev = (struct input_dev *) data;
--
-- switch (req) {
-- case PM_SUSPEND: /* enter D1-D3 */
-- suspended = 1;
-- h3600_flite_power(dev, FLITE_PWR_OFF);
-- break;
-- case PM_BLANK:
-- if (!suspended)
-- h3600_flite_power(dev, FLITE_PWR_OFF);
-- break;
-- case PM_RESUME: /* enter D0 */
-- /* same as unblank */
-- case PM_UNBLANK:
-- if (suspended) {
-- //initSerial();
-- suspended = 0;
-- }
-- h3600_flite_power(dev, FLITE_PWR_ON);
-- break;
-- }
-- return 0;
--}
- #endif
-
- /*
-@@ -199,7 +167,7 @@ static int h3600ts_pm_callback(struct pm
- */
- static void h3600ts_process_packet(struct h3600_dev *ts, struct pt_regs *regs)
- {
-- struct input_dev *dev = &ts->dev;
-+ struct input_dev *dev = ts->dev;
- static int touched = 0;
- int key, down = 0;
-
-@@ -295,6 +263,7 @@ static void h3600ts_process_packet(struc
- static int h3600ts_event(struct input_dev *dev, unsigned int type,
- unsigned int code, int value)
- {
-+#if 0
- struct h3600_dev *ts = dev->private;
-
- switch (type) {
-@@ -304,6 +273,8 @@ static int h3600ts_event(struct input_de
- }
- }
- return -1;
-+#endif
-+ return 0;
- }
-
- /*
-@@ -380,14 +351,48 @@ static irqreturn_t h3600ts_interrupt(str
- static int h3600ts_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct h3600_dev *ts;
-+ struct input_dev *input_dev;
- int err;
-
-- if (!(ts = kmalloc(sizeof(struct h3600_dev), GFP_KERNEL)))
-- return -ENOMEM;
-+ ts = kzalloc(sizeof(struct h3600_dev), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!ts || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail1;
-+ }
-
-- memset(ts, 0, sizeof(struct h3600_dev));
-+ ts->serio = serio;
-+ ts->dev = input_dev;
-+ sprintf(ts->phys, "%s/input0", serio->phys);
-
-- init_input_dev(&ts->dev);
-+ input_dev->name = "H3600 TouchScreen";
-+ input_dev->phys = ts->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_H3600;
-+ input_dev->id.product = 0x0666; /* FIXME !!! We can ask the hardware */
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-+ input_dev->private = ts;
-+
-+ input_dev->event = h3600ts_event;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS) | BIT(EV_LED) | BIT(EV_PWR);
-+ input_dev->ledbit[0] = BIT(LED_SLEEP);
-+ input_set_abs_params(input_dev, ABS_X, 60, 985, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 35, 1024, 0, 0);
-+
-+ set_bit(KEY_RECORD, input_dev->keybit);
-+ set_bit(KEY_Q, input_dev->keybit);
-+ set_bit(KEY_PROG1, input_dev->keybit);
-+ set_bit(KEY_PROG2, input_dev->keybit);
-+ set_bit(KEY_PROG3, input_dev->keybit);
-+ set_bit(KEY_UP, input_dev->keybit);
-+ set_bit(KEY_RIGHT, input_dev->keybit);
-+ set_bit(KEY_LEFT, input_dev->keybit);
-+ set_bit(KEY_DOWN, input_dev->keybit);
-+ set_bit(KEY_ENTER, input_dev->keybit);
-+ set_bit(KEY_SUSPEND, input_dev->keybit);
-+ set_bit(BTN_TOUCH, input_dev->keybit);
-
- /* Device specific stuff */
- set_GPIO_IRQ_edge(GPIO_BITSY_ACTION_BUTTON, GPIO_BOTH_EDGES);
-@@ -397,73 +402,35 @@ static int h3600ts_connect(struct serio
- SA_SHIRQ | SA_INTERRUPT | SA_SAMPLE_RANDOM,
- "h3600_action", &ts->dev)) {
- printk(KERN_ERR "h3600ts.c: Could not allocate Action Button IRQ!\n");
-- kfree(ts);
-- return -EBUSY;
-+ err = -EBUSY;
-+ goto fail2;
- }
-
- if (request_irq(IRQ_GPIO_BITSY_NPOWER_BUTTON, npower_button_handler,
- SA_SHIRQ | SA_INTERRUPT | SA_SAMPLE_RANDOM,
- "h3600_suspend", &ts->dev)) {
-- free_irq(IRQ_GPIO_BITSY_ACTION_BUTTON, &ts->dev);
- printk(KERN_ERR "h3600ts.c: Could not allocate Power Button IRQ!\n");
-- kfree(ts);
-- return -EBUSY;
-+ err = -EBUSY;
-+ goto fail3;
- }
-
-- /* Now we have things going we setup our input device */
-- ts->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS) | BIT(EV_LED) | BIT(EV_PWR);
-- ts->dev.ledbit[0] = BIT(LED_SLEEP);
-- input_set_abs_params(&ts->dev, ABS_X, 60, 985, 0, 0);
-- input_set_abs_params(&ts->dev, ABS_Y, 35, 1024, 0, 0);
--
-- set_bit(KEY_RECORD, ts->dev.keybit);
-- set_bit(KEY_Q, ts->dev.keybit);
-- set_bit(KEY_PROG1, ts->dev.keybit);
-- set_bit(KEY_PROG2, ts->dev.keybit);
-- set_bit(KEY_PROG3, ts->dev.keybit);
-- set_bit(KEY_UP, ts->dev.keybit);
-- set_bit(KEY_RIGHT, ts->dev.keybit);
-- set_bit(KEY_LEFT, ts->dev.keybit);
-- set_bit(KEY_DOWN, ts->dev.keybit);
-- set_bit(KEY_ENTER, ts->dev.keybit);
-- ts->dev.keybit[LONG(BTN_TOUCH)] |= BIT(BTN_TOUCH);
-- ts->dev.keybit[LONG(KEY_SUSPEND)] |= BIT(KEY_SUSPEND);
--
-- ts->serio = serio;
--
-- sprintf(ts->phys, "%s/input0", serio->phys);
--
-- ts->dev.event = h3600ts_event;
-- ts->dev.private = ts;
-- ts->dev.name = h3600_name;
-- ts->dev.phys = ts->phys;
-- ts->dev.id.bustype = BUS_RS232;
-- ts->dev.id.vendor = SERIO_H3600;
-- ts->dev.id.product = 0x0666; /* FIXME !!! We can ask the hardware */
-- ts->dev.id.version = 0x0100;
--
- serio_set_drvdata(serio, ts);
-
- err = serio_open(serio, drv);
-- if (err) {
-- free_irq(IRQ_GPIO_BITSY_ACTION_BUTTON, ts);
-- free_irq(IRQ_GPIO_BITSY_NPOWER_BUTTON, ts);
-- serio_set_drvdata(serio, NULL);
-- kfree(ts);
-+ if (err)
- return err;
-- }
-
- //h3600_flite_control(1, 25); /* default brightness */
--#ifdef CONFIG_PM
-- ts->pm_dev = pm_register(PM_ILLUMINATION_DEV, PM_SYS_LIGHT,
-- h3600ts_pm_callback);
-- printk("registered pm callback\n");
--#endif
-- input_register_device(&ts->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", h3600_name, serio->phys);
-+ input_register_device(ts->dev);
-
- return 0;
-+
-+fail3: free_irq(IRQ_GPIO_BITSY_NPOWER_BUTTON, ts->dev);
-+fail2: free_irq(IRQ_GPIO_BITSY_ACTION_BUTTON, ts->dev);
-+fail1: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(ts);
-+ return err;
- }
-
- /*
-@@ -476,9 +443,11 @@ static void h3600ts_disconnect(struct se
-
- free_irq(IRQ_GPIO_BITSY_ACTION_BUTTON, &ts->dev);
- free_irq(IRQ_GPIO_BITSY_NPOWER_BUTTON, &ts->dev);
-- input_unregister_device(&ts->dev);
-+ input_get_device(ts->dev);
-+ input_unregister_device(ts->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_put_device(ts->dev);
- kfree(ts);
- }
-
---- gregkh-2.6.orig/drivers/input/touchscreen/corgi_ts.c
-+++ gregkh-2.6/drivers/input/touchscreen/corgi_ts.c
-@@ -41,8 +41,7 @@ struct ts_event {
- };
-
- struct corgi_ts {
-- char phys[32];
-- struct input_dev input;
-+ struct input_dev *input;
- struct timer_list timer;
- struct ts_event tc;
- int pendown;
-@@ -182,14 +181,12 @@ static void new_data(struct corgi_ts *co
- if (!corgi_ts->tc.pressure && corgi_ts->pendown == 0)
- return;
-
-- if (regs)
-- input_regs(&corgi_ts->input, regs);
--
-- input_report_abs(&corgi_ts->input, ABS_X, corgi_ts->tc.x);
-- input_report_abs(&corgi_ts->input, ABS_Y, corgi_ts->tc.y);
-- input_report_abs(&corgi_ts->input, ABS_PRESSURE, corgi_ts->tc.pressure);
-- input_report_key(&corgi_ts->input, BTN_TOUCH, (corgi_ts->pendown != 0));
-- input_sync(&corgi_ts->input);
-+ input_regs(corgi_ts->input, regs);
-+ input_report_abs(corgi_ts->input, ABS_X, corgi_ts->tc.x);
-+ input_report_abs(corgi_ts->input, ABS_Y, corgi_ts->tc.y);
-+ input_report_abs(corgi_ts->input, ABS_PRESSURE, corgi_ts->tc.pressure);
-+ input_report_key(corgi_ts->input, BTN_TOUCH, (corgi_ts->pendown != 0));
-+ input_sync(corgi_ts->input);
- }
-
- static void ts_interrupt_main(struct corgi_ts *corgi_ts, int isTimer, struct pt_regs *regs)
-@@ -273,39 +270,44 @@ static int __init corgits_probe(struct d
- {
- struct corgi_ts *corgi_ts;
- struct platform_device *pdev = to_platform_device(dev);
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-
-- if (!(corgi_ts = kmalloc(sizeof(struct corgi_ts), GFP_KERNEL)))
-- return -ENOMEM;
-+ corgi_ts = kzalloc(sizeof(struct corgi_ts), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!corgi_ts || !input_dev)
-+ goto fail;
-
- dev_set_drvdata(dev, corgi_ts);
-
-- memset(corgi_ts, 0, sizeof(struct corgi_ts));
--
- corgi_ts->machinfo = dev->platform_data;
- corgi_ts->irq_gpio = platform_get_irq(pdev, 0);
-
- if (corgi_ts->irq_gpio < 0) {
-- kfree(corgi_ts);
-- return -ENODEV;
-+ err = -ENODEV;
-+ goto fail;
- }
-
-- init_input_dev(&corgi_ts->input);
-- corgi_ts->input.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- corgi_ts->input.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-- input_set_abs_params(&corgi_ts->input, ABS_X, X_AXIS_MIN, X_AXIS_MAX, 0, 0);
-- input_set_abs_params(&corgi_ts->input, ABS_Y, Y_AXIS_MIN, Y_AXIS_MAX, 0, 0);
-- input_set_abs_params(&corgi_ts->input, ABS_PRESSURE, PRESSURE_MIN, PRESSURE_MAX, 0, 0);
--
-- strcpy(corgi_ts->phys, "corgits/input0");
--
-- corgi_ts->input.private = corgi_ts;
-- corgi_ts->input.name = "Corgi Touchscreen";
-- corgi_ts->input.dev = dev;
-- corgi_ts->input.phys = corgi_ts->phys;
-- corgi_ts->input.id.bustype = BUS_HOST;
-- corgi_ts->input.id.vendor = 0x0001;
-- corgi_ts->input.id.product = 0x0002;
-- corgi_ts->input.id.version = 0x0100;
-+ corgi_ts->input = input_dev;
-+
-+ init_timer(&corgi_ts->timer);
-+ corgi_ts->timer.data = (unsigned long) corgi_ts;
-+ corgi_ts->timer.function = corgi_ts_timer;
-+
-+ input_dev->name = "Corgi Touchscreen";
-+ input_dev->phys = "corgits/input0";
-+ input_dev->id.bustype = BUS_HOST;
-+ input_dev->id.vendor = 0x0001;
-+ input_dev->id.product = 0x0002;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = dev;
-+ input_dev->private = corgi_ts;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_set_abs_params(input_dev, ABS_X, X_AXIS_MIN, X_AXIS_MAX, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, Y_AXIS_MIN, Y_AXIS_MAX, 0, 0);
-+ input_set_abs_params(input_dev, ABS_PRESSURE, PRESSURE_MIN, PRESSURE_MAX, 0, 0);
-
- pxa_gpio_mode(IRQ_TO_GPIO(corgi_ts->irq_gpio) | GPIO_IN);
-
-@@ -319,25 +321,24 @@ static int __init corgits_probe(struct d
- corgi_ssp_ads7846_putget((5u << ADSCTRL_ADR_SH) | ADSCTRL_STS);
- mdelay(5);
-
-- init_timer(&corgi_ts->timer);
-- corgi_ts->timer.data = (unsigned long) corgi_ts;
-- corgi_ts->timer.function = corgi_ts_timer;
--
-- input_register_device(&corgi_ts->input);
-- corgi_ts->power_mode = PWR_MODE_ACTIVE;
--
- if (request_irq(corgi_ts->irq_gpio, ts_interrupt, SA_INTERRUPT, "ts", corgi_ts)) {
-- input_unregister_device(&corgi_ts->input);
-- kfree(corgi_ts);
-- return -EBUSY;
-+ err = -EBUSY;
-+ goto fail;
- }
-
-+ input_register_device(corgi_ts->input);
-+
-+ corgi_ts->power_mode = PWR_MODE_ACTIVE;
-+
- /* Enable Falling Edge */
- set_irq_type(corgi_ts->irq_gpio, IRQT_FALLING);
-
-- printk(KERN_INFO "input: Corgi Touchscreen Registered\n");
--
- return 0;
-+
-+ fail: input_free_device(input_dev);
-+ kfree(corgi_ts);
-+ return err;
-+
- }
-
- static int corgits_remove(struct device *dev)
-@@ -347,7 +348,7 @@ static int corgits_remove(struct device
- free_irq(corgi_ts->irq_gpio, NULL);
- del_timer_sync(&corgi_ts->timer);
- corgi_ts->machinfo->put_hsync();
-- input_unregister_device(&corgi_ts->input);
-+ input_unregister_device(corgi_ts->input);
- kfree(corgi_ts);
- return 0;
- }
---- gregkh-2.6.orig/drivers/input/touchscreen/elo.c
-+++ gregkh-2.6/drivers/input/touchscreen/elo.c
-@@ -36,14 +36,12 @@ MODULE_LICENSE("GPL");
-
- #define ELO_MAX_LENGTH 10
-
--static char *elo_name = "Elo Serial TouchScreen";
--
- /*
- * Per-touchscreen data.
- */
-
- struct elo {
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- int id;
- int idx;
-@@ -54,7 +52,7 @@ struct elo {
-
- static void elo_process_data_10(struct elo* elo, unsigned char data, struct pt_regs *regs)
- {
-- struct input_dev *dev = &elo->dev;
-+ struct input_dev *dev = elo->dev;
-
- elo->csum += elo->data[elo->idx] = data;
-
-@@ -80,7 +78,7 @@ static void elo_process_data_10(struct e
- input_report_abs(dev, ABS_X, (elo->data[4] << 8) | elo->data[3]);
- input_report_abs(dev, ABS_Y, (elo->data[6] << 8) | elo->data[5]);
- input_report_abs(dev, ABS_PRESSURE, (elo->data[8] << 8) | elo->data[7]);
-- input_report_key(dev, BTN_TOUCH, elo->data[2] & 3);
-+ input_report_key(dev, BTN_TOUCH, elo->data[8] || elo->data[7]);
- input_sync(dev);
- }
- elo->idx = 0;
-@@ -91,7 +89,7 @@ static void elo_process_data_10(struct e
-
- static void elo_process_data_6(struct elo* elo, unsigned char data, struct pt_regs *regs)
- {
-- struct input_dev *dev = &elo->dev;
-+ struct input_dev *dev = elo->dev;
-
- elo->data[elo->idx] = data;
-
-@@ -129,7 +127,7 @@ static void elo_process_data_6(struct el
- case 5:
- if ((data & 0xf0) == 0) {
- input_report_abs(dev, ABS_PRESSURE, elo->data[5]);
-- input_report_key(dev, BTN_TOUCH, elo->data[5]);
-+ input_report_key(dev, BTN_TOUCH, !!elo->data[5]);
- }
- input_sync(dev);
- elo->idx = 0;
-@@ -139,7 +137,7 @@ static void elo_process_data_6(struct el
-
- static void elo_process_data_3(struct elo* elo, unsigned char data, struct pt_regs *regs)
- {
-- struct input_dev *dev = &elo->dev;
-+ struct input_dev *dev = elo->dev;
-
- elo->data[elo->idx] = data;
-
-@@ -191,7 +189,7 @@ static void elo_disconnect(struct serio
- {
- struct elo* elo = serio_get_drvdata(serio);
-
-- input_unregister_device(&elo->dev);
-+ input_unregister_device(elo->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
- kfree(elo);
-@@ -206,67 +204,68 @@ static void elo_disconnect(struct serio
- static int elo_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct elo *elo;
-+ struct input_dev *input_dev;
- int err;
-
-- if (!(elo = kmalloc(sizeof(struct elo), GFP_KERNEL)))
-- return -ENOMEM;
-+ elo = kzalloc(sizeof(struct elo), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!elo || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail;
-+ }
-
-- memset(elo, 0, sizeof(struct elo));
-+ elo->serio = serio;
-+ elo->id = serio->id.id;
-+ elo->dev = input_dev;
-+ snprintf(elo->phys, sizeof(elo->phys), "%s/input0", serio->phys);
-
-- init_input_dev(&elo->dev);
-- elo->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- elo->dev.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_dev->private = elo;
-+ input_dev->name = "Elo Serial TouchScreen";
-+ input_dev->phys = elo->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_ELO;
-+ input_dev->id.product = elo->id;
-+ input_dev->id.version = 0x0100;
-+ input_dev->cdev.dev = &serio->dev;
-
-- elo->id = serio->id.id;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-
- switch (elo->id) {
-
- case 0: /* 10-byte protocol */
-- input_set_abs_params(&elo->dev, ABS_X, 96, 4000, 0, 0);
-- input_set_abs_params(&elo->dev, ABS_Y, 96, 4000, 0, 0);
-- input_set_abs_params(&elo->dev, ABS_PRESSURE, 0, 255, 0, 0);
-+ input_set_abs_params(input_dev, ABS_X, 96, 4000, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 96, 4000, 0, 0);
-+ input_set_abs_params(input_dev, ABS_PRESSURE, 0, 255, 0, 0);
- break;
-
- case 1: /* 6-byte protocol */
-- input_set_abs_params(&elo->dev, ABS_PRESSURE, 0, 15, 0, 0);
-+ input_set_abs_params(input_dev, ABS_PRESSURE, 0, 15, 0, 0);
-
- case 2: /* 4-byte protocol */
-- input_set_abs_params(&elo->dev, ABS_X, 96, 4000, 0, 0);
-- input_set_abs_params(&elo->dev, ABS_Y, 96, 4000, 0, 0);
-+ input_set_abs_params(input_dev, ABS_X, 96, 4000, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 96, 4000, 0, 0);
- break;
-
- case 3: /* 3-byte protocol */
-- input_set_abs_params(&elo->dev, ABS_X, 0, 255, 0, 0);
-- input_set_abs_params(&elo->dev, ABS_Y, 0, 255, 0, 0);
-+ input_set_abs_params(input_dev, ABS_X, 0, 255, 0, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 0, 255, 0, 0);
- break;
- }
-
-- elo->serio = serio;
--
-- sprintf(elo->phys, "%s/input0", serio->phys);
--
-- elo->dev.private = elo;
-- elo->dev.name = elo_name;
-- elo->dev.phys = elo->phys;
-- elo->dev.id.bustype = BUS_RS232;
-- elo->dev.id.vendor = SERIO_ELO;
-- elo->dev.id.product = elo->id;
-- elo->dev.id.version = 0x0100;
--
- serio_set_drvdata(serio, elo);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(elo);
-- return err;
-- }
--
-- input_register_device(&elo->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", elo_name, serio->phys);
-+ if (err)
-+ goto fail;
-
-+ input_register_device(elo->dev);
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(elo);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/touchscreen/mtouch.c
-+++ gregkh-2.6/drivers/input/touchscreen/mtouch.c
-@@ -51,14 +51,12 @@ MODULE_LICENSE("GPL");
- #define MTOUCH_GET_YC(data) (((data[4])<<7) | data[3])
- #define MTOUCH_GET_TOUCHED(data) (MTOUCH_FORMAT_TABLET_TOUCH_BIT & data[0])
-
--static char *mtouch_name = "MicroTouch Serial TouchScreen";
--
- /*
- * Per-touchscreen data.
- */
-
- struct mtouch {
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct serio *serio;
- int idx;
- unsigned char data[MTOUCH_MAX_LENGTH];
-@@ -67,7 +65,7 @@ struct mtouch {
-
- static void mtouch_process_format_tablet(struct mtouch *mtouch, struct pt_regs *regs)
- {
-- struct input_dev *dev = &mtouch->dev;
-+ struct input_dev *dev = mtouch->dev;
-
- if (MTOUCH_FORMAT_TABLET_LENGTH == ++mtouch->idx) {
- input_regs(dev, regs);
-@@ -116,9 +114,11 @@ static void mtouch_disconnect(struct ser
- {
- struct mtouch* mtouch = serio_get_drvdata(serio);
-
-- input_unregister_device(&mtouch->dev);
-+ input_get_device(mtouch->dev);
-+ input_unregister_device(mtouch->dev);
- serio_close(serio);
- serio_set_drvdata(serio, NULL);
-+ input_put_device(mtouch->dev);
- kfree(mtouch);
- }
-
-@@ -131,46 +131,46 @@ static void mtouch_disconnect(struct ser
- static int mtouch_connect(struct serio *serio, struct serio_driver *drv)
- {
- struct mtouch *mtouch;
-+ struct input_dev *input_dev;
- int err;
-
-- if (!(mtouch = kmalloc(sizeof(*mtouch), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(mtouch, 0, sizeof(*mtouch));
--
-- init_input_dev(&mtouch->dev);
-- mtouch->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- mtouch->dev.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
--
-- input_set_abs_params(&mtouch->dev, ABS_X, MTOUCH_MIN_XC, MTOUCH_MAX_XC, 0, 0);
-- input_set_abs_params(&mtouch->dev, ABS_Y, MTOUCH_MIN_YC, MTOUCH_MAX_YC, 0, 0);
-+ mtouch = kzalloc(sizeof(struct mtouch), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!mtouch || !input_dev) {
-+ err = -ENOMEM;
-+ goto fail;
-+ }
-
- mtouch->serio = serio;
--
-+ mtouch->dev = input_dev;
- sprintf(mtouch->phys, "%s/input0", serio->phys);
-
-- mtouch->dev.private = mtouch;
-- mtouch->dev.name = mtouch_name;
-- mtouch->dev.phys = mtouch->phys;
-- mtouch->dev.id.bustype = BUS_RS232;
-- mtouch->dev.id.vendor = SERIO_MICROTOUCH;
-- mtouch->dev.id.product = 0;
-- mtouch->dev.id.version = 0x0100;
-+ input_dev->private = mtouch;
-+ input_dev->name = "MicroTouch Serial TouchScreen";
-+ input_dev->phys = mtouch->phys;
-+ input_dev->id.bustype = BUS_RS232;
-+ input_dev->id.vendor = SERIO_MICROTOUCH;
-+ input_dev->id.product = 0;
-+ input_dev->id.version = 0x0100;
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_set_abs_params(mtouch->dev, ABS_X, MTOUCH_MIN_XC, MTOUCH_MAX_XC, 0, 0);
-+ input_set_abs_params(mtouch->dev, ABS_Y, MTOUCH_MIN_YC, MTOUCH_MAX_YC, 0, 0);
-
- serio_set_drvdata(serio, mtouch);
-
- err = serio_open(serio, drv);
-- if (err) {
-- serio_set_drvdata(serio, NULL);
-- kfree(mtouch);
-- return err;
-- }
--
-- input_register_device(&mtouch->dev);
-+ if (err)
-+ goto fail;
-
-- printk(KERN_INFO "input: %s on %s\n", mtouch->dev.name, serio->phys);
-+ input_register_device(mtouch->dev);
-
- return 0;
-+
-+ fail: serio_set_drvdata(serio, NULL);
-+ input_free_device(input_dev);
-+ kfree(mtouch);
-+ return err;
- }
-
- /*
---- gregkh-2.6.orig/drivers/input/touchscreen/hp680_ts_input.c
-+++ gregkh-2.6/drivers/input/touchscreen/hp680_ts_input.c
-@@ -21,10 +21,8 @@
-
- static void do_softint(void *data);
-
--static struct input_dev hp680_ts_dev;
-+static struct input_dev *hp680_ts_dev;
- static DECLARE_WORK(work, do_softint, 0);
--static char *hp680_ts_name = "HP Jornada touchscreen";
--static char *hp680_ts_phys = "input0";
-
- static void do_softint(void *data)
- {
-@@ -58,14 +56,14 @@ static void do_softint(void *data)
- }
-
- if (touched) {
-- input_report_key(&hp680_ts_dev, BTN_TOUCH, 1);
-- input_report_abs(&hp680_ts_dev, ABS_X, absx);
-- input_report_abs(&hp680_ts_dev, ABS_Y, absy);
-+ input_report_key(hp680_ts_dev, BTN_TOUCH, 1);
-+ input_report_abs(hp680_ts_dev, ABS_X, absx);
-+ input_report_abs(hp680_ts_dev, ABS_Y, absy);
- } else {
-- input_report_key(&hp680_ts_dev, BTN_TOUCH, 0);
-+ input_report_key(hp680_ts_dev, BTN_TOUCH, 0);
- }
-
-- input_sync(&hp680_ts_dev);
-+ input_sync(hp680_ts_dev);
- enable_irq(HP680_TS_IRQ);
- }
-
-@@ -92,27 +90,29 @@ static int __init hp680_ts_init(void)
- scpcr |= SCPCR_TS_ENABLE;
- ctrl_outw(scpcr, SCPCR);
-
-- memset(&hp680_ts_dev, 0, sizeof(hp680_ts_dev));
-- init_input_dev(&hp680_ts_dev);
--
-- hp680_ts_dev.evbit[0] = BIT(EV_ABS) | BIT(EV_KEY);
-- hp680_ts_dev.absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-- hp680_ts_dev.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
--
-- hp680_ts_dev.absmin[ABS_X] = HP680_TS_ABS_X_MIN;
-- hp680_ts_dev.absmin[ABS_Y] = HP680_TS_ABS_Y_MIN;
-- hp680_ts_dev.absmax[ABS_X] = HP680_TS_ABS_X_MAX;
-- hp680_ts_dev.absmax[ABS_Y] = HP680_TS_ABS_Y_MAX;
--
-- hp680_ts_dev.name = hp680_ts_name;
-- hp680_ts_dev.phys = hp680_ts_phys;
-- input_register_device(&hp680_ts_dev);
--
-- if (request_irq
-- (HP680_TS_IRQ, hp680_ts_interrupt, SA_INTERRUPT, MODNAME, 0) < 0) {
-- printk(KERN_ERR "hp680_touchscreen.c : Can't allocate irq %d\n",
-+ hp680_ts_dev = input_allocate_device();
-+ if (!hp680_ts_dev)
-+ return -ENOMEM;
-+
-+ hp680_ts_dev->evbit[0] = BIT(EV_ABS) | BIT(EV_KEY);
-+ hp680_ts_dev->absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-+ hp680_ts_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+
-+ hp680_ts_dev->absmin[ABS_X] = HP680_TS_ABS_X_MIN;
-+ hp680_ts_dev->absmin[ABS_Y] = HP680_TS_ABS_Y_MIN;
-+ hp680_ts_dev->absmax[ABS_X] = HP680_TS_ABS_X_MAX;
-+ hp680_ts_dev->absmax[ABS_Y] = HP680_TS_ABS_Y_MAX;
-+
-+ hp680_ts_dev->name = "HP Jornada touchscreen";
-+ hp680_ts_dev->phys = "hp680_ts/input0";
-+
-+ input_register_device(hp680_ts_dev);
-+
-+ if (request_irq(HP680_TS_IRQ, hp680_ts_interrupt,
-+ SA_INTERRUPT, MODNAME, 0) < 0) {
-+ printk(KERN_ERR "hp680_touchscreen.c: Can't allocate irq %d\n",
- HP680_TS_IRQ);
-- input_unregister_device(&hp680_ts_dev);
-+ input_unregister_device(hp680_ts_dev);
- return -EBUSY;
- }
-
-@@ -124,7 +124,7 @@ static void __exit hp680_ts_exit(void)
- free_irq(HP680_TS_IRQ, 0);
- cancel_delayed_work(&work);
- flush_scheduled_work();
-- input_unregister_device(&hp680_ts_dev);
-+ input_unregister_device(hp680_ts_dev);
- }
-
- module_init(hp680_ts_init);
diff --git a/driver/input-convert-to-dynamic-ucb1x00-ts.patch b/driver/input-convert-to-dynamic-ucb1x00-ts.patch
deleted file mode 100644
index 91258c688a3b6..0000000000000
--- a/driver/input-convert-to-dynamic-ucb1x00-ts.patch
+++ /dev/null
@@ -1,104 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:18 2005
-Message-Id: <20050915070304.210476000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:48 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 17/28] Input: convert ucb1x00-ts to dynamic input_dev allocation
-
-Input: convert ucb1x00-ts to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/mfd/ucb1x00-ts.c | 45 +++++++++++++++++++++++++--------------------
- 1 file changed, 25 insertions(+), 20 deletions(-)
-
---- gregkh-2.6.orig/drivers/mfd/ucb1x00-ts.c
-+++ gregkh-2.6/drivers/mfd/ucb1x00-ts.c
-@@ -40,7 +40,7 @@
-
-
- struct ucb1x00_ts {
-- struct input_dev idev;
-+ struct input_dev *idev;
- struct ucb1x00 *ucb;
-
- wait_queue_head_t irq_wait;
-@@ -56,16 +56,16 @@ static int adcsync;
-
- static inline void ucb1x00_ts_evt_add(struct ucb1x00_ts *ts, u16 pressure, u16 x, u16 y)
- {
-- input_report_abs(&ts->idev, ABS_X, x);
-- input_report_abs(&ts->idev, ABS_Y, y);
-- input_report_abs(&ts->idev, ABS_PRESSURE, pressure);
-- input_sync(&ts->idev);
-+ input_report_abs(ts->idev, ABS_X, x);
-+ input_report_abs(ts->idev, ABS_Y, y);
-+ input_report_abs(ts->idev, ABS_PRESSURE, pressure);
-+ input_sync(ts->idev);
- }
-
- static inline void ucb1x00_ts_event_release(struct ucb1x00_ts *ts)
- {
-- input_report_abs(&ts->idev, ABS_PRESSURE, 0);
-- input_sync(&ts->idev);
-+ input_report_abs(ts->idev, ABS_PRESSURE, 0);
-+ input_sync(ts->idev);
- }
-
- /*
-@@ -341,26 +341,30 @@ static int ucb1x00_ts_add(struct ucb1x00
- {
- struct ucb1x00_ts *ts;
-
-- ts = kmalloc(sizeof(struct ucb1x00_ts), GFP_KERNEL);
-+ ts = kzalloc(sizeof(struct ucb1x00_ts), GFP_KERNEL);
- if (!ts)
- return -ENOMEM;
-
-- memset(ts, 0, sizeof(struct ucb1x00_ts));
-+ ts->idev = input_allocate_device();
-+ if (!ts->idev) {
-+ kfree(ts);
-+ return -ENOMEM;
-+ }
-
- ts->ucb = dev->ucb;
- ts->adcsync = adcsync ? UCB_SYNC : UCB_NOSYNC;
-
-- ts->idev.name = "Touchscreen panel";
-- ts->idev.id.product = ts->ucb->id;
-- ts->idev.open = ucb1x00_ts_open;
-- ts->idev.close = ucb1x00_ts_close;
--
-- __set_bit(EV_ABS, ts->idev.evbit);
-- __set_bit(ABS_X, ts->idev.absbit);
-- __set_bit(ABS_Y, ts->idev.absbit);
-- __set_bit(ABS_PRESSURE, ts->idev.absbit);
-+ ts->idev->name = "Touchscreen panel";
-+ ts->idev->id.product = ts->ucb->id;
-+ ts->idev->open = ucb1x00_ts_open;
-+ ts->idev->close = ucb1x00_ts_close;
-+
-+ __set_bit(EV_ABS, ts->idev->evbit);
-+ __set_bit(ABS_X, ts->idev->absbit);
-+ __set_bit(ABS_Y, ts->idev->absbit);
-+ __set_bit(ABS_PRESSURE, ts->idev->absbit);
-
-- input_register_device(&ts->idev);
-+ input_register_device(ts->idev);
-
- dev->priv = ts;
-
-@@ -370,7 +374,8 @@ static int ucb1x00_ts_add(struct ucb1x00
- static void ucb1x00_ts_remove(struct ucb1x00_dev *dev)
- {
- struct ucb1x00_ts *ts = dev->priv;
-- input_unregister_device(&ts->idev);
-+
-+ input_unregister_device(ts->idev);
- kfree(ts);
- }
-
diff --git a/driver/input-convert-to-dynamic-usb.patch b/driver/input-convert-to-dynamic-usb.patch
deleted file mode 100644
index eddda8fd16af0..0000000000000
--- a/driver/input-convert-to-dynamic-usb.patch
+++ /dev/null
@@ -1,3561 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:08 2005
-Message-Id: <20050915070304.070090000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:47 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 16/28] drivers/usb/input: convert to dynamic input_dev allocation
-
-Input: convert drivers/iusb/input to dynamic input_dev allocation
-
-This is required for input_dev sysfs integration
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/usb/input/acecad.c | 78 ++++++-------
- drivers/usb/input/aiptek.c | 209 ++++++++++++++++--------------------
- drivers/usb/input/appletouch.c | 130 +++++++++++-----------
- drivers/usb/input/ati_remote.c | 173 +++++++++++++++--------------
- drivers/usb/input/hid-core.c | 51 ++++----
- drivers/usb/input/hid-input.c | 58 +++++-----
- drivers/usb/input/hid-lgff.c | 17 +-
- drivers/usb/input/hid-tmff.c | 11 +
- drivers/usb/input/hid.h | 2
- drivers/usb/input/itmtouch.c | 72 +++++++-----
- drivers/usb/input/kbtab.c | 86 ++++++--------
- drivers/usb/input/keyspan_remote.c | 214 +++++++++++++++----------------------
- drivers/usb/input/mtouchusb.c | 111 +++++++++----------
- drivers/usb/input/pid.c | 12 +-
- drivers/usb/input/powermate.c | 136 ++++++++++++-----------
- drivers/usb/input/touchkitusb.c | 116 +++++++++-----------
- drivers/usb/input/usbkbd.c | 105 +++++++++---------
- drivers/usb/input/usbmouse.c | 97 ++++++++--------
- drivers/usb/input/wacom.c | 142 +++++++++++-------------
- drivers/usb/input/xpad.c | 97 +++++++---------
- drivers/usb/input/yealink.c | 66 ++++++-----
- 21 files changed, 971 insertions(+), 1012 deletions(-)
-
---- gregkh-2.6.orig/drivers/usb/input/hid-input.c
-+++ gregkh-2.6/drivers/usb/input/hid-input.c
-@@ -76,8 +76,8 @@ static struct {
- static void hidinput_configure_usage(struct hid_input *hidinput, struct hid_field *field,
- struct hid_usage *usage)
- {
-- struct input_dev *input = &hidinput->input;
-- struct hid_device *device = hidinput->input.private;
-+ struct input_dev *input = hidinput->input;
-+ struct hid_device *device = input->private;
- int max = 0, code;
- unsigned long *bit = NULL;
-
-@@ -461,7 +461,8 @@ void hidinput_hid_event(struct hid_devic
-
- if (!field->hidinput)
- return;
-- input = &field->hidinput->input;
-+
-+ input = field->hidinput->input;
-
- input_regs(input, regs);
-
-@@ -533,13 +534,10 @@ void hidinput_hid_event(struct hid_devic
-
- void hidinput_report_event(struct hid_device *hid, struct hid_report *report)
- {
-- struct list_head *lh;
- struct hid_input *hidinput;
-
-- list_for_each (lh, &hid->inputs) {
-- hidinput = list_entry(lh, struct hid_input, list);
-- input_sync(&hidinput->input);
-- }
-+ list_for_each_entry(hidinput, &hid->inputs, list)
-+ input_sync(hidinput->input);
- }
-
- static int hidinput_find_field(struct hid_device *hid, unsigned int type, unsigned int code, struct hid_field **field)
-@@ -604,6 +602,7 @@ int hidinput_connect(struct hid_device *
- struct usb_device *dev = hid->dev;
- struct hid_report *report;
- struct hid_input *hidinput = NULL;
-+ struct input_dev *input_dev;
- int i, j, k;
-
- INIT_LIST_HEAD(&hid->inputs);
-@@ -624,25 +623,28 @@ int hidinput_connect(struct hid_device *
- continue;
-
- if (!hidinput) {
-- hidinput = kmalloc(sizeof(*hidinput), GFP_KERNEL);
-- if (!hidinput) {
-+ hidinput = kzalloc(sizeof(*hidinput), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!hidinput || !input_dev) {
-+ kfree(hidinput);
-+ input_free_device(input_dev);
- err("Out of memory during hid input probe");
- return -1;
- }
-- memset(hidinput, 0, sizeof(*hidinput));
-
-- list_add_tail(&hidinput->list, &hid->inputs);
-+ input_dev->private = hid;
-+ input_dev->event = hidinput_input_event;
-+ input_dev->open = hidinput_open;
-+ input_dev->close = hidinput_close;
-+
-+ input_dev->name = hid->name;
-+ input_dev->phys = hid->phys;
-+ input_dev->uniq = hid->uniq;
-+ usb_to_input_id(dev, &input_dev->id);
-+ input_dev->cdev.dev = &hid->intf->dev;
-
-- hidinput->input.private = hid;
-- hidinput->input.event = hidinput_input_event;
-- hidinput->input.open = hidinput_open;
-- hidinput->input.close = hidinput_close;
--
-- hidinput->input.name = hid->name;
-- hidinput->input.phys = hid->phys;
-- hidinput->input.uniq = hid->uniq;
-- usb_to_input_id(dev, &hidinput->input.id);
-- hidinput->input.dev = &hid->intf->dev;
-+ hidinput->input = input_dev;
-+ list_add_tail(&hidinput->list, &hid->inputs);
- }
-
- for (i = 0; i < report->maxfield; i++)
-@@ -657,7 +659,7 @@ int hidinput_connect(struct hid_device *
- * UGCI) cram a lot of unrelated inputs into the
- * same interface. */
- hidinput->report = report;
-- input_register_device(&hidinput->input);
-+ input_register_device(hidinput->input);
- hidinput = NULL;
- }
- }
-@@ -667,7 +669,7 @@ int hidinput_connect(struct hid_device *
- * only useful in this case, and not for multi-input quirks. */
- if (hidinput) {
- hid_ff_init(hid);
-- input_register_device(&hidinput->input);
-+ input_register_device(hidinput->input);
- }
-
- return 0;
-@@ -675,13 +677,11 @@ int hidinput_connect(struct hid_device *
-
- void hidinput_disconnect(struct hid_device *hid)
- {
-- struct list_head *lh, *next;
-- struct hid_input *hidinput;
-+ struct hid_input *hidinput, *next;
-
-- list_for_each_safe(lh, next, &hid->inputs) {
-- hidinput = list_entry(lh, struct hid_input, list);
-- input_unregister_device(&hidinput->input);
-+ list_for_each_entry_safe(hidinput, next, &hid->inputs, list) {
- list_del(&hidinput->list);
-+ input_unregister_device(hidinput->input);
- kfree(hidinput);
- }
- }
---- gregkh-2.6.orig/drivers/usb/input/wacom.c
-+++ gregkh-2.6/drivers/usb/input/wacom.c
-@@ -111,7 +111,7 @@ struct wacom_features {
- struct wacom {
- signed char *data;
- dma_addr_t data_dma;
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct usb_device *usbdev;
- struct urb *irq;
- struct wacom_features *features;
-@@ -135,7 +135,7 @@ static void wacom_pl_irq(struct urb *urb
- {
- struct wacom *wacom = urb->context;
- unsigned char *data = wacom->data;
-- struct input_dev *dev = &wacom->dev;
-+ struct input_dev *dev = wacom->dev;
- int prox, pressure;
- int retval;
-
-@@ -225,7 +225,7 @@ static void wacom_ptu_irq(struct urb *ur
- {
- struct wacom *wacom = urb->context;
- unsigned char *data = wacom->data;
-- struct input_dev *dev = &wacom->dev;
-+ struct input_dev *dev = wacom->dev;
- int retval;
-
- switch (urb->status) {
-@@ -275,7 +275,7 @@ static void wacom_penpartner_irq(struct
- {
- struct wacom *wacom = urb->context;
- unsigned char *data = wacom->data;
-- struct input_dev *dev = &wacom->dev;
-+ struct input_dev *dev = wacom->dev;
- int retval;
-
- switch (urb->status) {
-@@ -318,7 +318,7 @@ static void wacom_graphire_irq(struct ur
- {
- struct wacom *wacom = urb->context;
- unsigned char *data = wacom->data;
-- struct input_dev *dev = &wacom->dev;
-+ struct input_dev *dev = wacom->dev;
- int x, y;
- int retval;
-
-@@ -397,7 +397,7 @@ static int wacom_intuos_inout(struct urb
- {
- struct wacom *wacom = urb->context;
- unsigned char *data = wacom->data;
-- struct input_dev *dev = &wacom->dev;
-+ struct input_dev *dev = wacom->dev;
- int idx;
-
- /* tool number */
-@@ -479,7 +479,7 @@ static void wacom_intuos_general(struct
- {
- struct wacom *wacom = urb->context;
- unsigned char *data = wacom->data;
-- struct input_dev *dev = &wacom->dev;
-+ struct input_dev *dev = wacom->dev;
- unsigned int t;
-
- /* general pen packet */
-@@ -509,7 +509,7 @@ static void wacom_intuos_irq(struct urb
- {
- struct wacom *wacom = urb->context;
- unsigned char *data = wacom->data;
-- struct input_dev *dev = &wacom->dev;
-+ struct input_dev *dev = wacom->dev;
- unsigned int t;
- int idx;
- int retval;
-@@ -738,95 +738,83 @@ static int wacom_probe(struct usb_interf
- {
- struct usb_device *dev = interface_to_usbdev(intf);
- struct usb_endpoint_descriptor *endpoint;
-- char rep_data[2] = {0x02, 0x02};
- struct wacom *wacom;
-- char path[64];
-+ struct input_dev *input_dev;
-+ char rep_data[2] = {0x02, 0x02};
-
-- if (!(wacom = kmalloc(sizeof(struct wacom), GFP_KERNEL)))
-- return -ENOMEM;
-- memset(wacom, 0, sizeof(struct wacom));
-+ wacom = kzalloc(sizeof(struct wacom), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!wacom || !input_dev)
-+ goto fail1;
-
- wacom->data = usb_buffer_alloc(dev, 10, GFP_KERNEL, &wacom->data_dma);
-- if (!wacom->data) {
-- kfree(wacom);
-- return -ENOMEM;
-- }
-+ if (!wacom->data)
-+ goto fail1;
-
- wacom->irq = usb_alloc_urb(0, GFP_KERNEL);
-- if (!wacom->irq) {
-- usb_buffer_free(dev, 10, wacom->data, wacom->data_dma);
-- kfree(wacom);
-- return -ENOMEM;
-- }
-+ if (!wacom->irq)
-+ goto fail2;
-+
-+ wacom->usbdev = dev;
-+ wacom->dev = input_dev;
-+ usb_make_path(dev, wacom->phys, sizeof(wacom->phys));
-+ strlcat(wacom->phys, "/input0", sizeof(wacom->phys));
-
- wacom->features = wacom_features + (id - wacom_ids);
-+ if (wacom->features->pktlen > 10)
-+ BUG();
-
-- wacom->dev.evbit[0] |= BIT(EV_KEY) | BIT(EV_ABS);
-- wacom->dev.absbit[0] |= BIT(ABS_X) | BIT(ABS_Y) | BIT(ABS_PRESSURE);
-- wacom->dev.keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_PEN) | BIT(BTN_TOUCH) | BIT(BTN_STYLUS);
-+ input_dev->name = wacom->features->name;
-+ usb_to_input_id(dev, &input_dev->id);
-+
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = wacom;
-+ input_dev->open = wacom_open;
-+ input_dev->close = wacom_close;
-+
-+ input_dev->evbit[0] |= BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_PEN) | BIT(BTN_TOUCH) | BIT(BTN_STYLUS);
-+ input_set_abs_params(input_dev, ABS_X, 0, wacom->features->y_max, 4, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 0, wacom->features->y_max, 4, 0);
-+ input_set_abs_params(input_dev, ABS_PRESSURE, 0, wacom->features->pressure_max, 0, 0);
-
- switch (wacom->features->type) {
- case GRAPHIRE:
-- wacom->dev.evbit[0] |= BIT(EV_REL);
-- wacom->dev.relbit[0] |= BIT(REL_WHEEL);
-- wacom->dev.absbit[0] |= BIT(ABS_DISTANCE);
-- wacom->dev.keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
-- wacom->dev.keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_RUBBER) | BIT(BTN_TOOL_MOUSE) | BIT(BTN_STYLUS2);
-+ input_dev->evbit[0] |= BIT(EV_REL);
-+ input_dev->relbit[0] |= BIT(REL_WHEEL);
-+ input_dev->keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
-+ input_dev->keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_RUBBER) | BIT(BTN_TOOL_MOUSE) | BIT(BTN_STYLUS2);
-+ input_set_abs_params(input_dev, ABS_DISTANCE, 0, wacom->features->distance_max, 0, 0);
- break;
-
- case INTUOS3:
- case CINTIQ:
-- wacom->dev.keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_FINGER);
-- wacom->dev.keybit[LONG(BTN_LEFT)] |= BIT(BTN_0) | BIT(BTN_1) | BIT(BTN_2) | BIT(BTN_3) | BIT(BTN_4) | BIT(BTN_5) | BIT(BTN_6) | BIT(BTN_7);
-- wacom->dev.absbit[0] |= BIT(ABS_RX) | BIT(ABS_RY);
-+ input_dev->keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_FINGER);
-+ input_dev->keybit[LONG(BTN_LEFT)] |= BIT(BTN_0) | BIT(BTN_1) | BIT(BTN_2) | BIT(BTN_3) | BIT(BTN_4) | BIT(BTN_5) | BIT(BTN_6) | BIT(BTN_7);
-+ input_set_abs_params(input_dev, ABS_RX, 0, 4097, 0, 0);
-+ input_set_abs_params(input_dev, ABS_RY, 0, 4097, 0, 0);
- /* fall through */
-
- case INTUOS:
-- wacom->dev.evbit[0] |= BIT(EV_MSC) | BIT(EV_REL);
-- wacom->dev.mscbit[0] |= BIT(MSC_SERIAL);
-- wacom->dev.relbit[0] |= BIT(REL_WHEEL);
-- wacom->dev.keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE) | BIT(BTN_SIDE) | BIT(BTN_EXTRA);
-- wacom->dev.keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_RUBBER) | BIT(BTN_TOOL_MOUSE) | BIT(BTN_TOOL_BRUSH)
-+ input_dev->evbit[0] |= BIT(EV_MSC) | BIT(EV_REL);
-+ input_dev->mscbit[0] |= BIT(MSC_SERIAL);
-+ input_dev->relbit[0] |= BIT(REL_WHEEL);
-+ input_dev->keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE) | BIT(BTN_SIDE) | BIT(BTN_EXTRA);
-+ input_dev->keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_RUBBER) | BIT(BTN_TOOL_MOUSE) | BIT(BTN_TOOL_BRUSH)
- | BIT(BTN_TOOL_PENCIL) | BIT(BTN_TOOL_AIRBRUSH) | BIT(BTN_TOOL_LENS) | BIT(BTN_STYLUS2);
-- wacom->dev.absbit[0] |= BIT(ABS_DISTANCE) | BIT(ABS_WHEEL) | BIT(ABS_TILT_X) | BIT(ABS_TILT_Y) | BIT(ABS_RZ) | BIT(ABS_THROTTLE);
-+ input_set_abs_params(input_dev, ABS_DISTANCE, 0, wacom->features->distance_max, 0, 0);
-+ input_set_abs_params(input_dev, ABS_WHEEL, 0, 1023, 0, 0);
-+ input_set_abs_params(input_dev, ABS_TILT_X, 0, 127, 0, 0);
-+ input_set_abs_params(input_dev, ABS_TILT_Y, 0, 127, 0, 0);
-+ input_set_abs_params(input_dev, ABS_RZ, -900, 899, 0, 0);
-+ input_set_abs_params(input_dev, ABS_THROTTLE, -1023, 1023, 0, 0);
- break;
-
- case PL:
-- wacom->dev.keybit[LONG(BTN_DIGI)] |= BIT(BTN_STYLUS2) | BIT(BTN_TOOL_RUBBER);
-+ input_dev->keybit[LONG(BTN_DIGI)] |= BIT(BTN_STYLUS2) | BIT(BTN_TOOL_RUBBER);
- break;
- }
-
-- wacom->dev.absmax[ABS_X] = wacom->features->x_max;
-- wacom->dev.absmax[ABS_Y] = wacom->features->y_max;
-- wacom->dev.absmax[ABS_PRESSURE] = wacom->features->pressure_max;
-- wacom->dev.absmax[ABS_DISTANCE] = wacom->features->distance_max;
-- wacom->dev.absmax[ABS_TILT_X] = 127;
-- wacom->dev.absmax[ABS_TILT_Y] = 127;
-- wacom->dev.absmax[ABS_WHEEL] = 1023;
--
-- wacom->dev.absmax[ABS_RX] = 4097;
-- wacom->dev.absmax[ABS_RY] = 4097;
-- wacom->dev.absmin[ABS_RZ] = -900;
-- wacom->dev.absmax[ABS_RZ] = 899;
-- wacom->dev.absmin[ABS_THROTTLE] = -1023;
-- wacom->dev.absmax[ABS_THROTTLE] = 1023;
--
-- wacom->dev.absfuzz[ABS_X] = 4;
-- wacom->dev.absfuzz[ABS_Y] = 4;
--
-- wacom->dev.private = wacom;
-- wacom->dev.open = wacom_open;
-- wacom->dev.close = wacom_close;
--
-- usb_make_path(dev, path, 64);
-- sprintf(wacom->phys, "%s/input0", path);
--
-- wacom->dev.name = wacom->features->name;
-- wacom->dev.phys = wacom->phys;
-- usb_to_input_id(dev, &wacom->dev.id);
-- wacom->dev.dev = &intf->dev;
-- wacom->usbdev = dev;
--
- endpoint = &intf->cur_altsetting->endpoint[0].desc;
-
- if (wacom->features->pktlen > 10)
-@@ -839,18 +827,20 @@ static int wacom_probe(struct usb_interf
- wacom->irq->transfer_dma = wacom->data_dma;
- wacom->irq->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-
-- input_register_device(&wacom->dev);
-+ input_register_device(wacom->dev);
-
- /* ask the tablet to report tablet data */
- usb_set_report(intf, 3, 2, rep_data, 2);
- /* repeat once (not sure why the first call often fails) */
- usb_set_report(intf, 3, 2, rep_data, 2);
-
-- printk(KERN_INFO "input: %s on %s\n", wacom->features->name, path);
--
- usb_set_intfdata(intf, wacom);
--
- return 0;
-+
-+fail2: usb_buffer_free(dev, 10, wacom->data, wacom->data_dma);
-+fail1: input_free_device(input_dev);
-+ kfree(wacom);
-+ return -ENOMEM;
- }
-
- static void wacom_disconnect(struct usb_interface *intf)
-@@ -860,7 +850,7 @@ static void wacom_disconnect(struct usb_
- usb_set_intfdata(intf, NULL);
- if (wacom) {
- usb_kill_urb(wacom->irq);
-- input_unregister_device(&wacom->dev);
-+ input_unregister_device(wacom->dev);
- usb_free_urb(wacom->irq);
- usb_buffer_free(interface_to_usbdev(intf), 10, wacom->data, wacom->data_dma);
- kfree(wacom);
---- gregkh-2.6.orig/drivers/usb/input/aiptek.c
-+++ gregkh-2.6/drivers/usb/input/aiptek.c
-@@ -317,7 +317,7 @@ struct aiptek_settings {
- };
-
- struct aiptek {
-- struct input_dev inputdev; /* input device struct */
-+ struct input_dev *inputdev; /* input device struct */
- struct usb_device *usbdev; /* usb device struct */
- struct urb *urb; /* urb for incoming reports */
- dma_addr_t data_dma; /* our dma stuffage */
-@@ -402,7 +402,7 @@ static void aiptek_irq(struct urb *urb,
- {
- struct aiptek *aiptek = urb->context;
- unsigned char *data = aiptek->data;
-- struct input_dev *inputdev = &aiptek->inputdev;
-+ struct input_dev *inputdev = aiptek->inputdev;
- int jitterable = 0;
- int retval, macro, x, y, z, left, right, middle, p, dv, tip, bs, pck;
-
-@@ -955,20 +955,20 @@ static int aiptek_program_tablet(struct
- /* Query getXextension */
- if ((ret = aiptek_query(aiptek, 0x01, 0x00)) < 0)
- return ret;
-- aiptek->inputdev.absmin[ABS_X] = 0;
-- aiptek->inputdev.absmax[ABS_X] = ret - 1;
-+ aiptek->inputdev->absmin[ABS_X] = 0;
-+ aiptek->inputdev->absmax[ABS_X] = ret - 1;
-
- /* Query getYextension */
- if ((ret = aiptek_query(aiptek, 0x01, 0x01)) < 0)
- return ret;
-- aiptek->inputdev.absmin[ABS_Y] = 0;
-- aiptek->inputdev.absmax[ABS_Y] = ret - 1;
-+ aiptek->inputdev->absmin[ABS_Y] = 0;
-+ aiptek->inputdev->absmax[ABS_Y] = ret - 1;
-
- /* Query getPressureLevels */
- if ((ret = aiptek_query(aiptek, 0x08, 0x00)) < 0)
- return ret;
-- aiptek->inputdev.absmin[ABS_PRESSURE] = 0;
-- aiptek->inputdev.absmax[ABS_PRESSURE] = ret - 1;
-+ aiptek->inputdev->absmin[ABS_PRESSURE] = 0;
-+ aiptek->inputdev->absmax[ABS_PRESSURE] = ret - 1;
-
- /* Depending on whether we are in absolute or relative mode, we will
- * do a switchToTablet(absolute) or switchToMouse(relative) command.
-@@ -1025,8 +1025,8 @@ static ssize_t show_tabletSize(struct de
- return 0;
-
- return snprintf(buf, PAGE_SIZE, "%dx%d\n",
-- aiptek->inputdev.absmax[ABS_X] + 1,
-- aiptek->inputdev.absmax[ABS_Y] + 1);
-+ aiptek->inputdev->absmax[ABS_X] + 1,
-+ aiptek->inputdev->absmax[ABS_Y] + 1);
- }
-
- /* These structs define the sysfs files, param #1 is the name of the
-@@ -1048,7 +1048,7 @@ static ssize_t show_tabletProductId(stru
- return 0;
-
- return snprintf(buf, PAGE_SIZE, "0x%04x\n",
-- aiptek->inputdev.id.product);
-+ aiptek->inputdev->id.product);
- }
-
- static DEVICE_ATTR(product_id, S_IRUGO, show_tabletProductId, NULL);
-@@ -1063,7 +1063,7 @@ static ssize_t show_tabletVendorId(struc
- if (aiptek == NULL)
- return 0;
-
-- return snprintf(buf, PAGE_SIZE, "0x%04x\n", aiptek->inputdev.id.vendor);
-+ return snprintf(buf, PAGE_SIZE, "0x%04x\n", aiptek->inputdev->id.vendor);
- }
-
- static DEVICE_ATTR(vendor_id, S_IRUGO, show_tabletVendorId, NULL);
-@@ -1977,7 +1977,6 @@ aiptek_probe(struct usb_interface *intf,
- struct input_dev *inputdev;
- struct input_handle *inputhandle;
- struct list_head *node, *next;
-- char path[64 + 1];
- int i;
- int speeds[] = { 0,
- AIPTEK_PROGRAMMABLE_DELAY_50,
-@@ -1996,24 +1995,26 @@ aiptek_probe(struct usb_interface *intf,
- */
- speeds[0] = programmableDelay;
-
-- if ((aiptek = kmalloc(sizeof(struct aiptek), GFP_KERNEL)) == NULL)
-- return -ENOMEM;
-- memset(aiptek, 0, sizeof(struct aiptek));
-+ aiptek = kzalloc(sizeof(struct aiptek), GFP_KERNEL);
-+ inputdev = input_allocate_device();
-+ if (!aiptek || !inputdev)
-+ goto fail1;
-
- aiptek->data = usb_buffer_alloc(usbdev, AIPTEK_PACKET_LENGTH,
- SLAB_ATOMIC, &aiptek->data_dma);
-- if (aiptek->data == NULL) {
-- kfree(aiptek);
-- return -ENOMEM;
-- }
-+ if (!aiptek->data)
-+ goto fail1;
-
- aiptek->urb = usb_alloc_urb(0, GFP_KERNEL);
-- if (aiptek->urb == NULL) {
-- usb_buffer_free(usbdev, AIPTEK_PACKET_LENGTH, aiptek->data,
-- aiptek->data_dma);
-- kfree(aiptek);
-- return -ENOMEM;
-- }
-+ if (!aiptek->urb)
-+ goto fail2;
-+
-+ aiptek->inputdev = inputdev;
-+ aiptek->usbdev = usbdev;
-+ aiptek->ifnum = intf->altsetting[0].desc.bInterfaceNumber;
-+ aiptek->inDelay = 0;
-+ aiptek->endDelay = 0;
-+ aiptek->previousJitterable = 0;
-
- /* Set up the curSettings struct. Said struct contains the current
- * programmable parameters. The newSetting struct contains changes
-@@ -2036,31 +2037,48 @@ aiptek_probe(struct usb_interface *intf,
-
- /* Both structs should have equivalent settings
- */
-- memcpy(&aiptek->newSetting, &aiptek->curSetting,
-- sizeof(struct aiptek_settings));
-+ aiptek->newSetting = aiptek->curSetting;
-+
-+ /* Determine the usb devices' physical path.
-+ * Asketh not why we always pretend we're using "../input0",
-+ * but I suspect this will have to be refactored one
-+ * day if a single USB device can be a keyboard & a mouse
-+ * & a tablet, and the inputX number actually will tell
-+ * us something...
-+ */
-+ usb_make_path(usbdev, aiptek->features.usbPath,
-+ sizeof(aiptek->features.usbPath));
-+ strlcat(aiptek->features.usbPath, "/input0",
-+ sizeof(aiptek->features.usbPath));
-+
-+ /* Set up client data, pointers to open and close routines
-+ * for the input device.
-+ */
-+ inputdev->name = "Aiptek";
-+ inputdev->phys = aiptek->features.usbPath;
-+ usb_to_input_id(usbdev, &inputdev->id);
-+ inputdev->cdev.dev = &intf->dev;
-+ inputdev->private = aiptek;
-+ inputdev->open = aiptek_open;
-+ inputdev->close = aiptek_close;
-
- /* Now program the capacities of the tablet, in terms of being
- * an input device.
- */
-- aiptek->inputdev.evbit[0] |= BIT(EV_KEY)
-+ inputdev->evbit[0] |= BIT(EV_KEY)
- | BIT(EV_ABS)
- | BIT(EV_REL)
- | BIT(EV_MSC);
-
-- aiptek->inputdev.absbit[0] |=
-- (BIT(ABS_X) |
-- BIT(ABS_Y) |
-- BIT(ABS_PRESSURE) |
-- BIT(ABS_TILT_X) |
-- BIT(ABS_TILT_Y) | BIT(ABS_WHEEL) | BIT(ABS_MISC));
-+ inputdev->absbit[0] |= BIT(ABS_MISC);
-
-- aiptek->inputdev.relbit[0] |=
-+ inputdev->relbit[0] |=
- (BIT(REL_X) | BIT(REL_Y) | BIT(REL_WHEEL) | BIT(REL_MISC));
-
-- aiptek->inputdev.keybit[LONG(BTN_LEFT)] |=
-+ inputdev->keybit[LONG(BTN_LEFT)] |=
- (BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE));
-
-- aiptek->inputdev.keybit[LONG(BTN_DIGI)] |=
-+ inputdev->keybit[LONG(BTN_DIGI)] |=
- (BIT(BTN_TOOL_PEN) |
- BIT(BTN_TOOL_RUBBER) |
- BIT(BTN_TOOL_PENCIL) |
-@@ -2070,70 +2088,26 @@ aiptek_probe(struct usb_interface *intf,
- BIT(BTN_TOOL_LENS) |
- BIT(BTN_TOUCH) | BIT(BTN_STYLUS) | BIT(BTN_STYLUS2));
-
-- aiptek->inputdev.mscbit[0] = BIT(MSC_SERIAL);
-+ inputdev->mscbit[0] = BIT(MSC_SERIAL);
-
- /* Programming the tablet macro keys needs to be done with a for loop
- * as the keycodes are discontiguous.
- */
- for (i = 0; i < sizeof(macroKeyEvents) / sizeof(macroKeyEvents[0]); ++i)
-- set_bit(macroKeyEvents[i], aiptek->inputdev.keybit);
--
-- /* Set up client data, pointers to open and close routines
-- * for the input device.
-- */
-- aiptek->inputdev.private = aiptek;
-- aiptek->inputdev.open = aiptek_open;
-- aiptek->inputdev.close = aiptek_close;
--
-- /* Determine the usb devices' physical path.
-- * Asketh not why we always pretend we're using "../input0",
-- * but I suspect this will have to be refactored one
-- * day if a single USB device can be a keyboard & a mouse
-- * & a tablet, and the inputX number actually will tell
-- * us something...
-- */
-- if (usb_make_path(usbdev, path, 64) > 0)
-- sprintf(aiptek->features.usbPath, "%s/input0", path);
-+ set_bit(macroKeyEvents[i], inputdev->keybit);
-
-- /* Program the input device coordinate capacities. We do not yet
-+ /*
-+ * Program the input device coordinate capacities. We do not yet
- * know what maximum X, Y, and Z values are, so we're putting fake
- * values in. Later, we'll ask the tablet to put in the correct
- * values.
- */
-- aiptek->inputdev.absmin[ABS_X] = 0;
-- aiptek->inputdev.absmax[ABS_X] = 2999;
-- aiptek->inputdev.absmin[ABS_Y] = 0;
-- aiptek->inputdev.absmax[ABS_Y] = 2249;
-- aiptek->inputdev.absmin[ABS_PRESSURE] = 0;
-- aiptek->inputdev.absmax[ABS_PRESSURE] = 511;
-- aiptek->inputdev.absmin[ABS_TILT_X] = AIPTEK_TILT_MIN;
-- aiptek->inputdev.absmax[ABS_TILT_X] = AIPTEK_TILT_MAX;
-- aiptek->inputdev.absmin[ABS_TILT_Y] = AIPTEK_TILT_MIN;
-- aiptek->inputdev.absmax[ABS_TILT_Y] = AIPTEK_TILT_MAX;
-- aiptek->inputdev.absmin[ABS_WHEEL] = AIPTEK_WHEEL_MIN;
-- aiptek->inputdev.absmax[ABS_WHEEL] = AIPTEK_WHEEL_MAX - 1;
-- aiptek->inputdev.absfuzz[ABS_X] = 0;
-- aiptek->inputdev.absfuzz[ABS_Y] = 0;
-- aiptek->inputdev.absfuzz[ABS_PRESSURE] = 0;
-- aiptek->inputdev.absfuzz[ABS_TILT_X] = 0;
-- aiptek->inputdev.absfuzz[ABS_TILT_Y] = 0;
-- aiptek->inputdev.absfuzz[ABS_WHEEL] = 0;
-- aiptek->inputdev.absflat[ABS_X] = 0;
-- aiptek->inputdev.absflat[ABS_Y] = 0;
-- aiptek->inputdev.absflat[ABS_PRESSURE] = 0;
-- aiptek->inputdev.absflat[ABS_TILT_X] = 0;
-- aiptek->inputdev.absflat[ABS_TILT_Y] = 0;
-- aiptek->inputdev.absflat[ABS_WHEEL] = 0;
-- aiptek->inputdev.name = "Aiptek";
-- aiptek->inputdev.phys = aiptek->features.usbPath;
-- usb_to_input_id(usbdev, &aiptek->inputdev.id);
-- aiptek->inputdev.dev = &intf->dev;
--
-- aiptek->usbdev = usbdev;
-- aiptek->ifnum = intf->altsetting[0].desc.bInterfaceNumber;
-- aiptek->inDelay = 0;
-- aiptek->endDelay = 0;
-- aiptek->previousJitterable = 0;
-+ input_set_abs_params(inputdev, ABS_X, 0, 2999, 0, 0);
-+ input_set_abs_params(inputdev, ABS_X, 0, 2249, 0, 0);
-+ input_set_abs_params(inputdev, ABS_PRESSURE, 0, 511, 0, 0);
-+ input_set_abs_params(inputdev, ABS_TILT_X, AIPTEK_TILT_MIN, AIPTEK_TILT_MAX, 0, 0);
-+ input_set_abs_params(inputdev, ABS_TILT_Y, AIPTEK_TILT_MIN, AIPTEK_TILT_MAX, 0, 0);
-+ input_set_abs_params(inputdev, ABS_WHEEL, AIPTEK_WHEEL_MIN, AIPTEK_WHEEL_MAX - 1, 0, 0);
-
- endpoint = &intf->altsetting[0].endpoint[0].desc;
-
-@@ -2150,28 +2124,6 @@ aiptek_probe(struct usb_interface *intf,
- aiptek->urb->transfer_dma = aiptek->data_dma;
- aiptek->urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-
-- /* Register the tablet as an Input Device
-- */
-- input_register_device(&aiptek->inputdev);
--
-- /* We now will look for the evdev device which is mapped to
-- * the tablet. The partial name is kept in the link list of
-- * input_handles associated with this input device.
-- * What identifies an evdev input_handler is that it begins
-- * with 'event', continues with a digit, and that in turn
-- * is mapped to /{devfs}/input/eventN.
-- */
-- inputdev = &aiptek->inputdev;
-- list_for_each_safe(node, next, &inputdev->h_list) {
-- inputhandle = to_handle(node);
-- if (strncmp(inputhandle->name, "event", 5) == 0) {
-- strcpy(aiptek->features.inputPath, inputhandle->name);
-- break;
-- }
-- }
--
-- info("input: Aiptek on %s (%s)\n", path, aiptek->features.inputPath);
--
- /* Program the tablet. This sets the tablet up in the mode
- * specified in newSetting, and also queries the tablet's
- * physical capacities.
-@@ -2186,13 +2138,32 @@ aiptek_probe(struct usb_interface *intf,
- for (i = 0; i < sizeof(speeds) / sizeof(speeds[0]); ++i) {
- aiptek->curSetting.programmableDelay = speeds[i];
- (void)aiptek_program_tablet(aiptek);
-- if (aiptek->inputdev.absmax[ABS_X] > 0) {
-+ if (aiptek->inputdev->absmax[ABS_X] > 0) {
- info("input: Aiptek using %d ms programming speed\n",
- aiptek->curSetting.programmableDelay);
- break;
- }
- }
-
-+ /* Register the tablet as an Input Device
-+ */
-+ input_register_device(aiptek->inputdev);
-+
-+ /* We now will look for the evdev device which is mapped to
-+ * the tablet. The partial name is kept in the link list of
-+ * input_handles associated with this input device.
-+ * What identifies an evdev input_handler is that it begins
-+ * with 'event', continues with a digit, and that in turn
-+ * is mapped to /{devfs}/input/eventN.
-+ */
-+ list_for_each_safe(node, next, &inputdev->h_list) {
-+ inputhandle = to_handle(node);
-+ if (strncmp(inputhandle->name, "event", 5) == 0) {
-+ strcpy(aiptek->features.inputPath, inputhandle->name);
-+ break;
-+ }
-+ }
-+
- /* Associate this driver's struct with the usb interface.
- */
- usb_set_intfdata(intf, aiptek);
-@@ -2207,6 +2178,12 @@ aiptek_probe(struct usb_interface *intf,
- info("aiptek: error loading 'evdev' module");
-
- return 0;
-+
-+fail2: usb_buffer_free(usbdev, AIPTEK_PACKET_LENGTH, aiptek->data,
-+ aiptek->data_dma);
-+fail1: input_free_device(inputdev);
-+ kfree(aiptek);
-+ return -ENOMEM;
- }
-
- /* Forward declaration */
-@@ -2234,7 +2211,7 @@ static void aiptek_disconnect(struct usb
- /* Free & unhook everything from the system.
- */
- usb_kill_urb(aiptek->urb);
-- input_unregister_device(&aiptek->inputdev);
-+ input_unregister_device(aiptek->inputdev);
- aiptek_delete_files(&intf->dev);
- usb_free_urb(aiptek->urb);
- usb_buffer_free(interface_to_usbdev(intf),
---- gregkh-2.6.orig/drivers/usb/input/hid.h
-+++ gregkh-2.6/drivers/usb/input/hid.h
-@@ -371,7 +371,7 @@ struct hid_control_fifo {
- struct hid_input {
- struct list_head list;
- struct hid_report *report;
-- struct input_dev input;
-+ struct input_dev *input;
- };
-
- struct hid_device { /* device report descriptor */
---- gregkh-2.6.orig/drivers/usb/input/xpad.c
-+++ gregkh-2.6/drivers/usb/input/xpad.c
-@@ -103,7 +103,7 @@ static struct usb_device_id xpad_table [
- MODULE_DEVICE_TABLE (usb, xpad_table);
-
- struct usb_xpad {
-- struct input_dev dev; /* input device interface */
-+ struct input_dev *dev; /* input device interface */
- struct usb_device *udev; /* usb device */
-
- struct urb *irq_in; /* urb for interrupt in report */
-@@ -125,7 +125,7 @@ struct usb_xpad {
-
- static void xpad_process_packet(struct usb_xpad *xpad, u16 cmd, unsigned char *data, struct pt_regs *regs)
- {
-- struct input_dev *dev = &xpad->dev;
-+ struct input_dev *dev = xpad->dev;
-
- input_regs(dev, regs);
-
-@@ -214,9 +214,9 @@ static void xpad_close (struct input_dev
- static int xpad_probe(struct usb_interface *intf, const struct usb_device_id *id)
- {
- struct usb_device *udev = interface_to_usbdev (intf);
-- struct usb_xpad *xpad = NULL;
-+ struct usb_xpad *xpad;
-+ struct input_dev *input_dev;
- struct usb_endpoint_descriptor *ep_irq_in;
-- char path[64];
- int i;
-
- for (i = 0; xpad_device[i].idVendor; i++) {
-@@ -225,89 +225,80 @@ static int xpad_probe(struct usb_interfa
- break;
- }
-
-- if ((xpad = kmalloc (sizeof(struct usb_xpad), GFP_KERNEL)) == NULL) {
-- err("cannot allocate memory for new pad");
-- return -ENOMEM;
-- }
-- memset(xpad, 0, sizeof(struct usb_xpad));
-+ xpad = kzalloc(sizeof(struct usb_xpad), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!xpad || !input_dev)
-+ goto fail1;
-
- xpad->idata = usb_buffer_alloc(udev, XPAD_PKT_LEN,
- SLAB_ATOMIC, &xpad->idata_dma);
-- if (!xpad->idata) {
-- kfree(xpad);
-- return -ENOMEM;
-- }
-+ if (!xpad->idata)
-+ goto fail1;
-
- xpad->irq_in = usb_alloc_urb(0, GFP_KERNEL);
-- if (!xpad->irq_in) {
-- err("cannot allocate memory for new pad irq urb");
-- usb_buffer_free(udev, XPAD_PKT_LEN, xpad->idata, xpad->idata_dma);
-- kfree(xpad);
-- return -ENOMEM;
-- }
--
-- ep_irq_in = &intf->cur_altsetting->endpoint[0].desc;
--
-- usb_fill_int_urb(xpad->irq_in, udev,
-- usb_rcvintpipe(udev, ep_irq_in->bEndpointAddress),
-- xpad->idata, XPAD_PKT_LEN, xpad_irq_in,
-- xpad, ep_irq_in->bInterval);
-- xpad->irq_in->transfer_dma = xpad->idata_dma;
-- xpad->irq_in->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-+ if (!xpad->irq_in)
-+ goto fail2;
-
- xpad->udev = udev;
-+ xpad->dev = input_dev;
-+ usb_make_path(udev, xpad->phys, sizeof(xpad->phys));
-+ strlcat(xpad->phys, "/input0", sizeof(xpad->phys));
-+
-+ input_dev->name = xpad_device[i].name;
-+ input_dev->phys = xpad->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = xpad;
-+ input_dev->open = xpad_open;
-+ input_dev->close = xpad_close;
-
-- usb_to_input_id(udev, &xpad->dev.id);
-- xpad->dev.dev = &intf->dev;
-- xpad->dev.private = xpad;
-- xpad->dev.name = xpad_device[i].name;
-- xpad->dev.phys = xpad->phys;
-- xpad->dev.open = xpad_open;
-- xpad->dev.close = xpad_close;
--
-- usb_make_path(udev, path, 64);
-- snprintf(xpad->phys, 64, "%s/input0", path);
--
-- xpad->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-
- for (i = 0; xpad_btn[i] >= 0; i++)
-- set_bit(xpad_btn[i], xpad->dev.keybit);
-+ set_bit(xpad_btn[i], input_dev->keybit);
-
- for (i = 0; xpad_abs[i] >= 0; i++) {
-
- signed short t = xpad_abs[i];
-
-- set_bit(t, xpad->dev.absbit);
-+ set_bit(t, input_dev->absbit);
-
- switch (t) {
- case ABS_X:
- case ABS_Y:
- case ABS_RX:
- case ABS_RY: /* the two sticks */
-- xpad->dev.absmax[t] = 32767;
-- xpad->dev.absmin[t] = -32768;
-- xpad->dev.absflat[t] = 128;
-- xpad->dev.absfuzz[t] = 16;
-+ input_set_abs_params(input_dev, t, -32768, 32767, 16, 128);
- break;
- case ABS_Z:
- case ABS_RZ: /* the triggers */
-- xpad->dev.absmax[t] = 255;
-- xpad->dev.absmin[t] = 0;
-+ input_set_abs_params(input_dev, t, 0, 255, 0, 0);
- break;
- case ABS_HAT0X:
- case ABS_HAT0Y: /* the d-pad */
-- xpad->dev.absmax[t] = 1;
-- xpad->dev.absmin[t] = -1;
-+ input_set_abs_params(input_dev, t, -1, 1, 0, 0);
- break;
- }
- }
-
-- input_register_device(&xpad->dev);
-+ ep_irq_in = &intf->cur_altsetting->endpoint[0].desc;
-+ usb_fill_int_urb(xpad->irq_in, udev,
-+ usb_rcvintpipe(udev, ep_irq_in->bEndpointAddress),
-+ xpad->idata, XPAD_PKT_LEN, xpad_irq_in,
-+ xpad, ep_irq_in->bInterval);
-+ xpad->irq_in->transfer_dma = xpad->idata_dma;
-+ xpad->irq_in->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-
-- printk(KERN_INFO "input: %s on %s", xpad->dev.name, path);
-+ input_register_device(xpad->dev);
-
- usb_set_intfdata(intf, xpad);
- return 0;
-+
-+fail2: usb_buffer_free(udev, XPAD_PKT_LEN, xpad->idata, xpad->idata_dma);
-+fail1: input_free_device(input_dev);
-+ kfree(xpad);
-+ return -ENOMEM;
-+
- }
-
- static void xpad_disconnect(struct usb_interface *intf)
-@@ -317,7 +308,7 @@ static void xpad_disconnect(struct usb_i
- usb_set_intfdata(intf, NULL);
- if (xpad) {
- usb_kill_urb(xpad->irq_in);
-- input_unregister_device(&xpad->dev);
-+ input_unregister_device(xpad->dev);
- usb_free_urb(xpad->irq_in);
- usb_buffer_free(interface_to_usbdev(intf), XPAD_PKT_LEN, xpad->idata, xpad->idata_dma);
- kfree(xpad);
---- gregkh-2.6.orig/drivers/usb/input/usbmouse.c
-+++ gregkh-2.6/drivers/usb/input/usbmouse.c
-@@ -50,7 +50,7 @@ struct usb_mouse {
- char name[128];
- char phys[64];
- struct usb_device *usbdev;
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct urb *irq;
-
- signed char *data;
-@@ -61,7 +61,7 @@ static void usb_mouse_irq(struct urb *ur
- {
- struct usb_mouse *mouse = urb->context;
- signed char *data = mouse->data;
-- struct input_dev *dev = &mouse->dev;
-+ struct input_dev *dev = mouse->dev;
- int status;
-
- switch (urb->status) {
-@@ -115,14 +115,14 @@ static void usb_mouse_close(struct input
- usb_kill_urb(mouse->irq);
- }
-
--static int usb_mouse_probe(struct usb_interface * intf, const struct usb_device_id * id)
-+static int usb_mouse_probe(struct usb_interface *intf, const struct usb_device_id *id)
- {
-- struct usb_device * dev = interface_to_usbdev(intf);
-+ struct usb_device *dev = interface_to_usbdev(intf);
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct usb_mouse *mouse;
-+ struct input_dev *input_dev;
- int pipe, maxp;
-- char path[64];
-
- interface = intf->cur_altsetting;
-
-@@ -130,59 +130,62 @@ static int usb_mouse_probe(struct usb_in
- return -ENODEV;
-
- endpoint = &interface->endpoint[0].desc;
-- if (!(endpoint->bEndpointAddress & 0x80))
-+ if (!(endpoint->bEndpointAddress & USB_DIR_IN))
- return -ENODEV;
-- if ((endpoint->bmAttributes & 3) != 3)
-+ if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) != USB_ENDPOINT_XFER_INT)
- return -ENODEV;
-
- pipe = usb_rcvintpipe(dev, endpoint->bEndpointAddress);
- maxp = usb_maxpacket(dev, pipe, usb_pipeout(pipe));
-
-- if (!(mouse = kmalloc(sizeof(struct usb_mouse), GFP_KERNEL)))
-- return -ENOMEM;
-- memset(mouse, 0, sizeof(struct usb_mouse));
-+ mouse = kzalloc(sizeof(struct usb_mouse), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!mouse || !input_dev)
-+ goto fail1;
-
- mouse->data = usb_buffer_alloc(dev, 8, SLAB_ATOMIC, &mouse->data_dma);
-- if (!mouse->data) {
-- kfree(mouse);
-- return -ENOMEM;
-- }
-+ if (!mouse->data)
-+ goto fail1;
-
- mouse->irq = usb_alloc_urb(0, GFP_KERNEL);
-- if (!mouse->irq) {
-- usb_buffer_free(dev, 8, mouse->data, mouse->data_dma);
-- kfree(mouse);
-- return -ENODEV;
-- }
-+ if (!mouse->irq)
-+ goto fail2;
-
- mouse->usbdev = dev;
--
-- mouse->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-- mouse->dev.keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
-- mouse->dev.relbit[0] = BIT(REL_X) | BIT(REL_Y);
-- mouse->dev.keybit[LONG(BTN_MOUSE)] |= BIT(BTN_SIDE) | BIT(BTN_EXTRA);
-- mouse->dev.relbit[0] |= BIT(REL_WHEEL);
--
-- mouse->dev.private = mouse;
-- mouse->dev.open = usb_mouse_open;
-- mouse->dev.close = usb_mouse_close;
--
-- usb_make_path(dev, path, 64);
-- sprintf(mouse->phys, "%s/input0", path);
--
-- mouse->dev.name = mouse->name;
-- mouse->dev.phys = mouse->phys;
-- usb_to_input_id(dev, &mouse->dev.id);
-- mouse->dev.dev = &intf->dev;
-+ mouse->dev = input_dev;
-
- if (dev->manufacturer)
-- strcat(mouse->name, dev->manufacturer);
-- if (dev->product)
-- sprintf(mouse->name, "%s %s", mouse->name, dev->product);
-+ strlcpy(mouse->name, dev->manufacturer, sizeof(mouse->name));
-+
-+ if (dev->product) {
-+ if (dev->manufacturer)
-+ strlcat(mouse->name, " ", sizeof(mouse->name));
-+ strlcat(mouse->name, dev->product, sizeof(mouse->name));
-+ }
-
- if (!strlen(mouse->name))
-- sprintf(mouse->name, "USB HIDBP Mouse %04x:%04x",
-- mouse->dev.id.vendor, mouse->dev.id.product);
-+ snprintf(mouse->name, sizeof(mouse->name),
-+ "USB HIDBP Mouse %04x:%04x",
-+ le16_to_cpu(dev->descriptor.idVendor),
-+ le16_to_cpu(dev->descriptor.idProduct));
-+
-+ usb_make_path(dev, mouse->phys, sizeof(mouse->phys));
-+ strlcat(mouse->phys, "/input0", sizeof(mouse->phys));
-+
-+ input_dev->name = mouse->name;
-+ input_dev->phys = mouse->phys;
-+ usb_to_input_id(dev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-+ input_dev->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
-+ input_dev->relbit[0] = BIT(REL_X) | BIT(REL_Y);
-+ input_dev->keybit[LONG(BTN_MOUSE)] |= BIT(BTN_SIDE) | BIT(BTN_EXTRA);
-+ input_dev->relbit[0] |= BIT(REL_WHEEL);
-+
-+ input_dev->private = mouse;
-+ input_dev->open = usb_mouse_open;
-+ input_dev->close = usb_mouse_close;
-
- usb_fill_int_urb(mouse->irq, dev, pipe, mouse->data,
- (maxp > 8 ? 8 : maxp),
-@@ -190,11 +193,15 @@ static int usb_mouse_probe(struct usb_in
- mouse->irq->transfer_dma = mouse->data_dma;
- mouse->irq->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-
-- input_register_device(&mouse->dev);
-- printk(KERN_INFO "input: %s on %s\n", mouse->name, path);
-+ input_register_device(mouse->dev);
-
- usb_set_intfdata(intf, mouse);
- return 0;
-+
-+fail2: usb_buffer_free(dev, 8, mouse->data, mouse->data_dma);
-+fail1: input_free_device(input_dev);
-+ kfree(mouse);
-+ return -ENOMEM;
- }
-
- static void usb_mouse_disconnect(struct usb_interface *intf)
-@@ -204,7 +211,7 @@ static void usb_mouse_disconnect(struct
- usb_set_intfdata(intf, NULL);
- if (mouse) {
- usb_kill_urb(mouse->irq);
-- input_unregister_device(&mouse->dev);
-+ input_unregister_device(mouse->dev);
- usb_free_urb(mouse->irq);
- usb_buffer_free(interface_to_usbdev(intf), 8, mouse->data, mouse->data_dma);
- kfree(mouse);
---- gregkh-2.6.orig/drivers/usb/input/usbkbd.c
-+++ gregkh-2.6/drivers/usb/input/usbkbd.c
-@@ -66,7 +66,7 @@ static unsigned char usb_kbd_keycode[256
- };
-
- struct usb_kbd {
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct usb_device *usbdev;
- unsigned char old[8];
- struct urb *irq, *led;
-@@ -99,29 +99,29 @@ static void usb_kbd_irq(struct urb *urb,
- goto resubmit;
- }
-
-- input_regs(&kbd->dev, regs);
-+ input_regs(kbd->dev, regs);
-
- for (i = 0; i < 8; i++)
-- input_report_key(&kbd->dev, usb_kbd_keycode[i + 224], (kbd->new[0] >> i) & 1);
-+ input_report_key(kbd->dev, usb_kbd_keycode[i + 224], (kbd->new[0] >> i) & 1);
-
- for (i = 2; i < 8; i++) {
-
- if (kbd->old[i] > 3 && memscan(kbd->new + 2, kbd->old[i], 6) == kbd->new + 8) {
- if (usb_kbd_keycode[kbd->old[i]])
-- input_report_key(&kbd->dev, usb_kbd_keycode[kbd->old[i]], 0);
-+ input_report_key(kbd->dev, usb_kbd_keycode[kbd->old[i]], 0);
- else
- info("Unknown key (scancode %#x) released.", kbd->old[i]);
- }
-
- if (kbd->new[i] > 3 && memscan(kbd->old + 2, kbd->new[i], 6) == kbd->old + 8) {
- if (usb_kbd_keycode[kbd->new[i]])
-- input_report_key(&kbd->dev, usb_kbd_keycode[kbd->new[i]], 1);
-+ input_report_key(kbd->dev, usb_kbd_keycode[kbd->new[i]], 1);
- else
- info("Unknown key (scancode %#x) pressed.", kbd->new[i]);
- }
- }
-
-- input_sync(&kbd->dev);
-+ input_sync(kbd->dev);
-
- memcpy(kbd->old, kbd->new, 8);
-
-@@ -227,12 +227,12 @@ static void usb_kbd_free_mem(struct usb_
- static int usb_kbd_probe(struct usb_interface *iface,
- const struct usb_device_id *id)
- {
-- struct usb_device * dev = interface_to_usbdev(iface);
-+ struct usb_device *dev = interface_to_usbdev(iface);
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct usb_kbd *kbd;
-+ struct input_dev *input_dev;
- int i, pipe, maxp;
-- char path[64];
-
- interface = iface->cur_altsetting;
-
-@@ -240,37 +240,59 @@ static int usb_kbd_probe(struct usb_inte
- return -ENODEV;
-
- endpoint = &interface->endpoint[0].desc;
-- if (!(endpoint->bEndpointAddress & 0x80))
-+ if (!(endpoint->bEndpointAddress & USB_DIR_IN))
- return -ENODEV;
-- if ((endpoint->bmAttributes & 3) != 3)
-+ if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) != USB_ENDPOINT_XFER_INT)
- return -ENODEV;
-
- pipe = usb_rcvintpipe(dev, endpoint->bEndpointAddress);
- maxp = usb_maxpacket(dev, pipe, usb_pipeout(pipe));
-
-- if (!(kbd = kmalloc(sizeof(struct usb_kbd), GFP_KERNEL)))
-- return -ENOMEM;
-- memset(kbd, 0, sizeof(struct usb_kbd));
-+ kbd = kzalloc(sizeof(struct usb_kbd), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!kbd || !input_dev)
-+ goto fail1;
-
-- if (usb_kbd_alloc_mem(dev, kbd)) {
-- usb_kbd_free_mem(dev, kbd);
-- kfree(kbd);
-- return -ENOMEM;
-- }
-+ if (usb_kbd_alloc_mem(dev, kbd))
-+ goto fail2;
-
- kbd->usbdev = dev;
-+ kbd->dev = input_dev;
-+
-+ if (dev->manufacturer)
-+ strlcpy(kbd->name, dev->manufacturer, sizeof(kbd->name));
-+
-+ if (dev->product) {
-+ if (dev->manufacturer)
-+ strlcat(kbd->name, " ", sizeof(kbd->name));
-+ strlcat(kbd->name, dev->product, sizeof(kbd->name));
-+ }
-+
-+ if (!strlen(kbd->name))
-+ snprintf(kbd->name, sizeof(kbd->name),
-+ "USB HIDBP Keyboard %04x:%04x",
-+ le16_to_cpu(dev->descriptor.idVendor),
-+ le16_to_cpu(dev->descriptor.idProduct));
-+
-+ usb_make_path(dev, kbd->phys, sizeof(kbd->phys));
-+ strlcpy(kbd->phys, "/input0", sizeof(kbd->phys));
-+
-+ input_dev->name = kbd->name;
-+ input_dev->phys = kbd->phys;
-+ usb_to_input_id(dev, &input_dev->id);
-+ input_dev->cdev.dev = &iface->dev;
-+ input_dev->private = kbd;
-
-- kbd->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_LED) | BIT(EV_REP);
-- kbd->dev.ledbit[0] = BIT(LED_NUML) | BIT(LED_CAPSL) | BIT(LED_SCROLLL) | BIT(LED_COMPOSE) | BIT(LED_KANA);
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_LED) | BIT(EV_REP);
-+ input_dev->ledbit[0] = BIT(LED_NUML) | BIT(LED_CAPSL) | BIT(LED_SCROLLL) | BIT(LED_COMPOSE) | BIT(LED_KANA);
-
- for (i = 0; i < 255; i++)
-- set_bit(usb_kbd_keycode[i], kbd->dev.keybit);
-- clear_bit(0, kbd->dev.keybit);
-+ set_bit(usb_kbd_keycode[i], input_dev->keybit);
-+ clear_bit(0, input_dev->keybit);
-
-- kbd->dev.private = kbd;
-- kbd->dev.event = usb_kbd_event;
-- kbd->dev.open = usb_kbd_open;
-- kbd->dev.close = usb_kbd_close;
-+ input_dev->event = usb_kbd_event;
-+ input_dev->open = usb_kbd_open;
-+ input_dev->close = usb_kbd_close;
-
- usb_fill_int_urb(kbd->irq, dev, pipe,
- kbd->new, (maxp > 8 ? 8 : maxp),
-@@ -284,37 +306,22 @@ static int usb_kbd_probe(struct usb_inte
- kbd->cr->wIndex = cpu_to_le16(interface->desc.bInterfaceNumber);
- kbd->cr->wLength = cpu_to_le16(1);
-
-- usb_make_path(dev, path, 64);
-- sprintf(kbd->phys, "%s/input0", path);
--
-- kbd->dev.name = kbd->name;
-- kbd->dev.phys = kbd->phys;
-- usb_to_input_id(dev, &kbd->dev.id);
-- kbd->dev.dev = &iface->dev;
--
-- if (dev->manufacturer)
-- strcat(kbd->name, dev->manufacturer);
-- if (dev->product)
-- sprintf(kbd->name, "%s %s", kbd->name, dev->product);
--
-- if (!strlen(kbd->name))
-- sprintf(kbd->name, "USB HIDBP Keyboard %04x:%04x",
-- kbd->dev.id.vendor, kbd->dev.id.product);
--
- usb_fill_control_urb(kbd->led, dev, usb_sndctrlpipe(dev, 0),
- (void *) kbd->cr, kbd->leds, 1,
- usb_kbd_led, kbd);
- kbd->led->setup_dma = kbd->cr_dma;
- kbd->led->transfer_dma = kbd->leds_dma;
-- kbd->led->transfer_flags |= (URB_NO_TRANSFER_DMA_MAP
-- | URB_NO_SETUP_DMA_MAP);
-+ kbd->led->transfer_flags |= (URB_NO_TRANSFER_DMA_MAP | URB_NO_SETUP_DMA_MAP);
-
-- input_register_device(&kbd->dev);
--
-- printk(KERN_INFO "input: %s on %s\n", kbd->name, path);
-+ input_register_device(kbd->dev);
-
- usb_set_intfdata(iface, kbd);
- return 0;
-+
-+fail2: usb_kbd_free_mem(dev, kbd);
-+fail1: input_free_device(input_dev);
-+ kfree(kbd);
-+ return -ENOMEM;
- }
-
- static void usb_kbd_disconnect(struct usb_interface *intf)
-@@ -324,7 +331,7 @@ static void usb_kbd_disconnect(struct us
- usb_set_intfdata(intf, NULL);
- if (kbd) {
- usb_kill_urb(kbd->irq);
-- input_unregister_device(&kbd->dev);
-+ input_unregister_device(kbd->dev);
- usb_kbd_free_mem(interface_to_usbdev(intf), kbd);
- kfree(kbd);
- }
---- gregkh-2.6.orig/drivers/usb/input/touchkitusb.c
-+++ gregkh-2.6/drivers/usb/input/touchkitusb.c
-@@ -68,7 +68,7 @@ struct touchkit_usb {
- dma_addr_t data_dma;
- struct urb *irq;
- struct usb_device *udev;
-- struct input_dev input;
-+ struct input_dev *input;
- char name[128];
- char phys[64];
- };
-@@ -115,12 +115,12 @@ static void touchkit_irq(struct urb *urb
- y = TOUCHKIT_GET_Y(touchkit->data);
- }
-
-- input_regs(&touchkit->input, regs);
-- input_report_key(&touchkit->input, BTN_TOUCH,
-+ input_regs(touchkit->input, regs);
-+ input_report_key(touchkit->input, BTN_TOUCH,
- TOUCHKIT_GET_TOUCHED(touchkit->data));
-- input_report_abs(&touchkit->input, ABS_X, x);
-- input_report_abs(&touchkit->input, ABS_Y, y);
-- input_sync(&touchkit->input);
-+ input_report_abs(touchkit->input, ABS_X, x);
-+ input_report_abs(touchkit->input, ABS_Y, y);
-+ input_sync(touchkit->input);
-
- exit:
- retval = usb_submit_urb(urb, GFP_ATOMIC);
-@@ -171,87 +171,81 @@ static void touchkit_free_buffers(struct
- static int touchkit_probe(struct usb_interface *intf,
- const struct usb_device_id *id)
- {
-- int ret;
- struct touchkit_usb *touchkit;
-+ struct input_dev *input_dev;
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct usb_device *udev = interface_to_usbdev(intf);
-- char path[64];
-
- interface = intf->cur_altsetting;
- endpoint = &interface->endpoint[0].desc;
-
-- touchkit = kmalloc(sizeof(struct touchkit_usb), GFP_KERNEL);
-- if (!touchkit)
-- return -ENOMEM;
--
-- memset(touchkit, 0, sizeof(struct touchkit_usb));
-- touchkit->udev = udev;
--
-- if (touchkit_alloc_buffers(udev, touchkit)) {
-- ret = -ENOMEM;
-+ touchkit = kzalloc(sizeof(struct touchkit_usb), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!touchkit || !input_dev)
- goto out_free;
-- }
-
-- touchkit->input.private = touchkit;
-- touchkit->input.open = touchkit_open;
-- touchkit->input.close = touchkit_close;
--
-- usb_make_path(udev, path, 64);
-- sprintf(touchkit->phys, "%s/input0", path);
--
-- touchkit->input.name = touchkit->name;
-- touchkit->input.phys = touchkit->phys;
-- usb_to_input_id(udev, &touchkit->input.id);
-- touchkit->input.dev = &intf->dev;
--
-- touchkit->input.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- touchkit->input.absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-- touchkit->input.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
--
-- /* Used to Scale Compensated Data */
-- touchkit->input.absmin[ABS_X] = TOUCHKIT_MIN_XC;
-- touchkit->input.absmax[ABS_X] = TOUCHKIT_MAX_XC;
-- touchkit->input.absfuzz[ABS_X] = TOUCHKIT_XC_FUZZ;
-- touchkit->input.absflat[ABS_X] = TOUCHKIT_XC_FLAT;
-- touchkit->input.absmin[ABS_Y] = TOUCHKIT_MIN_YC;
-- touchkit->input.absmax[ABS_Y] = TOUCHKIT_MAX_YC;
-- touchkit->input.absfuzz[ABS_Y] = TOUCHKIT_YC_FUZZ;
-- touchkit->input.absflat[ABS_Y] = TOUCHKIT_YC_FLAT;
--
-- if (udev->manufacturer)
-- strcat(touchkit->name, udev->manufacturer);
-- if (udev->product)
-- sprintf(touchkit->name, "%s %s", touchkit->name, udev->product);
--
-- if (!strlen(touchkit->name))
-- sprintf(touchkit->name, "USB Touchscreen %04x:%04x",
-- touchkit->input.id.vendor, touchkit->input.id.product);
-+ if (touchkit_alloc_buffers(udev, touchkit))
-+ goto out_free;
-
- touchkit->irq = usb_alloc_urb(0, GFP_KERNEL);
- if (!touchkit->irq) {
- dbg("%s - usb_alloc_urb failed: touchkit->irq", __FUNCTION__);
-- ret = -ENOMEM;
- goto out_free_buffers;
- }
-
-+ touchkit->udev = udev;
-+ touchkit->input = input_dev;
-+
-+ if (udev->manufacturer)
-+ strlcpy(touchkit->name, udev->manufacturer, sizeof(touchkit->name));
-+
-+ if (udev->product) {
-+ if (udev->manufacturer)
-+ strlcat(touchkit->name, " ", sizeof(touchkit->name));
-+ strlcat(touchkit->name, udev->product, sizeof(touchkit->name));
-+ }
-+
-+ if (!strlen(touchkit->name))
-+ snprintf(touchkit->name, sizeof(touchkit->name),
-+ "USB Touchscreen %04x:%04x",
-+ le16_to_cpu(udev->descriptor.idVendor),
-+ le16_to_cpu(udev->descriptor.idProduct));
-+
-+ usb_make_path(udev, touchkit->phys, sizeof(touchkit->phys));
-+ strlcpy(touchkit->phys, "/input0", sizeof(touchkit->phys));
-+
-+ input_dev->name = touchkit->name;
-+ input_dev->phys = touchkit->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = touchkit;
-+ input_dev->open = touchkit_open;
-+ input_dev->close = touchkit_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_set_abs_params(input_dev, ABS_X, TOUCHKIT_MIN_XC, TOUCHKIT_MAX_XC,
-+ TOUCHKIT_XC_FUZZ, TOUCHKIT_XC_FLAT);
-+ input_set_abs_params(input_dev, ABS_Y, TOUCHKIT_MIN_YC, TOUCHKIT_MAX_YC,
-+ TOUCHKIT_YC_FUZZ, TOUCHKIT_YC_FLAT);
-+
- usb_fill_int_urb(touchkit->irq, touchkit->udev,
-- usb_rcvintpipe(touchkit->udev, 0x81),
-- touchkit->data, TOUCHKIT_REPORT_DATA_SIZE,
-- touchkit_irq, touchkit, endpoint->bInterval);
-+ usb_rcvintpipe(touchkit->udev, 0x81),
-+ touchkit->data, TOUCHKIT_REPORT_DATA_SIZE,
-+ touchkit_irq, touchkit, endpoint->bInterval);
-
-- input_register_device(&touchkit->input);
-+ input_register_device(touchkit->input);
-
-- printk(KERN_INFO "input: %s on %s\n", touchkit->name, path);
- usb_set_intfdata(intf, touchkit);
--
- return 0;
-
- out_free_buffers:
- touchkit_free_buffers(udev, touchkit);
- out_free:
-+ input_free_device(input_dev);
- kfree(touchkit);
-- return ret;
-+ return -ENOMEM;
- }
-
- static void touchkit_disconnect(struct usb_interface *intf)
-@@ -265,8 +259,8 @@ static void touchkit_disconnect(struct u
-
- dbg("%s - touchkit is initialized, cleaning up", __FUNCTION__);
- usb_set_intfdata(intf, NULL);
-- input_unregister_device(&touchkit->input);
- usb_kill_urb(touchkit->irq);
-+ input_unregister_device(touchkit->input);
- usb_free_urb(touchkit->irq);
- touchkit_free_buffers(interface_to_usbdev(intf), touchkit);
- kfree(touchkit);
---- gregkh-2.6.orig/drivers/usb/input/powermate.c
-+++ gregkh-2.6/drivers/usb/input/powermate.c
-@@ -68,7 +68,7 @@ struct powermate_device {
- struct usb_ctrlrequest *configcr;
- dma_addr_t configcr_dma;
- struct usb_device *udev;
-- struct input_dev input;
-+ struct input_dev *input;
- spinlock_t lock;
- int static_brightness;
- int pulse_speed;
-@@ -106,10 +106,10 @@ static void powermate_irq(struct urb *ur
- }
-
- /* handle updates to device state */
-- input_regs(&pm->input, regs);
-- input_report_key(&pm->input, BTN_0, pm->data[0] & 0x01);
-- input_report_rel(&pm->input, REL_DIAL, pm->data[1]);
-- input_sync(&pm->input);
-+ input_regs(pm->input, regs);
-+ input_report_key(pm->input, BTN_0, pm->data[0] & 0x01);
-+ input_report_rel(pm->input, REL_DIAL, pm->data[1]);
-+ input_sync(pm->input);
-
- exit:
- retval = usb_submit_urb (urb, GFP_ATOMIC);
-@@ -153,10 +153,10 @@ static void powermate_sync_state(struct
-
- Only values of 'arg' quite close to 255 are particularly useful/spectacular.
- */
-- if (pm->pulse_speed < 255){
-+ if (pm->pulse_speed < 255) {
- op = 0; // divide
- arg = 255 - pm->pulse_speed;
-- } else if (pm->pulse_speed > 255){
-+ } else if (pm->pulse_speed > 255) {
- op = 2; // multiply
- arg = pm->pulse_speed - 255;
- } else {
-@@ -166,11 +166,11 @@ static void powermate_sync_state(struct
- pm->configcr->wValue = cpu_to_le16( (pm->pulse_table << 8) | SET_PULSE_MODE );
- pm->configcr->wIndex = cpu_to_le16( (arg << 8) | op );
- pm->requires_update &= ~UPDATE_PULSE_MODE;
-- }else if (pm->requires_update & UPDATE_STATIC_BRIGHTNESS){
-+ } else if (pm->requires_update & UPDATE_STATIC_BRIGHTNESS) {
- pm->configcr->wValue = cpu_to_le16( SET_STATIC_BRIGHTNESS );
- pm->configcr->wIndex = cpu_to_le16( pm->static_brightness );
- pm->requires_update &= ~UPDATE_STATIC_BRIGHTNESS;
-- }else{
-+ } else {
- printk(KERN_ERR "powermate: unknown update required");
- pm->requires_update = 0; /* fudge the bug */
- return;
-@@ -228,19 +228,19 @@ static void powermate_pulse_led(struct p
- spin_lock_irqsave(&pm->lock, flags);
-
- /* mark state updates which are required */
-- if (static_brightness != pm->static_brightness){
-+ if (static_brightness != pm->static_brightness) {
- pm->static_brightness = static_brightness;
- pm->requires_update |= UPDATE_STATIC_BRIGHTNESS;
- }
-- if (pulse_asleep != pm->pulse_asleep){
-+ if (pulse_asleep != pm->pulse_asleep) {
- pm->pulse_asleep = pulse_asleep;
- pm->requires_update |= (UPDATE_PULSE_ASLEEP | UPDATE_STATIC_BRIGHTNESS);
- }
-- if (pulse_awake != pm->pulse_awake){
-+ if (pulse_awake != pm->pulse_awake) {
- pm->pulse_awake = pulse_awake;
- pm->requires_update |= (UPDATE_PULSE_AWAKE | UPDATE_STATIC_BRIGHTNESS);
- }
-- if (pulse_speed != pm->pulse_speed || pulse_table != pm->pulse_table){
-+ if (pulse_speed != pm->pulse_speed || pulse_table != pm->pulse_table) {
- pm->pulse_speed = pulse_speed;
- pm->pulse_table = pulse_table;
- pm->requires_update |= UPDATE_PULSE_MODE;
-@@ -283,6 +283,7 @@ static int powermate_alloc_buffers(struc
- SLAB_ATOMIC, &pm->data_dma);
- if (!pm->data)
- return -1;
-+
- pm->configcr = usb_buffer_alloc(udev, sizeof(*(pm->configcr)),
- SLAB_ATOMIC, &pm->configcr_dma);
- if (!pm->configcr)
-@@ -308,8 +309,9 @@ static int powermate_probe(struct usb_in
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct powermate_device *pm;
-+ struct input_dev *input_dev;
- int pipe, maxp;
-- char path[64];
-+ int err = -ENOMEM;
-
- interface = intf->cur_altsetting;
- endpoint = &interface->endpoint[0].desc;
-@@ -323,42 +325,61 @@ static int powermate_probe(struct usb_in
- 0, interface->desc.bInterfaceNumber, NULL, 0,
- USB_CTRL_SET_TIMEOUT);
-
-- if (!(pm = kmalloc(sizeof(struct powermate_device), GFP_KERNEL)))
-- return -ENOMEM;
--
-- memset(pm, 0, sizeof(struct powermate_device));
-- pm->udev = udev;
-+ pm = kzalloc(sizeof(struct powermate_device), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!pm || !input_dev)
-+ goto fail1;
-
-- if (powermate_alloc_buffers(udev, pm)) {
-- powermate_free_buffers(udev, pm);
-- kfree(pm);
-- return -ENOMEM;
-- }
-+ if (powermate_alloc_buffers(udev, pm))
-+ goto fail2;
-
- pm->irq = usb_alloc_urb(0, GFP_KERNEL);
-- if (!pm->irq) {
-- powermate_free_buffers(udev, pm);
-- kfree(pm);
-- return -ENOMEM;
-- }
-+ if (!pm->irq)
-+ goto fail2;
-
- pm->config = usb_alloc_urb(0, GFP_KERNEL);
-- if (!pm->config) {
-- usb_free_urb(pm->irq);
-- powermate_free_buffers(udev, pm);
-- kfree(pm);
-- return -ENOMEM;
-- }
-+ if (!pm->config)
-+ goto fail3;
-+
-+ pm->udev = udev;
-+ pm->input = input_dev;
-+
-+ usb_make_path(udev, pm->phys, sizeof(pm->phys));
-+ strlcpy(pm->phys, "/input0", sizeof(pm->phys));
-
- spin_lock_init(&pm->lock);
-- init_input_dev(&pm->input);
-+
-+ switch (le16_to_cpu(udev->descriptor.idProduct)) {
-+ case POWERMATE_PRODUCT_NEW:
-+ input_dev->name = pm_name_powermate;
-+ break;
-+ case POWERMATE_PRODUCT_OLD:
-+ input_dev->name = pm_name_soundknob;
-+ break;
-+ default:
-+ input_dev->name = pm_name_soundknob;
-+ printk(KERN_WARNING "powermate: unknown product id %04x\n",
-+ le16_to_cpu(udev->descriptor.idProduct));
-+ }
-+
-+ input_dev->phys = pm->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = pm;
-+
-+ input_dev->event = powermate_input_event;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL) | BIT(EV_MSC);
-+ input_dev->keybit[LONG(BTN_0)] = BIT(BTN_0);
-+ input_dev->relbit[LONG(REL_DIAL)] = BIT(REL_DIAL);
-+ input_dev->mscbit[LONG(MSC_PULSELED)] = BIT(MSC_PULSELED);
-
- /* get a handle to the interrupt data pipe */
- pipe = usb_rcvintpipe(udev, endpoint->bEndpointAddress);
- maxp = usb_maxpacket(udev, pipe, usb_pipeout(pipe));
-
-- if(maxp < POWERMATE_PAYLOAD_SIZE_MIN || maxp > POWERMATE_PAYLOAD_SIZE_MAX){
-- printk("powermate: Expected payload of %d--%d bytes, found %d bytes!\n",
-+ if (maxp < POWERMATE_PAYLOAD_SIZE_MIN || maxp > POWERMATE_PAYLOAD_SIZE_MAX) {
-+ printk(KERN_WARNING "powermate: Expected payload of %d--%d bytes, found %d bytes!\n",
- POWERMATE_PAYLOAD_SIZE_MIN, POWERMATE_PAYLOAD_SIZE_MAX, maxp);
- maxp = POWERMATE_PAYLOAD_SIZE_MAX;
- }
-@@ -371,35 +392,11 @@ static int powermate_probe(struct usb_in
-
- /* register our interrupt URB with the USB system */
- if (usb_submit_urb(pm->irq, GFP_KERNEL)) {
-- powermate_free_buffers(udev, pm);
-- kfree(pm);
-- return -EIO; /* failure */
-+ err = -EIO;
-+ goto fail4;
- }
-
-- switch (le16_to_cpu(udev->descriptor.idProduct)) {
-- case POWERMATE_PRODUCT_NEW: pm->input.name = pm_name_powermate; break;
-- case POWERMATE_PRODUCT_OLD: pm->input.name = pm_name_soundknob; break;
-- default:
-- pm->input.name = pm_name_soundknob;
-- printk(KERN_WARNING "powermate: unknown product id %04x\n",
-- le16_to_cpu(udev->descriptor.idProduct));
-- }
--
-- pm->input.private = pm;
-- pm->input.evbit[0] = BIT(EV_KEY) | BIT(EV_REL) | BIT(EV_MSC);
-- pm->input.keybit[LONG(BTN_0)] = BIT(BTN_0);
-- pm->input.relbit[LONG(REL_DIAL)] = BIT(REL_DIAL);
-- pm->input.mscbit[LONG(MSC_PULSELED)] = BIT(MSC_PULSELED);
-- usb_to_input_id(udev, &pm->input.id);
-- pm->input.event = powermate_input_event;
-- pm->input.dev = &intf->dev;
-- pm->input.phys = pm->phys;
--
-- input_register_device(&pm->input);
--
-- usb_make_path(udev, path, 64);
-- snprintf(pm->phys, 64, "%s/input0", path);
-- printk(KERN_INFO "input: %s on %s\n", pm->input.name, pm->input.phys);
-+ input_register_device(pm->input);
-
- /* force an update of everything */
- pm->requires_update = UPDATE_PULSE_ASLEEP | UPDATE_PULSE_AWAKE | UPDATE_PULSE_MODE | UPDATE_STATIC_BRIGHTNESS;
-@@ -407,6 +404,13 @@ static int powermate_probe(struct usb_in
-
- usb_set_intfdata(intf, pm);
- return 0;
-+
-+fail4: usb_free_urb(pm->config);
-+fail3: usb_free_urb(pm->irq);
-+fail2: powermate_free_buffers(udev, pm);
-+fail1: input_free_device(input_dev);
-+ kfree(pm);
-+ return err;
- }
-
- /* Called when a USB device we've accepted ownership of is removed */
-@@ -418,7 +422,7 @@ static void powermate_disconnect(struct
- if (pm) {
- pm->requires_update = 0;
- usb_kill_urb(pm->irq);
-- input_unregister_device(&pm->input);
-+ input_unregister_device(pm->input);
- usb_free_urb(pm->irq);
- usb_free_urb(pm->config);
- powermate_free_buffers(interface_to_usbdev(intf), pm);
---- gregkh-2.6.orig/drivers/usb/input/kbtab.c
-+++ gregkh-2.6/drivers/usb/input/kbtab.c
-@@ -34,7 +34,7 @@ MODULE_PARM_DESC(kb_pressure_click, "pre
- struct kbtab {
- signed char *data;
- dma_addr_t data_dma;
-- struct input_dev dev;
-+ struct input_dev *dev;
- struct usb_device *usbdev;
- struct urb *irq;
- int x, y;
-@@ -48,7 +48,7 @@ static void kbtab_irq(struct urb *urb, s
- {
- struct kbtab *kbtab = urb->context;
- unsigned char *data = kbtab->data;
-- struct input_dev *dev = &kbtab->dev;
-+ struct input_dev *dev = kbtab->dev;
- int retval;
-
- switch (urb->status) {
-@@ -124,53 +124,43 @@ static int kbtab_probe(struct usb_interf
- struct usb_device *dev = interface_to_usbdev(intf);
- struct usb_endpoint_descriptor *endpoint;
- struct kbtab *kbtab;
-- char path[64];
-+ struct input_dev *input_dev;
-
-- if (!(kbtab = kmalloc(sizeof(struct kbtab), GFP_KERNEL)))
-- return -ENOMEM;
-- memset(kbtab, 0, sizeof(struct kbtab));
-+ kbtab = kzalloc(sizeof(struct kbtab), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!kbtab || !input_dev)
-+ goto fail1;
-
- kbtab->data = usb_buffer_alloc(dev, 8, GFP_KERNEL, &kbtab->data_dma);
-- if (!kbtab->data) {
-- kfree(kbtab);
-- return -ENOMEM;
-- }
-+ if (!kbtab->data)
-+ goto fail1;
-
- kbtab->irq = usb_alloc_urb(0, GFP_KERNEL);
-- if (!kbtab->irq) {
-- usb_buffer_free(dev, 10, kbtab->data, kbtab->data_dma);
-- kfree(kbtab);
-- return -ENOMEM;
-- }
--
-- kbtab->dev.evbit[0] |= BIT(EV_KEY) | BIT(EV_ABS) | BIT(EV_MSC);
-- kbtab->dev.absbit[0] |= BIT(ABS_X) | BIT(ABS_Y) | BIT(ABS_PRESSURE);
--
-- kbtab->dev.keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
--
-- kbtab->dev.keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_PEN) | BIT(BTN_TOUCH);
--
-- kbtab->dev.mscbit[0] |= BIT(MSC_SERIAL);
-+ if (!kbtab->irq)
-+ goto fail2;
-
-- kbtab->dev.absmax[ABS_X] = 0x2000;
-- kbtab->dev.absmax[ABS_Y] = 0x1750;
-- kbtab->dev.absmax[ABS_PRESSURE] = 0xff;
--
-- kbtab->dev.absfuzz[ABS_X] = 4;
-- kbtab->dev.absfuzz[ABS_Y] = 4;
--
-- kbtab->dev.private = kbtab;
-- kbtab->dev.open = kbtab_open;
-- kbtab->dev.close = kbtab_close;
-+ kbtab->usbdev = dev;
-+ kbtab->dev = input_dev;
-
-- usb_make_path(dev, path, 64);
-- sprintf(kbtab->phys, "%s/input0", path);
-+ usb_make_path(dev, kbtab->phys, sizeof(kbtab->phys));
-+ strlcat(kbtab->phys, "/input0", sizeof(kbtab->phys));
-
-- kbtab->dev.name = "KB Gear Tablet";
-- kbtab->dev.phys = kbtab->phys;
-- usb_to_input_id(dev, &kbtab->dev.id);
-- kbtab->dev.dev = &intf->dev;
-- kbtab->usbdev = dev;
-+ input_dev->name = "KB Gear Tablet";
-+ input_dev->phys = kbtab->phys;
-+ usb_to_input_id(dev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = kbtab;
-+
-+ input_dev->open = kbtab_open;
-+ input_dev->close = kbtab_close;
-+
-+ input_dev->evbit[0] |= BIT(EV_KEY) | BIT(EV_ABS) | BIT(EV_MSC);
-+ input_dev->keybit[LONG(BTN_LEFT)] |= BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
-+ input_dev->keybit[LONG(BTN_DIGI)] |= BIT(BTN_TOOL_PEN) | BIT(BTN_TOUCH);
-+ input_dev->mscbit[0] |= BIT(MSC_SERIAL);
-+ input_set_abs_params(input_dev, ABS_X, 0, 0x2000, 4, 0);
-+ input_set_abs_params(input_dev, ABS_X, 0, 0x1750, 4, 0);
-+ input_set_abs_params(input_dev, ABS_PRESSURE, 0, 0xff, 0, 0);
-
- endpoint = &intf->cur_altsetting->endpoint[0].desc;
-
-@@ -181,23 +171,25 @@ static int kbtab_probe(struct usb_interf
- kbtab->irq->transfer_dma = kbtab->data_dma;
- kbtab->irq->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-
-- input_register_device(&kbtab->dev);
--
-- printk(KERN_INFO "input: KB Gear Tablet on %s\n", path);
-+ input_register_device(kbtab->dev);
-
- usb_set_intfdata(intf, kbtab);
--
- return 0;
-+
-+fail2: usb_buffer_free(dev, 10, kbtab->data, kbtab->data_dma);
-+fail1: input_free_device(input_dev);
-+ kfree(kbtab);
-+ return -ENOMEM;
- }
-
- static void kbtab_disconnect(struct usb_interface *intf)
- {
-- struct kbtab *kbtab = usb_get_intfdata (intf);
-+ struct kbtab *kbtab = usb_get_intfdata(intf);
-
- usb_set_intfdata(intf, NULL);
- if (kbtab) {
- usb_kill_urb(kbtab->irq);
-- input_unregister_device(&kbtab->dev);
-+ input_unregister_device(kbtab->dev);
- usb_free_urb(kbtab->irq);
- usb_buffer_free(interface_to_usbdev(intf), 10, kbtab->data, kbtab->data_dma);
- kfree(kbtab);
---- gregkh-2.6.orig/drivers/usb/input/ati_remote.c
-+++ gregkh-2.6/drivers/usb/input/ati_remote.c
-@@ -112,7 +112,6 @@
-
- #define NAME_BUFSIZE 80 /* size of product name, path buffers */
- #define DATA_BUFSIZE 63 /* size of URB data buffers */
--#define ATI_INPUTNUM 1 /* Which input device to register as */
-
- static unsigned long channel_mask;
- module_param(channel_mask, ulong, 0444);
-@@ -162,7 +161,7 @@ static char accel[] = { 1, 2, 4, 6, 9, 1
- static DECLARE_MUTEX(disconnect_sem);
-
- struct ati_remote {
-- struct input_dev idev;
-+ struct input_dev *idev;
- struct usb_device *udev;
- struct usb_interface *interface;
-
-@@ -198,15 +197,13 @@ struct ati_remote {
- #define KIND_ACCEL 7 /* Directional keypad - left, right, up, down.*/
-
- /* Translation table from hardware messages to input events. */
--static struct
--{
-+static struct {
- short kind;
- unsigned char data1, data2;
- int type;
- unsigned int code;
- int value;
--} ati_remote_tbl[] =
--{
-+} ati_remote_tbl[] = {
- /* Directional control pad axes */
- {KIND_ACCEL, 0x35, 0x70, EV_REL, REL_X, -1}, /* left */
- {KIND_ACCEL, 0x36, 0x71, EV_REL, REL_X, 1}, /* right */
-@@ -286,7 +283,6 @@ static struct
-
- /* Local function prototypes */
- static void ati_remote_dump (unsigned char *data, unsigned int actual_length);
--static void ati_remote_delete (struct ati_remote *dev);
- static int ati_remote_open (struct input_dev *inputdev);
- static void ati_remote_close (struct input_dev *inputdev);
- static int ati_remote_sendpacket (struct ati_remote *ati_remote, u16 cmd, unsigned char *data);
-@@ -428,7 +424,7 @@ static void ati_remote_input_report(stru
- {
- struct ati_remote *ati_remote = urb->context;
- unsigned char *data= ati_remote->inbuf;
-- struct input_dev *dev = &ati_remote->idev;
-+ struct input_dev *dev = ati_remote->idev;
- int index, acc;
- int remote_num;
-
-@@ -587,38 +583,55 @@ static void ati_remote_irq_in(struct urb
- }
-
- /*
-- * ati_remote_delete
-+ * ati_remote_alloc_buffers
- */
--static void ati_remote_delete(struct ati_remote *ati_remote)
-+static int ati_remote_alloc_buffers(struct usb_device *udev,
-+ struct ati_remote *ati_remote)
- {
-- if (ati_remote->irq_urb)
-- usb_kill_urb(ati_remote->irq_urb);
-+ ati_remote->inbuf = usb_buffer_alloc(udev, DATA_BUFSIZE, SLAB_ATOMIC,
-+ &ati_remote->inbuf_dma);
-+ if (!ati_remote->inbuf)
-+ return -1;
-
-- if (ati_remote->out_urb)
-- usb_kill_urb(ati_remote->out_urb);
-+ ati_remote->outbuf = usb_buffer_alloc(udev, DATA_BUFSIZE, SLAB_ATOMIC,
-+ &ati_remote->outbuf_dma);
-+ if (!ati_remote->outbuf)
-+ return -1;
-
-- input_unregister_device(&ati_remote->idev);
-+ ati_remote->irq_urb = usb_alloc_urb(0, GFP_KERNEL);
-+ if (!ati_remote->irq_urb)
-+ return -1;
-
-- if (ati_remote->inbuf)
-- usb_buffer_free(ati_remote->udev, DATA_BUFSIZE,
-- ati_remote->inbuf, ati_remote->inbuf_dma);
-+ ati_remote->out_urb = usb_alloc_urb(0, GFP_KERNEL);
-+ if (!ati_remote->out_urb)
-+ return -1;
-
-- if (ati_remote->outbuf)
-- usb_buffer_free(ati_remote->udev, DATA_BUFSIZE,
-- ati_remote->outbuf, ati_remote->outbuf_dma);
-+ return 0;
-+}
-
-+/*
-+ * ati_remote_free_buffers
-+ */
-+static void ati_remote_free_buffers(struct ati_remote *ati_remote)
-+{
- if (ati_remote->irq_urb)
- usb_free_urb(ati_remote->irq_urb);
-
- if (ati_remote->out_urb)
- usb_free_urb(ati_remote->out_urb);
-
-- kfree(ati_remote);
-+ if (ati_remote->inbuf)
-+ usb_buffer_free(ati_remote->udev, DATA_BUFSIZE,
-+ ati_remote->inbuf, ati_remote->inbuf_dma);
-+
-+ if (ati_remote->outbuf)
-+ usb_buffer_free(ati_remote->udev, DATA_BUFSIZE,
-+ ati_remote->inbuf, ati_remote->outbuf_dma);
- }
-
- static void ati_remote_input_init(struct ati_remote *ati_remote)
- {
-- struct input_dev *idev = &(ati_remote->idev);
-+ struct input_dev *idev = ati_remote->idev;
- int i;
-
- idev->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);
-@@ -637,7 +650,7 @@ static void ati_remote_input_init(struct
- idev->phys = ati_remote->phys;
-
- usb_to_input_id(ati_remote->udev, &idev->id);
-- idev->dev = &ati_remote->udev->dev;
-+ idev->cdev.dev = &ati_remote->udev->dev;
- }
-
- static int ati_remote_initialize(struct ati_remote *ati_remote)
-@@ -674,7 +687,7 @@ static int ati_remote_initialize(struct
- (ati_remote_sendpacket(ati_remote, 0x8007, init2))) {
- dev_err(&ati_remote->interface->dev,
- "Initializing ati_remote hardware failed.\n");
-- return 1;
-+ return -EIO;
- }
-
- return 0;
-@@ -686,95 +699,83 @@ static int ati_remote_initialize(struct
- static int ati_remote_probe(struct usb_interface *interface, const struct usb_device_id *id)
- {
- struct usb_device *udev = interface_to_usbdev(interface);
-- struct ati_remote *ati_remote = NULL;
-- struct usb_host_interface *iface_host;
-- int retval = -ENOMEM;
-- char path[64];
--
-- /* Allocate and clear an ati_remote struct */
-- if (!(ati_remote = kmalloc(sizeof (struct ati_remote), GFP_KERNEL)))
-- return -ENOMEM;
-- memset(ati_remote, 0x00, sizeof (struct ati_remote));
-+ struct usb_host_interface *iface_host = interface->cur_altsetting;
-+ struct usb_endpoint_descriptor *endpoint_in, *endpoint_out;
-+ struct ati_remote *ati_remote;
-+ struct input_dev *input_dev;
-+ int err = -ENOMEM;
-
-- iface_host = interface->cur_altsetting;
- if (iface_host->desc.bNumEndpoints != 2) {
- err("%s: Unexpected desc.bNumEndpoints\n", __FUNCTION__);
-- retval = -ENODEV;
-- goto error;
-+ return -ENODEV;
- }
-
-- ati_remote->endpoint_in = &(iface_host->endpoint[0].desc);
-- ati_remote->endpoint_out = &(iface_host->endpoint[1].desc);
-- ati_remote->udev = udev;
-- ati_remote->interface = interface;
-+ endpoint_in = &iface_host->endpoint[0].desc;
-+ endpoint_out = &iface_host->endpoint[1].desc;
-
-- if (!(ati_remote->endpoint_in->bEndpointAddress & 0x80)) {
-+ if (!(endpoint_in->bEndpointAddress & USB_DIR_IN)) {
- err("%s: Unexpected endpoint_in->bEndpointAddress\n", __FUNCTION__);
-- retval = -ENODEV;
-- goto error;
-+ return -ENODEV;
- }
-- if ((ati_remote->endpoint_in->bmAttributes & 3) != 3) {
-+ if ((endpoint_in->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) != USB_ENDPOINT_XFER_INT) {
- err("%s: Unexpected endpoint_in->bmAttributes\n", __FUNCTION__);
-- retval = -ENODEV;
-- goto error;
-+ return -ENODEV;
- }
-- if (le16_to_cpu(ati_remote->endpoint_in->wMaxPacketSize) == 0) {
-+ if (le16_to_cpu(endpoint_in->wMaxPacketSize) == 0) {
- err("%s: endpoint_in message size==0? \n", __FUNCTION__);
-- retval = -ENODEV;
-- goto error;
-+ return -ENODEV;
- }
-
-+ ati_remote = kzalloc(sizeof (struct ati_remote), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!ati_remote || !input_dev)
-+ goto fail1;
-+
- /* Allocate URB buffers, URBs */
-- ati_remote->inbuf = usb_buffer_alloc(udev, DATA_BUFSIZE, SLAB_ATOMIC,
-- &ati_remote->inbuf_dma);
-- if (!ati_remote->inbuf)
-- goto error;
-+ if (ati_remote_alloc_buffers(udev, ati_remote))
-+ goto fail2;
-
-- ati_remote->outbuf = usb_buffer_alloc(udev, DATA_BUFSIZE, SLAB_ATOMIC,
-- &ati_remote->outbuf_dma);
-- if (!ati_remote->outbuf)
-- goto error;
-+ ati_remote->endpoint_in = endpoint_in;
-+ ati_remote->endpoint_out = endpoint_out;
-+ ati_remote->udev = udev;
-+ ati_remote->idev = input_dev;
-+ ati_remote->interface = interface;
-
-- ati_remote->irq_urb = usb_alloc_urb(0, GFP_KERNEL);
-- if (!ati_remote->irq_urb)
-- goto error;
-+ usb_make_path(udev, ati_remote->phys, sizeof(ati_remote->phys));
-+ strlcpy(ati_remote->phys, "/input0", sizeof(ati_remote->phys));
-
-- ati_remote->out_urb = usb_alloc_urb(0, GFP_KERNEL);
-- if (!ati_remote->out_urb)
-- goto error;
--
-- usb_make_path(udev, path, NAME_BUFSIZE);
-- sprintf(ati_remote->phys, "%s/input%d", path, ATI_INPUTNUM);
- if (udev->manufacturer)
-- strcat(ati_remote->name, udev->manufacturer);
-+ strlcpy(ati_remote->name, udev->manufacturer, sizeof(ati_remote->name));
-
- if (udev->product)
-- sprintf(ati_remote->name, "%s %s", ati_remote->name, udev->product);
-+ snprintf(ati_remote->name, sizeof(ati_remote->name),
-+ "%s %s", ati_remote->name, udev->product);
-
- if (!strlen(ati_remote->name))
-- sprintf(ati_remote->name, DRIVER_DESC "(%04x,%04x)",
-+ snprintf(ati_remote->name, sizeof(ati_remote->name),
-+ DRIVER_DESC "(%04x,%04x)",
- le16_to_cpu(ati_remote->udev->descriptor.idVendor),
- le16_to_cpu(ati_remote->udev->descriptor.idProduct));
-
-+ ati_remote_input_init(ati_remote);
-+
- /* Device Hardware Initialization - fills in ati_remote->idev from udev. */
-- retval = ati_remote_initialize(ati_remote);
-- if (retval)
-- goto error;
-+ err = ati_remote_initialize(ati_remote);
-+ if (err)
-+ goto fail3;
-
- /* Set up and register input device */
-- ati_remote_input_init(ati_remote);
-- input_register_device(&ati_remote->idev);
--
-- dev_info(&ati_remote->interface->dev, "Input registered: %s on %s\n",
-- ati_remote->name, path);
-+ input_register_device(ati_remote->idev);
-
- usb_set_intfdata(interface, ati_remote);
-+ return 0;
-
--error:
-- if (retval)
-- ati_remote_delete(ati_remote);
--
-- return retval;
-+fail3: usb_kill_urb(ati_remote->irq_urb);
-+ usb_kill_urb(ati_remote->out_urb);
-+fail2: ati_remote_free_buffers(ati_remote);
-+fail1: input_free_device(input_dev);
-+ kfree(ati_remote);
-+ return err;
- }
-
- /*
-@@ -791,7 +792,11 @@ static void ati_remote_disconnect(struct
- return;
- }
-
-- ati_remote_delete(ati_remote);
-+ usb_kill_urb(ati_remote->irq_urb);
-+ usb_kill_urb(ati_remote->out_urb);
-+ input_unregister_device(ati_remote->idev);
-+ ati_remote_free_buffers(ati_remote);
-+ kfree(ati_remote);
- }
-
- /*
---- gregkh-2.6.orig/drivers/usb/input/mtouchusb.c
-+++ gregkh-2.6/drivers/usb/input/mtouchusb.c
-@@ -98,7 +98,7 @@ struct mtouch_usb {
- dma_addr_t data_dma;
- struct urb *irq;
- struct usb_device *udev;
-- struct input_dev input;
-+ struct input_dev *input;
- char name[128];
- char phys[64];
- };
-@@ -135,14 +135,14 @@ static void mtouchusb_irq(struct urb *ur
- goto exit;
- }
-
-- input_regs(&mtouch->input, regs);
-- input_report_key(&mtouch->input, BTN_TOUCH,
-+ input_regs(mtouch->input, regs);
-+ input_report_key(mtouch->input, BTN_TOUCH,
- MTOUCHUSB_GET_TOUCHED(mtouch->data));
-- input_report_abs(&mtouch->input, ABS_X, MTOUCHUSB_GET_XC(mtouch->data));
-- input_report_abs(&mtouch->input, ABS_Y,
-+ input_report_abs(mtouch->input, ABS_X, MTOUCHUSB_GET_XC(mtouch->data));
-+ input_report_abs(mtouch->input, ABS_Y,
- (raw_coordinates ? MTOUCHUSB_MAX_RAW_YC : MTOUCHUSB_MAX_CALIB_YC)
- - MTOUCHUSB_GET_YC(mtouch->data));
-- input_sync(&mtouch->input);
-+ input_sync(mtouch->input);
-
- exit:
- retval = usb_submit_urb(urb, GFP_ATOMIC);
-@@ -195,10 +195,10 @@ static void mtouchusb_free_buffers(struc
- static int mtouchusb_probe(struct usb_interface *intf, const struct usb_device_id *id)
- {
- struct mtouch_usb *mtouch;
-+ struct input_dev *input_dev;
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct usb_device *udev = interface_to_usbdev(intf);
-- char path[64];
- int nRet;
-
- dbg("%s - called", __FUNCTION__);
-@@ -209,57 +209,55 @@ static int mtouchusb_probe(struct usb_in
- dbg("%s - setting endpoint", __FUNCTION__);
- endpoint = &interface->endpoint[0].desc;
-
-- if (!(mtouch = kmalloc(sizeof(struct mtouch_usb), GFP_KERNEL))) {
-+ mtouch = kzalloc(sizeof(struct mtouch_usb), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!mtouch || !input_dev) {
- err("%s - Out of memory.", __FUNCTION__);
-- return -ENOMEM;
-+ goto fail1;
- }
-
-- memset(mtouch, 0, sizeof(struct mtouch_usb));
-- mtouch->udev = udev;
--
- dbg("%s - allocating buffers", __FUNCTION__);
-- if (mtouchusb_alloc_buffers(udev, mtouch)) {
-- mtouchusb_free_buffers(udev, mtouch);
-- kfree(mtouch);
-- return -ENOMEM;
-- }
-+ if (mtouchusb_alloc_buffers(udev, mtouch))
-+ goto fail2;
-
-- mtouch->input.private = mtouch;
-- mtouch->input.open = mtouchusb_open;
-- mtouch->input.close = mtouchusb_close;
--
-- usb_make_path(udev, path, 64);
-- sprintf(mtouch->phys, "%s/input0", path);
--
-- mtouch->input.name = mtouch->name;
-- mtouch->input.phys = mtouch->phys;
-- usb_to_input_id(udev, &mtouch->input.id);
-- mtouch->input.dev = &intf->dev;
--
-- mtouch->input.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- mtouch->input.absbit[0] = BIT(ABS_X) | BIT(ABS_Y);
-- mtouch->input.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
--
-- /* Used to Scale Compensated Data and Flip Y */
-- mtouch->input.absmin[ABS_X] = MTOUCHUSB_MIN_XC;
-- mtouch->input.absmax[ABS_X] = raw_coordinates ?
-- MTOUCHUSB_MAX_RAW_XC : MTOUCHUSB_MAX_CALIB_XC;
-- mtouch->input.absfuzz[ABS_X] = MTOUCHUSB_XC_FUZZ;
-- mtouch->input.absflat[ABS_X] = MTOUCHUSB_XC_FLAT;
-- mtouch->input.absmin[ABS_Y] = MTOUCHUSB_MIN_YC;
-- mtouch->input.absmax[ABS_Y] = raw_coordinates ?
-- MTOUCHUSB_MAX_RAW_YC : MTOUCHUSB_MAX_CALIB_YC;
-- mtouch->input.absfuzz[ABS_Y] = MTOUCHUSB_YC_FUZZ;
-- mtouch->input.absflat[ABS_Y] = MTOUCHUSB_YC_FLAT;
-+ mtouch->udev = udev;
-+ mtouch->input = input_dev;
-
- if (udev->manufacturer)
-- strcat(mtouch->name, udev->manufacturer);
-- if (udev->product)
-- sprintf(mtouch->name, "%s %s", mtouch->name, udev->product);
-+ strlcpy(mtouch->name, udev->manufacturer, sizeof(mtouch->name));
-+
-+ if (udev->product) {
-+ if (udev->manufacturer)
-+ strlcat(mtouch->name, " ", sizeof(mtouch->name));
-+ strlcat(mtouch->name, udev->product, sizeof(mtouch->name));
-+ }
-
- if (!strlen(mtouch->name))
-- sprintf(mtouch->name, "USB Touchscreen %04x:%04x",
-- mtouch->input.id.vendor, mtouch->input.id.product);
-+ snprintf(mtouch->name, sizeof(mtouch->name),
-+ "USB Touchscreen %04x:%04x",
-+ le16_to_cpu(udev->descriptor.idVendor),
-+ le16_to_cpu(udev->descriptor.idProduct));
-+
-+ usb_make_path(udev, mtouch->phys, sizeof(mtouch->phys));
-+ strlcpy(mtouch->phys, "/input0", sizeof(mtouch->phys));
-+
-+ input_dev->name = mtouch->name;
-+ input_dev->phys = mtouch->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = mtouch;
-+
-+ input_dev->open = mtouchusb_open;
-+ input_dev->close = mtouchusb_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+ input_set_abs_params(input_dev, ABS_X, MTOUCHUSB_MIN_XC,
-+ raw_coordinates ? MTOUCHUSB_MAX_RAW_XC : MTOUCHUSB_MAX_CALIB_XC,
-+ MTOUCHUSB_XC_FUZZ, MTOUCHUSB_XC_FLAT);
-+ input_set_abs_params(input_dev, ABS_Y, MTOUCHUSB_MIN_YC,
-+ raw_coordinates ? MTOUCHUSB_MAX_RAW_YC : MTOUCHUSB_MAX_CALIB_YC,
-+ MTOUCHUSB_YC_FUZZ, MTOUCHUSB_YC_FLAT);
-
- nRet = usb_control_msg(mtouch->udev, usb_rcvctrlpipe(udev, 0),
- MTOUCHUSB_RESET,
-@@ -272,9 +270,7 @@ static int mtouchusb_probe(struct usb_in
- mtouch->irq = usb_alloc_urb(0, GFP_KERNEL);
- if (!mtouch->irq) {
- dbg("%s - usb_alloc_urb failed: mtouch->irq", __FUNCTION__);
-- mtouchusb_free_buffers(udev, mtouch);
-- kfree(mtouch);
-- return -ENOMEM;
-+ goto fail2;
- }
-
- dbg("%s - usb_fill_int_urb", __FUNCTION__);
-@@ -284,7 +280,7 @@ static int mtouchusb_probe(struct usb_in
- mtouchusb_irq, mtouch, endpoint->bInterval);
-
- dbg("%s - input_register_device", __FUNCTION__);
-- input_register_device(&mtouch->input);
-+ input_register_device(mtouch->input);
-
- nRet = usb_control_msg(mtouch->udev, usb_rcvctrlpipe(udev, 0),
- MTOUCHUSB_ASYNC_REPORT,
-@@ -293,10 +289,13 @@ static int mtouchusb_probe(struct usb_in
- dbg("%s - usb_control_msg - MTOUCHUSB_ASYNC_REPORT - bytes|err: %d",
- __FUNCTION__, nRet);
-
-- printk(KERN_INFO "input: %s on %s\n", mtouch->name, path);
- usb_set_intfdata(intf, mtouch);
--
- return 0;
-+
-+fail2: mtouchusb_free_buffers(udev, mtouch);
-+fail1: input_free_device(input_dev);
-+ kfree(mtouch);
-+ return -ENOMEM;
- }
-
- static void mtouchusb_disconnect(struct usb_interface *intf)
-@@ -308,7 +307,7 @@ static void mtouchusb_disconnect(struct
- if (mtouch) {
- dbg("%s - mtouch is initialized, cleaning up", __FUNCTION__);
- usb_kill_urb(mtouch->irq);
-- input_unregister_device(&mtouch->input);
-+ input_unregister_device(mtouch->input);
- usb_free_urb(mtouch->irq);
- mtouchusb_free_buffers(interface_to_usbdev(intf), mtouch);
- kfree(mtouch);
---- gregkh-2.6.orig/drivers/usb/input/pid.c
-+++ gregkh-2.6/drivers/usb/input/pid.c
-@@ -262,6 +262,7 @@ int hid_pid_init(struct hid_device *hid)
- {
- struct hid_ff_pid *private;
- struct hid_input *hidinput = list_entry(&hid->inputs, struct hid_input, list);
-+ struct input_dev *input_dev = hidinput->input;
-
- private = hid->ff_private = kzalloc(sizeof(struct hid_ff_pid), GFP_KERNEL);
- if (!private)
-@@ -281,11 +282,12 @@ int hid_pid_init(struct hid_device *hid)
- usb_fill_control_urb(private->urbffout, hid->dev, 0,
- (void *)&private->ffcr, private->ctrl_buffer, 8,
- hid_pid_ctrl_out, hid);
-- hidinput->input.upload_effect = hid_pid_upload_effect;
-- hidinput->input.flush = hid_pid_flush;
-- hidinput->input.ff_effects_max = 8; // A random default
-- set_bit(EV_FF, hidinput->input.evbit);
-- set_bit(EV_FF_STATUS, hidinput->input.evbit);
-+
-+ input_dev->upload_effect = hid_pid_upload_effect;
-+ input_dev->flush = hid_pid_flush;
-+ input_dev->ff_effects_max = 8; // A random default
-+ set_bit(EV_FF, input_dev->evbit);
-+ set_bit(EV_FF_STATUS, input_dev->evbit);
-
- spin_lock_init(&private->lock);
-
---- gregkh-2.6.orig/drivers/usb/input/hid-lgff.c
-+++ gregkh-2.6/drivers/usb/input/hid-lgff.c
-@@ -255,22 +255,19 @@ static void hid_lgff_input_init(struct h
- u16 idVendor = le16_to_cpu(hid->dev->descriptor.idVendor);
- u16 idProduct = le16_to_cpu(hid->dev->descriptor.idProduct);
- struct hid_input *hidinput = list_entry(hid->inputs.next, struct hid_input, list);
-+ struct input_dev *input_dev = hidinput->input;
-
- while (dev->idVendor && (idVendor != dev->idVendor || idProduct != dev->idProduct))
- dev++;
-
-- ff = dev->ff;
-+ for (ff = dev->ff; *ff >= 0; ff++)
-+ set_bit(*ff, input_dev->ffbit);
-
-- while (*ff >= 0) {
-- set_bit(*ff, hidinput->input.ffbit);
-- ++ff;
-- }
--
-- hidinput->input.upload_effect = hid_lgff_upload_effect;
-- hidinput->input.flush = hid_lgff_flush;
-+ input_dev->upload_effect = hid_lgff_upload_effect;
-+ input_dev->flush = hid_lgff_flush;
-
-- set_bit(EV_FF, hidinput->input.evbit);
-- hidinput->input.ff_effects_max = LGFF_EFFECTS;
-+ set_bit(EV_FF, input_dev->evbit);
-+ input_dev->ff_effects_max = LGFF_EFFECTS;
- }
-
- static void hid_lgff_exit(struct hid_device* hid)
---- gregkh-2.6.orig/drivers/usb/input/hid-tmff.c
-+++ gregkh-2.6/drivers/usb/input/hid-tmff.c
-@@ -111,6 +111,7 @@ int hid_tmff_init(struct hid_device *hid
- struct tmff_device *private;
- struct list_head *pos;
- struct hid_input *hidinput = list_entry(hid->inputs.next, struct hid_input, list);
-+ struct input_dev *input_dev = hidinput->input;
-
- private = kmalloc(sizeof(struct tmff_device), GFP_KERNEL);
- if (!private)
-@@ -155,7 +156,7 @@ int hid_tmff_init(struct hid_device *hid
- private->report = report;
- private->rumble = field;
-
-- set_bit(FF_RUMBLE, hidinput->input.ffbit);
-+ set_bit(FF_RUMBLE, input_dev->ffbit);
- break;
-
- default:
-@@ -164,11 +165,11 @@ int hid_tmff_init(struct hid_device *hid
- }
-
- /* Fallthrough to here only when a valid usage is found */
-- hidinput->input.upload_effect = hid_tmff_upload_effect;
-- hidinput->input.flush = hid_tmff_flush;
-+ input_dev->upload_effect = hid_tmff_upload_effect;
-+ input_dev->flush = hid_tmff_flush;
-
-- set_bit(EV_FF, hidinput->input.evbit);
-- hidinput->input.ff_effects_max = TMFF_EFFECTS;
-+ set_bit(EV_FF, input_dev->evbit);
-+ input_dev->ff_effects_max = TMFF_EFFECTS;
- }
- }
-
---- gregkh-2.6.orig/drivers/usb/input/hid-core.c
-+++ gregkh-2.6/drivers/usb/input/hid-core.c
-@@ -1619,8 +1619,8 @@ static struct hid_device *usb_hid_config
- struct hid_descriptor *hdesc;
- struct hid_device *hid;
- unsigned quirks = 0, rsize = 0;
-- char *buf, *rdesc;
-- int n, insize = 0;
-+ char *rdesc;
-+ int n, len, insize = 0;
-
- for (n = 0; hid_blacklist[n].idVendor; n++)
- if ((hid_blacklist[n].idVendor == le16_to_cpu(dev->descriptor.idVendor)) &&
-@@ -1630,10 +1630,11 @@ static struct hid_device *usb_hid_config
- if (quirks & HID_QUIRK_IGNORE)
- return NULL;
-
-- if (usb_get_extra_descriptor(interface, HID_DT_HID, &hdesc) && ((!interface->desc.bNumEndpoints) ||
-- usb_get_extra_descriptor(&interface->endpoint[0], HID_DT_HID, &hdesc))) {
-- dbg("class descriptor not present\n");
-- return NULL;
-+ if (usb_get_extra_descriptor(interface, HID_DT_HID, &hdesc) &&
-+ (!interface->desc.bNumEndpoints ||
-+ usb_get_extra_descriptor(&interface->endpoint[0], HID_DT_HID, &hdesc))) {
-+ dbg("class descriptor not present\n");
-+ return NULL;
- }
-
- for (n = 0; n < hdesc->bNumDescriptors; n++)
-@@ -1749,32 +1750,34 @@ static struct hid_device *usb_hid_config
-
- hid->name[0] = 0;
-
-- if (!(buf = kmalloc(64, GFP_KERNEL)))
-- goto fail;
-+ if (dev->manufacturer)
-+ strlcpy(hid->name, dev->manufacturer, sizeof(hid->name));
-+
-+ if (dev->product) {
-+ if (dev->manufacturer)
-+ strlcat(hid->name, " ", sizeof(hid->name));
-+ strlcat(hid->name, dev->product, sizeof(hid->name));
-+ }
-
-- if (dev->manufacturer) {
-- strcat(hid->name, dev->manufacturer);
-- if (dev->product)
-- snprintf(hid->name, 64, "%s %s", hid->name, dev->product);
-- } else if (dev->product) {
-- snprintf(hid->name, 128, "%s", dev->product);
-- } else
-- snprintf(hid->name, 128, "%04x:%04x",
-- le16_to_cpu(dev->descriptor.idVendor),
-- le16_to_cpu(dev->descriptor.idProduct));
--
-- usb_make_path(dev, buf, 64);
-- snprintf(hid->phys, 64, "%s/input%d", buf,
-- intf->altsetting[0].desc.bInterfaceNumber);
-+ if (!strlen(hid->name))
-+ snprintf(hid->name, sizeof(hid->name), "HID %04x:%04x",
-+ le16_to_cpu(dev->descriptor.idVendor),
-+ le16_to_cpu(dev->descriptor.idProduct));
-+
-+ usb_make_path(dev, hid->phys, sizeof(hid->phys));
-+ strlcat(hid->phys, "/input", sizeof(hid->phys));
-+ len = strlen(hid->phys);
-+ if (len < sizeof(hid->phys) - 1)
-+ snprintf(hid->phys + len, sizeof(hid->phys) - len,
-+ "%d", intf->altsetting[0].desc.bInterfaceNumber);
-
- if (usb_string(dev, dev->descriptor.iSerialNumber, hid->uniq, 64) <= 0)
- hid->uniq[0] = 0;
-
-- kfree(buf);
--
- hid->urbctrl = usb_alloc_urb(0, GFP_KERNEL);
- if (!hid->urbctrl)
- goto fail;
-+
- usb_fill_control_urb(hid->urbctrl, dev, 0, (void *) hid->cr,
- hid->ctrlbuf, 1, hid_ctrl, hid);
- hid->urbctrl->setup_dma = hid->cr_dma;
---- gregkh-2.6.orig/drivers/usb/input/acecad.c
-+++ gregkh-2.6/drivers/usb/input/acecad.c
-@@ -53,7 +53,7 @@ struct usb_acecad {
- char name[128];
- char phys[64];
- struct usb_device *usbdev;
-- struct input_dev dev;
-+ struct input_dev *input;
- struct urb *irq;
-
- signed char *data;
-@@ -64,7 +64,7 @@ static void usb_acecad_irq(struct urb *u
- {
- struct usb_acecad *acecad = urb->context;
- unsigned char *data = acecad->data;
-- struct input_dev *dev = &acecad->dev;
-+ struct input_dev *dev = acecad->input;
- int prox, status;
-
- switch (urb->status) {
-@@ -135,8 +135,8 @@ static int usb_acecad_probe(struct usb_i
- struct usb_host_interface *interface = intf->cur_altsetting;
- struct usb_endpoint_descriptor *endpoint;
- struct usb_acecad *acecad;
-+ struct input_dev *input_dev;
- int pipe, maxp;
-- char path[64];
-
- if (interface->desc.bNumEndpoints != 1)
- return -ENODEV;
-@@ -153,8 +153,9 @@ static int usb_acecad_probe(struct usb_i
- maxp = usb_maxpacket(dev, pipe, usb_pipeout(pipe));
-
- acecad = kzalloc(sizeof(struct usb_acecad), GFP_KERNEL);
-- if (!acecad)
-- return -ENOMEM;
-+ input_dev = input_allocate_device();
-+ if (!acecad || !input_dev)
-+ goto fail1;
-
- acecad->data = usb_buffer_alloc(dev, 8, SLAB_KERNEL, &acecad->data_dma);
- if (!acecad->data)
-@@ -164,6 +165,9 @@ static int usb_acecad_probe(struct usb_i
- if (!acecad->irq)
- goto fail2;
-
-+ acecad->usbdev = dev;
-+ acecad->input = input_dev;
-+
- if (dev->manufacturer)
- strlcpy(acecad->name, dev->manufacturer, sizeof(acecad->name));
-
-@@ -173,48 +177,48 @@ static int usb_acecad_probe(struct usb_i
- strlcat(acecad->name, dev->product, sizeof(acecad->name));
- }
-
-- usb_make_path(dev, path, sizeof(path));
-- snprintf(acecad->phys, sizeof(acecad->phys), "%s/input0", path);
-+ usb_make_path(dev, acecad->phys, sizeof(acecad->phys));
-+ strlcat(acecad->phys, "/input0", sizeof(acecad->phys));
-
-- acecad->usbdev = dev;
--
-- acecad->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- acecad->dev.absbit[0] = BIT(ABS_X) | BIT(ABS_Y) | BIT(ABS_PRESSURE);
-- acecad->dev.keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
-- acecad->dev.keybit[LONG(BTN_DIGI)] = BIT(BTN_TOOL_PEN) |BIT(BTN_TOUCH) | BIT(BTN_STYLUS) | BIT(BTN_STYLUS2);
-+ input_dev->name = acecad->name;
-+ input_dev->phys = acecad->phys;
-+ usb_to_input_id(dev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = acecad;
-+
-+ input_dev->open = usb_acecad_open;
-+ input_dev->close = usb_acecad_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->absbit[0] = BIT(ABS_X) | BIT(ABS_Y) | BIT(ABS_PRESSURE);
-+ input_dev->keybit[LONG(BTN_LEFT)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);
-+ input_dev->keybit[LONG(BTN_DIGI)] = BIT(BTN_TOOL_PEN) |BIT(BTN_TOUCH) | BIT(BTN_STYLUS) | BIT(BTN_STYLUS2);
-
- switch (id->driver_info) {
- case 0:
-- acecad->dev.absmax[ABS_X] = 5000;
-- acecad->dev.absmax[ABS_Y] = 3750;
-- acecad->dev.absmax[ABS_PRESSURE] = 512;
-+ input_dev->absmax[ABS_X] = 5000;
-+ input_dev->absmax[ABS_Y] = 3750;
-+ input_dev->absmax[ABS_PRESSURE] = 512;
- if (!strlen(acecad->name))
- snprintf(acecad->name, sizeof(acecad->name),
- "USB Acecad Flair Tablet %04x:%04x",
-- dev->descriptor.idVendor, dev->descriptor.idProduct);
-+ le16_to_cpu(dev->descriptor.idVendor),
-+ le16_to_cpu(dev->descriptor.idProduct));
- break;
- case 1:
-- acecad->dev.absmax[ABS_X] = 3000;
-- acecad->dev.absmax[ABS_Y] = 2250;
-- acecad->dev.absmax[ABS_PRESSURE] = 1024;
-+ input_dev->absmax[ABS_X] = 3000;
-+ input_dev->absmax[ABS_Y] = 2250;
-+ input_dev->absmax[ABS_PRESSURE] = 1024;
- if (!strlen(acecad->name))
- snprintf(acecad->name, sizeof(acecad->name),
- "USB Acecad 302 Tablet %04x:%04x",
-- dev->descriptor.idVendor, dev->descriptor.idProduct);
-+ le16_to_cpu(dev->descriptor.idVendor),
-+ le16_to_cpu(dev->descriptor.idProduct));
- break;
- }
-
-- acecad->dev.absfuzz[ABS_X] = 4;
-- acecad->dev.absfuzz[ABS_Y] = 4;
--
-- acecad->dev.private = acecad;
-- acecad->dev.open = usb_acecad_open;
-- acecad->dev.close = usb_acecad_close;
--
-- acecad->dev.name = acecad->name;
-- acecad->dev.phys = acecad->phys;
-- usb_to_input_id(dev, &acecad->dev.id);
-- acecad->dev.dev = &intf->dev;
-+ input_dev->absfuzz[ABS_X] = 4;
-+ input_dev->absfuzz[ABS_Y] = 4;
-
- usb_fill_int_urb(acecad->irq, dev, pipe,
- acecad->data, maxp > 8 ? 8 : maxp,
-@@ -222,17 +226,15 @@ static int usb_acecad_probe(struct usb_i
- acecad->irq->transfer_dma = acecad->data_dma;
- acecad->irq->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-
-- input_register_device(&acecad->dev);
--
-- printk(KERN_INFO "input: %s with packet size %d on %s\n",
-- acecad->name, maxp, path);
-+ input_register_device(acecad->input);
-
- usb_set_intfdata(intf, acecad);
-
- return 0;
-
- fail2: usb_buffer_free(dev, 8, acecad->data, acecad->data_dma);
-- fail1: kfree(acecad);
-+ fail1: input_free_device(input_dev);
-+ kfree(acecad);
- return -ENOMEM;
- }
-
-@@ -243,7 +245,7 @@ static void usb_acecad_disconnect(struct
- usb_set_intfdata(intf, NULL);
- if (acecad) {
- usb_kill_urb(acecad->irq);
-- input_unregister_device(&acecad->dev);
-+ input_unregister_device(acecad->input);
- usb_free_urb(acecad->irq);
- usb_buffer_free(interface_to_usbdev(intf), 10, acecad->data, acecad->data_dma);
- kfree(acecad);
---- gregkh-2.6.orig/drivers/usb/input/itmtouch.c
-+++ gregkh-2.6/drivers/usb/input/itmtouch.c
-@@ -73,7 +73,7 @@ MODULE_LICENSE( DRIVER_LICENSE );
-
- struct itmtouch_dev {
- struct usb_device *usbdev; /* usb device */
-- struct input_dev inputdev; /* input device */
-+ struct input_dev *inputdev; /* input device */
- struct urb *readurb; /* urb */
- char rbuf[ITM_BUFSIZE]; /* data */
- int users;
-@@ -88,9 +88,9 @@ static struct usb_device_id itmtouch_ids
-
- static void itmtouch_irq(struct urb *urb, struct pt_regs *regs)
- {
-- struct itmtouch_dev * itmtouch = urb->context;
-+ struct itmtouch_dev *itmtouch = urb->context;
- unsigned char *data = urb->transfer_buffer;
-- struct input_dev *dev = &itmtouch->inputdev;
-+ struct input_dev *dev = itmtouch->inputdev;
- int retval;
-
- switch (urb->status) {
-@@ -156,49 +156,62 @@ static void itmtouch_close(struct input_
- static int itmtouch_probe(struct usb_interface *intf, const struct usb_device_id *id)
- {
- struct itmtouch_dev *itmtouch;
-+ struct input_dev *input_dev;
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct usb_device *udev = interface_to_usbdev(intf);
- unsigned int pipe;
- unsigned int maxp;
-- char path[PATH_SIZE];
-
- interface = intf->cur_altsetting;
- endpoint = &interface->endpoint[0].desc;
-
-- if (!(itmtouch = kzalloc(sizeof(struct itmtouch_dev), GFP_KERNEL))) {
-+ itmtouch = kzalloc(sizeof(struct itmtouch_dev), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!itmtouch || !input_dev) {
- err("%s - Out of memory.", __FUNCTION__);
-- return -ENOMEM;
-+ goto fail;
- }
-
- itmtouch->usbdev = udev;
-+ itmtouch->inputdev = input_dev;
-
-- itmtouch->inputdev.private = itmtouch;
-- itmtouch->inputdev.open = itmtouch_open;
-- itmtouch->inputdev.close = itmtouch_close;
--
-- usb_make_path(udev, path, PATH_SIZE);
--
-- itmtouch->inputdev.evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-- itmtouch->inputdev.absbit[0] = BIT(ABS_X) | BIT(ABS_Y) | BIT(ABS_PRESSURE);
-- itmtouch->inputdev.keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
--
-- itmtouch->inputdev.name = itmtouch->name;
-- itmtouch->inputdev.phys = itmtouch->phys;
-- usb_to_input_id(udev, &itmtouch->inputdev.id);
-- itmtouch->inputdev.dev = &intf->dev;
-+ if (udev->manufacturer)
-+ strlcpy(itmtouch->name, udev->manufacturer, sizeof(itmtouch->name));
-+
-+ if (udev->product) {
-+ if (udev->manufacturer)
-+ strlcat(itmtouch->name, " ", sizeof(itmtouch->name));
-+ strlcat(itmtouch->name, udev->product, sizeof(itmtouch->name));
-+ }
-
- if (!strlen(itmtouch->name))
- sprintf(itmtouch->name, "USB ITM touchscreen");
-
-+ usb_make_path(udev, itmtouch->phys, sizeof(itmtouch->phys));
-+ strlcpy(itmtouch->phys, "/input0", sizeof(itmtouch->phys));
-+
-+ input_dev->name = itmtouch->name;
-+ input_dev->phys = itmtouch->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+ input_dev->private = itmtouch;
-+
-+ input_dev->open = itmtouch_open;
-+ input_dev->close = itmtouch_close;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS);
-+ input_dev->absbit[0] = BIT(ABS_X) | BIT(ABS_Y) | BIT(ABS_PRESSURE);
-+ input_dev->keybit[LONG(BTN_TOUCH)] = BIT(BTN_TOUCH);
-+
- /* device limits */
- /* as specified by the ITM datasheet, X and Y are 12bit,
- * Z (pressure) is 8 bit. However, the fields are defined up
- * to 14 bits for future possible expansion.
- */
-- input_set_abs_params(&itmtouch->inputdev, ABS_X, 0, 0x0FFF, 2, 0);
-- input_set_abs_params(&itmtouch->inputdev, ABS_Y, 0, 0x0FFF, 2, 0);
-- input_set_abs_params(&itmtouch->inputdev, ABS_PRESSURE, 0, 0xFF, 2, 0);
-+ input_set_abs_params(input_dev, ABS_X, 0, 0x0FFF, 2, 0);
-+ input_set_abs_params(input_dev, ABS_Y, 0, 0x0FFF, 2, 0);
-+ input_set_abs_params(input_dev, ABS_PRESSURE, 0, 0xFF, 2, 0);
-
- /* initialise the URB so we can read from the transport stream */
- pipe = usb_rcvintpipe(itmtouch->usbdev, endpoint->bEndpointAddress);
-@@ -208,22 +221,23 @@ static int itmtouch_probe(struct usb_int
- maxp = ITM_BUFSIZE;
-
- itmtouch->readurb = usb_alloc_urb(0, GFP_KERNEL);
--
- if (!itmtouch->readurb) {
- dbg("%s - usb_alloc_urb failed: itmtouch->readurb", __FUNCTION__);
-- kfree(itmtouch);
-- return -ENOMEM;
-+ goto fail;
- }
-
- usb_fill_int_urb(itmtouch->readurb, itmtouch->usbdev, pipe, itmtouch->rbuf,
- maxp, itmtouch_irq, itmtouch, endpoint->bInterval);
-
-- input_register_device(&itmtouch->inputdev);
-+ input_register_device(itmtouch->inputdev);
-
-- printk(KERN_INFO "itmtouch: %s registered on %s\n", itmtouch->name, path);
- usb_set_intfdata(intf, itmtouch);
-
- return 0;
-+
-+ fail: input_free_device(input_dev);
-+ kfree(itmtouch);
-+ return -ENOMEM;
- }
-
- static void itmtouch_disconnect(struct usb_interface *intf)
-@@ -233,7 +247,7 @@ static void itmtouch_disconnect(struct u
- usb_set_intfdata(intf, NULL);
-
- if (itmtouch) {
-- input_unregister_device(&itmtouch->inputdev);
-+ input_unregister_device(itmtouch->inputdev);
- usb_kill_urb(itmtouch->readurb);
- usb_free_urb(itmtouch->readurb);
- kfree(itmtouch);
---- gregkh-2.6.orig/drivers/usb/input/keyspan_remote.c
-+++ gregkh-2.6/drivers/usb/input/keyspan_remote.c
-@@ -20,6 +20,7 @@
- #include <linux/moduleparam.h>
- #include <linux/input.h>
- #include <linux/usb.h>
-+#include <linux/usb_input.h>
-
- #define DRIVER_VERSION "v0.1"
- #define DRIVER_AUTHOR "Michael Downey <downey@zymeta.com>"
-@@ -75,7 +76,7 @@ struct usb_keyspan {
- char name[128];
- char phys[64];
- struct usb_device* udev;
-- struct input_dev input;
-+ struct input_dev *input;
- struct usb_interface* interface;
- struct usb_endpoint_descriptor* in_endpoint;
- struct urb* irq_urb;
-@@ -136,12 +137,11 @@ static struct usb_driver keyspan_driver;
- */
- static void keyspan_print(struct usb_keyspan* dev) /*unsigned char* data)*/
- {
-- char codes[4*RECV_SIZE];
-+ char codes[4 * RECV_SIZE];
- int i;
-
-- for (i = 0; i < RECV_SIZE; i++) {
-- snprintf(codes+i*3, 4, "%02x ", dev->in_buffer[i]);
-- }
-+ for (i = 0; i < RECV_SIZE; i++)
-+ snprintf(codes + i * 3, 4, "%02x ", dev->in_buffer[i]);
-
- dev_info(&dev->udev->dev, "%s\n", codes);
- }
-@@ -153,7 +153,7 @@ static void keyspan_print(struct usb_key
- static int keyspan_load_tester(struct usb_keyspan* dev, int bits_needed)
- {
- if (dev->data.bits_left >= bits_needed)
-- return(0);
-+ return 0;
-
- /*
- * Somehow we've missed the last message. The message will be repeated
-@@ -162,7 +162,7 @@ static int keyspan_load_tester(struct us
- if (dev->data.pos >= dev->data.len) {
- dev_dbg(&dev->udev, "%s - Error ran out of data. pos: %d, len: %d\n",
- __FUNCTION__, dev->data.pos, dev->data.len);
-- return(-1);
-+ return -1;
- }
-
- /* Load as much as we can into the tester. */
-@@ -172,7 +172,7 @@ static int keyspan_load_tester(struct us
- dev->data.bits_left += 8;
- }
-
-- return(0);
-+ return 0;
- }
-
- /*
-@@ -311,10 +311,10 @@ static void keyspan_check_data(struct us
- __FUNCTION__, message.system, message.button, message.toggle);
-
- if (message.toggle != remote->toggle) {
-- input_regs(&remote->input, regs);
-- input_report_key(&remote->input, keyspan_key_table[message.button], 1);
-- input_report_key(&remote->input, keyspan_key_table[message.button], 0);
-- input_sync(&remote->input);
-+ input_regs(remote->input, regs);
-+ input_report_key(remote->input, keyspan_key_table[message.button], 1);
-+ input_report_key(remote->input, keyspan_key_table[message.button], 0);
-+ input_sync(remote->input);
- remote->toggle = message.toggle;
- }
-
-@@ -397,14 +397,9 @@ static int keyspan_open(struct input_dev
- {
- struct usb_keyspan *remote = dev->private;
-
-- if (remote->open++)
-- return 0;
--
- remote->irq_urb->dev = remote->udev;
-- if (usb_submit_urb(remote->irq_urb, GFP_KERNEL)) {
-- remote->open--;
-+ if (usb_submit_urb(remote->irq_urb, GFP_KERNEL))
- return -EIO;
-- }
-
- return 0;
- }
-@@ -413,8 +408,26 @@ static void keyspan_close(struct input_d
- {
- struct usb_keyspan *remote = dev->private;
-
-- if (!--remote->open)
-- usb_kill_urb(remote->irq_urb);
-+ usb_kill_urb(remote->irq_urb);
-+}
-+
-+static struct usb_endpoint_descriptor *keyspan_get_in_endpoint(struct usb_host_interface *iface)
-+{
-+
-+ struct usb_endpoint_descriptor *endpoint;
-+ int i;
-+
-+ for (i = 0; i < iface->desc.bNumEndpoints; ++i) {
-+ endpoint = &iface->endpoint[i].desc;
-+
-+ if ((endpoint->bEndpointAddress & USB_DIR_IN) &&
-+ ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) == USB_ENDPOINT_XFER_INT)) {
-+ /* we found our interrupt in endpoint */
-+ return endpoint;
-+ }
-+ }
-+
-+ return NULL;
- }
-
- /*
-@@ -422,110 +435,78 @@ static void keyspan_close(struct input_d
- */
- static int keyspan_probe(struct usb_interface *interface, const struct usb_device_id *id)
- {
-- int i;
-- int retval = -ENOMEM;
-- char path[64];
-- char *buf;
-- struct usb_keyspan *remote = NULL;
-- struct usb_host_interface *iface_desc;
-+ struct usb_device *udev = interface_to_usbdev(interface);
- struct usb_endpoint_descriptor *endpoint;
-- struct usb_device *udev = usb_get_dev(interface_to_usbdev(interface));
-+ struct usb_keyspan *remote;
-+ struct input_dev *input_dev;
-+ int i, retval;
-
-- /* allocate memory for our device state and initialize it */
-- remote = kmalloc(sizeof(*remote), GFP_KERNEL);
-- if (remote == NULL) {
-- err("Out of memory\n");
-- goto error;
-+ endpoint = keyspan_get_in_endpoint(interface->cur_altsetting);
-+ if (!endpoint)
-+ return -ENODEV;
-+
-+ remote = kzalloc(sizeof(*remote), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!remote || !input_dev) {
-+ retval = -ENOMEM;
-+ goto fail1;
- }
-- memset(remote, 0x00, sizeof(*remote));
-
- remote->udev = udev;
-+ remote->input = input_dev;
- remote->interface = interface;
-+ remote->in_endpoint = endpoint;
- remote->toggle = -1; /* Set to -1 so we will always not match the toggle from the first remote message. */
-
-- /* set up the endpoint information */
-- /* use only the first in interrupt endpoint */
-- iface_desc = interface->cur_altsetting;
-- for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i) {
-- endpoint = &iface_desc->endpoint[i].desc;
--
-- if (!remote->in_endpoint &&
-- (endpoint->bEndpointAddress & USB_DIR_IN) &&
-- ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) == USB_ENDPOINT_XFER_INT)) {
-- /* we found our interrupt in endpoint */
-- remote->in_endpoint = endpoint;
--
-- remote->in_buffer = usb_buffer_alloc(remote->udev, RECV_SIZE, SLAB_ATOMIC, &remote->in_dma);
-- if (!remote->in_buffer) {
-- retval = -ENOMEM;
-- goto error;
-- }
-- }
-- }
--
-- if (!remote->in_endpoint) {
-- err("Could not find interrupt input endpoint.\n");
-- retval = -ENODEV;
-- goto error;
-+ remote->in_buffer = usb_buffer_alloc(udev, RECV_SIZE, SLAB_ATOMIC, &remote->in_dma);
-+ if (!remote->in_buffer) {
-+ retval = -ENOMEM;
-+ goto fail1;
- }
-
- remote->irq_urb = usb_alloc_urb(0, GFP_KERNEL);
- if (!remote->irq_urb) {
-- err("Failed to allocate urb.\n");
- retval = -ENOMEM;
-- goto error;
-+ goto fail2;
- }
-
-- retval = keyspan_setup(remote->udev);
-+ retval = keyspan_setup(udev);
- if (retval) {
-- err("Failed to setup device.\n");
- retval = -ENODEV;
-- goto error;
-- }
--
-- /*
-- * Setup the input system with the bits we are going to be reporting
-- */
-- remote->input.evbit[0] = BIT(EV_KEY); /* We will only report KEY events. */
-- for (i = 0; i < 32; ++i) {
-- if (keyspan_key_table[i] != KEY_RESERVED) {
-- set_bit(keyspan_key_table[i], remote->input.keybit);
-- }
-+ goto fail3;
- }
-
-- remote->input.private = remote;
-- remote->input.open = keyspan_open;
-- remote->input.close = keyspan_close;
--
-- usb_make_path(remote->udev, path, 64);
-- sprintf(remote->phys, "%s/input0", path);
--
-- remote->input.name = remote->name;
-- remote->input.phys = remote->phys;
-- remote->input.id.bustype = BUS_USB;
-- remote->input.id.vendor = le16_to_cpu(remote->udev->descriptor.idVendor);
-- remote->input.id.product = le16_to_cpu(remote->udev->descriptor.idProduct);
-- remote->input.id.version = le16_to_cpu(remote->udev->descriptor.bcdDevice);
-+ if (udev->manufacturer)
-+ strlcpy(remote->name, udev->manufacturer, sizeof(remote->name));
-
-- if (!(buf = kmalloc(63, GFP_KERNEL))) {
-- usb_buffer_free(remote->udev, RECV_SIZE, remote->in_buffer, remote->in_dma);
-- kfree(remote);
-- return -ENOMEM;
-+ if (udev->product) {
-+ if (udev->manufacturer)
-+ strlcat(remote->name, " ", sizeof(remote->name));
-+ strlcat(remote->name, udev->product, sizeof(remote->name));
- }
-
-- if (remote->udev->descriptor.iManufacturer &&
-- usb_string(remote->udev, remote->udev->descriptor.iManufacturer, buf, 63) > 0)
-- strcat(remote->name, buf);
--
-- if (remote->udev->descriptor.iProduct &&
-- usb_string(remote->udev, remote->udev->descriptor.iProduct, buf, 63) > 0)
-- sprintf(remote->name, "%s %s", remote->name, buf);
--
- if (!strlen(remote->name))
-- sprintf(remote->name, "USB Keyspan Remote %04x:%04x",
-- remote->input.id.vendor, remote->input.id.product);
--
-- kfree(buf);
-+ snprintf(remote->name, sizeof(remote->name),
-+ "USB Keyspan Remote %04x:%04x",
-+ le16_to_cpu(udev->descriptor.idVendor),
-+ le16_to_cpu(udev->descriptor.idProduct));
-+
-+ usb_make_path(udev, remote->phys, sizeof(remote->phys));
-+ strlcat(remote->phys, "/input0", sizeof(remote->phys));
-+
-+ input_dev->name = remote->name;
-+ input_dev->phys = remote->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &interface->dev;
-+
-+ input_dev->evbit[0] = BIT(EV_KEY); /* We will only report KEY events. */
-+ for (i = 0; i < ARRAY_SIZE(keyspan_key_table); i++)
-+ if (keyspan_key_table[i] != KEY_RESERVED)
-+ set_bit(keyspan_key_table[i], input_dev->keybit);
-+
-+ input_dev->private = remote;
-+ input_dev->open = keyspan_open;
-+ input_dev->close = keyspan_close;
-
- /*
- * Initialize the URB to access the device. The urb gets sent to the device in keyspan_open()
-@@ -538,27 +519,17 @@ static int keyspan_probe(struct usb_inte
- remote->irq_urb->transfer_flags |= URB_NO_TRANSFER_DMA_MAP;
-
- /* we can register the device now, as it is ready */
-- input_register_device(&remote->input);
-+ input_register_device(remote->input);
-
- /* save our data pointer in this interface device */
- usb_set_intfdata(interface, remote);
-
-- /* let the user know what node this device is now attached to */
-- info("connected: %s on %s", remote->name, path);
- return 0;
-
--error:
-- /*
-- * In case of error we need to clean up any allocated buffers
-- */
-- if (remote->irq_urb)
-- usb_free_urb(remote->irq_urb);
--
-- if (remote->in_buffer)
-- usb_buffer_free(remote->udev, RECV_SIZE, remote->in_buffer, remote->in_dma);
--
-- if (remote)
-- kfree(remote);
-+ fail3: usb_free_urb(remote->irq_urb);
-+ fail2: usb_buffer_free(udev, RECV_SIZE, remote->in_buffer, remote->in_dma);
-+ fail1: kfree(remote);
-+ input_free_device(input_dev);
-
- return retval;
- }
-@@ -570,23 +541,16 @@ static void keyspan_disconnect(struct us
- {
- struct usb_keyspan *remote;
-
-- /* prevent keyspan_open() from racing keyspan_disconnect() */
-- lock_kernel();
--
- remote = usb_get_intfdata(interface);
- usb_set_intfdata(interface, NULL);
-
- if (remote) { /* We have a valid driver structure so clean up everything we allocated. */
-- input_unregister_device(&remote->input);
-+ input_unregister_device(remote->input);
- usb_kill_urb(remote->irq_urb);
- usb_free_urb(remote->irq_urb);
-- usb_buffer_free(interface_to_usbdev(interface), RECV_SIZE, remote->in_buffer, remote->in_dma);
-+ usb_buffer_free(remote->udev, RECV_SIZE, remote->in_buffer, remote->in_dma);
- kfree(remote);
- }
--
-- unlock_kernel();
--
-- info("USB Keyspan now disconnected");
- }
-
- /*
---- gregkh-2.6.orig/drivers/usb/input/yealink.c
-+++ gregkh-2.6/drivers/usb/input/yealink.c
-@@ -54,6 +54,7 @@
- #include <linux/module.h>
- #include <linux/rwsem.h>
- #include <linux/usb.h>
-+#include <linux/usb_input.h>
-
- #include "map_to_7segment.h"
- #include "yealink.h"
-@@ -101,12 +102,12 @@ static const struct lcd_segment_map {
- };
-
- struct yealink_dev {
-- struct input_dev idev; /* input device */
-+ struct input_dev *idev; /* input device */
- struct usb_device *udev; /* usb device */
-
- /* irq input channel */
- struct yld_ctl_packet *irq_data;
-- dma_addr_t irq_dma;
-+ dma_addr_t irq_dma;
- struct urb *urb_irq;
-
- /* control output channel */
-@@ -237,7 +238,7 @@ static int map_p1k_to_key(int scancode)
- */
- static void report_key(struct yealink_dev *yld, int key, struct pt_regs *regs)
- {
-- struct input_dev *idev = &yld->idev;
-+ struct input_dev *idev = yld->idev;
-
- input_regs(idev, regs);
- if (yld->key_code >= 0) {
-@@ -809,8 +810,12 @@ static int usb_cleanup(struct yealink_de
- }
- if (yld->urb_ctl)
- usb_free_urb(yld->urb_ctl);
-- if (yld->idev.dev)
-- input_unregister_device(&yld->idev);
-+ if (yld->idev) {
-+ if (err)
-+ input_free_device(yld->idev);
-+ else
-+ input_unregister_device(yld->idev);
-+ }
- if (yld->ctl_req)
- usb_buffer_free(yld->udev, sizeof(*(yld->ctl_req)),
- yld->ctl_req, yld->ctl_req_dma);
-@@ -857,7 +862,7 @@ static int usb_probe(struct usb_interfac
- struct usb_host_interface *interface;
- struct usb_endpoint_descriptor *endpoint;
- struct yealink_dev *yld;
-- char path[64];
-+ struct input_dev *input_dev;
- int ret, pipe, i;
-
- i = usb_match(udev);
-@@ -866,17 +871,21 @@ static int usb_probe(struct usb_interfac
-
- interface = intf->cur_altsetting;
- endpoint = &interface->endpoint[0].desc;
-- if (!(endpoint->bEndpointAddress & 0x80))
-+ if (!(endpoint->bEndpointAddress & USB_DIR_IN))
- return -EIO;
-- if ((endpoint->bmAttributes & 3) != 3)
-+ if ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK) != USB_ENDPOINT_XFER_INT)
- return -EIO;
-
-- if ((yld = kmalloc(sizeof(struct yealink_dev), GFP_KERNEL)) == NULL)
-+ yld = kzalloc(sizeof(struct yealink_dev), GFP_KERNEL);
-+ if (!yld)
- return -ENOMEM;
-
-- memset(yld, 0, sizeof(*yld));
- yld->udev = udev;
-
-+ yld->idev = input_dev = input_allocate_device();
-+ if (!input_dev)
-+ return usb_cleanup(yld, -ENOMEM);
-+
- /* allocate usb buffers */
- yld->irq_data = usb_buffer_alloc(udev, USB_PKT_LEN,
- SLAB_ATOMIC, &yld->irq_dma);
-@@ -935,42 +944,37 @@ static int usb_probe(struct usb_interfac
- yld->urb_ctl->dev = udev;
-
- /* find out the physical bus location */
-- if (usb_make_path(udev, path, sizeof(path)) > 0)
-- snprintf(yld->phys, sizeof(yld->phys)-1, "%s/input0", path);
-+ usb_make_path(udev, yld->phys, sizeof(yld->phys));
-+ strlcat(yld->phys, "/input0", sizeof(yld->phys));
-
- /* register settings for the input device */
-- init_input_dev(&yld->idev);
-- yld->idev.private = yld;
-- yld->idev.id.bustype = BUS_USB;
-- yld->idev.id.vendor = le16_to_cpu(udev->descriptor.idVendor);
-- yld->idev.id.product = le16_to_cpu(udev->descriptor.idProduct);
-- yld->idev.id.version = le16_to_cpu(udev->descriptor.bcdDevice);
-- yld->idev.dev = &intf->dev;
-- yld->idev.name = yld_device[i].name;
-- yld->idev.phys = yld->phys;
-- /* yld->idev.event = input_ev; TODO */
-- yld->idev.open = input_open;
-- yld->idev.close = input_close;
-+ input_dev->name = yld_device[i].name;
-+ input_dev->phys = yld->phys;
-+ usb_to_input_id(udev, &input_dev->id);
-+ input_dev->cdev.dev = &intf->dev;
-+
-+ input_dev->private = yld;
-+ input_dev->open = input_open;
-+ input_dev->close = input_close;
-+ /* input_dev->event = input_ev; TODO */
-
- /* register available key events */
-- yld->idev.evbit[0] = BIT(EV_KEY);
-+ input_dev->evbit[0] = BIT(EV_KEY);
- for (i = 0; i < 256; i++) {
- int k = map_p1k_to_key(i);
- if (k >= 0) {
-- set_bit(k & 0xff, yld->idev.keybit);
-+ set_bit(k & 0xff, input_dev->keybit);
- if (k >> 8)
-- set_bit(k >> 8, yld->idev.keybit);
-+ set_bit(k >> 8, input_dev->keybit);
- }
- }
-
-- printk(KERN_INFO "input: %s on %s\n", yld->idev.name, path);
--
-- input_register_device(&yld->idev);
-+ input_register_device(yld->idev);
-
- usb_set_intfdata(intf, yld);
-
- /* clear visible elements */
-- for (i=0; i<ARRAY_SIZE(lcdMap); i++)
-+ for (i = 0; i < ARRAY_SIZE(lcdMap); i++)
- setChar(yld, i, ' ');
-
- /* display driver version on LCD line 3 */
---- gregkh-2.6.orig/drivers/usb/input/appletouch.c
-+++ gregkh-2.6/drivers/usb/input/appletouch.c
-@@ -39,7 +39,7 @@
- #define APPLE_VENDOR_ID 0x05AC
-
- #define ATP_DEVICE(prod) \
-- .match_flags = USB_DEVICE_ID_MATCH_DEVICE | \
-+ .match_flags = USB_DEVICE_ID_MATCH_DEVICE | \
- USB_DEVICE_ID_MATCH_INT_CLASS | \
- USB_DEVICE_ID_MATCH_INT_PROTOCOL, \
- .idVendor = APPLE_VENDOR_ID, \
-@@ -78,9 +78,9 @@ MODULE_DEVICE_TABLE (usb, atp_table);
- * We try to keep the touchpad aspect ratio while still doing only simple
- * arithmetics.
- * The factors below give coordinates like:
-- * 0 <= x < 960 on 12" and 15" Powerbooks
-- * 0 <= x < 1600 on 17" Powerbooks
-- * 0 <= y < 646
-+ * 0 <= x < 960 on 12" and 15" Powerbooks
-+ * 0 <= x < 1600 on 17" Powerbooks
-+ * 0 <= y < 646
- */
- #define ATP_XFACT 64
- #define ATP_YFACT 43
-@@ -93,11 +93,12 @@ MODULE_DEVICE_TABLE (usb, atp_table);
-
- /* Structure to hold all of our device specific stuff */
- struct atp {
-+ char phys[64];
- struct usb_device * udev; /* usb device */
- struct urb * urb; /* usb request block */
- signed char * data; /* transferred data */
- int open; /* non-zero if opened */
-- struct input_dev input; /* input dev */
-+ struct input_dev *input; /* input dev */
- int valid; /* are the sensors valid ? */
- int x_old; /* last reported x/y, */
- int y_old; /* used for smoothing */
-@@ -114,11 +115,11 @@ struct atp {
- int i; \
- printk("appletouch: %s %lld", msg, (long long)jiffies); \
- for (i = 0; i < ATP_XSENSORS + ATP_YSENSORS; i++) \
-- printk(" %02x", tab[i]); \
-- printk("\n"); \
-+ printk(" %02x", tab[i]); \
-+ printk("\n"); \
- }
-
--#define dprintk(format, a...) \
-+#define dprintk(format, a...) \
- do { \
- if (debug) printk(format, ##a); \
- } while (0)
-@@ -219,8 +220,8 @@ static void atp_complete(struct urb* urb
- for (i = 16; i < ATP_XSENSORS; i++)
- if (dev->xy_cur[i]) {
- printk("appletouch: 17\" model detected.\n");
-- input_set_abs_params(&dev->input, ABS_X, 0,
-- (ATP_XSENSORS - 1) *
-+ input_set_abs_params(dev->input, ABS_X, 0,
-+ (ATP_XSENSORS - 1) *
- ATP_XFACT - 1,
- ATP_FUZZ, 0);
- break;
-@@ -260,12 +261,12 @@ static void atp_complete(struct urb* urb
- "Xz: %3d Yz: %3d\n",
- x, y, x_z, y_z);
-
-- input_report_key(&dev->input, BTN_TOUCH, 1);
-- input_report_abs(&dev->input, ABS_X, x);
-- input_report_abs(&dev->input, ABS_Y, y);
-- input_report_abs(&dev->input, ABS_PRESSURE,
-+ input_report_key(dev->input, BTN_TOUCH, 1);
-+ input_report_abs(dev->input, ABS_X, x);
-+ input_report_abs(dev->input, ABS_Y, y);
-+ input_report_abs(dev->input, ABS_PRESSURE,
- min(ATP_PRESSURE, x_z + y_z));
-- atp_report_fingers(&dev->input, max(x_f, y_f));
-+ atp_report_fingers(dev->input, max(x_f, y_f));
- }
- dev->x_old = x;
- dev->y_old = y;
-@@ -273,17 +274,17 @@ static void atp_complete(struct urb* urb
- else if (!x && !y) {
-
- dev->x_old = dev->y_old = -1;
-- input_report_key(&dev->input, BTN_TOUCH, 0);
-- input_report_abs(&dev->input, ABS_PRESSURE, 0);
-- atp_report_fingers(&dev->input, 0);
-+ input_report_key(dev->input, BTN_TOUCH, 0);
-+ input_report_abs(dev->input, ABS_PRESSURE, 0);
-+ atp_report_fingers(dev->input, 0);
-
- /* reset the accumulator on release */
- memset(dev->xy_acc, 0, sizeof(dev->xy_acc));
- }
-
-- input_report_key(&dev->input, BTN_LEFT, !!dev->data[80]);
-+ input_report_key(dev->input, BTN_LEFT, !!dev->data[80]);
-
-- input_sync(&dev->input);
-+ input_sync(dev->input);
-
- exit:
- retval = usb_submit_urb(dev->urb, GFP_ATOMIC);
-@@ -314,21 +315,14 @@ static void atp_close(struct input_dev *
-
- static int atp_probe(struct usb_interface *iface, const struct usb_device_id *id)
- {
-- struct atp *dev = NULL;
-+ struct atp *dev;
-+ struct input_dev *input_dev;
-+ struct usb_device *udev = interface_to_usbdev(iface);
- struct usb_host_interface *iface_desc;
- struct usb_endpoint_descriptor *endpoint;
- int int_in_endpointAddr = 0;
- int i, retval = -ENOMEM;
-
-- /* allocate memory for our device state and initialize it */
-- dev = kmalloc(sizeof(struct atp), GFP_KERNEL);
-- if (dev == NULL) {
-- err("Out of memory");
-- goto err_kmalloc;
-- }
-- memset(dev, 0, sizeof(struct atp));
--
-- dev->udev = interface_to_usbdev(iface);
-
- /* set up the endpoint information */
- /* use only the first interrupt-in endpoint */
-@@ -345,70 +339,82 @@ static int atp_probe(struct usb_interfac
- }
- }
- if (!int_in_endpointAddr) {
-- retval = -EIO;
- err("Could not find int-in endpoint");
-- goto err_endpoint;
-+ return -EIO;
- }
-
-- /* save our data pointer in this interface device */
-- usb_set_intfdata(iface, dev);
-+ /* allocate memory for our device state and initialize it */
-+ dev = kzalloc(sizeof(struct atp), GFP_KERNEL);
-+ input_dev = input_allocate_device();
-+ if (!dev || !input_dev) {
-+ err("Out of memory");
-+ goto err_free_devs;
-+ }
-+
-+ dev->udev = udev;
-+ dev->input = input_dev;
-
- dev->urb = usb_alloc_urb(0, GFP_KERNEL);
- if (!dev->urb) {
- retval = -ENOMEM;
-- goto err_usballoc;
-+ goto err_free_devs;
- }
-+
- dev->data = usb_buffer_alloc(dev->udev, ATP_DATASIZE, GFP_KERNEL,
- &dev->urb->transfer_dma);
- if (!dev->data) {
- retval = -ENOMEM;
-- goto err_usbbufalloc;
-+ goto err_free_urb;
- }
-- usb_fill_int_urb(dev->urb, dev->udev,
-- usb_rcvintpipe(dev->udev, int_in_endpointAddr),
-+
-+ usb_fill_int_urb(dev->urb, udev,
-+ usb_rcvintpipe(udev, int_in_endpointAddr),
- dev->data, ATP_DATASIZE, atp_complete, dev, 1);
-
-- init_input_dev(&dev->input);
-- dev->input.name = "appletouch";
-- dev->input.dev = &iface->dev;
-- dev->input.private = dev;
-- dev->input.open = atp_open;
-- dev->input.close = atp_close;
-+ usb_make_path(udev, dev->phys, sizeof(dev->phys));
-+ strlcat(dev->phys, "/input0", sizeof(dev->phys));
-
-- usb_to_input_id(dev->udev, &dev->input.id);
-+ input_dev->name = "appletouch";
-+ input_dev->phys = dev->phys;
-+ usb_to_input_id(dev->udev, &input_dev->id);
-+ input_dev->cdev.dev = &iface->dev;
-+
-+ input_dev->private = dev;
-+ input_dev->open = atp_open;
-+ input_dev->close = atp_close;
-
-- set_bit(EV_ABS, dev->input.evbit);
-+ set_bit(EV_ABS, input_dev->evbit);
-
- /*
- * 12" and 15" Powerbooks only have 16 x sensors,
- * 17" models are detected later.
- */
-- input_set_abs_params(&dev->input, ABS_X, 0,
-+ input_set_abs_params(input_dev, ABS_X, 0,
- (16 - 1) * ATP_XFACT - 1, ATP_FUZZ, 0);
-- input_set_abs_params(&dev->input, ABS_Y, 0,
-+ input_set_abs_params(input_dev, ABS_Y, 0,
- (ATP_YSENSORS - 1) * ATP_YFACT - 1, ATP_FUZZ, 0);
-- input_set_abs_params(&dev->input, ABS_PRESSURE, 0, ATP_PRESSURE, 0, 0);
-+ input_set_abs_params(input_dev, ABS_PRESSURE, 0, ATP_PRESSURE, 0, 0);
-
-- set_bit(EV_KEY, dev->input.evbit);
-- set_bit(BTN_TOUCH, dev->input.keybit);
-- set_bit(BTN_TOOL_FINGER, dev->input.keybit);
-- set_bit(BTN_TOOL_DOUBLETAP, dev->input.keybit);
-- set_bit(BTN_TOOL_TRIPLETAP, dev->input.keybit);
-- set_bit(BTN_LEFT, dev->input.keybit);
-+ set_bit(EV_KEY, input_dev->evbit);
-+ set_bit(BTN_TOUCH, input_dev->keybit);
-+ set_bit(BTN_TOOL_FINGER, input_dev->keybit);
-+ set_bit(BTN_TOOL_DOUBLETAP, input_dev->keybit);
-+ set_bit(BTN_TOOL_TRIPLETAP, input_dev->keybit);
-+ set_bit(BTN_LEFT, input_dev->keybit);
-
-- input_register_device(&dev->input);
-+ input_register_device(dev->input);
-
-- printk(KERN_INFO "input: appletouch connected\n");
-+ /* save our data pointer in this interface device */
-+ usb_set_intfdata(iface, dev);
-
- return 0;
-
--err_usbbufalloc:
-+ err_free_urb:
- usb_free_urb(dev->urb);
--err_usballoc:
-+ err_free_devs:
- usb_set_intfdata(iface, NULL);
--err_endpoint:
- kfree(dev);
--err_kmalloc:
-+ input_free_device(input_dev);
- return retval;
- }
-
-@@ -419,7 +425,7 @@ static void atp_disconnect(struct usb_in
- usb_set_intfdata(iface, NULL);
- if (dev) {
- usb_kill_urb(dev->urb);
-- input_unregister_device(&dev->input);
-+ input_unregister_device(dev->input);
- usb_free_urb(dev->urb);
- usb_buffer_free(dev->udev, ATP_DATASIZE,
- dev->data, dev->urb->transfer_dma);
diff --git a/driver/input-export-input_dev-data-in-sysfs.patch b/driver/input-export-input_dev-data-in-sysfs.patch
deleted file mode 100644
index 779d53f6ce002..0000000000000
--- a/driver/input-export-input_dev-data-in-sysfs.patch
+++ /dev/null
@@ -1,241 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:13 2005
-Message-Id: <20050915070305.283905000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:55 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 24/28] Input: export input_dev data via sysfs attributes
-
-Input: export various input device attributes via sysfs
-
-The following structure is exported:
-
- input0/
- |-- name
- |-- phys
- |-- uniq
- |-- id/{bustype|vendor|product|version}
- `-- capabilities/{ev|abs|rel|key|led|msc|ff|sw}
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/input.c | 156 ++++++++++++++++++++++++++++++++++++++++++--------
- 1 file changed, 133 insertions(+), 23 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -434,6 +434,23 @@ static void input_call_hotplug(char *ver
-
- #endif
-
-+static int input_print_bitmap(char *buf, unsigned long *bitmap, int max)
-+{
-+ int i;
-+ int len = 0;
-+
-+ for (i = NBITS(max) - 1; i > 0; i--)
-+ if (bitmap[i])
-+ break;
-+
-+ for (; i >= 0; i--)
-+ len += sprintf(buf + len, "%lx%s", bitmap[i], i > 0 ? " " : "");
-+
-+ len += sprintf(buf + len, "\n");
-+
-+ return len;
-+}
-+
- #ifdef CONFIG_PROC_FS
-
- static struct proc_dir_entry *proc_bus_input_dir;
-@@ -455,20 +472,17 @@ static unsigned int input_devices_poll(s
- return 0;
- }
-
--#define SPRINTF_BIT_B(bit, name, max) \
-- do { \
-- len += sprintf(buf + len, "B: %s", name); \
-- for (i = NBITS(max) - 1; i >= 0; i--) \
-- if (dev->bit[i]) break; \
-- for (; i >= 0; i--) \
-- len += sprintf(buf + len, "%lx ", dev->bit[i]); \
-- len += sprintf(buf + len, "\n"); \
-+#define SPRINTF_BIT_B(ev, bm) \
-+ do { \
-+ len += sprintf(buf + len, "B: %s=", #ev); \
-+ len += input_print_bitmap(buf + len, \
-+ dev->bm##bit, ev##_MAX); \
- } while (0)
-
--#define SPRINTF_BIT_B2(bit, name, max, ev) \
-- do { \
-- if (test_bit(ev, dev->evbit)) \
-- SPRINTF_BIT_B(bit, name, max); \
-+#define SPRINTF_BIT_B2(ev, bm) \
-+ do { \
-+ if (test_bit(EV_##ev, dev->evbit)) \
-+ SPRINTF_BIT_B(ev, bm); \
- } while (0)
-
- static int input_devices_read(char *buf, char **start, off_t pos, int count, int *eof, void *data)
-@@ -478,7 +492,7 @@ static int input_devices_read(char *buf,
- const char *path;
-
- off_t at = 0;
-- int i, len, cnt = 0;
-+ int len, cnt = 0;
-
- list_for_each_entry(dev, &input_dev_list, node) {
-
-@@ -497,15 +511,15 @@ static int input_devices_read(char *buf,
-
- len += sprintf(buf + len, "\n");
-
-- SPRINTF_BIT_B(evbit, "EV=", EV_MAX);
-- SPRINTF_BIT_B2(keybit, "KEY=", KEY_MAX, EV_KEY);
-- SPRINTF_BIT_B2(relbit, "REL=", REL_MAX, EV_REL);
-- SPRINTF_BIT_B2(absbit, "ABS=", ABS_MAX, EV_ABS);
-- SPRINTF_BIT_B2(mscbit, "MSC=", MSC_MAX, EV_MSC);
-- SPRINTF_BIT_B2(ledbit, "LED=", LED_MAX, EV_LED);
-- SPRINTF_BIT_B2(sndbit, "SND=", SND_MAX, EV_SND);
-- SPRINTF_BIT_B2(ffbit, "FF=", FF_MAX, EV_FF);
-- SPRINTF_BIT_B2(swbit, "SW=", SW_MAX, EV_SW);
-+ SPRINTF_BIT_B(EV, ev);
-+ SPRINTF_BIT_B2(KEY, key);
-+ SPRINTF_BIT_B2(REL, rel);
-+ SPRINTF_BIT_B2(ABS, abs);
-+ SPRINTF_BIT_B2(MSC, msc);
-+ SPRINTF_BIT_B2(LED, led);
-+ SPRINTF_BIT_B2(SND, snd);
-+ SPRINTF_BIT_B2(FF, ff);
-+ SPRINTF_BIT_B2(SW, sw);
-
- len += sprintf(buf + len, "\n");
-
-@@ -612,6 +626,96 @@ static inline int input_proc_init(void)
- static inline void input_proc_exit(void) { }
- #endif
-
-+#define INPUT_DEV_STRING_ATTR_SHOW(name) \
-+static ssize_t input_dev_show_##name(struct class_device *dev, char *buf) \
-+{ \
-+ struct input_dev *input_dev = to_input_dev(dev); \
-+ int retval; \
-+ \
-+ retval = down_interruptible(&input_dev->sem); \
-+ if (retval) \
-+ return retval; \
-+ \
-+ retval = sprintf(buf, "%s\n", input_dev->name ? input_dev->name : ""); \
-+ \
-+ up(&input_dev->sem); \
-+ \
-+ return retval; \
-+}
-+
-+INPUT_DEV_STRING_ATTR_SHOW(name);
-+INPUT_DEV_STRING_ATTR_SHOW(phys);
-+INPUT_DEV_STRING_ATTR_SHOW(uniq);
-+
-+static struct class_device_attribute input_dev_attrs[] = {
-+ __ATTR(name, S_IRUGO, input_dev_show_name, NULL),
-+ __ATTR(phys, S_IRUGO, input_dev_show_phys, NULL),
-+ __ATTR(uniq, S_IRUGO, input_dev_show_uniq, NULL),
-+ __ATTR_NULL
-+};
-+
-+#define INPUT_DEV_ID_ATTR(name) \
-+static ssize_t input_dev_show_id_##name(struct class_device *dev, char *buf) \
-+{ \
-+ struct input_dev *input_dev = to_input_dev(dev); \
-+ return sprintf(buf, "%04x\n", input_dev->id.name); \
-+} \
-+static CLASS_DEVICE_ATTR(name, S_IRUGO, input_dev_show_id_##name, NULL);
-+
-+INPUT_DEV_ID_ATTR(bustype);
-+INPUT_DEV_ID_ATTR(vendor);
-+INPUT_DEV_ID_ATTR(product);
-+INPUT_DEV_ID_ATTR(version);
-+
-+static struct attribute *input_dev_id_attrs[] = {
-+ &class_device_attr_bustype.attr,
-+ &class_device_attr_vendor.attr,
-+ &class_device_attr_product.attr,
-+ &class_device_attr_version.attr,
-+ NULL
-+};
-+
-+static struct attribute_group input_dev_id_attr_group = {
-+ .name = "id",
-+ .attrs = input_dev_id_attrs,
-+};
-+
-+#define INPUT_DEV_CAP_ATTR(ev, bm) \
-+static ssize_t input_dev_show_cap_##bm(struct class_device *dev, char *buf) \
-+{ \
-+ struct input_dev *input_dev = to_input_dev(dev); \
-+ return input_print_bitmap(buf, input_dev->bm##bit, ev##_MAX); \
-+} \
-+static CLASS_DEVICE_ATTR(bm, S_IRUGO, input_dev_show_cap_##bm, NULL);
-+
-+INPUT_DEV_CAP_ATTR(EV, ev);
-+INPUT_DEV_CAP_ATTR(KEY, key);
-+INPUT_DEV_CAP_ATTR(REL, rel);
-+INPUT_DEV_CAP_ATTR(ABS, abs);
-+INPUT_DEV_CAP_ATTR(MSC, msc);
-+INPUT_DEV_CAP_ATTR(LED, led);
-+INPUT_DEV_CAP_ATTR(SND, snd);
-+INPUT_DEV_CAP_ATTR(FF, ff);
-+INPUT_DEV_CAP_ATTR(SW, sw);
-+
-+static struct attribute *input_dev_caps_attrs[] = {
-+ &class_device_attr_ev.attr,
-+ &class_device_attr_key.attr,
-+ &class_device_attr_rel.attr,
-+ &class_device_attr_abs.attr,
-+ &class_device_attr_msc.attr,
-+ &class_device_attr_led.attr,
-+ &class_device_attr_snd.attr,
-+ &class_device_attr_ff.attr,
-+ &class_device_attr_sw.attr,
-+ NULL
-+};
-+
-+static struct attribute_group input_dev_caps_attr_group = {
-+ .name = "capabilities",
-+ .attrs = input_dev_caps_attrs,
-+};
-+
- static void input_dev_release(struct class_device *class_dev)
- {
- struct input_dev *dev = to_input_dev(class_dev);
-@@ -623,6 +727,7 @@ static void input_dev_release(struct cla
- static struct class input_dev_class = {
- .name = "input_dev",
- .release = input_dev_release,
-+ .class_dev_attrs = input_dev_attrs,
- };
-
- struct input_dev *input_allocate_device(void)
-@@ -660,6 +765,8 @@ static void input_register_classdevice(s
- kfree(path);
-
- class_device_add(&dev->cdev);
-+ sysfs_create_group(&dev->cdev.kobj, &input_dev_id_attr_group);
-+ sysfs_create_group(&dev->cdev.kobj, &input_dev_caps_attr_group);
- }
-
- void input_register_device(struct input_dev *dev)
-@@ -726,8 +833,11 @@ void input_unregister_device(struct inpu
-
- list_del_init(&dev->node);
-
-- if (dev->dynalloc)
-+ if (dev->dynalloc) {
-+ sysfs_remove_group(&dev->cdev.kobj, &input_dev_caps_attr_group);
-+ sysfs_remove_group(&dev->cdev.kobj, &input_dev_id_attr_group);
- class_device_unregister(&dev->cdev);
-+ }
-
- input_wakeup_procfs_readers();
- }
diff --git a/driver/input-input_dev_class-export.patch b/driver/input-input_dev_class-export.patch
deleted file mode 100644
index ace3ae30eb60e..0000000000000
--- a/driver/input-input_dev_class-export.patch
+++ /dev/null
@@ -1,39 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: INPUT: export input_dev_class so that input drivers can use it.
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/input/input.c | 3 ++-
- include/linux/input.h | 1 +
- 2 files changed, 3 insertions(+), 1 deletion(-)
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -40,6 +40,7 @@ EXPORT_SYMBOL(input_accept_process);
- EXPORT_SYMBOL(input_flush_device);
- EXPORT_SYMBOL(input_event);
- EXPORT_SYMBOL(input_class);
-+EXPORT_SYMBOL_GPL(input_dev_class);
-
- #define INPUT_DEVICES 256
-
-@@ -724,7 +725,7 @@ static void input_dev_release(struct cla
- module_put(THIS_MODULE);
- }
-
--static struct class input_dev_class = {
-+struct class input_dev_class = {
- .name = "input_dev",
- .release = input_dev_release,
- .class_dev_attrs = input_dev_attrs,
---- gregkh-2.6.orig/include/linux/input.h
-+++ gregkh-2.6/include/linux/input.h
-@@ -1075,6 +1075,7 @@ static inline void input_set_abs_params(
- }
-
- extern struct class *input_class;
-+extern struct class input_dev_class;
-
- #endif
- #endif
diff --git a/driver/input-register-class_device-sooner.patch b/driver/input-register-class_device-sooner.patch
deleted file mode 100644
index 1bb55be7ed7e7..0000000000000
--- a/driver/input-register-class_device-sooner.patch
+++ /dev/null
@@ -1,34 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: INPUT: register the input class device sooner
-
-This is needed so we can actually use the class device within the input
-handlers.
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/input/input.c | 6 +++---
- 1 file changed, 3 insertions(+), 3 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -795,6 +795,9 @@ void input_register_device(struct input_
- INIT_LIST_HEAD(&dev->h_list);
- list_add_tail(&dev->node, &input_dev_list);
-
-+ if (dev->dynalloc)
-+ input_register_classdevice(dev);
-+
- list_for_each_entry(handler, &input_handler_list, node)
- if (!handler->blacklist || !input_match_device(handler->blacklist, dev))
- if ((id = input_match_device(handler->id_table, dev)))
-@@ -802,9 +805,6 @@ void input_register_device(struct input_
- input_link_handle(handle);
-
-
-- if (dev->dynalloc)
-- input_register_classdevice(dev);
--
- #ifdef CONFIG_HOTPLUG
- input_call_hotplug("add", dev);
- #endif
diff --git a/driver/input-remove-custom-hotplug.patch b/driver/input-remove-custom-hotplug.patch
deleted file mode 100644
index 664cef38e7ca6..0000000000000
--- a/driver/input-remove-custom-hotplug.patch
+++ /dev/null
@@ -1,335 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:13 2005
-Message-Id: <20050915070305.574517000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:57 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 26/28] input core: remove custom-made hotplug handler
-
-Input: remove custom-made hotplug handler
-
-Now that all input devices are registered with sysfs we can remove
-old custom-made hotplug handler and crate a standard one.
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/input.c | 249 ++++++++++++++++++++------------------------------
- 1 file changed, 104 insertions(+), 145 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -316,125 +316,7 @@ static struct input_device_id *input_mat
- return NULL;
- }
-
--
--/*
-- * Input hotplugging interface - loading event handlers based on
-- * device bitfields.
-- */
--
--#ifdef CONFIG_HOTPLUG
--
--/*
-- * Input hotplugging invokes what /proc/sys/kernel/hotplug says
-- * (normally /sbin/hotplug) when input devices get added or removed.
-- *
-- * This invokes a user mode policy agent, typically helping to load driver
-- * or other modules, configure the device, and more. Drivers can provide
-- * a MODULE_DEVICE_TABLE to help with module loading subtasks.
-- *
-- */
--
--#define SPRINTF_BIT_A(bit, name, max) \
-- do { \
-- envp[i++] = scratch; \
-- scratch += sprintf(scratch, name); \
-- for (j = NBITS(max) - 1; j >= 0; j--) \
-- if (dev->bit[j]) break; \
-- for (; j >= 0; j--) \
-- scratch += sprintf(scratch, "%lx ", dev->bit[j]); \
-- scratch++; \
-- } while (0)
--
--#define SPRINTF_BIT_A2(bit, name, max, ev) \
-- do { \
-- if (test_bit(ev, dev->evbit)) \
-- SPRINTF_BIT_A(bit, name, max); \
-- } while (0)
--
--static void input_call_hotplug(char *verb, struct input_dev *dev)
--{
-- char *argv[3], **envp, *buf, *scratch;
-- int i = 0, j, value;
--
-- if (!hotplug_path[0]) {
-- printk(KERN_ERR "input.c: calling hotplug without a hotplug agent defined\n");
-- return;
-- }
-- if (in_interrupt()) {
-- printk(KERN_ERR "input.c: calling hotplug from interrupt\n");
-- return;
-- }
-- if (!current->fs->root) {
-- printk(KERN_WARNING "input.c: calling hotplug without valid filesystem\n");
-- return;
-- }
-- if (!(envp = (char **) kmalloc(20 * sizeof(char *), GFP_KERNEL))) {
-- printk(KERN_ERR "input.c: not enough memory allocating hotplug environment\n");
-- return;
-- }
-- if (!(buf = kmalloc(1024, GFP_KERNEL))) {
-- kfree (envp);
-- printk(KERN_ERR "input.c: not enough memory allocating hotplug environment\n");
-- return;
-- }
--
-- argv[0] = hotplug_path;
-- argv[1] = "input";
-- argv[2] = NULL;
--
-- envp[i++] = "HOME=/";
-- envp[i++] = "PATH=/sbin:/bin:/usr/sbin:/usr/bin";
--
-- scratch = buf;
--
-- envp[i++] = scratch;
-- scratch += sprintf(scratch, "ACTION=%s", verb) + 1;
--
-- envp[i++] = scratch;
-- scratch += sprintf(scratch, "PRODUCT=%x/%x/%x/%x",
-- dev->id.bustype, dev->id.vendor, dev->id.product, dev->id.version) + 1;
--
-- if (dev->name) {
-- envp[i++] = scratch;
-- scratch += sprintf(scratch, "NAME=%s", dev->name) + 1;
-- }
--
-- if (dev->phys) {
-- envp[i++] = scratch;
-- scratch += sprintf(scratch, "PHYS=%s", dev->phys) + 1;
-- }
--
-- SPRINTF_BIT_A(evbit, "EV=", EV_MAX);
-- SPRINTF_BIT_A2(keybit, "KEY=", KEY_MAX, EV_KEY);
-- SPRINTF_BIT_A2(relbit, "REL=", REL_MAX, EV_REL);
-- SPRINTF_BIT_A2(absbit, "ABS=", ABS_MAX, EV_ABS);
-- SPRINTF_BIT_A2(mscbit, "MSC=", MSC_MAX, EV_MSC);
-- SPRINTF_BIT_A2(ledbit, "LED=", LED_MAX, EV_LED);
-- SPRINTF_BIT_A2(sndbit, "SND=", SND_MAX, EV_SND);
-- SPRINTF_BIT_A2(ffbit, "FF=", FF_MAX, EV_FF);
-- SPRINTF_BIT_A2(swbit, "SW=", SW_MAX, EV_SW);
--
-- envp[i++] = NULL;
--
--#ifdef INPUT_DEBUG
-- printk(KERN_DEBUG "input.c: calling %s %s [%s %s %s %s %s]\n",
-- argv[0], argv[1], envp[0], envp[1], envp[2], envp[3], envp[4]);
--#endif
--
-- value = call_usermodehelper(argv [0], argv, envp, 0);
--
-- kfree(buf);
-- kfree(envp);
--
--#ifdef INPUT_DEBUG
-- if (value != 0)
-- printk(KERN_DEBUG "input.c: hotplug returned %d\n", value);
--#endif
--}
--
--#endif
--
--static int input_print_bitmap(char *buf, unsigned long *bitmap, int max)
-+static int input_print_bitmap(char *buf, int buf_size, unsigned long *bitmap, int max)
- {
- int i;
- int len = 0;
-@@ -444,10 +326,8 @@ static int input_print_bitmap(char *buf,
- break;
-
- for (; i >= 0; i--)
-- len += sprintf(buf + len, "%lx%s", bitmap[i], i > 0 ? " " : "");
--
-- len += sprintf(buf + len, "\n");
--
-+ len += snprintf(buf + len, max(buf_size - len, 0),
-+ "%lx%s", bitmap[i], i > 0 ? " " : "");
- return len;
- }
-
-@@ -472,17 +352,18 @@ static unsigned int input_devices_poll(s
- return 0;
- }
-
--#define SPRINTF_BIT_B(ev, bm) \
-+#define SPRINTF_BIT(ev, bm) \
- do { \
- len += sprintf(buf + len, "B: %s=", #ev); \
-- len += input_print_bitmap(buf + len, \
-+ len += input_print_bitmap(buf + len, INT_MAX, \
- dev->bm##bit, ev##_MAX); \
-+ len += sprintf(buf + len, "\n"); \
- } while (0)
-
--#define SPRINTF_BIT_B2(ev, bm) \
-+#define TEST_AND_SPRINTF_BIT(ev, bm) \
- do { \
- if (test_bit(EV_##ev, dev->evbit)) \
-- SPRINTF_BIT_B(ev, bm); \
-+ SPRINTF_BIT(ev, bm); \
- } while (0)
-
- static int input_devices_read(char *buf, char **start, off_t pos, int count, int *eof, void *data)
-@@ -511,15 +392,15 @@ static int input_devices_read(char *buf,
-
- len += sprintf(buf + len, "\n");
-
-- SPRINTF_BIT_B(EV, ev);
-- SPRINTF_BIT_B2(KEY, key);
-- SPRINTF_BIT_B2(REL, rel);
-- SPRINTF_BIT_B2(ABS, abs);
-- SPRINTF_BIT_B2(MSC, msc);
-- SPRINTF_BIT_B2(LED, led);
-- SPRINTF_BIT_B2(SND, snd);
-- SPRINTF_BIT_B2(FF, ff);
-- SPRINTF_BIT_B2(SW, sw);
-+ SPRINTF_BIT(EV, ev);
-+ TEST_AND_SPRINTF_BIT(KEY, key);
-+ TEST_AND_SPRINTF_BIT(REL, rel);
-+ TEST_AND_SPRINTF_BIT(ABS, abs);
-+ TEST_AND_SPRINTF_BIT(MSC, msc);
-+ TEST_AND_SPRINTF_BIT(LED, led);
-+ TEST_AND_SPRINTF_BIT(SND, snd);
-+ TEST_AND_SPRINTF_BIT(FF, ff);
-+ TEST_AND_SPRINTF_BIT(SW, sw);
-
- len += sprintf(buf + len, "\n");
-
-@@ -689,7 +570,7 @@ static struct attribute_group input_dev_
- static ssize_t input_dev_show_cap_##bm(struct class_device *dev, char *buf) \
- { \
- struct input_dev *input_dev = to_input_dev(dev); \
-- return input_print_bitmap(buf, input_dev->bm##bit, ev##_MAX); \
-+ return input_print_bitmap(buf, PAGE_SIZE, input_dev->bm##bit, ev##_MAX);\
- } \
- static CLASS_DEVICE_ATTR(bm, S_IRUGO, input_dev_show_cap_##bm, NULL);
-
-@@ -729,9 +610,95 @@ static void input_dev_release(struct cla
- module_put(THIS_MODULE);
- }
-
-+/*
-+ * Input hotplugging interface - loading event handlers based on
-+ * device bitfields.
-+ */
-+static int input_add_hotplug_bm_var(char **envp, int num_envp, int *cur_index,
-+ char *buffer, int buffer_size, int *cur_len,
-+ const char *name, unsigned long *bitmap, int max)
-+{
-+ if (*cur_index >= num_envp - 1)
-+ return -ENOMEM;
-+
-+ envp[*cur_index] = buffer + *cur_len;
-+
-+ *cur_len += snprintf(buffer + *cur_len, max(buffer_size - *cur_len, 0), name);
-+ if (*cur_len > buffer_size)
-+ return -ENOMEM;
-+
-+ *cur_len += input_print_bitmap(buffer + *cur_len,
-+ max(buffer_size - *cur_len, 0),
-+ bitmap, max) + 1;
-+ if (*cur_len > buffer_size)
-+ return -ENOMEM;
-+
-+ (*cur_index)++;
-+ return 0;
-+}
-+
-+#define INPUT_ADD_HOTPLUG_VAR(fmt, val...) \
-+ do { \
-+ int err = add_hotplug_env_var(envp, num_envp, &i, \
-+ buffer, buffer_size, &len, \
-+ fmt, val); \
-+ if (err) \
-+ return err; \
-+ } while (0)
-+
-+#define INPUT_ADD_HOTPLUG_BM_VAR(name, bm, max) \
-+ do { \
-+ int err = input_add_hotplug_bm_var(envp, num_envp, &i, \
-+ buffer, buffer_size, &len, \
-+ name, bm, max); \
-+ if (err) \
-+ return err; \
-+ } while (0)
-+
-+static int input_dev_hotplug(struct class_device *cdev, char **envp,
-+ int num_envp, char *buffer, int buffer_size)
-+{
-+ struct input_dev *dev = to_input_dev(cdev);
-+ int i = 0;
-+ int len = 0;
-+
-+ INPUT_ADD_HOTPLUG_VAR("PRODUCT=%x/%x/%x/%x",
-+ dev->id.bustype, dev->id.vendor,
-+ dev->id.product, dev->id.version);
-+ if (dev->name)
-+ INPUT_ADD_HOTPLUG_VAR("NAME=\"%s\"", dev->name);
-+ if (dev->phys)
-+ INPUT_ADD_HOTPLUG_VAR("PHYS=\"%s\"", dev->phys);
-+ if (dev->phys)
-+ INPUT_ADD_HOTPLUG_VAR("UNIQ=\"%s\"", dev->uniq);
-+
-+ INPUT_ADD_HOTPLUG_BM_VAR("EV=", dev->evbit, EV_MAX);
-+ if (test_bit(EV_KEY, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("KEY=", dev->keybit, KEY_MAX);
-+ if (test_bit(EV_REL, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("REL=", dev->relbit, REL_MAX);
-+ if (test_bit(EV_ABS, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("ABS=", dev->absbit, ABS_MAX);
-+ if (test_bit(EV_MSC, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("MSC=", dev->mscbit, MSC_MAX);
-+ if (test_bit(EV_LED, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("LED=", dev->ledbit, LED_MAX);
-+ if (test_bit(EV_SND, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("SND=", dev->sndbit, SND_MAX);
-+ if (test_bit(EV_FF, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("FF=", dev->ffbit, FF_MAX);
-+ if (test_bit(EV_SW, dev->evbit))
-+ INPUT_ADD_HOTPLUG_BM_VAR("SW=", dev->swbit, SW_MAX);
-+
-+ envp[i] = NULL;
-+
-+ return 0;
-+}
-+
- struct class input_class = {
- .name = "input",
- .release = input_dev_release,
-+ .hotplug = input_dev_hotplug,
- };
-
- struct input_dev *input_allocate_device(void)
-@@ -810,10 +777,6 @@ void input_register_device(struct input_
- input_link_handle(handle);
-
-
--#ifdef CONFIG_HOTPLUG
-- input_call_hotplug("add", dev);
--#endif
--
- input_wakeup_procfs_readers();
- }
-
-@@ -832,10 +795,6 @@ void input_unregister_device(struct inpu
- handle->handler->disconnect(handle);
- }
-
--#ifdef CONFIG_HOTPLUG
-- input_call_hotplug("remove", dev);
--#endif
--
- list_del_init(&dev->node);
-
- if (dev->dynalloc) {
diff --git a/driver/input-remove-devfs.patch b/driver/input-remove-devfs.patch
deleted file mode 100644
index 248bf84a22b05..0000000000000
--- a/driver/input-remove-devfs.patch
+++ /dev/null
@@ -1,188 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:16 2005
-Message-Id: <20050915070302.693817000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:38 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 07/28] Input: kill devfs references
-
-Input: remove references to devfs from input subsystem
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/evdev.c | 4 ----
- drivers/input/input.c | 7 -------
- drivers/input/joydev.c | 4 ----
- drivers/input/mousedev.c | 9 +--------
- drivers/input/tsdev.c | 7 -------
- 5 files changed, 1 insertion(+), 30 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/evdev.c
-+++ gregkh-2.6/drivers/input/evdev.c
-@@ -20,7 +20,6 @@
- #include <linux/major.h>
- #include <linux/smp_lock.h>
- #include <linux/device.h>
--#include <linux/devfs_fs_kernel.h>
- #include <linux/compat.h>
-
- struct evdev {
-@@ -687,8 +686,6 @@ static struct input_handle *evdev_connec
-
- evdev_table[minor] = evdev;
-
-- devfs_mk_cdev(MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor),
-- S_IFCHR|S_IRUGO|S_IWUSR, "input/event%d", minor);
- class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor),
- dev->dev, "event%d", minor);
-@@ -703,7 +700,6 @@ static void evdev_disconnect(struct inpu
-
- class_device_destroy(input_class,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + evdev->minor));
-- devfs_remove("input/event%d", evdev->minor);
- evdev->exist = 0;
-
- if (evdev->open) {
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -22,7 +22,6 @@
- #include <linux/interrupt.h>
- #include <linux/poll.h>
- #include <linux/device.h>
--#include <linux/devfs_fs_kernel.h>
-
- MODULE_AUTHOR("Vojtech Pavlik <vojtech@suse.cz>");
- MODULE_DESCRIPTION("Input core");
-@@ -770,13 +769,8 @@ static int __init input_init(void)
- goto fail2;
- }
-
-- err = devfs_mk_dir("input");
-- if (err)
-- goto fail3;
--
- return 0;
-
-- fail3: unregister_chrdev(INPUT_MAJOR, "input");
- fail2: input_proc_exit();
- fail1: class_destroy(input_class);
- return err;
-@@ -785,7 +779,6 @@ static int __init input_init(void)
- static void __exit input_exit(void)
- {
- input_proc_exit();
-- devfs_remove("input");
- unregister_chrdev(INPUT_MAJOR, "input");
- class_destroy(input_class);
- }
---- gregkh-2.6.orig/drivers/input/joydev.c
-+++ gregkh-2.6/drivers/input/joydev.c
-@@ -26,7 +26,6 @@
- #include <linux/init.h>
- #include <linux/smp_lock.h>
- #include <linux/device.h>
--#include <linux/devfs_fs_kernel.h>
-
- MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
- MODULE_DESCRIPTION("Joystick device interfaces");
-@@ -514,8 +513,6 @@ static struct input_handle *joydev_conne
-
- joydev_table[minor] = joydev;
-
-- devfs_mk_cdev(MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + minor),
-- S_IFCHR|S_IRUGO|S_IWUSR, "input/js%d", minor);
- class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + minor),
- dev->dev, "js%d", minor);
-@@ -529,7 +526,6 @@ static void joydev_disconnect(struct inp
- struct joydev_list *list;
-
- class_device_destroy(input_class, MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + joydev->minor));
-- devfs_remove("input/js%d", joydev->minor);
- joydev->exist = 0;
-
- if (joydev->open) {
---- gregkh-2.6.orig/drivers/input/mousedev.c
-+++ gregkh-2.6/drivers/input/mousedev.c
-@@ -9,7 +9,7 @@
- * the Free Software Foundation.
- */
-
--#define MOUSEDEV_MINOR_BASE 32
-+#define MOUSEDEV_MINOR_BASE 32
- #define MOUSEDEV_MINORS 32
- #define MOUSEDEV_MIX 31
-
-@@ -24,7 +24,6 @@
- #include <linux/random.h>
- #include <linux/major.h>
- #include <linux/device.h>
--#include <linux/devfs_fs_kernel.h>
- #ifdef CONFIG_INPUT_MOUSEDEV_PSAUX
- #include <linux/miscdevice.h>
- #endif
-@@ -649,8 +648,6 @@ static struct input_handle *mousedev_con
-
- mousedev_table[minor] = mousedev;
-
-- devfs_mk_cdev(MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + minor),
-- S_IFCHR|S_IRUGO|S_IWUSR, "input/mouse%d", minor);
- class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + minor),
- dev->dev, "mouse%d", minor);
-@@ -665,7 +662,6 @@ static void mousedev_disconnect(struct i
-
- class_device_destroy(input_class,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + mousedev->minor));
-- devfs_remove("input/mouse%d", mousedev->minor);
- mousedev->exist = 0;
-
- if (mousedev->open) {
-@@ -738,8 +734,6 @@ static int __init mousedev_init(void)
- mousedev_mix.exist = 1;
- mousedev_mix.minor = MOUSEDEV_MIX;
-
-- devfs_mk_cdev(MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX),
-- S_IFCHR|S_IRUGO|S_IWUSR, "input/mice");
- class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX), NULL, "mice");
-
-@@ -759,7 +753,6 @@ static void __exit mousedev_exit(void)
- if (psaux_registered)
- misc_deregister(&psaux_mouse);
- #endif
-- devfs_remove("input/mice");
- class_device_destroy(input_class,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX));
- input_unregister_handler(&mousedev_handler);
---- gregkh-2.6.orig/drivers/input/tsdev.c
-+++ gregkh-2.6/drivers/input/tsdev.c
-@@ -53,7 +53,6 @@
- #include <linux/random.h>
- #include <linux/time.h>
- #include <linux/device.h>
--#include <linux/devfs_fs_kernel.h>
-
- #ifndef CONFIG_INPUT_TSDEV_SCREEN_X
- #define CONFIG_INPUT_TSDEV_SCREEN_X 240
-@@ -410,10 +409,6 @@ static struct input_handle *tsdev_connec
-
- tsdev_table[minor] = tsdev;
-
-- devfs_mk_cdev(MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor),
-- S_IFCHR|S_IRUGO|S_IWUSR, "input/ts%d", minor);
-- devfs_mk_cdev(MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor + TSDEV_MINORS/2),
-- S_IFCHR|S_IRUGO|S_IWUSR, "input/tsraw%d", minor);
- class_device_create(input_class, NULL,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor),
- dev->dev, "ts%d", minor);
-@@ -428,8 +423,6 @@ static void tsdev_disconnect(struct inpu
-
- class_device_destroy(input_class,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + tsdev->minor));
-- devfs_remove("input/ts%d", tsdev->minor);
-- devfs_remove("input/tsraw%d", tsdev->minor);
- tsdev->exist = 0;
-
- if (tsdev->open) {
diff --git a/driver/input-remove-input_class.patch b/driver/input-remove-input_class.patch
deleted file mode 100644
index 79dd4941de049..0000000000000
--- a/driver/input-remove-input_class.patch
+++ /dev/null
@@ -1,78 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: INPUT: remove the input_class structure, as it is unused.
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/input/input.c | 18 +++---------------
- include/linux/input.h | 1 -
- 2 files changed, 3 insertions(+), 16 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -39,7 +39,6 @@ EXPORT_SYMBOL(input_close_device);
- EXPORT_SYMBOL(input_accept_process);
- EXPORT_SYMBOL(input_flush_device);
- EXPORT_SYMBOL(input_event);
--EXPORT_SYMBOL(input_class);
- EXPORT_SYMBOL_GPL(input_dev_class);
-
- #define INPUT_DEVICES 256
-@@ -927,8 +926,6 @@ static struct file_operations input_fops
- .open = input_open_file,
- };
-
--struct class *input_class;
--
- static int __init input_init(void)
- {
- int err;
-@@ -939,27 +936,19 @@ static int __init input_init(void)
- return err;
- }
-
-- input_class = class_create(THIS_MODULE, "input");
-- if (IS_ERR(input_class)) {
-- printk(KERN_ERR "input: unable to register input class\n");
-- err = PTR_ERR(input_class);
-- goto fail1;
-- }
--
- err = input_proc_init();
- if (err)
-- goto fail2;
-+ goto fail1;
-
- err = register_chrdev(INPUT_MAJOR, "input", &input_fops);
- if (err) {
- printk(KERN_ERR "input: unable to register char major %d", INPUT_MAJOR);
-- goto fail3;
-+ goto fail2;
- }
-
- return 0;
-
-- fail3: input_proc_exit();
-- fail2: class_destroy(input_class);
-+ fail2: input_proc_exit();
- fail1: class_unregister(&input_dev_class);
- return err;
- }
-@@ -968,7 +957,6 @@ static void __exit input_exit(void)
- {
- input_proc_exit();
- unregister_chrdev(INPUT_MAJOR, "input");
-- class_destroy(input_class);
- class_unregister(&input_dev_class);
- }
-
---- gregkh-2.6.orig/include/linux/input.h
-+++ gregkh-2.6/include/linux/input.h
-@@ -1074,7 +1074,6 @@ static inline void input_set_abs_params(
- dev->absbit[LONG(axis)] |= BIT(axis);
- }
-
--extern struct class *input_class;
- extern struct class input_dev_class;
-
- #endif
diff --git a/driver/input-rename-input_dev_class.patch b/driver/input-rename-input_dev_class.patch
deleted file mode 100644
index 752e1f264d369..0000000000000
--- a/driver/input-rename-input_dev_class.patch
+++ /dev/null
@@ -1,182 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: INPUT: rename input_dev_class to input_class to be correct.
-
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/input/evdev.c | 4 ++--
- drivers/input/input.c | 14 +++++++-------
- drivers/input/joydev.c | 4 ++--
- drivers/input/mousedev.c | 8 ++++----
- drivers/input/tsdev.c | 4 ++--
- include/linux/input.h | 2 +-
- 6 files changed, 18 insertions(+), 18 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/evdev.c
-+++ gregkh-2.6/drivers/input/evdev.c
-@@ -686,7 +686,7 @@ static struct input_handle *evdev_connec
-
- evdev_table[minor] = evdev;
-
-- class_device_create(&input_dev_class, &dev->cdev,
-+ class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor),
- dev->cdev.dev, "event%d", minor);
-
-@@ -698,7 +698,7 @@ static void evdev_disconnect(struct inpu
- struct evdev *evdev = handle->private;
- struct evdev_list *list;
-
-- class_device_destroy(&input_dev_class,
-+ class_device_destroy(&input_class,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + evdev->minor));
- evdev->exist = 0;
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -39,7 +39,7 @@ EXPORT_SYMBOL(input_close_device);
- EXPORT_SYMBOL(input_accept_process);
- EXPORT_SYMBOL(input_flush_device);
- EXPORT_SYMBOL(input_event);
--EXPORT_SYMBOL_GPL(input_dev_class);
-+EXPORT_SYMBOL_GPL(input_class);
-
- #define INPUT_DEVICES 256
-
-@@ -729,8 +729,8 @@ static void input_dev_release(struct cla
- module_put(THIS_MODULE);
- }
-
--struct class input_dev_class = {
-- .name = "input_dev",
-+struct class input_class = {
-+ .name = "input",
- .release = input_dev_release,
- };
-
-@@ -741,7 +741,7 @@ struct input_dev *input_allocate_device(
- dev = kzalloc(sizeof(struct input_dev), GFP_KERNEL);
- if (dev) {
- dev->dynalloc = 1;
-- dev->cdev.class = &input_dev_class;
-+ dev->cdev.class = &input_class;
- class_device_initialize(&dev->cdev);
- INIT_LIST_HEAD(&dev->h_list);
- INIT_LIST_HEAD(&dev->node);
-@@ -930,7 +930,7 @@ static int __init input_init(void)
- {
- int err;
-
-- err = class_register(&input_dev_class);
-+ err = class_register(&input_class);
- if (err) {
- printk(KERN_ERR "input: unable to register input_dev class\n");
- return err;
-@@ -949,7 +949,7 @@ static int __init input_init(void)
- return 0;
-
- fail2: input_proc_exit();
-- fail1: class_unregister(&input_dev_class);
-+ fail1: class_unregister(&input_class);
- return err;
- }
-
-@@ -957,7 +957,7 @@ static void __exit input_exit(void)
- {
- input_proc_exit();
- unregister_chrdev(INPUT_MAJOR, "input");
-- class_unregister(&input_dev_class);
-+ class_unregister(&input_class);
- }
-
- subsys_initcall(input_init);
---- gregkh-2.6.orig/drivers/input/joydev.c
-+++ gregkh-2.6/drivers/input/joydev.c
-@@ -513,7 +513,7 @@ static struct input_handle *joydev_conne
-
- joydev_table[minor] = joydev;
-
-- class_device_create(&input_dev_class, &dev->cdev,
-+ class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + minor),
- dev->cdev.dev, "js%d", minor);
-
-@@ -525,7 +525,7 @@ static void joydev_disconnect(struct inp
- struct joydev *joydev = handle->private;
- struct joydev_list *list;
-
-- class_device_destroy(&input_dev_class, MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + joydev->minor));
-+ class_device_destroy(&input_class, MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + joydev->minor));
- joydev->exist = 0;
-
- if (joydev->open) {
---- gregkh-2.6.orig/drivers/input/mousedev.c
-+++ gregkh-2.6/drivers/input/mousedev.c
-@@ -648,7 +648,7 @@ static struct input_handle *mousedev_con
-
- mousedev_table[minor] = mousedev;
-
-- class_device_create(&input_dev_class, &dev->cdev,
-+ class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + minor),
- dev->cdev.dev, "mouse%d", minor);
-
-@@ -660,7 +660,7 @@ static void mousedev_disconnect(struct i
- struct mousedev *mousedev = handle->private;
- struct mousedev_list *list;
-
-- class_device_destroy(&input_dev_class,
-+ class_device_destroy(&input_class,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + mousedev->minor));
- mousedev->exist = 0;
-
-@@ -734,7 +734,7 @@ static int __init mousedev_init(void)
- mousedev_mix.exist = 1;
- mousedev_mix.minor = MOUSEDEV_MIX;
-
-- class_device_create(&input_dev_class, NULL,
-+ class_device_create(&input_class, NULL,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX), NULL, "mice");
-
- #ifdef CONFIG_INPUT_MOUSEDEV_PSAUX
-@@ -753,7 +753,7 @@ static void __exit mousedev_exit(void)
- if (psaux_registered)
- misc_deregister(&psaux_mouse);
- #endif
-- class_device_destroy(&input_dev_class,
-+ class_device_destroy(&input_class,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + MOUSEDEV_MIX));
- input_unregister_handler(&mousedev_handler);
- }
---- gregkh-2.6.orig/drivers/input/tsdev.c
-+++ gregkh-2.6/drivers/input/tsdev.c
-@@ -409,7 +409,7 @@ static struct input_handle *tsdev_connec
-
- tsdev_table[minor] = tsdev;
-
-- class_device_create(&input_dev_class, &dev->cdev,
-+ class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor),
- dev->cdev.dev, "ts%d", minor);
-
-@@ -421,7 +421,7 @@ static void tsdev_disconnect(struct inpu
- struct tsdev *tsdev = handle->private;
- struct tsdev_list *list;
-
-- class_device_destroy(&input_dev_class,
-+ class_device_destroy(&input_class,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + tsdev->minor));
- tsdev->exist = 0;
-
---- gregkh-2.6.orig/include/linux/input.h
-+++ gregkh-2.6/include/linux/input.h
-@@ -1074,7 +1074,7 @@ static inline void input_set_abs_params(
- dev->absbit[LONG(axis)] |= BIT(axis);
- }
-
--extern struct class input_dev_class;
-+extern struct class input_class;
-
- #endif
- #endif
diff --git a/driver/input-show-sysfs-path-in-proc.patch b/driver/input-show-sysfs-path-in-proc.patch
deleted file mode 100644
index fa50ddafdba8d..0000000000000
--- a/driver/input-show-sysfs-path-in-proc.patch
+++ /dev/null
@@ -1,50 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:12 2005
-Message-Id: <20050915070305.162996000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:54 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 23/28] Input: show sysfs path in /proc/bus/input/devices
-
-Input: show sysfs path in /proc/bus/input/devices
-
-Show that sysfs and phys path are different objects.
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/input.c | 6 ++++++
- 1 file changed, 6 insertions(+)
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -475,17 +475,21 @@ static int input_devices_read(char *buf,
- {
- struct input_dev *dev;
- struct input_handle *handle;
-+ const char *path;
-
- off_t at = 0;
- int i, len, cnt = 0;
-
- list_for_each_entry(dev, &input_dev_list, node) {
-
-+ path = dev->dynalloc ? kobject_get_path(&dev->cdev.kobj, GFP_KERNEL) : NULL;
-+
- len = sprintf(buf, "I: Bus=%04x Vendor=%04x Product=%04x Version=%04x\n",
- dev->id.bustype, dev->id.vendor, dev->id.product, dev->id.version);
-
- len += sprintf(buf + len, "N: Name=\"%s\"\n", dev->name ? dev->name : "");
- len += sprintf(buf + len, "P: Phys=%s\n", dev->phys ? dev->phys : "");
-+ len += sprintf(buf + len, "S: Sysfs=%s\n", path ? path : "");
- len += sprintf(buf + len, "H: Handlers=");
-
- list_for_each_entry(handle, &dev->h_list, d_node)
-@@ -516,6 +520,8 @@ static int input_devices_read(char *buf,
- if (cnt >= count)
- break;
- }
-+
-+ kfree(path);
- }
-
- if (&dev->node == &input_dev_list)
diff --git a/driver/input-sysfs-intregration.patch b/driver/input-sysfs-intregration.patch
deleted file mode 100644
index 8c23b45bbd006..0000000000000
--- a/driver/input-sysfs-intregration.patch
+++ /dev/null
@@ -1,207 +0,0 @@
-From dtor_core@ameritech.net Thu Sep 15 07:50:22 2005
-Message-Id: <20050915070302.813567000.dtor_core@ameritech.net>
-Date: Thu, 15 Sep 2005 02:01:39 -0500
-From: Dmitry Torokhov <dtor_core@ameritech.net>
-Cc: Andrew Morton <akpm@osdl.org>, Greg KH <gregkh@suse.de>, Kay Sievers <kay.sievers@vrfy.org>, Vojtech Pavlik <vojtech@suse.cz>, Hannes Reinecke <hare@suse.de>
-Subject: [patch 08/28] Input: prepare to sysfs integration
-
-Input: prepare to sysfs integration
-
-Add struct class_device to input_dev; add input_allocate_dev()
-to dynamically allocate input devices; dynamically allocated
-devices are automatically registered with sysfs.
-
-Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/input/input.c | 77 ++++++++++++++++++++++++++++++++++++++++++++++----
- include/linux/input.h | 24 ++++++++++++++-
- 2 files changed, 95 insertions(+), 6 deletions(-)
-
---- gregkh-2.6.orig/include/linux/input.h
-+++ gregkh-2.6/include/linux/input.h
-@@ -12,6 +12,7 @@
- #ifdef __KERNEL__
- #include <linux/time.h>
- #include <linux/list.h>
-+#include <linux/device.h>
- #else
- #include <sys/time.h>
- #include <sys/ioctl.h>
-@@ -889,11 +890,15 @@ struct input_dev {
- struct semaphore sem; /* serializes open and close operations */
- unsigned int users;
-
-- struct device *dev;
-+ struct class_device cdev;
-+ struct device *dev; /* will be removed soon */
-+
-+ int dynalloc; /* temporarily */
-
- struct list_head h_list;
- struct list_head node;
- };
-+#define to_input_dev(d) container_of(d, struct input_dev, cdev)
-
- /*
- * Structure for hotplug & device<->driver matching.
-@@ -984,6 +989,23 @@ static inline void init_input_dev(struct
- INIT_LIST_HEAD(&dev->node);
- }
-
-+struct input_dev *input_allocate_device(void);
-+
-+static inline void input_free_device(struct input_dev *dev)
-+{
-+ kfree(dev);
-+}
-+
-+static inline struct input_dev *input_get_device(struct input_dev *dev)
-+{
-+ return to_input_dev(class_device_get(&dev->cdev));
-+}
-+
-+static inline void input_put_device(struct input_dev *dev)
-+{
-+ class_device_put(&dev->cdev);
-+}
-+
- void input_register_device(struct input_dev *);
- void input_unregister_device(struct input_dev *);
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -27,6 +27,7 @@ MODULE_AUTHOR("Vojtech Pavlik <vojtech@s
- MODULE_DESCRIPTION("Input core");
- MODULE_LICENSE("GPL");
-
-+EXPORT_SYMBOL(input_allocate_device);
- EXPORT_SYMBOL(input_register_device);
- EXPORT_SYMBOL(input_unregister_device);
- EXPORT_SYMBOL(input_register_handler);
-@@ -605,6 +606,56 @@ static inline int input_proc_init(void)
- static inline void input_proc_exit(void) { }
- #endif
-
-+static void input_dev_release(struct class_device *class_dev)
-+{
-+ struct input_dev *dev = to_input_dev(class_dev);
-+
-+ kfree(dev);
-+ module_put(THIS_MODULE);
-+}
-+
-+static struct class input_dev_class = {
-+ .name = "input_dev",
-+ .release = input_dev_release,
-+};
-+
-+struct input_dev *input_allocate_device(void)
-+{
-+ struct input_dev *dev;
-+
-+ dev = kzalloc(sizeof(struct input_dev), GFP_KERNEL);
-+ if (dev) {
-+ dev->dynalloc = 1;
-+ dev->cdev.class = &input_dev_class;
-+ class_device_initialize(&dev->cdev);
-+ INIT_LIST_HEAD(&dev->h_list);
-+ INIT_LIST_HEAD(&dev->node);
-+ }
-+
-+ return dev;
-+}
-+
-+static void input_register_classdevice(struct input_dev *dev)
-+{
-+ static atomic_t input_no = ATOMIC_INIT(0);
-+ const char *path;
-+
-+ __module_get(THIS_MODULE);
-+
-+ dev->dev = dev->cdev.dev;
-+
-+ snprintf(dev->cdev.class_id, sizeof(dev->cdev.class_id),
-+ "input%ld", (unsigned long) atomic_inc_return(&input_no) - 1);
-+
-+ path = kobject_get_path(&dev->cdev.class->subsys.kset.kobj, GFP_KERNEL);
-+ printk(KERN_INFO "input: %s/%s as %s\n",
-+ dev->name ? dev->name : "Unspecified device",
-+ path ? path : "", dev->cdev.class_id);
-+ kfree(path);
-+
-+ class_device_add(&dev->cdev);
-+}
-+
- void input_register_device(struct input_dev *dev)
- {
- struct input_handle *handle;
-@@ -637,6 +688,10 @@ void input_register_device(struct input_
- if ((handle = handler->connect(handler, dev, id)))
- input_link_handle(handle);
-
-+
-+ if (dev->dynalloc)
-+ input_register_classdevice(dev);
-+
- #ifdef CONFIG_HOTPLUG
- input_call_hotplug("add", dev);
- #endif
-@@ -665,6 +720,9 @@ void input_unregister_device(struct inpu
-
- list_del_init(&dev->node);
-
-+ if (dev->dynalloc)
-+ class_device_unregister(&dev->cdev);
-+
- input_wakeup_procfs_readers();
- }
-
-@@ -753,26 +811,34 @@ static int __init input_init(void)
- {
- int err;
-
-+ err = class_register(&input_dev_class);
-+ if (err) {
-+ printk(KERN_ERR "input: unable to register input_dev class\n");
-+ return err;
-+ }
-+
- input_class = class_create(THIS_MODULE, "input");
- if (IS_ERR(input_class)) {
- printk(KERN_ERR "input: unable to register input class\n");
-- return PTR_ERR(input_class);
-+ err = PTR_ERR(input_class);
-+ goto fail1;
- }
-
- err = input_proc_init();
- if (err)
-- goto fail1;
-+ goto fail2;
-
- err = register_chrdev(INPUT_MAJOR, "input", &input_fops);
- if (err) {
- printk(KERN_ERR "input: unable to register char major %d", INPUT_MAJOR);
-- goto fail2;
-+ goto fail3;
- }
-
- return 0;
-
-- fail2: input_proc_exit();
-- fail1: class_destroy(input_class);
-+ fail3: input_proc_exit();
-+ fail2: class_destroy(input_class);
-+ fail1: class_unregister(&input_dev_class);
- return err;
- }
-
-@@ -781,6 +847,7 @@ static void __exit input_exit(void)
- input_proc_exit();
- unregister_chrdev(INPUT_MAJOR, "input");
- class_destroy(input_class);
-+ class_unregister(&input_dev_class);
- }
-
- subsys_initcall(input_init);
diff --git a/driver/input_backward_compatible_symlink.patch b/driver/input_backward_compatible_symlink.patch
deleted file mode 100644
index 910f58e0d5bef..0000000000000
--- a/driver/input_backward_compatible_symlink.patch
+++ /dev/null
@@ -1,154 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: INPUT: Create symlinks for backwards compatibility
-
-This creates symlinks in /sys/class/input/ to the nested class devices
-to help userspace cope with the nesting.
-
-Unfortunatly udev still needs to be updated as it can't handle symlinks
-properly here :(
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- drivers/input/evdev.c | 10 ++++++++--
- drivers/input/joydev.c | 10 ++++++++--
- drivers/input/mousedev.c | 10 ++++++++--
- drivers/input/tsdev.c | 10 ++++++++--
- 4 files changed, 32 insertions(+), 8 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/evdev.c
-+++ gregkh-2.6/drivers/input/evdev.c
-@@ -661,6 +661,7 @@ static struct file_operations evdev_fops
- static struct input_handle *evdev_connect(struct input_handler *handler, struct input_dev *dev, struct input_device_id *id)
- {
- struct evdev *evdev;
-+ struct class_device *cdev;
- int minor;
-
- for (minor = 0; minor < EVDEV_MINORS && evdev_table[minor]; minor++);
-@@ -686,9 +687,13 @@ static struct input_handle *evdev_connec
-
- evdev_table[minor] = evdev;
-
-- class_device_create(&input_class, &dev->cdev,
-+ cdev = class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor),
-- dev->cdev.dev, "event%d", minor);
-+ dev->cdev.dev, evdev->name);
-+
-+ /* temporary symlink to keep userspace happy */
-+ sysfs_create_link(&input_class.subsys.kset.kobj, &cdev->kobj,
-+ evdev->name);
-
- return &evdev->handle;
- }
-@@ -698,6 +703,7 @@ static void evdev_disconnect(struct inpu
- struct evdev *evdev = handle->private;
- struct evdev_list *list;
-
-+ sysfs_remove_link(&input_class.subsys.kset.kobj, evdev->name);
- class_device_destroy(&input_class,
- MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + evdev->minor));
- evdev->exist = 0;
---- gregkh-2.6.orig/drivers/input/joydev.c
-+++ gregkh-2.6/drivers/input/joydev.c
-@@ -448,6 +448,7 @@ static struct file_operations joydev_fop
- static struct input_handle *joydev_connect(struct input_handler *handler, struct input_dev *dev, struct input_device_id *id)
- {
- struct joydev *joydev;
-+ struct class_device *cdev;
- int i, j, t, minor;
-
- for (minor = 0; minor < JOYDEV_MINORS && joydev_table[minor]; minor++);
-@@ -513,9 +514,13 @@ static struct input_handle *joydev_conne
-
- joydev_table[minor] = joydev;
-
-- class_device_create(&input_class, &dev->cdev,
-+ cdev = class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + minor),
-- dev->cdev.dev, "js%d", minor);
-+ dev->cdev.dev, joydev->name);
-+
-+ /* temporary symlink to keep userspace happy */
-+ sysfs_create_link(&input_class.subsys.kset.kobj, &cdev->kobj,
-+ joydev->name);
-
- return &joydev->handle;
- }
-@@ -525,6 +530,7 @@ static void joydev_disconnect(struct inp
- struct joydev *joydev = handle->private;
- struct joydev_list *list;
-
-+ sysfs_remove_link(&input_class.subsys.kset.kobj, joydev->name);
- class_device_destroy(&input_class, MKDEV(INPUT_MAJOR, JOYDEV_MINOR_BASE + joydev->minor));
- joydev->exist = 0;
-
---- gregkh-2.6.orig/drivers/input/mousedev.c
-+++ gregkh-2.6/drivers/input/mousedev.c
-@@ -620,6 +620,7 @@ static struct file_operations mousedev_f
- static struct input_handle *mousedev_connect(struct input_handler *handler, struct input_dev *dev, struct input_device_id *id)
- {
- struct mousedev *mousedev;
-+ struct class_device *cdev;
- int minor = 0;
-
- for (minor = 0; minor < MOUSEDEV_MINORS && mousedev_table[minor]; minor++);
-@@ -648,9 +649,13 @@ static struct input_handle *mousedev_con
-
- mousedev_table[minor] = mousedev;
-
-- class_device_create(&input_class, &dev->cdev,
-+ cdev = class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + minor),
-- dev->cdev.dev, "mouse%d", minor);
-+ dev->cdev.dev, mousedev->name);
-+
-+ /* temporary symlink to keep userspace happy */
-+ sysfs_create_link(&input_class.subsys.kset.kobj, &cdev->kobj,
-+ mousedev->name);
-
- return &mousedev->handle;
- }
-@@ -660,6 +665,7 @@ static void mousedev_disconnect(struct i
- struct mousedev *mousedev = handle->private;
- struct mousedev_list *list;
-
-+ sysfs_remove_link(&input_class.subsys.kset.kobj, mousedev->name);
- class_device_destroy(&input_class,
- MKDEV(INPUT_MAJOR, MOUSEDEV_MINOR_BASE + mousedev->minor));
- mousedev->exist = 0;
---- gregkh-2.6.orig/drivers/input/tsdev.c
-+++ gregkh-2.6/drivers/input/tsdev.c
-@@ -368,6 +368,7 @@ static struct input_handle *tsdev_connec
- struct input_device_id *id)
- {
- struct tsdev *tsdev;
-+ struct class_device *cdev;
- int minor, delta;
-
- for (minor = 0; minor < TSDEV_MINORS/2 && tsdev_table[minor];
-@@ -409,9 +410,13 @@ static struct input_handle *tsdev_connec
-
- tsdev_table[minor] = tsdev;
-
-- class_device_create(&input_class, &dev->cdev,
-+ cdev = class_device_create(&input_class, &dev->cdev,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + minor),
-- dev->cdev.dev, "ts%d", minor);
-+ dev->cdev.dev, tsdev->name);
-+
-+ /* temporary symlink to keep userspace happy */
-+ sysfs_create_link(&input_class.subsys.kset.kobj, &cdev->kobj,
-+ tsdev->name);
-
- return &tsdev->handle;
- }
-@@ -421,6 +426,7 @@ static void tsdev_disconnect(struct inpu
- struct tsdev *tsdev = handle->private;
- struct tsdev_list *list;
-
-+ sysfs_remove_link(&input_class.subsys.kset.kobj, tsdev->name);
- class_device_destroy(&input_class,
- MKDEV(INPUT_MAJOR, TSDEV_MINOR_BASE + tsdev->minor));
- tsdev->exist = 0;
diff --git a/driver/input_oops_fix.patch b/driver/input_oops_fix.patch
deleted file mode 100644
index acc62c4384bef..0000000000000
--- a/driver/input_oops_fix.patch
+++ /dev/null
@@ -1,57 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: INPUT: Fix oops when accessing sysfs files of nested input devices
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
-
----
- drivers/input/input.c | 19 ++++++++++++-------
- 1 file changed, 12 insertions(+), 7 deletions(-)
-
---- gregkh-2.6.orig/drivers/input/input.c
-+++ gregkh-2.6/drivers/input/input.c
-@@ -642,17 +642,22 @@ static ssize_t input_dev_show_##name(str
- up(&input_dev->sem); \
- \
- return retval; \
--}
-+} \
-+static CLASS_DEVICE_ATTR(name, S_IRUGO, input_dev_show_##name, NULL);
-
- INPUT_DEV_STRING_ATTR_SHOW(name);
- INPUT_DEV_STRING_ATTR_SHOW(phys);
- INPUT_DEV_STRING_ATTR_SHOW(uniq);
-
--static struct class_device_attribute input_dev_attrs[] = {
-- __ATTR(name, S_IRUGO, input_dev_show_name, NULL),
-- __ATTR(phys, S_IRUGO, input_dev_show_phys, NULL),
-- __ATTR(uniq, S_IRUGO, input_dev_show_uniq, NULL),
-- __ATTR_NULL
-+static struct attribute *input_dev_attrs[] = {
-+ &class_device_attr_name.attr,
-+ &class_device_attr_phys.attr,
-+ &class_device_attr_uniq.attr,
-+ NULL
-+};
-+
-+static struct attribute_group input_dev_group = {
-+ .attrs = input_dev_attrs,
- };
-
- #define INPUT_DEV_ID_ATTR(name) \
-@@ -728,7 +733,6 @@ static void input_dev_release(struct cla
- struct class input_dev_class = {
- .name = "input_dev",
- .release = input_dev_release,
-- .class_dev_attrs = input_dev_attrs,
- };
-
- struct input_dev *input_allocate_device(void)
-@@ -766,6 +770,7 @@ static void input_register_classdevice(s
- kfree(path);
-
- class_device_add(&dev->cdev);
-+ sysfs_create_group(&dev->cdev.kobj, &input_dev_group);
- sysfs_create_group(&dev->cdev.kobj, &input_dev_id_attr_group);
- sysfs_create_group(&dev->cdev.kobj, &input_dev_caps_attr_group);
- }
diff --git a/driver/kernel-doc-drivers-base-fixes.patch b/driver/kernel-doc-drivers-base-fixes.patch
deleted file mode 100644
index b85e027056890..0000000000000
--- a/driver/kernel-doc-drivers-base-fixes.patch
+++ /dev/null
@@ -1,53 +0,0 @@
-From rdunlap@xenotime.net Sun Oct 23 12:47:04 2005
-Date: Sun, 23 Oct 2005 11:59:14 -0700
-From: "Randy.Dunlap" <rdunlap@xenotime.net>
-Cc: gregkh <greg@kroah.com>
-Subject: [PATCH] kernel-doc: drivers/base fixes
-Message-Id: <20051023115914.51f96ddc.rdunlap@xenotime.net>
-
-From: Randy Dunlap <rdunlap@xenotime.net>
-
-driver/base: add missing function parameters; eliminate all warnings.
-
-Signed-off-by: Randy Dunlap <rdunlap@xenotime.net>
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
----
- drivers/base/core.c | 4 ++--
- drivers/base/driver.c | 3 ++-
- 2 files changed, 4 insertions(+), 3 deletions(-)
-
---- gregkh-2.6.orig/drivers/base/driver.c
-+++ gregkh-2.6/drivers/base/driver.c
-@@ -28,6 +28,7 @@ static struct device * next_device(struc
- /**
- * driver_for_each_device - Iterator for devices bound to a driver.
- * @drv: Driver we're iterating.
-+ * @start: Device to begin with
- * @data: Data to pass to the callback.
- * @fn: Function to call for each device.
- *
-@@ -57,7 +58,7 @@ EXPORT_SYMBOL_GPL(driver_for_each_device
-
- /**
- * driver_find_device - device iterator for locating a particular device.
-- * @driver: The device's driver
-+ * @drv: The device's driver
- * @start: Device to begin with
- * @data: Data to pass to match function
- * @match: Callback function to check device
---- gregkh-2.6.orig/drivers/base/core.c
-+++ gregkh-2.6/drivers/base/core.c
-@@ -407,11 +407,11 @@ static struct device * next_device(struc
-
- /**
- * device_for_each_child - device child iterator.
-- * @dev: parent struct device.
-+ * @parent: parent struct device.
- * @data: data for the callback.
- * @fn: function to be called for each device.
- *
-- * Iterate over @dev's child devices, and call @fn for each,
-+ * Iterate over @parent's child devices, and call @fn for each,
- * passing it @data.
- *
- * We check the return of @fn each time. If it returns anything
diff --git a/driver/update-udev-version.patch b/driver/update-udev-version.patch
deleted file mode 100644
index 1dd0388034b3c..0000000000000
--- a/driver/update-udev-version.patch
+++ /dev/null
@@ -1,25 +0,0 @@
-From: Greg Kroah-Hartman <gregkh@suse.de>
-Subject: update required version of udev
-
-The 071 release is needed to handle the input changes. Older versions
-will work properly with module-based systems, but not for users that
-build input stuff into the kernel.
-
-
-Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-
----
- Documentation/Changes | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
---- gregkh-2.6.orig/Documentation/Changes
-+++ gregkh-2.6/Documentation/Changes
-@@ -65,7 +65,7 @@ o isdn4k-utils 3.1pre1
- o nfs-utils 1.0.5 # showmount --version
- o procps 3.2.0 # ps --version
- o oprofile 0.9 # oprofiled --version
--o udev 058 # udevinfo -V
-+o udev 071 # udevinfo -V
-
- Kernel compilation
- ==================