Skip to content

Commit

Permalink
Input: elan_i2c - add new trackpoint report type 0x5F
Browse files Browse the repository at this point in the history
commit 056115d upstream.

The 0x5F is a new trackpoint report type used by some modules.

Signed-off-by: Jingle Wu <jingle.wu@emc.com.tw>
Link: https://lore.kernel.org/r/20201211071511.32349-1-jingle.wu@emc.com.tw
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Cc: Nikolai Kostrigin <nickel@basealt.ru>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
  • Loading branch information
jinglewu authored and gregkh committed Mar 7, 2021
1 parent dde807b commit a4b0bfb
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 14 deletions.
16 changes: 16 additions & 0 deletions drivers/input/mouse/elan_i2c.h
Expand Up @@ -28,6 +28,22 @@

#define ETP_FEATURE_REPORT_MK BIT(0)

#define ETP_REPORT_ID 0x5D
#define ETP_TP_REPORT_ID 0x5E
#define ETP_TP_REPORT_ID2 0x5F
#define ETP_REPORT_ID2 0x60 /* High precision report */

#define ETP_REPORT_ID_OFFSET 2
#define ETP_TOUCH_INFO_OFFSET 3
#define ETP_FINGER_DATA_OFFSET 4
#define ETP_HOVER_INFO_OFFSET 30
#define ETP_MK_DATA_OFFSET 33 /* For high precision reports */

#define ETP_MAX_REPORT_LEN 39

#define ETP_MAX_FINGERS 5
#define ETP_FINGER_DATA_LEN 5

/* IAP Firmware handling */
#define ETP_PRODUCT_ID_FORMAT_STRING "%d.0"
#define ETP_FW_NAME "elan_i2c_" ETP_PRODUCT_ID_FORMAT_STRING ".bin"
Expand Down
13 changes: 1 addition & 12 deletions drivers/input/mouse/elan_i2c_core.c
Expand Up @@ -47,18 +47,6 @@
#define ETP_FINGER_WIDTH 15
#define ETP_RETRY_COUNT 3

#define ETP_MAX_FINGERS 5
#define ETP_FINGER_DATA_LEN 5
#define ETP_REPORT_ID 0x5D
#define ETP_REPORT_ID2 0x60 /* High precision report */
#define ETP_TP_REPORT_ID 0x5E
#define ETP_REPORT_ID_OFFSET 2
#define ETP_TOUCH_INFO_OFFSET 3
#define ETP_FINGER_DATA_OFFSET 4
#define ETP_HOVER_INFO_OFFSET 30
#define ETP_MK_DATA_OFFSET 33 /* For high precision reports */
#define ETP_MAX_REPORT_LEN 39

/* The main device structure */
struct elan_tp_data {
struct i2c_client *client;
Expand Down Expand Up @@ -1076,6 +1064,7 @@ static irqreturn_t elan_isr(int irq, void *dev_id)
elan_report_absolute(data, report, true);
break;
case ETP_TP_REPORT_ID:
case ETP_TP_REPORT_ID2:
elan_report_trackpoint(data, report);
break;
default:
Expand Down
8 changes: 6 additions & 2 deletions drivers/input/mouse/elan_i2c_smbus.c
Expand Up @@ -45,6 +45,7 @@
#define ETP_SMBUS_CALIBRATE_QUERY 0xC5

#define ETP_SMBUS_REPORT_LEN 32
#define ETP_SMBUS_REPORT_LEN2 7
#define ETP_SMBUS_REPORT_OFFSET 2
#define ETP_SMBUS_HELLOPACKET_LEN 5
#define ETP_SMBUS_IAP_PASSWORD 0x1234
Expand Down Expand Up @@ -497,10 +498,13 @@ static int elan_smbus_get_report(struct i2c_client *client,
return len;
}

if (len != ETP_SMBUS_REPORT_LEN) {
if (report[ETP_REPORT_ID_OFFSET] == ETP_TP_REPORT_ID2)
report_len = ETP_SMBUS_REPORT_LEN2;

if (len != report_len) {
dev_err(&client->dev,
"wrong report length (%d vs %d expected)\n",
len, ETP_SMBUS_REPORT_LEN);
len, report_len);
return -EIO;
}

Expand Down

0 comments on commit a4b0bfb

Please sign in to comment.