Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input
Pull input subsystem fixes from Dmitry Torokhov: "Just a few driver fixes." * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input: Input: tsc40 - remove wrong announcement of pressure support Input: lpc32xx-keys - select INPUT_MATRIXKMAP Input: pxa27x_keypad - clear pending interrupts on keypad config Input: wacom - correct bad Cintiq 24HD check Input: wacom - add INPUT_PROP_DIRECT flag to Cintiq 24HD Input: egalax_ts - get gpio from devicetree
This commit is contained in:
@@ -0,0 +1,19 @@
|
|||||||
|
* EETI eGalax Multiple Touch Controller
|
||||||
|
|
||||||
|
Required properties:
|
||||||
|
- compatible: must be "eeti,egalax_ts"
|
||||||
|
- reg: i2c slave address
|
||||||
|
- interrupt-parent: the phandle for the interrupt controller
|
||||||
|
- interrupts: touch controller interrupt
|
||||||
|
- wakeup-gpios: the gpio pin to be used for waking up the controller
|
||||||
|
as well as uased as irq pin
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
egalax_ts@04 {
|
||||||
|
compatible = "eeti,egalax_ts";
|
||||||
|
reg = <0x04>;
|
||||||
|
interrupt-parent = <&gpio1>;
|
||||||
|
interrupts = <9 2>;
|
||||||
|
wakeup-gpios = <&gpio1 9 0>;
|
||||||
|
};
|
@@ -335,6 +335,7 @@ config KEYBOARD_LOCOMO
|
|||||||
config KEYBOARD_LPC32XX
|
config KEYBOARD_LPC32XX
|
||||||
tristate "LPC32XX matrix key scanner support"
|
tristate "LPC32XX matrix key scanner support"
|
||||||
depends on ARCH_LPC32XX && OF
|
depends on ARCH_LPC32XX && OF
|
||||||
|
select INPUT_MATRIXKMAP
|
||||||
help
|
help
|
||||||
Say Y here if you want to use NXP LPC32XX SoC key scanner interface,
|
Say Y here if you want to use NXP LPC32XX SoC key scanner interface,
|
||||||
connected to a key matrix.
|
connected to a key matrix.
|
||||||
|
@@ -368,6 +368,9 @@ static void pxa27x_keypad_config(struct pxa27x_keypad *keypad)
|
|||||||
unsigned int mask = 0, direct_key_num = 0;
|
unsigned int mask = 0, direct_key_num = 0;
|
||||||
unsigned long kpc = 0;
|
unsigned long kpc = 0;
|
||||||
|
|
||||||
|
/* clear pending interrupt bit */
|
||||||
|
keypad_readl(KPC);
|
||||||
|
|
||||||
/* enable matrix keys with automatic scan */
|
/* enable matrix keys with automatic scan */
|
||||||
if (pdata->matrix_key_rows && pdata->matrix_key_cols) {
|
if (pdata->matrix_key_rows && pdata->matrix_key_cols) {
|
||||||
kpc |= KPC_ASACT | KPC_MIE | KPC_ME | KPC_MS_ALL;
|
kpc |= KPC_ASACT | KPC_MIE | KPC_ME | KPC_MS_ALL;
|
||||||
|
@@ -391,7 +391,7 @@ static int wacom_parse_hid(struct usb_interface *intf,
|
|||||||
features->pktlen = WACOM_PKGLEN_TPC2FG;
|
features->pktlen = WACOM_PKGLEN_TPC2FG;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (features->type == MTSCREEN || WACOM_24HDT)
|
if (features->type == MTSCREEN || features->type == WACOM_24HDT)
|
||||||
features->pktlen = WACOM_PKGLEN_MTOUCH;
|
features->pktlen = WACOM_PKGLEN_MTOUCH;
|
||||||
|
|
||||||
if (features->type == BAMBOO_PT) {
|
if (features->type == BAMBOO_PT) {
|
||||||
|
@@ -1518,6 +1518,9 @@ int wacom_setup_input_capabilities(struct input_dev *input_dev,
|
|||||||
|
|
||||||
input_set_abs_params(input_dev, ABS_Z, -900, 899, 0, 0);
|
input_set_abs_params(input_dev, ABS_Z, -900, 899, 0, 0);
|
||||||
input_set_abs_params(input_dev, ABS_THROTTLE, 0, 71, 0, 0);
|
input_set_abs_params(input_dev, ABS_THROTTLE, 0, 71, 0, 0);
|
||||||
|
|
||||||
|
__set_bit(INPUT_PROP_DIRECT, input_dev->propbit);
|
||||||
|
|
||||||
wacom_setup_cintiq(wacom_wac);
|
wacom_setup_cintiq(wacom_wac);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@@ -239,7 +239,7 @@ config TOUCHSCREEN_EETI
|
|||||||
|
|
||||||
config TOUCHSCREEN_EGALAX
|
config TOUCHSCREEN_EGALAX
|
||||||
tristate "EETI eGalax multi-touch panel support"
|
tristate "EETI eGalax multi-touch panel support"
|
||||||
depends on I2C
|
depends on I2C && OF
|
||||||
help
|
help
|
||||||
Say Y here to enable support for I2C connected EETI
|
Say Y here to enable support for I2C connected EETI
|
||||||
eGalax multi-touch panels.
|
eGalax multi-touch panels.
|
||||||
|
@@ -28,6 +28,7 @@
|
|||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/bitops.h>
|
#include <linux/bitops.h>
|
||||||
#include <linux/input/mt.h>
|
#include <linux/input/mt.h>
|
||||||
|
#include <linux/of_gpio.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Mouse Mode: some panel may configure the controller to mouse mode,
|
* Mouse Mode: some panel may configure the controller to mouse mode,
|
||||||
@@ -122,9 +123,17 @@ static irqreturn_t egalax_ts_interrupt(int irq, void *dev_id)
|
|||||||
/* wake up controller by an falling edge of interrupt gpio. */
|
/* wake up controller by an falling edge of interrupt gpio. */
|
||||||
static int egalax_wake_up_device(struct i2c_client *client)
|
static int egalax_wake_up_device(struct i2c_client *client)
|
||||||
{
|
{
|
||||||
int gpio = irq_to_gpio(client->irq);
|
struct device_node *np = client->dev.of_node;
|
||||||
|
int gpio;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
if (!np)
|
||||||
|
return -ENODEV;
|
||||||
|
|
||||||
|
gpio = of_get_named_gpio(np, "wakeup-gpios", 0);
|
||||||
|
if (!gpio_is_valid(gpio))
|
||||||
|
return -ENODEV;
|
||||||
|
|
||||||
ret = gpio_request(gpio, "egalax_irq");
|
ret = gpio_request(gpio, "egalax_irq");
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
dev_err(&client->dev,
|
dev_err(&client->dev,
|
||||||
@@ -181,7 +190,11 @@ static int __devinit egalax_ts_probe(struct i2c_client *client,
|
|||||||
ts->input_dev = input_dev;
|
ts->input_dev = input_dev;
|
||||||
|
|
||||||
/* controller may be in sleep, wake it up. */
|
/* controller may be in sleep, wake it up. */
|
||||||
egalax_wake_up_device(client);
|
error = egalax_wake_up_device(client);
|
||||||
|
if (error) {
|
||||||
|
dev_err(&client->dev, "Failed to wake up the controller\n");
|
||||||
|
goto err_free_dev;
|
||||||
|
}
|
||||||
|
|
||||||
ret = egalax_firmware_version(client);
|
ret = egalax_firmware_version(client);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
@@ -274,11 +287,17 @@ static int egalax_ts_resume(struct device *dev)
|
|||||||
|
|
||||||
static SIMPLE_DEV_PM_OPS(egalax_ts_pm_ops, egalax_ts_suspend, egalax_ts_resume);
|
static SIMPLE_DEV_PM_OPS(egalax_ts_pm_ops, egalax_ts_suspend, egalax_ts_resume);
|
||||||
|
|
||||||
|
static struct of_device_id egalax_ts_dt_ids[] = {
|
||||||
|
{ .compatible = "eeti,egalax_ts" },
|
||||||
|
{ /* sentinel */ }
|
||||||
|
};
|
||||||
|
|
||||||
static struct i2c_driver egalax_ts_driver = {
|
static struct i2c_driver egalax_ts_driver = {
|
||||||
.driver = {
|
.driver = {
|
||||||
.name = "egalax_ts",
|
.name = "egalax_ts",
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.pm = &egalax_ts_pm_ops,
|
.pm = &egalax_ts_pm_ops,
|
||||||
|
.of_match_table = of_match_ptr(egalax_ts_dt_ids),
|
||||||
},
|
},
|
||||||
.id_table = egalax_ts_id,
|
.id_table = egalax_ts_id,
|
||||||
.probe = egalax_ts_probe,
|
.probe = egalax_ts_probe,
|
||||||
|
@@ -107,7 +107,6 @@ static int tsc_connect(struct serio *serio, struct serio_driver *drv)
|
|||||||
__set_bit(BTN_TOUCH, input_dev->keybit);
|
__set_bit(BTN_TOUCH, input_dev->keybit);
|
||||||
input_set_abs_params(ptsc->dev, ABS_X, 0, 0x3ff, 0, 0);
|
input_set_abs_params(ptsc->dev, ABS_X, 0, 0x3ff, 0, 0);
|
||||||
input_set_abs_params(ptsc->dev, ABS_Y, 0, 0x3ff, 0, 0);
|
input_set_abs_params(ptsc->dev, ABS_Y, 0, 0x3ff, 0, 0);
|
||||||
input_set_abs_params(ptsc->dev, ABS_PRESSURE, 0, 0, 0, 0);
|
|
||||||
|
|
||||||
serio_set_drvdata(serio, ptsc);
|
serio_set_drvdata(serio, ptsc);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user