diff options
Diffstat (limited to 'drivers/input/touchscreen')
| -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 | ||||
| -rw-r--r-- | drivers/input/touchscreen/s6sy761.c | 15 | ||||
| -rw-r--r-- | drivers/input/touchscreen/stmfts.c | 15 | 
6 files changed, 34 insertions, 29 deletions
| 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"); diff --git a/drivers/input/touchscreen/s6sy761.c b/drivers/input/touchscreen/s6sy761.c index 26b1cb8a88ec..675efa93d444 100644 --- a/drivers/input/touchscreen/s6sy761.c +++ b/drivers/input/touchscreen/s6sy761.c @@ -1,13 +1,8 @@ -/* - * Copyright (c) 2017 Samsung Electronics Co., Ltd. - * Author: Andi Shyti <andi.shyti@samsung.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation. - * - * Samsung S6SY761 Touchscreen device driver - */ +// SPDX-License-Identifier: GPL-2.0 +// Samsung S6SY761 Touchscreen device driver +// +// Copyright (c) 2017 Samsung Electronics Co., Ltd. +// Copyright (c) 2017 Andi Shyti <andi.shyti@samsung.com>  #include <asm/unaligned.h>  #include <linux/delay.h> diff --git a/drivers/input/touchscreen/stmfts.c b/drivers/input/touchscreen/stmfts.c index c12d01899939..2a123e20a42e 100644 --- a/drivers/input/touchscreen/stmfts.c +++ b/drivers/input/touchscreen/stmfts.c @@ -1,13 +1,8 @@ -/* - * Copyright (c) 2017 Samsung Electronics Co., Ltd. - * Author: Andi Shyti <andi.shyti@samsung.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation. - * - * STMicroelectronics FTS Touchscreen device driver - */ +// SPDX-License-Identifier: GPL-2.0 +// STMicroelectronics FTS Touchscreen device driver +// +// Copyright (c) 2017 Samsung Electronics Co., Ltd. +// Copyright (c) 2017 Andi Shyti <andi.shyti@samsung.com>  #include <linux/delay.h>  #include <linux/i2c.h> | 
