diff options
author | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
---|---|---|
committer | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
commit | c71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch) | |
tree | ecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /drivers/input/keyboard/gpio_keys.c | |
parent | ea53c912f8a86a8567697115b6a0d8152beee5c8 (diff) | |
parent | 6a00f206debf8a5c8899055726ad127dbeeed098 (diff) |
Merge branch 'mpi-master' into wip-k-fmlpwip-k-fmlp
Conflicts:
litmus/sched_cedf.c
Diffstat (limited to 'drivers/input/keyboard/gpio_keys.c')
-rw-r--r-- | drivers/input/keyboard/gpio_keys.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/drivers/input/keyboard/gpio_keys.c b/drivers/input/keyboard/gpio_keys.c index 6069abe31e42..6e6145b9a4c1 100644 --- a/drivers/input/keyboard/gpio_keys.c +++ b/drivers/input/keyboard/gpio_keys.c | |||
@@ -322,9 +322,14 @@ static void gpio_keys_report_event(struct gpio_button_data *bdata) | |||
322 | struct gpio_keys_button *button = bdata->button; | 322 | struct gpio_keys_button *button = bdata->button; |
323 | struct input_dev *input = bdata->input; | 323 | struct input_dev *input = bdata->input; |
324 | unsigned int type = button->type ?: EV_KEY; | 324 | unsigned int type = button->type ?: EV_KEY; |
325 | int state = (gpio_get_value(button->gpio) ? 1 : 0) ^ button->active_low; | 325 | int state = (gpio_get_value_cansleep(button->gpio) ? 1 : 0) ^ button->active_low; |
326 | 326 | ||
327 | input_event(input, type, button->code, !!state); | 327 | if (type == EV_ABS) { |
328 | if (state) | ||
329 | input_event(input, type, button->code, button->value); | ||
330 | } else { | ||
331 | input_event(input, type, button->code, !!state); | ||
332 | } | ||
328 | input_sync(input); | 333 | input_sync(input); |
329 | } | 334 | } |
330 | 335 | ||
@@ -363,7 +368,7 @@ static int __devinit gpio_keys_setup_key(struct platform_device *pdev, | |||
363 | struct gpio_button_data *bdata, | 368 | struct gpio_button_data *bdata, |
364 | struct gpio_keys_button *button) | 369 | struct gpio_keys_button *button) |
365 | { | 370 | { |
366 | char *desc = button->desc ? button->desc : "gpio_keys"; | 371 | const char *desc = button->desc ? button->desc : "gpio_keys"; |
367 | struct device *dev = &pdev->dev; | 372 | struct device *dev = &pdev->dev; |
368 | unsigned long irqflags; | 373 | unsigned long irqflags; |
369 | int irq, error; | 374 | int irq, error; |
@@ -410,8 +415,8 @@ static int __devinit gpio_keys_setup_key(struct platform_device *pdev, | |||
410 | if (!button->can_disable) | 415 | if (!button->can_disable) |
411 | irqflags |= IRQF_SHARED; | 416 | irqflags |= IRQF_SHARED; |
412 | 417 | ||
413 | error = request_irq(irq, gpio_keys_isr, irqflags, desc, bdata); | 418 | error = request_any_context_irq(irq, gpio_keys_isr, irqflags, desc, bdata); |
414 | if (error) { | 419 | if (error < 0) { |
415 | dev_err(dev, "Unable to claim irq %d; error %d\n", | 420 | dev_err(dev, "Unable to claim irq %d; error %d\n", |
416 | irq, error); | 421 | irq, error); |
417 | goto fail3; | 422 | goto fail3; |
@@ -468,7 +473,7 @@ static int __devinit gpio_keys_probe(struct platform_device *pdev) | |||
468 | platform_set_drvdata(pdev, ddata); | 473 | platform_set_drvdata(pdev, ddata); |
469 | input_set_drvdata(input, ddata); | 474 | input_set_drvdata(input, ddata); |
470 | 475 | ||
471 | input->name = pdev->name; | 476 | input->name = pdata->name ? : pdev->name; |
472 | input->phys = "gpio-keys/input0"; | 477 | input->phys = "gpio-keys/input0"; |
473 | input->dev.parent = &pdev->dev; | 478 | input->dev.parent = &pdev->dev; |
474 | input->open = gpio_keys_open; | 479 | input->open = gpio_keys_open; |