devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices
@ 2019-01-03 19:23 Marco Felsch
  2019-01-03 19:23 ` [PATCH 1/5] dt-bindings: Input: edt-ft5x06 - add support for FT5726 Marco Felsch
                   ` (5 more replies)
  0 siblings, 6 replies; 9+ messages in thread
From: Marco Felsch @ 2019-01-03 19:23 UTC (permalink / raw)
  To: dmitry.torokhov, robh+dt, mark.rutland
  Cc: devicetree, kernel, linux-input, hdegoede, simon.budig

This series adds the support for Evervision Focaltech based touchscreen
controllers. Evervision uses three different controllers, depending on
the display resolution, these are:
 - FT5306
 - FT5726
 - FT5C26.

It seems that the firmware for all controllers doesn't differ, but I
had only a FT5726 based device. So this series adds only the support
for those devices.

The Evervision vendor-prefix was added in an another patchset [1].

This patchset is based on the v4.20-rc1 tag.

[1] https://www.spinics.net/lists/devicetree/msg266938.html

Marco Felsch (5):
  dt-bindings: Input: edt-ft5x06 - add support for FT5726
  Input: edt-ft5x06 - add support for Evervision FT5726
  Input: edt-ft5x06 - Add support to update ev-ft5726 registers
  dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726
  Input: edt-ft5x06 - add offset support for ev-ft5726

 .../bindings/input/touchscreen/edt-ft5x06.txt |  13 ++-
 drivers/input/touchscreen/edt-ft5x06.c        | 110 ++++++++++++++++--
 2 files changed, 114 insertions(+), 9 deletions(-)

-- 
2.19.1

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [PATCH 1/5] dt-bindings: Input: edt-ft5x06 - add support for FT5726
  2019-01-03 19:23 [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Marco Felsch
@ 2019-01-03 19:23 ` Marco Felsch
  2019-01-11 17:02   ` Rob Herring
  2019-01-03 19:23 ` [PATCH 2/5] Input: edt-ft5x06 - add support for Evervision FT5726 Marco Felsch
                   ` (4 subsequent siblings)
  5 siblings, 1 reply; 9+ messages in thread
From: Marco Felsch @ 2019-01-03 19:23 UTC (permalink / raw)
  To: dmitry.torokhov, robh+dt, mark.rutland
  Cc: devicetree, kernel, linux-input, hdegoede, simon.budig

The FT5726 controller has up to 72 channels, 42 Tx-channels and 30
Rx-channels. The recommended touchpoint size is less equal 11.6".

This adds the support for the FT5726 controller flashed with the
Evervision firmware.

Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
---
 .../devicetree/bindings/input/touchscreen/edt-ft5x06.txt      | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt b/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt
index da2dc5d6c98b..179e434f5619 100644
--- a/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt
+++ b/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt
@@ -1,11 +1,12 @@
 FocalTech EDT-FT5x06 Polytouch driver
 =====================================
 
-There are 3 variants of the chip for various touch panel sizes
+There are 5 variants of the chip for various touch panel sizes
 FT5206GE1  2.8" .. 3.8"
 FT5306DE4  4.3" .. 7"
 FT5406EE8  7"   .. 8.9"
 FT5506EEG  7"   .. 8.9"
+FT5726NEI  5.7” .. 11.6"
 
 The software interface is identical for all those chips, so that
 currently there is no need for the driver to distinguish between the
@@ -19,6 +20,7 @@ Required properties:
            or:  "edt,edt-ft5306"
            or:  "edt,edt-ft5406"
            or:  "edt,edt-ft5506"
+           or:  "evervision,ev-ft5726"
            or:  "focaltech,ft6236"
 
  - reg:         I2C slave address of the chip (0x38)
-- 
2.19.1

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 2/5] Input: edt-ft5x06 - add support for Evervision FT5726
  2019-01-03 19:23 [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Marco Felsch
  2019-01-03 19:23 ` [PATCH 1/5] dt-bindings: Input: edt-ft5x06 - add support for FT5726 Marco Felsch
@ 2019-01-03 19:23 ` Marco Felsch
  2019-01-03 19:23 ` [PATCH 3/5] Input: edt-ft5x06 - Add support to update ev-ft5726 registers Marco Felsch
                   ` (3 subsequent siblings)
  5 siblings, 0 replies; 9+ messages in thread
From: Marco Felsch @ 2019-01-03 19:23 UTC (permalink / raw)
  To: dmitry.torokhov, robh+dt, mark.rutland
  Cc: devicetree, kernel, linux-input, hdegoede, simon.budig

Evervision displays are using different Focaltech touchscreen
controllers. This commit adds the initial support for the ones using the
FT5726 controller. Receiving the touch data is the same as for the
GENERIC_FT but the x and y cooridnates are swapped. The main differences
are the register addresses where the GAIN and THRESHOLD parameters are
stored.

Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
---
 drivers/input/touchscreen/edt-ft5x06.c | 44 ++++++++++++++++++++++++--
 1 file changed, 41 insertions(+), 3 deletions(-)

diff --git a/drivers/input/touchscreen/edt-ft5x06.c b/drivers/input/touchscreen/edt-ft5x06.c
index 1e18ca0d1b4e..1cd5b804a456 100644
--- a/drivers/input/touchscreen/edt-ft5x06.c
+++ b/drivers/input/touchscreen/edt-ft5x06.c
@@ -31,6 +31,7 @@
 #include <linux/interrupt.h>
 #include <linux/input.h>
 #include <linux/i2c.h>
+#include <linux/kernel.h>
 #include <linux/uaccess.h>
 #include <linux/delay.h>
 #include <linux/debugfs.h>
@@ -53,6 +54,9 @@
 #define M09_REGISTER_NUM_X		0x94
 #define M09_REGISTER_NUM_Y		0x95
 
+#define EV_REGISTER_THRESHOLD		0x40
+#define EV_REGISTER_GAIN		0x41
+
 #define NO_REGISTER			0xff
 
 #define WORK_REGISTER_OPMODE		0x3c
@@ -73,6 +77,7 @@ enum edt_ver {
 	EDT_M06,
 	EDT_M09,
 	EDT_M12,
+	EV_FT,
 	GENERIC_FT,
 };
 
@@ -190,6 +195,7 @@ static irqreturn_t edt_ft5x06_ts_isr(int irq, void *dev_id)
 
 	case EDT_M09:
 	case EDT_M12:
+	case EV_FT:
 	case GENERIC_FT:
 		cmd = 0x0;
 		offset = 3;
@@ -242,6 +248,10 @@ static irqreturn_t edt_ft5x06_ts_isr(int irq, void *dev_id)
 
 		x = ((buf[0] << 8) | buf[1]) & 0x0fff;
 		y = ((buf[2] << 8) | buf[3]) & 0x0fff;
+		/* The FT5x26 send the y coordinate first */
+		if (tsdata->version == EV_FT)
+			swap(x, y);
+
 		id = (buf[2] >> 4) & 0x0f;
 		down = type != TOUCH_EVENT_UP;
 
@@ -275,8 +285,10 @@ static int edt_ft5x06_register_write(struct edt_ft5x06_ts_data *tsdata,
 		wrbuf[3] = wrbuf[0] ^ wrbuf[1] ^ wrbuf[2];
 		return edt_ft5x06_ts_readwrite(tsdata->client, 4,
 					wrbuf, 0, NULL);
+	/* fallthrough */
 	case EDT_M09:
 	case EDT_M12:
+	case EV_FT:
 	case GENERIC_FT:
 		wrbuf[0] = addr;
 		wrbuf[1] = value;
@@ -315,8 +327,10 @@ static int edt_ft5x06_register_read(struct edt_ft5x06_ts_data *tsdata,
 		}
 		break;
 
+	/* fallthrough */
 	case EDT_M09:
 	case EDT_M12:
+	case EV_FT:
 	case GENERIC_FT:
 		wrbuf[0] = addr;
 		error = edt_ft5x06_ts_readwrite(tsdata->client, 1,
@@ -605,8 +619,9 @@ static int edt_ft5x06_work_mode(struct edt_ft5x06_ts_data *tsdata)
 				  tsdata->threshold);
 	edt_ft5x06_register_write(tsdata, reg_addr->reg_gain,
 				  tsdata->gain);
-	edt_ft5x06_register_write(tsdata, reg_addr->reg_offset,
-				  tsdata->offset);
+	if (reg_addr->reg_offset != NO_REGISTER)
+		edt_ft5x06_register_write(tsdata, reg_addr->reg_offset,
+					  tsdata->offset);
 	if (reg_addr->reg_report_rate != NO_REGISTER)
 		edt_ft5x06_register_write(tsdata, reg_addr->reg_report_rate,
 				  tsdata->report_rate);
@@ -867,6 +882,16 @@ static int edt_ft5x06_ts_identify(struct i2c_client *client,
 		case 0x5a:   /* Solomon Goldentek Display */
 			snprintf(model_name, EDT_NAME_LEN, "GKTW50SCED1R0");
 			break;
+		case 0x59:  /* Evervision Display with FT5xx6 TS */
+			tsdata->version = EV_FT;
+			error = edt_ft5x06_ts_readwrite(client, 1, "\x53",
+							1, rdbuf);
+			if (error)
+				return error;
+			strlcpy(fw_version, rdbuf, 1);
+			snprintf(model_name, EDT_NAME_LEN,
+				 "EVERVISION-FT5726NEi");
+			break;
 		default:
 			snprintf(model_name, EDT_NAME_LEN,
 				 "generic ft5x06 (%02x)",
@@ -912,7 +937,9 @@ edt_ft5x06_ts_get_parameters(struct edt_ft5x06_ts_data *tsdata)
 	tsdata->threshold = edt_ft5x06_register_read(tsdata,
 						     reg_addr->reg_threshold);
 	tsdata->gain = edt_ft5x06_register_read(tsdata, reg_addr->reg_gain);
-	tsdata->offset = edt_ft5x06_register_read(tsdata, reg_addr->reg_offset);
+	if (reg_addr->reg_offset != NO_REGISTER)
+		tsdata->offset =
+			edt_ft5x06_register_read(tsdata, reg_addr->reg_offset);
 	if (reg_addr->reg_report_rate != NO_REGISTER)
 		tsdata->report_rate = edt_ft5x06_register_read(tsdata,
 						reg_addr->reg_report_rate);
@@ -954,6 +981,15 @@ edt_ft5x06_ts_set_regs(struct edt_ft5x06_ts_data *tsdata)
 		reg_addr->reg_num_y = M09_REGISTER_NUM_Y;
 		break;
 
+	case EV_FT:
+		reg_addr->reg_threshold = EV_REGISTER_THRESHOLD;
+		reg_addr->reg_gain = EV_REGISTER_GAIN;
+		reg_addr->reg_offset = NO_REGISTER;
+		reg_addr->reg_num_x = NO_REGISTER;
+		reg_addr->reg_num_y = NO_REGISTER;
+		reg_addr->reg_report_rate = NO_REGISTER;
+		break;
+
 	case GENERIC_FT:
 		/* this is a guesswork */
 		reg_addr->reg_threshold = M09_REGISTER_THRESHOLD;
@@ -1155,6 +1191,7 @@ static const struct edt_i2c_chip_data edt_ft6236_data = {
 static const struct i2c_device_id edt_ft5x06_ts_id[] = {
 	{ .name = "edt-ft5x06", .driver_data = (long)&edt_ft5x06_data },
 	{ .name = "edt-ft5506", .driver_data = (long)&edt_ft5506_data },
+	{ .name = "ev-ft5726", .driver_data = (long)&edt_ft5506_data },
 	/* Note no edt- prefix for compatibility with the ft6236.c driver */
 	{ .name = "ft6236", .driver_data = (long)&edt_ft6236_data },
 	{ /* sentinel */ }
@@ -1167,6 +1204,7 @@ static const struct of_device_id edt_ft5x06_of_match[] = {
 	{ .compatible = "edt,edt-ft5306", .data = &edt_ft5x06_data },
 	{ .compatible = "edt,edt-ft5406", .data = &edt_ft5x06_data },
 	{ .compatible = "edt,edt-ft5506", .data = &edt_ft5506_data },
+	{ .compatible = "evervision,ev-ft5726", .data = &edt_ft5506_data },
 	/* Note focaltech vendor prefix for compatibility with ft6236.c */
 	{ .compatible = "focaltech,ft6236", .data = &edt_ft6236_data },
 	{ /* sentinel */ }
-- 
2.19.1

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 3/5] Input: edt-ft5x06 - Add support to update ev-ft5726 registers
  2019-01-03 19:23 [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Marco Felsch
  2019-01-03 19:23 ` [PATCH 1/5] dt-bindings: Input: edt-ft5x06 - add support for FT5726 Marco Felsch
  2019-01-03 19:23 ` [PATCH 2/5] Input: edt-ft5x06 - add support for Evervision FT5726 Marco Felsch
@ 2019-01-03 19:23 ` Marco Felsch
  2019-01-03 19:23 ` [PATCH 4/5] dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726 Marco Felsch
                   ` (2 subsequent siblings)
  5 siblings, 0 replies; 9+ messages in thread
From: Marco Felsch @ 2019-01-03 19:23 UTC (permalink / raw)
  To: dmitry.torokhov, robh+dt, mark.rutland
  Cc: devicetree, kernel, linux-input, hdegoede, simon.budig

Currently only the threshold and gain parameters can be read.

Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
---
 drivers/input/touchscreen/edt-ft5x06.c | 20 +++++++++++++++-----
 1 file changed, 15 insertions(+), 5 deletions(-)

diff --git a/drivers/input/touchscreen/edt-ft5x06.c b/drivers/input/touchscreen/edt-ft5x06.c
index 1cd5b804a456..a67915535b47 100644
--- a/drivers/input/touchscreen/edt-ft5x06.c
+++ b/drivers/input/touchscreen/edt-ft5x06.c
@@ -353,9 +353,10 @@ struct edt_ft5x06_attribute {
 	u8 limit_high;
 	u8 addr_m06;
 	u8 addr_m09;
+	u8 addr_ev;
 };
 
-#define EDT_ATTR(_field, _mode, _addr_m06, _addr_m09,			\
+#define EDT_ATTR(_field, _mode, _addr_m06, _addr_m09, _addr_ev,		\
 		_limit_low, _limit_high)				\
 	struct edt_ft5x06_attribute edt_ft5x06_attr_##_field = {	\
 		.dattr = __ATTR(_field, _mode,				\
@@ -364,6 +365,7 @@ struct edt_ft5x06_attribute {
 		.field_offset = offsetof(struct edt_ft5x06_ts_data, _field), \
 		.addr_m06 = _addr_m06,					\
 		.addr_m09 = _addr_m09,					\
+		.addr_ev  = _addr_ev,					\
 		.limit_low = _limit_low,				\
 		.limit_high = _limit_high,				\
 	}
@@ -400,6 +402,10 @@ static ssize_t edt_ft5x06_setting_show(struct device *dev,
 		addr = attr->addr_m09;
 		break;
 
+	case EV_FT:
+		addr = attr->addr_ev;
+		break;
+
 	default:
 		error = -ENODEV;
 		goto out;
@@ -471,6 +477,10 @@ static ssize_t edt_ft5x06_setting_store(struct device *dev,
 		addr = attr->addr_m09;
 		break;
 
+	case EV_FT:
+		addr = attr->addr_ev;
+		break;
+
 	default:
 		error = -ENODEV;
 		goto out;
@@ -494,16 +504,16 @@ static ssize_t edt_ft5x06_setting_store(struct device *dev,
 
 /* m06, m09: range 0-31, m12: range 0-5 */
 static EDT_ATTR(gain, S_IWUSR | S_IRUGO, WORK_REGISTER_GAIN,
-		M09_REGISTER_GAIN, 0, 31);
+		M09_REGISTER_GAIN, EV_REGISTER_GAIN, 0, 31);
 /* m06, m09: range 0-31, m12: range 0-16 */
 static EDT_ATTR(offset, S_IWUSR | S_IRUGO, WORK_REGISTER_OFFSET,
-		M09_REGISTER_OFFSET, 0, 31);
+		M09_REGISTER_OFFSET, NO_REGISTER, 0, 31);
 /* m06: range 20 to 80, m09: range 0 to 30, m12: range 1 to 255... */
 static EDT_ATTR(threshold, S_IWUSR | S_IRUGO, WORK_REGISTER_THRESHOLD,
-		M09_REGISTER_THRESHOLD, 0, 255);
+		M09_REGISTER_THRESHOLD, EV_REGISTER_THRESHOLD, 0, 255);
 /* m06: range 3 to 14, m12: (0x64: 100Hz) */
 static EDT_ATTR(report_rate, S_IWUSR | S_IRUGO, WORK_REGISTER_REPORT_RATE,
-		NO_REGISTER, 0, 255);
+		NO_REGISTER, NO_REGISTER, 0, 255);
 
 static struct attribute *edt_ft5x06_attrs[] = {
 	&edt_ft5x06_attr_gain.dattr.attr,
-- 
2.19.1

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 4/5] dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726
  2019-01-03 19:23 [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Marco Felsch
                   ` (2 preceding siblings ...)
  2019-01-03 19:23 ` [PATCH 3/5] Input: edt-ft5x06 - Add support to update ev-ft5726 registers Marco Felsch
@ 2019-01-03 19:23 ` Marco Felsch
  2019-01-11 17:04   ` Rob Herring
  2019-01-03 19:23 ` [PATCH 5/5] Input: edt-ft5x06 - add offset support for ev-ft5726 Marco Felsch
  2019-01-14  7:42 ` [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Dmitry Torokhov
  5 siblings, 1 reply; 9+ messages in thread
From: Marco Felsch @ 2019-01-03 19:23 UTC (permalink / raw)
  To: dmitry.torokhov, robh+dt, mark.rutland
  Cc: devicetree, kernel, linux-input, hdegoede, simon.budig

The evervision,ev-ft5726 devices has a more advanced offset support,
since they support setting the offset for the x and y position.

Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
---
 .../devicetree/bindings/input/touchscreen/edt-ft5x06.txt | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt b/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt
index 179e434f5619..870b8c5cce9b 100644
--- a/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt
+++ b/Documentation/devicetree/bindings/input/touchscreen/edt-ft5x06.txt
@@ -44,6 +44,15 @@ Optional properties:
 
  - offset:      allows setting the edge compensation in the range from
                 0 to 31.
+
+ - offset-x:    Same as offset, but applies only to the horizontal position.
+                Range from 0 to 80, only supported by evervision,ev-ft5726
+                devices.
+
+ - offset-y:    Same as offset, but applies only to the vertical position.
+                Range from 0 to 80, only supported by evervision,ev-ft5726
+                devices.
+
  - touchscreen-size-x	   : See touchscreen.txt
  - touchscreen-size-y	   : See touchscreen.txt
  - touchscreen-fuzz-x      : See touchscreen.txt
-- 
2.19.1

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 5/5] Input: edt-ft5x06 - add offset support for ev-ft5726
  2019-01-03 19:23 [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Marco Felsch
                   ` (3 preceding siblings ...)
  2019-01-03 19:23 ` [PATCH 4/5] dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726 Marco Felsch
@ 2019-01-03 19:23 ` Marco Felsch
  2019-01-14  7:42 ` [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Dmitry Torokhov
  5 siblings, 0 replies; 9+ messages in thread
From: Marco Felsch @ 2019-01-03 19:23 UTC (permalink / raw)
  To: dmitry.torokhov, robh+dt, mark.rutland
  Cc: devicetree, kernel, linux-input, hdegoede, simon.budig

Unfortunately the evervision focaltech implementation uses two offset
registers, one for the x coordinate and one for y.

This patch extends the driver to handle those offset registers only for
devices that support these.

Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
---
 drivers/input/touchscreen/edt-ft5x06.c | 46 ++++++++++++++++++++++++++
 1 file changed, 46 insertions(+)

diff --git a/drivers/input/touchscreen/edt-ft5x06.c b/drivers/input/touchscreen/edt-ft5x06.c
index a67915535b47..702bfda7ee77 100644
--- a/drivers/input/touchscreen/edt-ft5x06.c
+++ b/drivers/input/touchscreen/edt-ft5x06.c
@@ -56,6 +56,8 @@
 
 #define EV_REGISTER_THRESHOLD		0x40
 #define EV_REGISTER_GAIN		0x41
+#define EV_REGISTER_OFFSET_Y		0x45
+#define EV_REGISTER_OFFSET_X		0x46
 
 #define NO_REGISTER			0xff
 
@@ -86,6 +88,8 @@ struct edt_reg_addr {
 	int reg_report_rate;
 	int reg_gain;
 	int reg_offset;
+	int reg_offset_x;
+	int reg_offset_y;
 	int reg_num_x;
 	int reg_num_y;
 };
@@ -111,6 +115,8 @@ struct edt_ft5x06_ts_data {
 	int threshold;
 	int gain;
 	int offset;
+	int offset_x;
+	int offset_y;
 	int report_rate;
 	int max_support_points;
 
@@ -508,6 +514,12 @@ static EDT_ATTR(gain, S_IWUSR | S_IRUGO, WORK_REGISTER_GAIN,
 /* m06, m09: range 0-31, m12: range 0-16 */
 static EDT_ATTR(offset, S_IWUSR | S_IRUGO, WORK_REGISTER_OFFSET,
 		M09_REGISTER_OFFSET, NO_REGISTER, 0, 31);
+/* m06, m09, m12: no supported, ev_ft: range 0-80 */
+static EDT_ATTR(offset_x, S_IWUSR | S_IRUGO, NO_REGISTER, NO_REGISTER,
+		EV_REGISTER_OFFSET_X, 0, 80);
+/* m06, m09, m12: no supported, ev_ft: range 0-80 */
+static EDT_ATTR(offset_y, S_IWUSR | S_IRUGO, NO_REGISTER, NO_REGISTER,
+		EV_REGISTER_OFFSET_Y, 0, 80);
 /* m06: range 20 to 80, m09: range 0 to 30, m12: range 1 to 255... */
 static EDT_ATTR(threshold, S_IWUSR | S_IRUGO, WORK_REGISTER_THRESHOLD,
 		M09_REGISTER_THRESHOLD, EV_REGISTER_THRESHOLD, 0, 255);
@@ -518,6 +530,8 @@ static EDT_ATTR(report_rate, S_IWUSR | S_IRUGO, WORK_REGISTER_REPORT_RATE,
 static struct attribute *edt_ft5x06_attrs[] = {
 	&edt_ft5x06_attr_gain.dattr.attr,
 	&edt_ft5x06_attr_offset.dattr.attr,
+	&edt_ft5x06_attr_offset_x.dattr.attr,
+	&edt_ft5x06_attr_offset_y.dattr.attr,
 	&edt_ft5x06_attr_threshold.dattr.attr,
 	&edt_ft5x06_attr_report_rate.dattr.attr,
 	NULL
@@ -632,6 +646,12 @@ static int edt_ft5x06_work_mode(struct edt_ft5x06_ts_data *tsdata)
 	if (reg_addr->reg_offset != NO_REGISTER)
 		edt_ft5x06_register_write(tsdata, reg_addr->reg_offset,
 					  tsdata->offset);
+	if (reg_addr->reg_offset_x != NO_REGISTER)
+		edt_ft5x06_register_write(tsdata, reg_addr->reg_offset_x,
+					  tsdata->offset_x);
+	if (reg_addr->reg_offset_y != NO_REGISTER)
+		edt_ft5x06_register_write(tsdata, reg_addr->reg_offset_y,
+					  tsdata->offset_y);
 	if (reg_addr->reg_report_rate != NO_REGISTER)
 		edt_ft5x06_register_write(tsdata, reg_addr->reg_report_rate,
 				  tsdata->report_rate);
@@ -937,6 +957,18 @@ static void edt_ft5x06_ts_get_defaults(struct device *dev,
 		edt_ft5x06_register_write(tsdata, reg_addr->reg_offset, val);
 		tsdata->offset = val;
 	}
+
+	error = device_property_read_u32(dev, "offset-x", &val);
+	if (!error) {
+		edt_ft5x06_register_write(tsdata, reg_addr->reg_offset_x, val);
+		tsdata->offset_x = val;
+	}
+
+	error = device_property_read_u32(dev, "offset-y", &val);
+	if (!error) {
+		edt_ft5x06_register_write(tsdata, reg_addr->reg_offset_y, val);
+		tsdata->offset_y = val;
+	}
 }
 
 static void
@@ -950,6 +982,12 @@ edt_ft5x06_ts_get_parameters(struct edt_ft5x06_ts_data *tsdata)
 	if (reg_addr->reg_offset != NO_REGISTER)
 		tsdata->offset =
 			edt_ft5x06_register_read(tsdata, reg_addr->reg_offset);
+	if (reg_addr->reg_offset_x != NO_REGISTER)
+		tsdata->offset_x = edt_ft5x06_register_read(tsdata,
+						reg_addr->reg_offset_x);
+	if (reg_addr->reg_offset_y != NO_REGISTER)
+		tsdata->offset_y = edt_ft5x06_register_read(tsdata,
+						reg_addr->reg_offset_y);
 	if (reg_addr->reg_report_rate != NO_REGISTER)
 		tsdata->report_rate = edt_ft5x06_register_read(tsdata,
 						reg_addr->reg_report_rate);
@@ -977,6 +1015,8 @@ edt_ft5x06_ts_set_regs(struct edt_ft5x06_ts_data *tsdata)
 		reg_addr->reg_report_rate = WORK_REGISTER_REPORT_RATE;
 		reg_addr->reg_gain = WORK_REGISTER_GAIN;
 		reg_addr->reg_offset = WORK_REGISTER_OFFSET;
+		reg_addr->reg_offset_x = NO_REGISTER;
+		reg_addr->reg_offset_y = NO_REGISTER;
 		reg_addr->reg_num_x = WORK_REGISTER_NUM_X;
 		reg_addr->reg_num_y = WORK_REGISTER_NUM_Y;
 		break;
@@ -987,6 +1027,8 @@ edt_ft5x06_ts_set_regs(struct edt_ft5x06_ts_data *tsdata)
 		reg_addr->reg_report_rate = NO_REGISTER;
 		reg_addr->reg_gain = M09_REGISTER_GAIN;
 		reg_addr->reg_offset = M09_REGISTER_OFFSET;
+		reg_addr->reg_offset_x = NO_REGISTER;
+		reg_addr->reg_offset_y = NO_REGISTER;
 		reg_addr->reg_num_x = M09_REGISTER_NUM_X;
 		reg_addr->reg_num_y = M09_REGISTER_NUM_Y;
 		break;
@@ -995,6 +1037,8 @@ edt_ft5x06_ts_set_regs(struct edt_ft5x06_ts_data *tsdata)
 		reg_addr->reg_threshold = EV_REGISTER_THRESHOLD;
 		reg_addr->reg_gain = EV_REGISTER_GAIN;
 		reg_addr->reg_offset = NO_REGISTER;
+		reg_addr->reg_offset_x = EV_REGISTER_OFFSET_X;
+		reg_addr->reg_offset_y = EV_REGISTER_OFFSET_Y;
 		reg_addr->reg_num_x = NO_REGISTER;
 		reg_addr->reg_num_y = NO_REGISTER;
 		reg_addr->reg_report_rate = NO_REGISTER;
@@ -1005,6 +1049,8 @@ edt_ft5x06_ts_set_regs(struct edt_ft5x06_ts_data *tsdata)
 		reg_addr->reg_threshold = M09_REGISTER_THRESHOLD;
 		reg_addr->reg_gain = M09_REGISTER_GAIN;
 		reg_addr->reg_offset = M09_REGISTER_OFFSET;
+		reg_addr->reg_offset_x = NO_REGISTER;
+		reg_addr->reg_offset_y = NO_REGISTER;
 		break;
 	}
 }
-- 
2.19.1

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* Re: [PATCH 1/5] dt-bindings: Input: edt-ft5x06 - add support for FT5726
  2019-01-03 19:23 ` [PATCH 1/5] dt-bindings: Input: edt-ft5x06 - add support for FT5726 Marco Felsch
@ 2019-01-11 17:02   ` Rob Herring
  0 siblings, 0 replies; 9+ messages in thread
From: Rob Herring @ 2019-01-11 17:02 UTC (permalink / raw)
  To: Marco Felsch
  Cc: dmitry.torokhov, robh+dt, mark.rutland, devicetree, kernel,
	linux-input, hdegoede, simon.budig

On Thu,  3 Jan 2019 20:23:23 +0100, Marco Felsch wrote:
> The FT5726 controller has up to 72 channels, 42 Tx-channels and 30
> Rx-channels. The recommended touchpoint size is less equal 11.6".
> 
> This adds the support for the FT5726 controller flashed with the
> Evervision firmware.
> 
> Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
> ---
>  .../devicetree/bindings/input/touchscreen/edt-ft5x06.txt      | 4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
> 

Reviewed-by: Rob Herring <robh@kernel.org>

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH 4/5] dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726
  2019-01-03 19:23 ` [PATCH 4/5] dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726 Marco Felsch
@ 2019-01-11 17:04   ` Rob Herring
  0 siblings, 0 replies; 9+ messages in thread
From: Rob Herring @ 2019-01-11 17:04 UTC (permalink / raw)
  To: Marco Felsch
  Cc: dmitry.torokhov, robh+dt, mark.rutland, devicetree, kernel,
	linux-input, hdegoede, simon.budig

On Thu,  3 Jan 2019 20:23:26 +0100, Marco Felsch wrote:
> The evervision,ev-ft5726 devices has a more advanced offset support,
> since they support setting the offset for the x and y position.
> 
> Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
> ---
>  .../devicetree/bindings/input/touchscreen/edt-ft5x06.txt | 9 +++++++++
>  1 file changed, 9 insertions(+)
> 

Reviewed-by: Rob Herring <robh@kernel.org>

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices
  2019-01-03 19:23 [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Marco Felsch
                   ` (4 preceding siblings ...)
  2019-01-03 19:23 ` [PATCH 5/5] Input: edt-ft5x06 - add offset support for ev-ft5726 Marco Felsch
@ 2019-01-14  7:42 ` Dmitry Torokhov
  5 siblings, 0 replies; 9+ messages in thread
From: Dmitry Torokhov @ 2019-01-14  7:42 UTC (permalink / raw)
  To: Marco Felsch
  Cc: robh+dt, mark.rutland, devicetree, kernel, linux-input, hdegoede,
	simon.budig

On Thu, Jan 03, 2019 at 08:23:22PM +0100, Marco Felsch wrote:
> This series adds the support for Evervision Focaltech based touchscreen
> controllers. Evervision uses three different controllers, depending on
> the display resolution, these are:
>  - FT5306
>  - FT5726
>  - FT5C26.
> 
> It seems that the firmware for all controllers doesn't differ, but I
> had only a FT5726 based device. So this series adds only the support
> for those devices.
> 
> The Evervision vendor-prefix was added in an another patchset [1].
> 
> This patchset is based on the v4.20-rc1 tag.
> 
> [1] https://www.spinics.net/lists/devicetree/msg266938.html
> 
> Marco Felsch (5):
>   dt-bindings: Input: edt-ft5x06 - add support for FT5726
>   Input: edt-ft5x06 - add support for Evervision FT5726
>   Input: edt-ft5x06 - Add support to update ev-ft5726 registers
>   dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726
>   Input: edt-ft5x06 - add offset support for ev-ft5726
> 
>  .../bindings/input/touchscreen/edt-ft5x06.txt |  13 ++-
>  drivers/input/touchscreen/edt-ft5x06.c        | 110 ++++++++++++++++--
>  2 files changed, 114 insertions(+), 9 deletions(-)

Applied the lot, thank you.

-- 
Dmitry

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2019-01-14  7:42 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-01-03 19:23 [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Marco Felsch
2019-01-03 19:23 ` [PATCH 1/5] dt-bindings: Input: edt-ft5x06 - add support for FT5726 Marco Felsch
2019-01-11 17:02   ` Rob Herring
2019-01-03 19:23 ` [PATCH 2/5] Input: edt-ft5x06 - add support for Evervision FT5726 Marco Felsch
2019-01-03 19:23 ` [PATCH 3/5] Input: edt-ft5x06 - Add support to update ev-ft5726 registers Marco Felsch
2019-01-03 19:23 ` [PATCH 4/5] dt-bindings: Input: edt-ft5x06 - add offset bindings for ft5726 Marco Felsch
2019-01-11 17:04   ` Rob Herring
2019-01-03 19:23 ` [PATCH 5/5] Input: edt-ft5x06 - add offset support for ev-ft5726 Marco Felsch
2019-01-14  7:42 ` [PATCH 0/5] Input: edt-ft5x06 - Add support for Evervision FT devices Dmitry Torokhov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).