aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/input
diff options
context:
space:
mode:
authorMarco Felsch <m.felsch@pengutronix.de>2019-01-14 02:10:22 -0500
committerDmitry Torokhov <dmitry.torokhov@gmail.com>2019-01-14 02:13:27 -0500
commit2ebc1919e9a9812903ab684cc53862015987e7a0 (patch)
tree37d8e54927b51372d518b212033de3ecb495c4c1 /drivers/input
parenta2f39dac0decd9943ba14e14fb58535bb149fd4e (diff)
Input: edt-ft5x06 - add support to update ev-ft5726 registers
Currently only the threshold and gain parameters can be read. Signed-off-by: Marco Felsch <m.felsch@pengutronix.de> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Diffstat (limited to 'drivers/input')
-rw-r--r--drivers/input/touchscreen/edt-ft5x06.c20
1 files 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 {
353 u8 limit_high; 353 u8 limit_high;
354 u8 addr_m06; 354 u8 addr_m06;
355 u8 addr_m09; 355 u8 addr_m09;
356 u8 addr_ev;
356}; 357};
357 358
358#define EDT_ATTR(_field, _mode, _addr_m06, _addr_m09, \ 359#define EDT_ATTR(_field, _mode, _addr_m06, _addr_m09, _addr_ev, \
359 _limit_low, _limit_high) \ 360 _limit_low, _limit_high) \
360 struct edt_ft5x06_attribute edt_ft5x06_attr_##_field = { \ 361 struct edt_ft5x06_attribute edt_ft5x06_attr_##_field = { \
361 .dattr = __ATTR(_field, _mode, \ 362 .dattr = __ATTR(_field, _mode, \
@@ -364,6 +365,7 @@ struct edt_ft5x06_attribute {
364 .field_offset = offsetof(struct edt_ft5x06_ts_data, _field), \ 365 .field_offset = offsetof(struct edt_ft5x06_ts_data, _field), \
365 .addr_m06 = _addr_m06, \ 366 .addr_m06 = _addr_m06, \
366 .addr_m09 = _addr_m09, \ 367 .addr_m09 = _addr_m09, \
368 .addr_ev = _addr_ev, \
367 .limit_low = _limit_low, \ 369 .limit_low = _limit_low, \
368 .limit_high = _limit_high, \ 370 .limit_high = _limit_high, \
369 } 371 }
@@ -400,6 +402,10 @@ static ssize_t edt_ft5x06_setting_show(struct device *dev,
400 addr = attr->addr_m09; 402 addr = attr->addr_m09;
401 break; 403 break;
402 404
405 case EV_FT:
406 addr = attr->addr_ev;
407 break;
408
403 default: 409 default:
404 error = -ENODEV; 410 error = -ENODEV;
405 goto out; 411 goto out;
@@ -471,6 +477,10 @@ static ssize_t edt_ft5x06_setting_store(struct device *dev,
471 addr = attr->addr_m09; 477 addr = attr->addr_m09;
472 break; 478 break;
473 479
480 case EV_FT:
481 addr = attr->addr_ev;
482 break;
483
474 default: 484 default:
475 error = -ENODEV; 485 error = -ENODEV;
476 goto out; 486 goto out;
@@ -494,16 +504,16 @@ out:
494 504
495/* m06, m09: range 0-31, m12: range 0-5 */ 505/* m06, m09: range 0-31, m12: range 0-5 */
496static EDT_ATTR(gain, S_IWUSR | S_IRUGO, WORK_REGISTER_GAIN, 506static EDT_ATTR(gain, S_IWUSR | S_IRUGO, WORK_REGISTER_GAIN,
497 M09_REGISTER_GAIN, 0, 31); 507 M09_REGISTER_GAIN, EV_REGISTER_GAIN, 0, 31);
498/* m06, m09: range 0-31, m12: range 0-16 */ 508/* m06, m09: range 0-31, m12: range 0-16 */
499static EDT_ATTR(offset, S_IWUSR | S_IRUGO, WORK_REGISTER_OFFSET, 509static EDT_ATTR(offset, S_IWUSR | S_IRUGO, WORK_REGISTER_OFFSET,
500 M09_REGISTER_OFFSET, 0, 31); 510 M09_REGISTER_OFFSET, NO_REGISTER, 0, 31);
501/* m06: range 20 to 80, m09: range 0 to 30, m12: range 1 to 255... */ 511/* m06: range 20 to 80, m09: range 0 to 30, m12: range 1 to 255... */
502static EDT_ATTR(threshold, S_IWUSR | S_IRUGO, WORK_REGISTER_THRESHOLD, 512static EDT_ATTR(threshold, S_IWUSR | S_IRUGO, WORK_REGISTER_THRESHOLD,
503 M09_REGISTER_THRESHOLD, 0, 255); 513 M09_REGISTER_THRESHOLD, EV_REGISTER_THRESHOLD, 0, 255);
504/* m06: range 3 to 14, m12: (0x64: 100Hz) */ 514/* m06: range 3 to 14, m12: (0x64: 100Hz) */
505static EDT_ATTR(report_rate, S_IWUSR | S_IRUGO, WORK_REGISTER_REPORT_RATE, 515static EDT_ATTR(report_rate, S_IWUSR | S_IRUGO, WORK_REGISTER_REPORT_RATE,
506 NO_REGISTER, 0, 255); 516 NO_REGISTER, NO_REGISTER, 0, 255);
507 517
508static struct attribute *edt_ft5x06_attrs[] = { 518static struct attribute *edt_ft5x06_attrs[] = {
509 &edt_ft5x06_attr_gain.dattr.attr, 519 &edt_ft5x06_attr_gain.dattr.attr,