xref: /linux/drivers/hid/hid-goodix-spi.c (revision cc4332afb5631b0e9d2ce5699b7f4b7caf743526)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * Goodix GT7986U SPI Driver Code for HID.
4  *
5  * Copyright (C) 2024 Godix, Inc.
6  */
7 #include <asm/unaligned.h>
8 #include <linux/delay.h>
9 #include <linux/hid.h>
10 #include <linux/interrupt.h>
11 #include <linux/kernel.h>
12 #include <linux/module.h>
13 #include <linux/mutex.h>
14 #include <linux/of.h>
15 #include <linux/sizes.h>
16 #include <linux/spi/spi.h>
17 
18 #define GOODIX_DEV_CONFIRM_ADDR		0x10000
19 #define GOODIX_HID_DESC_ADDR		0x1058C
20 #define GOODIX_HID_REPORT_DESC_ADDR	0x105AA
21 #define GOODIX_HID_SIGN_ADDR		0x10D32
22 
23 #define GOODIX_HID_GET_REPORT_CMD	0x02
24 #define GOODIX_HID_SET_REPORT_CMD	0x03
25 
26 #define GOODIX_HID_MAX_INBUF_SIZE	128
27 #define GOODIX_HID_ACK_READY_FLAG	0x01
28 #define GOODIX_HID_REPORT_READY_FLAG	0x80
29 
30 #define GOODIX_DEV_CONFIRM_VAL		0xAA
31 
32 #define GOODIX_SPI_WRITE_FLAG		0xF0
33 #define GOODIX_SPI_READ_FLAG		0xF1
34 #define GOODIX_SPI_TRANS_PREFIX_LEN	1
35 #define GOODIX_REGISTER_WIDTH		4
36 #define GOODIX_SPI_READ_DUMMY_LEN	3
37 #define GOODIX_SPI_READ_PREFIX_LEN	(GOODIX_SPI_TRANS_PREFIX_LEN + \
38 					 GOODIX_REGISTER_WIDTH + \
39 					 GOODIX_SPI_READ_DUMMY_LEN)
40 #define GOODIX_SPI_WRITE_PREFIX_LEN	(GOODIX_SPI_TRANS_PREFIX_LEN + \
41 					 GOODIX_REGISTER_WIDTH)
42 
43 #define GOODIX_CHECKSUM_SIZE		sizeof(u16)
44 #define GOODIX_NORMAL_RESET_DELAY_MS	150
45 
46 struct goodix_hid_report_header {
47 	u8 flag;
48 	__le16 size;
49 } __packed;
50 #define GOODIX_HID_ACK_HEADER_SIZE	sizeof(struct goodix_hid_report_header)
51 
52 struct goodix_hid_report_package {
53 	__le16 size;
54 	u8 data[];
55 };
56 
57 #define GOODIX_HID_PKG_LEN_SIZE		sizeof(u16)
58 #define GOODIX_HID_COOR_DATA_LEN	82
59 #define GOODIX_HID_COOR_PKG_LEN		(GOODIX_HID_PKG_LEN_SIZE + \
60 					 GOODIX_HID_COOR_DATA_LEN)
61 
62 /* power state */
63 #define GOODIX_SPI_POWER_ON		0x00
64 #define GOODIX_SPI_POWER_SLEEP		0x01
65 
66 /* flags used to record the current device operating state */
67 #define GOODIX_HID_STARTED		0
68 
69 struct goodix_hid_report_event {
70 	struct goodix_hid_report_header hdr;
71 	u8 data[GOODIX_HID_COOR_PKG_LEN];
72 } __packed;
73 
74 struct goodix_hid_desc {
75 	__le16 desc_length;
76 	__le16 bcd_version;
77 	__le16 report_desc_length;
78 	__le16 report_desc_register;
79 	__le16 input_register;
80 	__le16 max_input_length;
81 	__le16 output_register;
82 	__le16 max_output_length;
83 	__le16 cmd_register;
84 	__le16 data_register;
85 	__le16 vendor_id;
86 	__le16 product_id;
87 	__le16 version_id;
88 	__le32 reserved;
89 } __packed;
90 
91 struct goodix_ts_data {
92 	struct device *dev;
93 	struct spi_device *spi;
94 	struct hid_device *hid;
95 	struct goodix_hid_desc hid_desc;
96 
97 	struct gpio_desc *reset_gpio;
98 	u32 hid_report_addr;
99 
100 	unsigned long flags;
101 	/* lock for hid raw request operation */
102 	struct mutex hid_request_lock;
103 	/* buffer used to store hid report event */
104 	u8 *event_buf;
105 	u32 hid_max_event_sz;
106 	/* buffer used to do spi data transfer */
107 	u8 xfer_buf[SZ_2K] ____cacheline_aligned;
108 };
109 
110 static void *goodix_get_event_report(struct goodix_ts_data *ts, u32 addr,
111 				     u8 *data, size_t len)
112 {
113 	struct spi_device *spi = to_spi_device(&ts->spi->dev);
114 	struct spi_transfer xfers;
115 	struct spi_message spi_msg;
116 	int error;
117 
118 	/* buffer format: 0xF1 + addr(4bytes) + dummy(3bytes) + data */
119 	data[0] = GOODIX_SPI_READ_FLAG;
120 	put_unaligned_be32(addr, data + GOODIX_SPI_TRANS_PREFIX_LEN);
121 
122 	spi_message_init(&spi_msg);
123 	memset(&xfers, 0, sizeof(xfers));
124 	xfers.tx_buf = data;
125 	xfers.rx_buf = data;
126 	xfers.len = GOODIX_SPI_READ_PREFIX_LEN + len;
127 	spi_message_add_tail(&xfers, &spi_msg);
128 
129 	error = spi_sync(spi, &spi_msg);
130 	if (error) {
131 		dev_err(ts->dev, "spi transfer error: %d", error);
132 		return NULL;
133 	}
134 
135 	return data + GOODIX_SPI_READ_PREFIX_LEN;
136 }
137 
138 static int goodix_spi_read(struct goodix_ts_data *ts, u32 addr,
139 			   void *data, size_t len)
140 {
141 	struct spi_device *spi = to_spi_device(&ts->spi->dev);
142 	struct spi_transfer xfers;
143 	struct spi_message spi_msg;
144 	int error;
145 
146 	if (GOODIX_SPI_READ_PREFIX_LEN + len > sizeof(ts->xfer_buf)) {
147 		dev_err(ts->dev, "read data len exceed limit %zu",
148 			sizeof(ts->xfer_buf) - GOODIX_SPI_READ_PREFIX_LEN);
149 		return -EINVAL;
150 	}
151 
152 	/* buffer format: 0xF1 + addr(4bytes) + dummy(3bytes) + data */
153 	ts->xfer_buf[0] = GOODIX_SPI_READ_FLAG;
154 	put_unaligned_be32(addr, ts->xfer_buf + GOODIX_SPI_TRANS_PREFIX_LEN);
155 
156 	spi_message_init(&spi_msg);
157 	memset(&xfers, 0, sizeof(xfers));
158 	xfers.tx_buf = ts->xfer_buf;
159 	xfers.rx_buf = ts->xfer_buf;
160 	xfers.len = GOODIX_SPI_READ_PREFIX_LEN + len;
161 	spi_message_add_tail(&xfers, &spi_msg);
162 
163 	error = spi_sync(spi, &spi_msg);
164 	if (error)
165 		dev_err(ts->dev, "spi transfer error: %d", error);
166 	else
167 		memcpy(data, ts->xfer_buf + GOODIX_SPI_READ_PREFIX_LEN, len);
168 
169 	return error;
170 }
171 
172 static int goodix_spi_write(struct goodix_ts_data *ts, u32 addr,
173 			    const void *data, size_t len)
174 {
175 	struct spi_device *spi = to_spi_device(&ts->spi->dev);
176 	struct spi_transfer xfers;
177 	struct spi_message spi_msg;
178 	int error;
179 
180 	if (GOODIX_SPI_WRITE_PREFIX_LEN + len > sizeof(ts->xfer_buf)) {
181 		dev_err(ts->dev, "write data len exceed limit %zu",
182 			sizeof(ts->xfer_buf) - GOODIX_SPI_WRITE_PREFIX_LEN);
183 		return -EINVAL;
184 	}
185 
186 	/* buffer format: 0xF0 + addr(4bytes) + data */
187 	ts->xfer_buf[0] = GOODIX_SPI_WRITE_FLAG;
188 	put_unaligned_be32(addr, ts->xfer_buf + GOODIX_SPI_TRANS_PREFIX_LEN);
189 	memcpy(ts->xfer_buf + GOODIX_SPI_WRITE_PREFIX_LEN, data, len);
190 
191 	spi_message_init(&spi_msg);
192 	memset(&xfers, 0, sizeof(xfers));
193 	xfers.tx_buf = ts->xfer_buf;
194 	xfers.len = GOODIX_SPI_WRITE_PREFIX_LEN + len;
195 	spi_message_add_tail(&xfers, &spi_msg);
196 
197 	error = spi_sync(spi, &spi_msg);
198 	if (error)
199 		dev_err(ts->dev, "spi transfer error: %d", error);
200 
201 	return error;
202 }
203 
204 static int goodix_dev_confirm(struct goodix_ts_data *ts)
205 {
206 	u8 tx_buf[8], rx_buf[8];
207 	int retry = 3;
208 	int error;
209 
210 	gpiod_set_value_cansleep(ts->reset_gpio, 0);
211 	usleep_range(4000, 4100);
212 
213 	memset(tx_buf, GOODIX_DEV_CONFIRM_VAL, sizeof(tx_buf));
214 	while (retry--) {
215 		error = goodix_spi_write(ts, GOODIX_DEV_CONFIRM_ADDR,
216 					 tx_buf, sizeof(tx_buf));
217 		if (error)
218 			return error;
219 
220 		error = goodix_spi_read(ts, GOODIX_DEV_CONFIRM_ADDR,
221 					rx_buf, sizeof(rx_buf));
222 		if (error)
223 			return error;
224 
225 		if (!memcmp(tx_buf, rx_buf, sizeof(tx_buf)))
226 			return 0;
227 
228 		usleep_range(5000, 5100);
229 	}
230 
231 	dev_err(ts->dev, "device confirm failed, rx_buf: %*ph", 8, rx_buf);
232 	return -EINVAL;
233 }
234 
235 /**
236  * goodix_hid_parse() - hid-core .parse() callback
237  * @hid: hid device instance
238  *
239  * This function gets called during call to hid_add_device
240  *
241  * Return: 0 on success and non zero on error
242  */
243 static int goodix_hid_parse(struct hid_device *hid)
244 {
245 	struct goodix_ts_data *ts = hid->driver_data;
246 	u16 rsize;
247 	int error;
248 
249 	rsize = le16_to_cpu(ts->hid_desc.report_desc_length);
250 	if (!rsize || rsize > HID_MAX_DESCRIPTOR_SIZE) {
251 		dev_err(ts->dev, "invalid report desc size, %d", rsize);
252 		return -EINVAL;
253 	}
254 
255 	u8 *rdesc __free(kfree) = kzalloc(rsize, GFP_KERNEL);
256 	if (!rdesc)
257 		return -ENOMEM;
258 
259 	error = goodix_spi_read(ts, GOODIX_HID_REPORT_DESC_ADDR, rdesc, rsize);
260 	if (error) {
261 		dev_err(ts->dev, "failed get report desc, %d", error);
262 		return error;
263 	}
264 
265 	error = hid_parse_report(hid, rdesc, rsize);
266 	if (error) {
267 		dev_err(ts->dev, "failed parse report, %d", error);
268 		return error;
269 	}
270 
271 	return 0;
272 }
273 
274 static int goodix_hid_get_report_length(struct hid_report *report)
275 {
276 	return ((report->size - 1) >> 3) + 1 +
277 		report->device->report_enum[report->type].numbered + 2;
278 }
279 
280 static void goodix_hid_find_max_report(struct hid_device *hid, unsigned int type,
281 				       unsigned int *max)
282 {
283 	struct hid_report *report;
284 	unsigned int size;
285 
286 	list_for_each_entry(report, &hid->report_enum[type].report_list, list) {
287 		size = goodix_hid_get_report_length(report);
288 		if (*max < size)
289 			*max = size;
290 	}
291 }
292 
293 static int goodix_hid_start(struct hid_device *hid)
294 {
295 	struct goodix_ts_data *ts = hid->driver_data;
296 	unsigned int bufsize = GOODIX_HID_COOR_PKG_LEN;
297 	u32 report_size;
298 
299 	goodix_hid_find_max_report(hid, HID_INPUT_REPORT, &bufsize);
300 	goodix_hid_find_max_report(hid, HID_OUTPUT_REPORT, &bufsize);
301 	goodix_hid_find_max_report(hid, HID_FEATURE_REPORT, &bufsize);
302 
303 	report_size = GOODIX_SPI_READ_PREFIX_LEN +
304 			GOODIX_HID_ACK_HEADER_SIZE + bufsize;
305 	if (report_size <= ts->hid_max_event_sz)
306 		return 0;
307 
308 	ts->event_buf = devm_krealloc(ts->dev, ts->event_buf,
309 				      report_size, GFP_KERNEL);
310 	if (!ts->event_buf)
311 		return -ENOMEM;
312 
313 	ts->hid_max_event_sz = report_size;
314 	return 0;
315 }
316 
317 static void goodix_hid_stop(struct hid_device *hid)
318 {
319 	hid->claimed = 0;
320 }
321 
322 static int goodix_hid_open(struct hid_device *hid)
323 {
324 	struct goodix_ts_data *ts = hid->driver_data;
325 
326 	set_bit(GOODIX_HID_STARTED, &ts->flags);
327 	return 0;
328 }
329 
330 static void goodix_hid_close(struct hid_device *hid)
331 {
332 	struct goodix_ts_data *ts = hid->driver_data;
333 
334 	clear_bit(GOODIX_HID_STARTED, &ts->flags);
335 }
336 
337 /* Return date length of response data */
338 static int goodix_hid_check_ack_status(struct goodix_ts_data *ts, u32 *resp_len)
339 {
340 	struct goodix_hid_report_header hdr;
341 	int retry = 20;
342 	int error;
343 	int len;
344 
345 	while (retry--) {
346 		/*
347 		 * 3 bytes of hid request response data
348 		 * - byte 0:    Ack flag, value of 1 for data ready
349 		 * - bytes 1-2: Response data length
350 		 */
351 		error = goodix_spi_read(ts, ts->hid_report_addr,
352 					&hdr, sizeof(hdr));
353 		if (!error && (hdr.flag & GOODIX_HID_ACK_READY_FLAG)) {
354 			len = le16_to_cpu(hdr.size);
355 			if (len < GOODIX_HID_PKG_LEN_SIZE) {
356 				dev_err(ts->dev, "hrd.size too short: %d", len);
357 				return -EINVAL;
358 			}
359 			*resp_len = len;
360 			return 0;
361 		}
362 
363 		/* Wait 10ms for another try */
364 		usleep_range(10000, 11000);
365 	}
366 
367 	return -EINVAL;
368 }
369 
370 /**
371  * goodix_hid_get_raw_report() - Process hidraw GET REPORT operation
372  * @hid: hid device instance
373  * @reportnum: Report ID
374  * @buf: Buffer for store the report date
375  * @len: Length fo report data
376  * @report_type: Report type
377  *
378  * The function for hid_ll_driver.get_raw_report to handle the HIDRAW ioctl
379  * get report request. The transmitted data follows the standard i2c-hid
380  * protocol with a specified header.
381  *
382  * Return: The length of the data in the buf on success, negative error code
383  */
384 static int goodix_hid_get_raw_report(struct hid_device *hid,
385 				     unsigned char reportnum,
386 				     u8 *buf, size_t len,
387 				     unsigned char report_type)
388 {
389 	struct goodix_ts_data *ts = hid->driver_data;
390 	u16 data_register = le16_to_cpu(ts->hid_desc.data_register);
391 	u16 cmd_register = le16_to_cpu(ts->hid_desc.cmd_register);
392 	u8 tmp_buf[GOODIX_HID_MAX_INBUF_SIZE];
393 	int tx_len = 0, args_len = 0;
394 	u32 response_data_len;
395 	u8 args[3];
396 	int error;
397 
398 	if (report_type == HID_OUTPUT_REPORT)
399 		return -EINVAL;
400 
401 	if (reportnum == 3) {
402 		/* Get win8 signature data */
403 		error = goodix_spi_read(ts, GOODIX_HID_SIGN_ADDR, buf, len);
404 		if (error) {
405 			dev_err(ts->dev, "failed get win8 sign: %d", error);
406 			return -EINVAL;
407 		}
408 		return len;
409 	}
410 
411 	if (reportnum >= 0x0F)
412 		args[args_len++] = reportnum;
413 
414 	put_unaligned_le16(data_register, args + args_len);
415 	args_len += sizeof(data_register);
416 
417 	/* Clean 3 bytes of hid ack header data */
418 	memset(tmp_buf, 0, GOODIX_HID_ACK_HEADER_SIZE);
419 	tx_len += GOODIX_HID_ACK_HEADER_SIZE;
420 
421 	put_unaligned_le16(cmd_register, tmp_buf + tx_len);
422 	tx_len += sizeof(cmd_register);
423 
424 	tmp_buf[tx_len] = (report_type == HID_FEATURE_REPORT ? 0x03 : 0x01) << 4;
425 	tmp_buf[tx_len] |=  reportnum >= 0x0F ? 0x0F : reportnum;
426 	tx_len++;
427 
428 	tmp_buf[tx_len++] = GOODIX_HID_GET_REPORT_CMD;
429 
430 	memcpy(tmp_buf + tx_len, args, args_len);
431 	tx_len += args_len;
432 
433 	/* Step1: write report request info */
434 	error = goodix_spi_write(ts, ts->hid_report_addr, tmp_buf, tx_len);
435 	if (error) {
436 		dev_err(ts->dev, "failed send read feature cmd, %d", error);
437 		return error;
438 	}
439 
440 	/* No need read response data */
441 	if (!len)
442 		return 0;
443 
444 	/* Step2: check response data status */
445 	error = goodix_hid_check_ack_status(ts, &response_data_len);
446 	if (error)
447 		return error;
448 
449 	len = min(len, response_data_len - GOODIX_HID_PKG_LEN_SIZE);
450 	/* Step3: read response data(skip 2bytes of hid pkg length) */
451 	error = goodix_spi_read(ts, ts->hid_report_addr +
452 				GOODIX_HID_ACK_HEADER_SIZE +
453 				GOODIX_HID_PKG_LEN_SIZE, buf, len);
454 	if (error) {
455 		dev_err(ts->dev, "failed read hid response data, %d", error);
456 		return error;
457 	}
458 
459 	if (buf[0] != reportnum) {
460 		dev_err(ts->dev, "incorrect report (%d vs %d expected)",
461 			buf[0], reportnum);
462 		return -EINVAL;
463 	}
464 	return len;
465 }
466 
467 /**
468  * goodix_hid_set_raw_report() - process hidraw SET REPORT operation
469  * @hid: HID device
470  * @reportnum: Report ID
471  * @buf: Buffer for communication
472  * @len: Length of data in the buffer
473  * @report_type: Report type
474  *
475  * The function for hid_ll_driver.get_raw_report to handle the HIDRAW ioctl
476  * set report request. The transmitted data follows the standard i2c-hid
477  * protocol with a specified header.
478  *
479  * Return: The length of the data sent, negative error code on failure
480  */
481 static int goodix_hid_set_raw_report(struct hid_device *hid,
482 				     unsigned char reportnum,
483 				     __u8 *buf, size_t len,
484 				     unsigned char report_type)
485 {
486 	struct goodix_ts_data *ts = hid->driver_data;
487 	u16 data_register = le16_to_cpu(ts->hid_desc.data_register);
488 	u16 cmd_register = le16_to_cpu(ts->hid_desc.cmd_register);
489 	int tx_len = 0, args_len = 0;
490 	u8 tmp_buf[GOODIX_HID_MAX_INBUF_SIZE];
491 	u8 args[5];
492 	int error;
493 
494 	if (reportnum >= 0x0F) {
495 		args[args_len++] = reportnum;
496 		reportnum = 0x0F;
497 	}
498 
499 	put_unaligned_le16(data_register, args + args_len);
500 	args_len += sizeof(data_register);
501 
502 	put_unaligned_le16(GOODIX_HID_PKG_LEN_SIZE + len, args + args_len);
503 	args_len += GOODIX_HID_PKG_LEN_SIZE;
504 
505 	/* Clean 3 bytes of hid ack header data */
506 	memset(tmp_buf, 0, GOODIX_HID_ACK_HEADER_SIZE);
507 	tx_len += GOODIX_HID_ACK_HEADER_SIZE;
508 
509 	put_unaligned_le16(cmd_register, tmp_buf + tx_len);
510 	tx_len += sizeof(cmd_register);
511 
512 	tmp_buf[tx_len++] = ((report_type == HID_FEATURE_REPORT ? 0x03 : 0x02) << 4) | reportnum;
513 	tmp_buf[tx_len++] = GOODIX_HID_SET_REPORT_CMD;
514 
515 	memcpy(tmp_buf + tx_len, args, args_len);
516 	tx_len += args_len;
517 
518 	memcpy(tmp_buf + tx_len, buf, len);
519 	tx_len += len;
520 
521 	error = goodix_spi_write(ts, ts->hid_report_addr, tmp_buf, tx_len);
522 	if (error) {
523 		dev_err(ts->dev, "failed send report: %*ph", tx_len, tmp_buf);
524 		return error;
525 	}
526 	return len;
527 }
528 
529 static int goodix_hid_raw_request(struct hid_device *hid,
530 				  unsigned char reportnum,
531 				  __u8 *buf, size_t len,
532 				  unsigned char rtype, int reqtype)
533 {
534 	struct goodix_ts_data *ts = hid->driver_data;
535 	int error = -EINVAL;
536 
537 	guard(mutex)(&ts->hid_request_lock);
538 	switch (reqtype) {
539 	case HID_REQ_GET_REPORT:
540 		error = goodix_hid_get_raw_report(hid, reportnum, buf,
541 						  len, rtype);
542 		break;
543 	case HID_REQ_SET_REPORT:
544 		if (buf[0] == reportnum)
545 			error = goodix_hid_set_raw_report(hid, reportnum,
546 							  buf, len, rtype);
547 		break;
548 	default:
549 		break;
550 	}
551 
552 	return error;
553 }
554 
555 static struct hid_ll_driver goodix_hid_ll_driver = {
556 	.parse = goodix_hid_parse,
557 	.start = goodix_hid_start,
558 	.stop = goodix_hid_stop,
559 	.open = goodix_hid_open,
560 	.close = goodix_hid_close,
561 	.raw_request = goodix_hid_raw_request
562 };
563 
564 static irqreturn_t goodix_hid_irq(int irq, void *data)
565 {
566 	struct goodix_ts_data *ts = data;
567 	struct goodix_hid_report_event *event;
568 	struct goodix_hid_report_package *pkg;
569 	u16 report_size;
570 
571 	if (!test_bit(GOODIX_HID_STARTED, &ts->flags))
572 		return IRQ_HANDLED;
573 	/*
574 	 * First, read buffer with space for header and coordinate package:
575 	 * - event header = 3 bytes
576 	 * - coordinate event = GOODIX_HID_COOR_PKG_LEN bytes
577 	 *
578 	 * If the data size info in the event header exceeds
579 	 * GOODIX_HID_COOR_PKG_LEN, it means that there are other packages
580 	 * besides the coordinate package.
581 	 */
582 	event = goodix_get_event_report(ts, ts->hid_report_addr, ts->event_buf,
583 					GOODIX_HID_ACK_HEADER_SIZE +
584 					GOODIX_HID_COOR_PKG_LEN);
585 	if (!event) {
586 		dev_err(ts->dev, "failed get coordinate data");
587 		return IRQ_HANDLED;
588 	}
589 
590 	/* Check coordinate data valid falg */
591 	if (event->hdr.flag != GOODIX_HID_REPORT_READY_FLAG)
592 		return IRQ_HANDLED;
593 
594 	pkg = (struct goodix_hid_report_package *)event->data;
595 	if (le16_to_cpu(pkg->size) < GOODIX_HID_PKG_LEN_SIZE) {
596 		dev_err(ts->dev, "invalid coordinate event package size, %d",
597 			le16_to_cpu(pkg->size));
598 		return IRQ_HANDLED;
599 	}
600 	hid_input_report(ts->hid, HID_INPUT_REPORT, pkg->data,
601 			 le16_to_cpu(pkg->size) - GOODIX_HID_PKG_LEN_SIZE, 1);
602 
603 	report_size = le16_to_cpu(event->hdr.size);
604 	/* Check if there are other packages */
605 	if (report_size <= GOODIX_HID_COOR_PKG_LEN)
606 		return IRQ_HANDLED;
607 
608 	if (report_size >= ts->hid_max_event_sz) {
609 		dev_err(ts->dev, "package size exceed limit %d vs %d",
610 			report_size, ts->hid_max_event_sz);
611 		return IRQ_HANDLED;
612 	}
613 
614 	/* Read the package behind the coordinate data */
615 	pkg = goodix_get_event_report(ts, ts->hid_report_addr + sizeof(*event),
616 				      ts->event_buf,
617 				      report_size - GOODIX_HID_COOR_PKG_LEN);
618 	if (!pkg) {
619 		dev_err(ts->dev, "failed read attachment data content");
620 		return IRQ_HANDLED;
621 	}
622 
623 	hid_input_report(ts->hid, HID_INPUT_REPORT, pkg->data,
624 			 le16_to_cpu(pkg->size) - GOODIX_HID_PKG_LEN_SIZE, 1);
625 
626 	return IRQ_HANDLED;
627 }
628 
629 static int goodix_hid_init(struct goodix_ts_data *ts)
630 {
631 	struct hid_device *hid;
632 	int error;
633 
634 	/* Get hid descriptor */
635 	error = goodix_spi_read(ts, GOODIX_HID_DESC_ADDR, &ts->hid_desc,
636 				sizeof(ts->hid_desc));
637 	if (error) {
638 		dev_err(ts->dev, "failed get hid desc, %d", error);
639 		return error;
640 	}
641 
642 	hid = hid_allocate_device();
643 	if (IS_ERR(hid))
644 		return PTR_ERR(hid);
645 
646 	hid->driver_data = ts;
647 	hid->ll_driver = &goodix_hid_ll_driver;
648 	hid->bus = BUS_SPI;
649 	hid->dev.parent = &ts->spi->dev;
650 
651 	hid->version = le16_to_cpu(ts->hid_desc.bcd_version);
652 	hid->vendor = le16_to_cpu(ts->hid_desc.vendor_id);
653 	hid->product = le16_to_cpu(ts->hid_desc.product_id);
654 	snprintf(hid->name, sizeof(hid->name), "%s %04X:%04X", "hid-gdix",
655 		 hid->vendor, hid->product);
656 
657 	error = hid_add_device(hid);
658 	if (error) {
659 		dev_err(ts->dev, "failed add hid device, %d", error);
660 		hid_destroy_device(hid);
661 		return error;
662 	}
663 
664 	ts->hid = hid;
665 	return 0;
666 }
667 
668 static int goodix_spi_probe(struct spi_device *spi)
669 {
670 	struct device *dev = &spi->dev;
671 	struct goodix_ts_data *ts;
672 	int error;
673 
674 	/* init spi_device */
675 	spi->mode            = SPI_MODE_0;
676 	spi->bits_per_word   = 8;
677 	error = spi_setup(spi);
678 	if (error)
679 		return error;
680 
681 	ts = devm_kzalloc(dev, sizeof(*ts), GFP_KERNEL);
682 	if (!ts)
683 		return -ENOMEM;
684 
685 	mutex_init(&ts->hid_request_lock);
686 	spi_set_drvdata(spi, ts);
687 	ts->spi = spi;
688 	ts->dev = dev;
689 	ts->hid_max_event_sz = GOODIX_SPI_READ_PREFIX_LEN +
690 			       GOODIX_HID_ACK_HEADER_SIZE + GOODIX_HID_COOR_PKG_LEN;
691 	ts->event_buf = devm_kmalloc(dev, ts->hid_max_event_sz, GFP_KERNEL);
692 	if (!ts->event_buf)
693 		return -ENOMEM;
694 
695 	ts->reset_gpio = devm_gpiod_get_optional(dev, "reset", GPIOD_OUT_HIGH);
696 	if (IS_ERR(ts->reset_gpio))
697 		return dev_err_probe(dev, PTR_ERR(ts->reset_gpio),
698 				     "failed to request reset gpio\n");
699 
700 	error = device_property_read_u32(dev, "goodix,hid-report-addr",
701 					 &ts->hid_report_addr);
702 	if (error)
703 		return dev_err_probe(dev, error,
704 				     "failed get hid report addr\n");
705 
706 	error = goodix_dev_confirm(ts);
707 	if (error)
708 		return error;
709 
710 	/* Waits 150ms for firmware to fully boot */
711 	msleep(GOODIX_NORMAL_RESET_DELAY_MS);
712 
713 	error = goodix_hid_init(ts);
714 	if (error) {
715 		dev_err(dev, "failed init hid device");
716 		return error;
717 	}
718 
719 	error = devm_request_threaded_irq(&ts->spi->dev, ts->spi->irq,
720 					  NULL, goodix_hid_irq, IRQF_ONESHOT,
721 					  "goodix_spi_hid", ts);
722 	if (error) {
723 		dev_err(ts->dev, "could not register interrupt, irq = %d, %d",
724 			ts->spi->irq, error);
725 		goto err_destroy_hid;
726 	}
727 
728 	return 0;
729 
730 err_destroy_hid:
731 	hid_destroy_device(ts->hid);
732 	return error;
733 }
734 
735 static void goodix_spi_remove(struct spi_device *spi)
736 {
737 	struct goodix_ts_data *ts = spi_get_drvdata(spi);
738 
739 	disable_irq(spi->irq);
740 	hid_destroy_device(ts->hid);
741 }
742 
743 static int goodix_spi_set_power(struct goodix_ts_data *ts, int power_state)
744 {
745 	u8 power_control_cmd[] = {0x00, 0x00, 0x00, 0x87, 0x02, 0x00, 0x08};
746 	int error;
747 
748 	/* value 0 for power on, 1 for power sleep */
749 	power_control_cmd[5] = power_state;
750 
751 	guard(mutex)(&ts->hid_request_lock);
752 	error = goodix_spi_write(ts, ts->hid_report_addr, power_control_cmd,
753 				 sizeof(power_control_cmd));
754 	if (error) {
755 		dev_err(ts->dev, "failed set power mode: %s",
756 			power_state == GOODIX_SPI_POWER_ON ? "on" : "sleep");
757 		return error;
758 	}
759 	return 0;
760 }
761 
762 static int goodix_spi_suspend(struct device *dev)
763 {
764 	struct goodix_ts_data *ts = dev_get_drvdata(dev);
765 
766 	disable_irq(ts->spi->irq);
767 	return goodix_spi_set_power(ts, GOODIX_SPI_POWER_SLEEP);
768 }
769 
770 static int goodix_spi_resume(struct device *dev)
771 {
772 	struct goodix_ts_data *ts = dev_get_drvdata(dev);
773 
774 	enable_irq(ts->spi->irq);
775 	return goodix_spi_set_power(ts, GOODIX_SPI_POWER_ON);
776 }
777 
778 static DEFINE_SIMPLE_DEV_PM_OPS(goodix_spi_pm_ops,
779 				goodix_spi_suspend, goodix_spi_resume);
780 
781 #ifdef CONFIG_ACPI
782 static const struct acpi_device_id goodix_spi_acpi_match[] = {
783 	{ "GXTS7986" },
784 	{ },
785 };
786 MODULE_DEVICE_TABLE(acpi, goodix_spi_acpi_match);
787 #endif
788 
789 static const struct spi_device_id goodix_spi_ids[] = {
790 	{ "gt7986u" },
791 	{ },
792 };
793 MODULE_DEVICE_TABLE(spi, goodix_spi_ids);
794 
795 static struct spi_driver goodix_spi_driver = {
796 	.driver = {
797 		.name = "goodix-spi-hid",
798 		.acpi_match_table = ACPI_PTR(goodix_spi_acpi_match),
799 		.pm = pm_sleep_ptr(&goodix_spi_pm_ops),
800 	},
801 	.probe =	goodix_spi_probe,
802 	.remove =	goodix_spi_remove,
803 	.id_table =	goodix_spi_ids,
804 };
805 module_spi_driver(goodix_spi_driver);
806 
807 MODULE_DESCRIPTION("Goodix SPI driver for HID touchscreen");
808 MODULE_AUTHOR("Goodix, Inc.");
809 MODULE_LICENSE("GPL");
810