aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/omap24xx/patches-3.1/350-n8x0-gpioswitch-input.patch
diff options
context:
space:
mode:
authorMichael Büsch <mb@bu3sch.de>2011-10-29 19:02:50 +0000
committerMichael Büsch <mb@bu3sch.de>2011-10-29 19:02:50 +0000
commitf9cfd5e29736796a17afd288b065525716eb8e6e (patch)
treea8a9656048176fd8ca1331bc5221a0ccc1168089 /target/linux/omap24xx/patches-3.1/350-n8x0-gpioswitch-input.patch
parentc3b8a2419cfc6e3106f70cf7e3b0f1a647503856 (diff)
downloadupstream-f9cfd5e29736796a17afd288b065525716eb8e6e.tar.gz
upstream-f9cfd5e29736796a17afd288b065525716eb8e6e.tar.bz2
upstream-f9cfd5e29736796a17afd288b065525716eb8e6e.zip
omap24xx: Add 3.1 patchset.
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@28672 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/omap24xx/patches-3.1/350-n8x0-gpioswitch-input.patch')
-rw-r--r--target/linux/omap24xx/patches-3.1/350-n8x0-gpioswitch-input.patch100
1 files changed, 100 insertions, 0 deletions
diff --git a/target/linux/omap24xx/patches-3.1/350-n8x0-gpioswitch-input.patch b/target/linux/omap24xx/patches-3.1/350-n8x0-gpioswitch-input.patch
new file mode 100644
index 0000000000..22c7f200a3
--- /dev/null
+++ b/target/linux/omap24xx/patches-3.1/350-n8x0-gpioswitch-input.patch
@@ -0,0 +1,100 @@
+---
+ arch/arm/mach-omap2/board-n8x0.c | 73 +++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 73 insertions(+)
+
+Index: linux-3.1-rc4/arch/arm/mach-omap2/board-n8x0.c
+===================================================================
+--- linux-3.1-rc4.orig/arch/arm/mach-omap2/board-n8x0.c 2011-10-29 20:35:58.476842416 +0200
++++ linux-3.1-rc4/arch/arm/mach-omap2/board-n8x0.c 2011-10-29 20:36:02.012833998 +0200
+@@ -216,6 +216,77 @@ void __init n8x0_bt_init(void)
+ BUG();
+ }
+
++struct gpio_switch_input_dev {
++ struct input_dev *idev;
++ unsigned int swcode;
++};
++
++static struct gpio_switch_input_dev *slide_input;
++static struct gpio_switch_input_dev *kblock_input;
++
++static void n8x0_gpio_switch_input_notify(struct gpio_switch_input_dev *gdev,
++ int state)
++{
++ if (gdev) {
++ input_report_switch(gdev->idev, gdev->swcode, state);
++ input_sync(gdev->idev);
++ }
++}
++
++static void n8x0_slide_notify(void *data, int state)
++{
++ n8x0_gpio_switch_input_notify(slide_input, state);
++}
++
++static void n8x0_kb_lock_notify(void *data, int state)
++{
++ n8x0_gpio_switch_input_notify(kblock_input, state);
++}
++
++static struct gpio_switch_input_dev * __init gpioswitch_input_init(
++ const char *name,
++ unsigned int swcode)
++{
++ struct gpio_switch_input_dev *gdev;
++ int err;
++
++ gdev = kzalloc(sizeof(*gdev), GFP_KERNEL);
++ if (!gdev)
++ goto error;
++ gdev->swcode = swcode;
++
++ gdev->idev = input_allocate_device();
++ if (!gdev->idev)
++ goto err_free;
++
++ gdev->idev->evbit[0] = BIT_MASK(EV_SW);
++ gdev->idev->swbit[BIT_WORD(swcode)] = BIT_MASK(swcode);
++ gdev->idev->name = name;
++
++ err = input_register_device(gdev->idev);
++ if (err)
++ goto err_free_idev;
++
++ return gdev;
++
++err_free_idev:
++ input_free_device(gdev->idev);
++err_free:
++ kfree(gdev);
++error:
++ return NULL;
++}
++
++static int __init n8x0_gpio_switches_input_init(void)
++{
++ slide_input = gpioswitch_input_init("slide", SW_KEYPAD_SLIDE);
++ kblock_input = gpioswitch_input_init("kb_lock", SW_LID);
++ if (WARN_ON(!slide_input || !kblock_input))
++ return -ENODEV;
++ return 0;
++}
++late_initcall(n8x0_gpio_switches_input_init);
++
+ static struct omap_gpio_switch n8x0_gpio_switches[] __initdata = {
+ {
+ .name = "headphone",
+@@ -237,11 +308,13 @@ static struct omap_gpio_switch n8x0_gpio
+ .gpio = -1,
+ .debounce_rising = 200,
+ .debounce_falling = 200,
++ .notify = n8x0_slide_notify,
+ }, {
+ .name = "kb_lock",
+ .gpio = -1,
+ .debounce_rising = 200,
+ .debounce_falling = 200,
++ .notify = n8x0_kb_lock_notify,
+ },
+ };
+