diff options
Diffstat (limited to 'drivers/input')
| -rw-r--r-- | drivers/input/joystick/analog.c | 2 | ||||
| -rw-r--r-- | drivers/input/misc/ims-pcu.c | 2 | ||||
| -rw-r--r-- | drivers/input/misc/twl4030-vibra.c | 6 | ||||
| -rw-r--r-- | drivers/input/misc/twl6040-vibra.c | 3 | ||||
| -rw-r--r-- | drivers/input/misc/xen-kbdfront.c | 2 | ||||
| -rw-r--r-- | drivers/input/mouse/alps.c | 23 | ||||
| -rw-r--r-- | drivers/input/mouse/alps.h | 10 | ||||
| -rw-r--r-- | drivers/input/mouse/elantech.c | 2 | ||||
| -rw-r--r-- | drivers/input/mouse/synaptics.c | 1 | ||||
| -rw-r--r-- | drivers/input/rmi4/rmi_driver.c | 4 | ||||
| -rw-r--r-- | drivers/input/touchscreen/88pm860x-ts.c | 16 | ||||
| -rw-r--r-- | drivers/input/touchscreen/elants_i2c.c | 10 | ||||
| -rw-r--r-- | drivers/input/touchscreen/hideep.c | 3 | ||||
| -rw-r--r-- | drivers/input/touchscreen/of_touchscreen.c | 4 | 
14 files changed, 55 insertions, 33 deletions
| diff --git a/drivers/input/joystick/analog.c b/drivers/input/joystick/analog.c index 3d8ff09eba57..c868a878c84f 100644 --- a/drivers/input/joystick/analog.c +++ b/drivers/input/joystick/analog.c @@ -163,7 +163,7 @@ static unsigned int get_time_pit(void)  #define GET_TIME(x)	do { x = (unsigned int)rdtsc(); } while (0)  #define DELTA(x,y)	((y)-(x))  #define TIME_NAME	"TSC" -#elif defined(__alpha__) || defined(CONFIG_MN10300) || defined(CONFIG_ARM) || defined(CONFIG_ARM64) || defined(CONFIG_TILE) +#elif defined(__alpha__) || defined(CONFIG_MN10300) || defined(CONFIG_ARM) || defined(CONFIG_ARM64) || defined(CONFIG_RISCV) || defined(CONFIG_TILE)  #define GET_TIME(x)	do { x = get_cycles(); } while (0)  #define DELTA(x,y)	((y)-(x))  #define TIME_NAME	"get_cycles" diff --git a/drivers/input/misc/ims-pcu.c b/drivers/input/misc/ims-pcu.c index ae473123583b..3d51175c4d72 100644 --- a/drivers/input/misc/ims-pcu.c +++ b/drivers/input/misc/ims-pcu.c @@ -1651,7 +1651,7 @@ ims_pcu_get_cdc_union_desc(struct usb_interface *intf)  				return union_desc;  			dev_err(&intf->dev, -				"Union descriptor to short (%d vs %zd\n)", +				"Union descriptor too short (%d vs %zd)\n",  				union_desc->bLength, sizeof(*union_desc));  			return NULL;  		} diff --git a/drivers/input/misc/twl4030-vibra.c b/drivers/input/misc/twl4030-vibra.c index 6c51d404874b..c37aea9ac272 100644 --- a/drivers/input/misc/twl4030-vibra.c +++ b/drivers/input/misc/twl4030-vibra.c @@ -178,12 +178,14 @@ static SIMPLE_DEV_PM_OPS(twl4030_vibra_pm_ops,  			 twl4030_vibra_suspend, twl4030_vibra_resume);  static bool twl4030_vibra_check_coexist(struct twl4030_vibra_data *pdata, -			      struct device_node *node) +			      struct device_node *parent)  { +	struct device_node *node; +  	if (pdata && pdata->coexist)  		return true; -	node = of_find_node_by_name(node, "codec"); +	node = of_get_child_by_name(parent, "codec");  	if (node) {  		of_node_put(node);  		return true; diff --git a/drivers/input/misc/twl6040-vibra.c b/drivers/input/misc/twl6040-vibra.c index 5690eb7ff954..15e0d352c4cc 100644 --- a/drivers/input/misc/twl6040-vibra.c +++ b/drivers/input/misc/twl6040-vibra.c @@ -248,8 +248,7 @@ static int twl6040_vibra_probe(struct platform_device *pdev)  	int vddvibr_uV = 0;  	int error; -	of_node_get(twl6040_core_dev->of_node); -	twl6040_core_node = of_find_node_by_name(twl6040_core_dev->of_node, +	twl6040_core_node = of_get_child_by_name(twl6040_core_dev->of_node,  						 "vibra");  	if (!twl6040_core_node) {  		dev_err(&pdev->dev, "parent of node is missing?\n"); diff --git a/drivers/input/misc/xen-kbdfront.c b/drivers/input/misc/xen-kbdfront.c index 6bf56bb5f8d9..d91f3b1c5375 100644 --- a/drivers/input/misc/xen-kbdfront.c +++ b/drivers/input/misc/xen-kbdfront.c @@ -326,8 +326,6 @@ static int xenkbd_probe(struct xenbus_device *dev,  				     0, width, 0, 0);  		input_set_abs_params(mtouch, ABS_MT_POSITION_Y,  				     0, height, 0, 0); -		input_set_abs_params(mtouch, ABS_MT_PRESSURE, -				     0, 255, 0, 0);  		ret = input_mt_init_slots(mtouch, num_cont, INPUT_MT_DIRECT);  		if (ret) { diff --git a/drivers/input/mouse/alps.c b/drivers/input/mouse/alps.c index 579b899add26..dbe57da8c1a1 100644 --- a/drivers/input/mouse/alps.c +++ b/drivers/input/mouse/alps.c @@ -1250,29 +1250,32 @@ static int alps_decode_ss4_v2(struct alps_fields *f,  	case SS4_PACKET_ID_MULTI:  		if (priv->flags & ALPS_BUTTONPAD) {  			if (IS_SS4PLUS_DEV(priv->dev_id)) { -				f->mt[0].x = SS4_PLUS_BTL_MF_X_V2(p, 0); -				f->mt[1].x = SS4_PLUS_BTL_MF_X_V2(p, 1); +				f->mt[2].x = SS4_PLUS_BTL_MF_X_V2(p, 0); +				f->mt[3].x = SS4_PLUS_BTL_MF_X_V2(p, 1); +				no_data_x = SS4_PLUS_MFPACKET_NO_AX_BL;  			} else {  				f->mt[2].x = SS4_BTL_MF_X_V2(p, 0);  				f->mt[3].x = SS4_BTL_MF_X_V2(p, 1); +				no_data_x = SS4_MFPACKET_NO_AX_BL;  			} +			no_data_y = SS4_MFPACKET_NO_AY_BL;  			f->mt[2].y = SS4_BTL_MF_Y_V2(p, 0);  			f->mt[3].y = SS4_BTL_MF_Y_V2(p, 1); -			no_data_x = SS4_MFPACKET_NO_AX_BL; -			no_data_y = SS4_MFPACKET_NO_AY_BL;  		} else {  			if (IS_SS4PLUS_DEV(priv->dev_id)) { -				f->mt[0].x = SS4_PLUS_STD_MF_X_V2(p, 0); -				f->mt[1].x = SS4_PLUS_STD_MF_X_V2(p, 1); +				f->mt[2].x = SS4_PLUS_STD_MF_X_V2(p, 0); +				f->mt[3].x = SS4_PLUS_STD_MF_X_V2(p, 1); +				no_data_x = SS4_PLUS_MFPACKET_NO_AX;  			} else { -				f->mt[0].x = SS4_STD_MF_X_V2(p, 0); -				f->mt[1].x = SS4_STD_MF_X_V2(p, 1); +				f->mt[2].x = SS4_STD_MF_X_V2(p, 0); +				f->mt[3].x = SS4_STD_MF_X_V2(p, 1); +				no_data_x = SS4_MFPACKET_NO_AX;  			} +			no_data_y = SS4_MFPACKET_NO_AY; +  			f->mt[2].y = SS4_STD_MF_Y_V2(p, 0);  			f->mt[3].y = SS4_STD_MF_Y_V2(p, 1); -			no_data_x = SS4_MFPACKET_NO_AX; -			no_data_y = SS4_MFPACKET_NO_AY;  		}  		f->first_mp = 0; diff --git a/drivers/input/mouse/alps.h b/drivers/input/mouse/alps.h index c80a7c76cb76..79b6d69d1486 100644 --- a/drivers/input/mouse/alps.h +++ b/drivers/input/mouse/alps.h @@ -141,10 +141,12 @@ enum SS4_PACKET_ID {  #define SS4_TS_Z_V2(_b)		(s8)(_b[4] & 0x7F) -#define SS4_MFPACKET_NO_AX	8160	/* X-Coordinate value */ -#define SS4_MFPACKET_NO_AY	4080	/* Y-Coordinate value */ -#define SS4_MFPACKET_NO_AX_BL	8176	/* Buttonless X-Coordinate value */ -#define SS4_MFPACKET_NO_AY_BL	4088	/* Buttonless Y-Coordinate value */ +#define SS4_MFPACKET_NO_AX		8160	/* X-Coordinate value */ +#define SS4_MFPACKET_NO_AY		4080	/* Y-Coordinate value */ +#define SS4_MFPACKET_NO_AX_BL		8176	/* Buttonless X-Coord value */ +#define SS4_MFPACKET_NO_AY_BL		4088	/* Buttonless Y-Coord value */ +#define SS4_PLUS_MFPACKET_NO_AX		4080	/* SS4 PLUS, X */ +#define SS4_PLUS_MFPACKET_NO_AX_BL	4088	/* Buttonless SS4 PLUS, X */  /*   * enum V7_PACKET_ID - defines the packet type for V7 diff --git a/drivers/input/mouse/elantech.c b/drivers/input/mouse/elantech.c index b84cd978fce2..a4aaa748e987 100644 --- a/drivers/input/mouse/elantech.c +++ b/drivers/input/mouse/elantech.c @@ -1613,7 +1613,7 @@ static int elantech_set_properties(struct elantech_data *etd)  		case 5:  			etd->hw_version = 3;  			break; -		case 6 ... 14: +		case 6 ... 15:  			etd->hw_version = 4;  			break;  		default: diff --git a/drivers/input/mouse/synaptics.c b/drivers/input/mouse/synaptics.c index ee5466a374bf..cd9f61cb3fc6 100644 --- a/drivers/input/mouse/synaptics.c +++ b/drivers/input/mouse/synaptics.c @@ -173,6 +173,7 @@ static const char * const smbus_pnp_ids[] = {  	"LEN0046", /* X250 */  	"LEN004a", /* W541 */  	"LEN200f", /* T450s */ +	"LEN2018", /* T460p */  	NULL  }; diff --git a/drivers/input/rmi4/rmi_driver.c b/drivers/input/rmi4/rmi_driver.c index 4f2bb5947a4e..141ea228aac6 100644 --- a/drivers/input/rmi4/rmi_driver.c +++ b/drivers/input/rmi4/rmi_driver.c @@ -230,8 +230,10 @@ static irqreturn_t rmi_irq_fn(int irq, void *dev_id)  		rmi_dbg(RMI_DEBUG_CORE, &rmi_dev->dev,  			"Failed to process interrupt request: %d\n", ret); -	if (count) +	if (count) {  		kfree(attn_data.data); +		attn_data.data = NULL; +	}  	if (!kfifo_is_empty(&drvdata->attn_fifo))  		return rmi_irq_fn(irq, dev_id); diff --git a/drivers/input/touchscreen/88pm860x-ts.c b/drivers/input/touchscreen/88pm860x-ts.c index 7ed828a51f4c..3486d9403805 100644 --- a/drivers/input/touchscreen/88pm860x-ts.c +++ b/drivers/input/touchscreen/88pm860x-ts.c @@ -126,7 +126,7 @@ static int pm860x_touch_dt_init(struct platform_device *pdev,  	int data, n, ret;  	if (!np)  		return -ENODEV; -	np = of_find_node_by_name(np, "touch"); +	np = of_get_child_by_name(np, "touch");  	if (!np) {  		dev_err(&pdev->dev, "Can't find touch node\n");  		return -EINVAL; @@ -144,13 +144,13 @@ static int pm860x_touch_dt_init(struct platform_device *pdev,  	if (data) {  		ret = pm860x_reg_write(i2c, PM8607_GPADC_MISC1, data);  		if (ret < 0) -			return -EINVAL; +			goto err_put_node;  	}  	/* set tsi prebias time */  	if (!of_property_read_u32(np, "marvell,88pm860x-tsi-prebias", &data)) {  		ret = pm860x_reg_write(i2c, PM8607_TSI_PREBIAS, data);  		if (ret < 0) -			return -EINVAL; +			goto err_put_node;  	}  	/* set prebias & prechg time of pen detect */  	data = 0; @@ -161,10 +161,18 @@ static int pm860x_touch_dt_init(struct platform_device *pdev,  	if (data) {  		ret = pm860x_reg_write(i2c, PM8607_PD_PREBIAS, data);  		if (ret < 0) -			return -EINVAL; +			goto err_put_node;  	}  	of_property_read_u32(np, "marvell,88pm860x-resistor-X", res_x); + +	of_node_put(np); +  	return 0; + +err_put_node: +	of_node_put(np); + +	return -EINVAL;  }  #else  #define pm860x_touch_dt_init(x, y, z)	(-1) diff --git a/drivers/input/touchscreen/elants_i2c.c b/drivers/input/touchscreen/elants_i2c.c index e102d7764bc2..a458e5ec9e41 100644 --- a/drivers/input/touchscreen/elants_i2c.c +++ b/drivers/input/touchscreen/elants_i2c.c @@ -27,6 +27,7 @@  #include <linux/module.h>  #include <linux/input.h>  #include <linux/interrupt.h> +#include <linux/irq.h>  #include <linux/platform_device.h>  #include <linux/async.h>  #include <linux/i2c.h> @@ -1261,10 +1262,13 @@ static int elants_i2c_probe(struct i2c_client *client,  	}  	/* -	 * Systems using device tree should set up interrupt via DTS, -	 * the rest will use the default falling edge interrupts. +	 * Platform code (ACPI, DTS) should normally set up interrupt +	 * for us, but in case it did not let's fall back to using falling +	 * edge to be compatible with older Chromebooks.  	 */ -	irqflags = client->dev.of_node ? 0 : IRQF_TRIGGER_FALLING; +	irqflags = irq_get_trigger_type(client->irq); +	if (!irqflags) +		irqflags = IRQF_TRIGGER_FALLING;  	error = devm_request_threaded_irq(&client->dev, client->irq,  					  NULL, elants_i2c_irq, diff --git a/drivers/input/touchscreen/hideep.c b/drivers/input/touchscreen/hideep.c index fc080a7c2e1f..f1cd4dd9a4a3 100644 --- a/drivers/input/touchscreen/hideep.c +++ b/drivers/input/touchscreen/hideep.c @@ -10,8 +10,7 @@  #include <linux/of.h>  #include <linux/firmware.h>  #include <linux/delay.h> -#include <linux/gpio.h> -#include <linux/gpio/machine.h> +#include <linux/gpio/consumer.h>  #include <linux/i2c.h>  #include <linux/acpi.h>  #include <linux/interrupt.h> diff --git a/drivers/input/touchscreen/of_touchscreen.c b/drivers/input/touchscreen/of_touchscreen.c index 8d7f9c8f2771..9642f103b726 100644 --- a/drivers/input/touchscreen/of_touchscreen.c +++ b/drivers/input/touchscreen/of_touchscreen.c @@ -13,6 +13,7 @@  #include <linux/input.h>  #include <linux/input/mt.h>  #include <linux/input/touchscreen.h> +#include <linux/module.h>  static bool touchscreen_get_prop_u32(struct device *dev,  				     const char *property, @@ -185,3 +186,6 @@ void touchscreen_report_pos(struct input_dev *input,  	input_report_abs(input, multitouch ? ABS_MT_POSITION_Y : ABS_Y, y);  }  EXPORT_SYMBOL(touchscreen_report_pos); + +MODULE_LICENSE("GPL v2"); +MODULE_DESCRIPTION("Device-tree helpers functions for touchscreen devices"); |