xref: /openbmc/linux/drivers/input/mouse/cyapa.c (revision e8f6f3b4)
1 /*
2  * Cypress APA trackpad with I2C interface
3  *
4  * Author: Dudley Du <dudl@cypress.com>
5  * Further cleanup and restructuring by:
6  *   Daniel Kurtz <djkurtz@chromium.org>
7  *   Benson Leung <bleung@chromium.org>
8  *
9  * Copyright (C) 2011-2014 Cypress Semiconductor, Inc.
10  * Copyright (C) 2011-2012 Google, Inc.
11  *
12  * This file is subject to the terms and conditions of the GNU General Public
13  * License.  See the file COPYING in the main directory of this archive for
14  * more details.
15  */
16 
17 #include <linux/delay.h>
18 #include <linux/i2c.h>
19 #include <linux/input.h>
20 #include <linux/input/mt.h>
21 #include <linux/interrupt.h>
22 #include <linux/module.h>
23 #include <linux/slab.h>
24 
25 /* APA trackpad firmware generation */
26 #define CYAPA_GEN3   0x03   /* support MT-protocol B with tracking ID. */
27 
28 #define CYAPA_NAME   "Cypress APA Trackpad (cyapa)"
29 
30 /* commands for read/write registers of Cypress trackpad */
31 #define CYAPA_CMD_SOFT_RESET       0x00
32 #define CYAPA_CMD_POWER_MODE       0x01
33 #define CYAPA_CMD_DEV_STATUS       0x02
34 #define CYAPA_CMD_GROUP_DATA       0x03
35 #define CYAPA_CMD_GROUP_CMD        0x04
36 #define CYAPA_CMD_GROUP_QUERY      0x05
37 #define CYAPA_CMD_BL_STATUS        0x06
38 #define CYAPA_CMD_BL_HEAD          0x07
39 #define CYAPA_CMD_BL_CMD           0x08
40 #define CYAPA_CMD_BL_DATA          0x09
41 #define CYAPA_CMD_BL_ALL           0x0a
42 #define CYAPA_CMD_BLK_PRODUCT_ID   0x0b
43 #define CYAPA_CMD_BLK_HEAD         0x0c
44 
45 /* report data start reg offset address. */
46 #define DATA_REG_START_OFFSET  0x0000
47 
48 #define BL_HEAD_OFFSET 0x00
49 #define BL_DATA_OFFSET 0x10
50 
51 /*
52  * Operational Device Status Register
53  *
54  * bit 7: Valid interrupt source
55  * bit 6 - 4: Reserved
56  * bit 3 - 2: Power status
57  * bit 1 - 0: Device status
58  */
59 #define REG_OP_STATUS     0x00
60 #define OP_STATUS_SRC     0x80
61 #define OP_STATUS_POWER   0x0c
62 #define OP_STATUS_DEV     0x03
63 #define OP_STATUS_MASK (OP_STATUS_SRC | OP_STATUS_POWER | OP_STATUS_DEV)
64 
65 /*
66  * Operational Finger Count/Button Flags Register
67  *
68  * bit 7 - 4: Number of touched finger
69  * bit 3: Valid data
70  * bit 2: Middle Physical Button
71  * bit 1: Right Physical Button
72  * bit 0: Left physical Button
73  */
74 #define REG_OP_DATA1       0x01
75 #define OP_DATA_VALID      0x08
76 #define OP_DATA_MIDDLE_BTN 0x04
77 #define OP_DATA_RIGHT_BTN  0x02
78 #define OP_DATA_LEFT_BTN   0x01
79 #define OP_DATA_BTN_MASK (OP_DATA_MIDDLE_BTN | OP_DATA_RIGHT_BTN | \
80 			  OP_DATA_LEFT_BTN)
81 
82 /*
83  * Bootloader Status Register
84  *
85  * bit 7: Busy
86  * bit 6 - 5: Reserved
87  * bit 4: Bootloader running
88  * bit 3 - 1: Reserved
89  * bit 0: Checksum valid
90  */
91 #define REG_BL_STATUS        0x01
92 #define BL_STATUS_BUSY       0x80
93 #define BL_STATUS_RUNNING    0x10
94 #define BL_STATUS_DATA_VALID 0x08
95 #define BL_STATUS_CSUM_VALID 0x01
96 
97 /*
98  * Bootloader Error Register
99  *
100  * bit 7: Invalid
101  * bit 6: Invalid security key
102  * bit 5: Bootloading
103  * bit 4: Command checksum
104  * bit 3: Flash protection error
105  * bit 2: Flash checksum error
106  * bit 1 - 0: Reserved
107  */
108 #define REG_BL_ERROR         0x02
109 #define BL_ERROR_INVALID     0x80
110 #define BL_ERROR_INVALID_KEY 0x40
111 #define BL_ERROR_BOOTLOADING 0x20
112 #define BL_ERROR_CMD_CSUM    0x10
113 #define BL_ERROR_FLASH_PROT  0x08
114 #define BL_ERROR_FLASH_CSUM  0x04
115 
116 #define BL_STATUS_SIZE  3  /* length of bootloader status registers */
117 #define BLK_HEAD_BYTES 32
118 
119 #define PRODUCT_ID_SIZE  16
120 #define QUERY_DATA_SIZE  27
121 #define REG_PROTOCOL_GEN_QUERY_OFFSET  20
122 
123 #define REG_OFFSET_DATA_BASE     0x0000
124 #define REG_OFFSET_COMMAND_BASE  0x0028
125 #define REG_OFFSET_QUERY_BASE    0x002a
126 
127 #define CAPABILITY_LEFT_BTN_MASK	(0x01 << 3)
128 #define CAPABILITY_RIGHT_BTN_MASK	(0x01 << 4)
129 #define CAPABILITY_MIDDLE_BTN_MASK	(0x01 << 5)
130 #define CAPABILITY_BTN_MASK  (CAPABILITY_LEFT_BTN_MASK | \
131 			      CAPABILITY_RIGHT_BTN_MASK | \
132 			      CAPABILITY_MIDDLE_BTN_MASK)
133 
134 #define CYAPA_OFFSET_SOFT_RESET  REG_OFFSET_COMMAND_BASE
135 
136 #define REG_OFFSET_POWER_MODE (REG_OFFSET_COMMAND_BASE + 1)
137 
138 #define PWR_MODE_MASK   0xfc
139 #define PWR_MODE_FULL_ACTIVE (0x3f << 2)
140 #define PWR_MODE_IDLE        (0x05 << 2) /* default sleep time is 50 ms. */
141 #define PWR_MODE_OFF         (0x00 << 2)
142 
143 #define PWR_STATUS_MASK      0x0c
144 #define PWR_STATUS_ACTIVE    (0x03 << 2)
145 #define PWR_STATUS_IDLE      (0x02 << 2)
146 #define PWR_STATUS_OFF       (0x00 << 2)
147 
148 /*
149  * CYAPA trackpad device states.
150  * Used in register 0x00, bit1-0, DeviceStatus field.
151  * Other values indicate device is in an abnormal state and must be reset.
152  */
153 #define CYAPA_DEV_NORMAL  0x03
154 #define CYAPA_DEV_BUSY    0x01
155 
156 enum cyapa_state {
157 	CYAPA_STATE_OP,
158 	CYAPA_STATE_BL_IDLE,
159 	CYAPA_STATE_BL_ACTIVE,
160 	CYAPA_STATE_BL_BUSY,
161 	CYAPA_STATE_NO_DEVICE,
162 };
163 
164 
165 struct cyapa_touch {
166 	/*
167 	 * high bits or x/y position value
168 	 * bit 7 - 4: high 4 bits of x position value
169 	 * bit 3 - 0: high 4 bits of y position value
170 	 */
171 	u8 xy_hi;
172 	u8 x_lo;  /* low 8 bits of x position value. */
173 	u8 y_lo;  /* low 8 bits of y position value. */
174 	u8 pressure;
175 	/* id range is 1 - 15.  It is incremented with every new touch. */
176 	u8 id;
177 } __packed;
178 
179 /* The touch.id is used as the MT slot id, thus max MT slot is 15 */
180 #define CYAPA_MAX_MT_SLOTS  15
181 
182 struct cyapa_reg_data {
183 	/*
184 	 * bit 0 - 1: device status
185 	 * bit 3 - 2: power mode
186 	 * bit 6 - 4: reserved
187 	 * bit 7: interrupt valid bit
188 	 */
189 	u8 device_status;
190 	/*
191 	 * bit 7 - 4: number of fingers currently touching pad
192 	 * bit 3: valid data check bit
193 	 * bit 2: middle mechanism button state if exists
194 	 * bit 1: right mechanism button state if exists
195 	 * bit 0: left mechanism button state if exists
196 	 */
197 	u8 finger_btn;
198 	/* CYAPA reports up to 5 touches per packet. */
199 	struct cyapa_touch touches[5];
200 } __packed;
201 
202 /* The main device structure */
203 struct cyapa {
204 	enum cyapa_state state;
205 
206 	struct i2c_client *client;
207 	struct input_dev *input;
208 	char phys[32];	/* device physical location */
209 	bool irq_wake;  /* irq wake is enabled */
210 	bool smbus;
211 
212 	/* read from query data region. */
213 	char product_id[16];
214 	u8 btn_capability;
215 	u8 gen;
216 	int max_abs_x;
217 	int max_abs_y;
218 	int physical_size_x;
219 	int physical_size_y;
220 };
221 
222 static const u8 bl_deactivate[] = { 0x00, 0xff, 0x3b, 0x00, 0x01, 0x02, 0x03,
223 		0x04, 0x05, 0x06, 0x07 };
224 static const u8 bl_exit[] = { 0x00, 0xff, 0xa5, 0x00, 0x01, 0x02, 0x03, 0x04,
225 		0x05, 0x06, 0x07 };
226 
227 struct cyapa_cmd_len {
228 	u8 cmd;
229 	u8 len;
230 };
231 
232 #define CYAPA_ADAPTER_FUNC_NONE   0
233 #define CYAPA_ADAPTER_FUNC_I2C    1
234 #define CYAPA_ADAPTER_FUNC_SMBUS  2
235 #define CYAPA_ADAPTER_FUNC_BOTH   3
236 
237 /*
238  * macros for SMBus communication
239  */
240 #define SMBUS_READ   0x01
241 #define SMBUS_WRITE 0x00
242 #define SMBUS_ENCODE_IDX(cmd, idx) ((cmd) | (((idx) & 0x03) << 1))
243 #define SMBUS_ENCODE_RW(cmd, rw) ((cmd) | ((rw) & 0x01))
244 #define SMBUS_BYTE_BLOCK_CMD_MASK 0x80
245 #define SMBUS_GROUP_BLOCK_CMD_MASK 0x40
246 
247  /* for byte read/write command */
248 #define CMD_RESET 0
249 #define CMD_POWER_MODE 1
250 #define CMD_DEV_STATUS 2
251 #define SMBUS_BYTE_CMD(cmd) (((cmd) & 0x3f) << 1)
252 #define CYAPA_SMBUS_RESET SMBUS_BYTE_CMD(CMD_RESET)
253 #define CYAPA_SMBUS_POWER_MODE SMBUS_BYTE_CMD(CMD_POWER_MODE)
254 #define CYAPA_SMBUS_DEV_STATUS SMBUS_BYTE_CMD(CMD_DEV_STATUS)
255 
256  /* for group registers read/write command */
257 #define REG_GROUP_DATA 0
258 #define REG_GROUP_CMD 2
259 #define REG_GROUP_QUERY 3
260 #define SMBUS_GROUP_CMD(grp) (0x80 | (((grp) & 0x07) << 3))
261 #define CYAPA_SMBUS_GROUP_DATA SMBUS_GROUP_CMD(REG_GROUP_DATA)
262 #define CYAPA_SMBUS_GROUP_CMD SMBUS_GROUP_CMD(REG_GROUP_CMD)
263 #define CYAPA_SMBUS_GROUP_QUERY SMBUS_GROUP_CMD(REG_GROUP_QUERY)
264 
265  /* for register block read/write command */
266 #define CMD_BL_STATUS 0
267 #define CMD_BL_HEAD 1
268 #define CMD_BL_CMD 2
269 #define CMD_BL_DATA 3
270 #define CMD_BL_ALL 4
271 #define CMD_BLK_PRODUCT_ID 5
272 #define CMD_BLK_HEAD 6
273 #define SMBUS_BLOCK_CMD(cmd) (0xc0 | (((cmd) & 0x1f) << 1))
274 
275 /* register block read/write command in bootloader mode */
276 #define CYAPA_SMBUS_BL_STATUS SMBUS_BLOCK_CMD(CMD_BL_STATUS)
277 #define CYAPA_SMBUS_BL_HEAD SMBUS_BLOCK_CMD(CMD_BL_HEAD)
278 #define CYAPA_SMBUS_BL_CMD SMBUS_BLOCK_CMD(CMD_BL_CMD)
279 #define CYAPA_SMBUS_BL_DATA SMBUS_BLOCK_CMD(CMD_BL_DATA)
280 #define CYAPA_SMBUS_BL_ALL SMBUS_BLOCK_CMD(CMD_BL_ALL)
281 
282 /* register block read/write command in operational mode */
283 #define CYAPA_SMBUS_BLK_PRODUCT_ID SMBUS_BLOCK_CMD(CMD_BLK_PRODUCT_ID)
284 #define CYAPA_SMBUS_BLK_HEAD SMBUS_BLOCK_CMD(CMD_BLK_HEAD)
285 
286 static const struct cyapa_cmd_len cyapa_i2c_cmds[] = {
287 	{ CYAPA_OFFSET_SOFT_RESET, 1 },
288 	{ REG_OFFSET_COMMAND_BASE + 1, 1 },
289 	{ REG_OFFSET_DATA_BASE, 1 },
290 	{ REG_OFFSET_DATA_BASE, sizeof(struct cyapa_reg_data) },
291 	{ REG_OFFSET_COMMAND_BASE, 0 },
292 	{ REG_OFFSET_QUERY_BASE, QUERY_DATA_SIZE },
293 	{ BL_HEAD_OFFSET, 3 },
294 	{ BL_HEAD_OFFSET, 16 },
295 	{ BL_HEAD_OFFSET, 16 },
296 	{ BL_DATA_OFFSET, 16 },
297 	{ BL_HEAD_OFFSET, 32 },
298 	{ REG_OFFSET_QUERY_BASE, PRODUCT_ID_SIZE },
299 	{ REG_OFFSET_DATA_BASE, 32 }
300 };
301 
302 static const struct cyapa_cmd_len cyapa_smbus_cmds[] = {
303 	{ CYAPA_SMBUS_RESET, 1 },
304 	{ CYAPA_SMBUS_POWER_MODE, 1 },
305 	{ CYAPA_SMBUS_DEV_STATUS, 1 },
306 	{ CYAPA_SMBUS_GROUP_DATA, sizeof(struct cyapa_reg_data) },
307 	{ CYAPA_SMBUS_GROUP_CMD, 2 },
308 	{ CYAPA_SMBUS_GROUP_QUERY, QUERY_DATA_SIZE },
309 	{ CYAPA_SMBUS_BL_STATUS, 3 },
310 	{ CYAPA_SMBUS_BL_HEAD, 16 },
311 	{ CYAPA_SMBUS_BL_CMD, 16 },
312 	{ CYAPA_SMBUS_BL_DATA, 16 },
313 	{ CYAPA_SMBUS_BL_ALL, 32 },
314 	{ CYAPA_SMBUS_BLK_PRODUCT_ID, PRODUCT_ID_SIZE },
315 	{ CYAPA_SMBUS_BLK_HEAD, 16 },
316 };
317 
318 static ssize_t cyapa_i2c_reg_read_block(struct cyapa *cyapa, u8 reg, size_t len,
319 					u8 *values)
320 {
321 	return i2c_smbus_read_i2c_block_data(cyapa->client, reg, len, values);
322 }
323 
324 static ssize_t cyapa_i2c_reg_write_block(struct cyapa *cyapa, u8 reg,
325 					 size_t len, const u8 *values)
326 {
327 	return i2c_smbus_write_i2c_block_data(cyapa->client, reg, len, values);
328 }
329 
330 /*
331  * cyapa_smbus_read_block - perform smbus block read command
332  * @cyapa  - private data structure of the driver
333  * @cmd    - the properly encoded smbus command
334  * @len    - expected length of smbus command result
335  * @values - buffer to store smbus command result
336  *
337  * Returns negative errno, else the number of bytes written.
338  *
339  * Note:
340  * In trackpad device, the memory block allocated for I2C register map
341  * is 256 bytes, so the max read block for I2C bus is 256 bytes.
342  */
343 static ssize_t cyapa_smbus_read_block(struct cyapa *cyapa, u8 cmd, size_t len,
344 				      u8 *values)
345 {
346 	ssize_t ret;
347 	u8 index;
348 	u8 smbus_cmd;
349 	u8 *buf;
350 	struct i2c_client *client = cyapa->client;
351 
352 	if (!(SMBUS_BYTE_BLOCK_CMD_MASK & cmd))
353 		return -EINVAL;
354 
355 	if (SMBUS_GROUP_BLOCK_CMD_MASK & cmd) {
356 		/* read specific block registers command. */
357 		smbus_cmd = SMBUS_ENCODE_RW(cmd, SMBUS_READ);
358 		ret = i2c_smbus_read_block_data(client, smbus_cmd, values);
359 		goto out;
360 	}
361 
362 	ret = 0;
363 	for (index = 0; index * I2C_SMBUS_BLOCK_MAX < len; index++) {
364 		smbus_cmd = SMBUS_ENCODE_IDX(cmd, index);
365 		smbus_cmd = SMBUS_ENCODE_RW(smbus_cmd, SMBUS_READ);
366 		buf = values + I2C_SMBUS_BLOCK_MAX * index;
367 		ret = i2c_smbus_read_block_data(client, smbus_cmd, buf);
368 		if (ret < 0)
369 			goto out;
370 	}
371 
372 out:
373 	return ret > 0 ? len : ret;
374 }
375 
376 static s32 cyapa_read_byte(struct cyapa *cyapa, u8 cmd_idx)
377 {
378 	u8 cmd;
379 
380 	if (cyapa->smbus) {
381 		cmd = cyapa_smbus_cmds[cmd_idx].cmd;
382 		cmd = SMBUS_ENCODE_RW(cmd, SMBUS_READ);
383 	} else {
384 		cmd = cyapa_i2c_cmds[cmd_idx].cmd;
385 	}
386 	return i2c_smbus_read_byte_data(cyapa->client, cmd);
387 }
388 
389 static s32 cyapa_write_byte(struct cyapa *cyapa, u8 cmd_idx, u8 value)
390 {
391 	u8 cmd;
392 
393 	if (cyapa->smbus) {
394 		cmd = cyapa_smbus_cmds[cmd_idx].cmd;
395 		cmd = SMBUS_ENCODE_RW(cmd, SMBUS_WRITE);
396 	} else {
397 		cmd = cyapa_i2c_cmds[cmd_idx].cmd;
398 	}
399 	return i2c_smbus_write_byte_data(cyapa->client, cmd, value);
400 }
401 
402 static ssize_t cyapa_read_block(struct cyapa *cyapa, u8 cmd_idx, u8 *values)
403 {
404 	u8 cmd;
405 	size_t len;
406 
407 	if (cyapa->smbus) {
408 		cmd = cyapa_smbus_cmds[cmd_idx].cmd;
409 		len = cyapa_smbus_cmds[cmd_idx].len;
410 		return cyapa_smbus_read_block(cyapa, cmd, len, values);
411 	} else {
412 		cmd = cyapa_i2c_cmds[cmd_idx].cmd;
413 		len = cyapa_i2c_cmds[cmd_idx].len;
414 		return cyapa_i2c_reg_read_block(cyapa, cmd, len, values);
415 	}
416 }
417 
418 /*
419  * Query device for its current operating state.
420  *
421  */
422 static int cyapa_get_state(struct cyapa *cyapa)
423 {
424 	u8 status[BL_STATUS_SIZE];
425 	int error;
426 
427 	cyapa->state = CYAPA_STATE_NO_DEVICE;
428 
429 	/*
430 	 * Get trackpad status by reading 3 registers starting from 0.
431 	 * If the device is in the bootloader, this will be BL_HEAD.
432 	 * If the device is in operation mode, this will be the DATA regs.
433 	 *
434 	 */
435 	error = cyapa_i2c_reg_read_block(cyapa, BL_HEAD_OFFSET, BL_STATUS_SIZE,
436 				         status);
437 
438 	/*
439 	 * On smbus systems in OP mode, the i2c_reg_read will fail with
440 	 * -ETIMEDOUT.  In this case, try again using the smbus equivalent
441 	 * command.  This should return a BL_HEAD indicating CYAPA_STATE_OP.
442 	 */
443 	if (cyapa->smbus && (error == -ETIMEDOUT || error == -ENXIO))
444 		error = cyapa_read_block(cyapa, CYAPA_CMD_BL_STATUS, status);
445 
446 	if (error != BL_STATUS_SIZE)
447 		goto error;
448 
449 	if ((status[REG_OP_STATUS] & OP_STATUS_SRC) == OP_STATUS_SRC) {
450 		switch (status[REG_OP_STATUS] & OP_STATUS_DEV) {
451 		case CYAPA_DEV_NORMAL:
452 		case CYAPA_DEV_BUSY:
453 			cyapa->state = CYAPA_STATE_OP;
454 			break;
455 		default:
456 			error = -EAGAIN;
457 			goto error;
458 		}
459 	} else {
460 		if (status[REG_BL_STATUS] & BL_STATUS_BUSY)
461 			cyapa->state = CYAPA_STATE_BL_BUSY;
462 		else if (status[REG_BL_ERROR] & BL_ERROR_BOOTLOADING)
463 			cyapa->state = CYAPA_STATE_BL_ACTIVE;
464 		else
465 			cyapa->state = CYAPA_STATE_BL_IDLE;
466 	}
467 
468 	return 0;
469 error:
470 	return (error < 0) ? error : -EAGAIN;
471 }
472 
473 /*
474  * Poll device for its status in a loop, waiting up to timeout for a response.
475  *
476  * When the device switches state, it usually takes ~300 ms.
477  * However, when running a new firmware image, the device must calibrate its
478  * sensors, which can take as long as 2 seconds.
479  *
480  * Note: The timeout has granularity of the polling rate, which is 100 ms.
481  *
482  * Returns:
483  *   0 when the device eventually responds with a valid non-busy state.
484  *   -ETIMEDOUT if device never responds (too many -EAGAIN)
485  *   < 0    other errors
486  */
487 static int cyapa_poll_state(struct cyapa *cyapa, unsigned int timeout)
488 {
489 	int error;
490 	int tries = timeout / 100;
491 
492 	error = cyapa_get_state(cyapa);
493 	while ((error || cyapa->state >= CYAPA_STATE_BL_BUSY) && tries--) {
494 		msleep(100);
495 		error = cyapa_get_state(cyapa);
496 	}
497 	return (error == -EAGAIN || error == -ETIMEDOUT) ? -ETIMEDOUT : error;
498 }
499 
500 static int cyapa_bl_deactivate(struct cyapa *cyapa)
501 {
502 	int error;
503 
504 	error = cyapa_i2c_reg_write_block(cyapa, 0, sizeof(bl_deactivate),
505 					  bl_deactivate);
506 	if (error)
507 		return error;
508 
509 	/* wait for bootloader to switch to idle state; should take < 100ms */
510 	msleep(100);
511 	error = cyapa_poll_state(cyapa, 500);
512 	if (error)
513 		return error;
514 	if (cyapa->state != CYAPA_STATE_BL_IDLE)
515 		return -EAGAIN;
516 	return 0;
517 }
518 
519 /*
520  * Exit bootloader
521  *
522  * Send bl_exit command, then wait 50 - 100 ms to let device transition to
523  * operational mode.  If this is the first time the device's firmware is
524  * running, it can take up to 2 seconds to calibrate its sensors.  So, poll
525  * the device's new state for up to 2 seconds.
526  *
527  * Returns:
528  *   -EIO    failure while reading from device
529  *   -EAGAIN device is stuck in bootloader, b/c it has invalid firmware
530  *   0       device is supported and in operational mode
531  */
532 static int cyapa_bl_exit(struct cyapa *cyapa)
533 {
534 	int error;
535 
536 	error = cyapa_i2c_reg_write_block(cyapa, 0, sizeof(bl_exit), bl_exit);
537 	if (error)
538 		return error;
539 
540 	/*
541 	 * Wait for bootloader to exit, and operation mode to start.
542 	 * Normally, this takes at least 50 ms.
543 	 */
544 	usleep_range(50000, 100000);
545 	/*
546 	 * In addition, when a device boots for the first time after being
547 	 * updated to new firmware, it must first calibrate its sensors, which
548 	 * can take up to an additional 2 seconds.
549 	 */
550 	error = cyapa_poll_state(cyapa, 2000);
551 	if (error < 0)
552 		return error;
553 	if (cyapa->state != CYAPA_STATE_OP)
554 		return -EAGAIN;
555 
556 	return 0;
557 }
558 
559 /*
560  * Set device power mode
561  *
562  */
563 static int cyapa_set_power_mode(struct cyapa *cyapa, u8 power_mode)
564 {
565 	struct device *dev = &cyapa->client->dev;
566 	int ret;
567 	u8 power;
568 
569 	if (cyapa->state != CYAPA_STATE_OP)
570 		return 0;
571 
572 	ret = cyapa_read_byte(cyapa, CYAPA_CMD_POWER_MODE);
573 	if (ret < 0)
574 		return ret;
575 
576 	power = ret & ~PWR_MODE_MASK;
577 	power |= power_mode & PWR_MODE_MASK;
578 	ret = cyapa_write_byte(cyapa, CYAPA_CMD_POWER_MODE, power);
579 	if (ret < 0) {
580 		dev_err(dev, "failed to set power_mode 0x%02x err = %d\n",
581 			power_mode, ret);
582 		return ret;
583 	}
584 
585 	return 0;
586 }
587 
588 static int cyapa_get_query_data(struct cyapa *cyapa)
589 {
590 	u8 query_data[QUERY_DATA_SIZE];
591 	int ret;
592 
593 	if (cyapa->state != CYAPA_STATE_OP)
594 		return -EBUSY;
595 
596 	ret = cyapa_read_block(cyapa, CYAPA_CMD_GROUP_QUERY, query_data);
597 	if (ret < 0)
598 		return ret;
599 	if (ret != QUERY_DATA_SIZE)
600 		return -EIO;
601 
602 	memcpy(&cyapa->product_id[0], &query_data[0], 5);
603 	cyapa->product_id[5] = '-';
604 	memcpy(&cyapa->product_id[6], &query_data[5], 6);
605 	cyapa->product_id[12] = '-';
606 	memcpy(&cyapa->product_id[13], &query_data[11], 2);
607 	cyapa->product_id[15] = '\0';
608 
609 	cyapa->btn_capability = query_data[19] & CAPABILITY_BTN_MASK;
610 
611 	cyapa->gen = query_data[20] & 0x0f;
612 
613 	cyapa->max_abs_x = ((query_data[21] & 0xf0) << 4) | query_data[22];
614 	cyapa->max_abs_y = ((query_data[21] & 0x0f) << 8) | query_data[23];
615 
616 	cyapa->physical_size_x =
617 		((query_data[24] & 0xf0) << 4) | query_data[25];
618 	cyapa->physical_size_y =
619 		((query_data[24] & 0x0f) << 8) | query_data[26];
620 
621 	return 0;
622 }
623 
624 /*
625  * Check if device is operational.
626  *
627  * An operational device is responding, has exited bootloader, and has
628  * firmware supported by this driver.
629  *
630  * Returns:
631  *   -EBUSY  no device or in bootloader
632  *   -EIO    failure while reading from device
633  *   -EAGAIN device is still in bootloader
634  *           if ->state = CYAPA_STATE_BL_IDLE, device has invalid firmware
635  *   -EINVAL device is in operational mode, but not supported by this driver
636  *   0       device is supported
637  */
638 static int cyapa_check_is_operational(struct cyapa *cyapa)
639 {
640 	struct device *dev = &cyapa->client->dev;
641 	static const char unique_str[] = "CYTRA";
642 	int error;
643 
644 	error = cyapa_poll_state(cyapa, 2000);
645 	if (error)
646 		return error;
647 	switch (cyapa->state) {
648 	case CYAPA_STATE_BL_ACTIVE:
649 		error = cyapa_bl_deactivate(cyapa);
650 		if (error)
651 			return error;
652 
653 	/* Fallthrough state */
654 	case CYAPA_STATE_BL_IDLE:
655 		error = cyapa_bl_exit(cyapa);
656 		if (error)
657 			return error;
658 
659 	/* Fallthrough state */
660 	case CYAPA_STATE_OP:
661 		error = cyapa_get_query_data(cyapa);
662 		if (error)
663 			return error;
664 
665 		/* only support firmware protocol gen3 */
666 		if (cyapa->gen != CYAPA_GEN3) {
667 			dev_err(dev, "unsupported protocol version (%d)",
668 				cyapa->gen);
669 			return -EINVAL;
670 		}
671 
672 		/* only support product ID starting with CYTRA */
673 		if (memcmp(cyapa->product_id, unique_str,
674 			   sizeof(unique_str) - 1) != 0) {
675 			dev_err(dev, "unsupported product ID (%s)\n",
676 				cyapa->product_id);
677 			return -EINVAL;
678 		}
679 		return 0;
680 
681 	default:
682 		return -EIO;
683 	}
684 	return 0;
685 }
686 
687 static irqreturn_t cyapa_irq(int irq, void *dev_id)
688 {
689 	struct cyapa *cyapa = dev_id;
690 	struct device *dev = &cyapa->client->dev;
691 	struct input_dev *input = cyapa->input;
692 	struct cyapa_reg_data data;
693 	int i;
694 	int ret;
695 	int num_fingers;
696 
697 	if (device_may_wakeup(dev))
698 		pm_wakeup_event(dev, 0);
699 
700 	ret = cyapa_read_block(cyapa, CYAPA_CMD_GROUP_DATA, (u8 *)&data);
701 	if (ret != sizeof(data))
702 		goto out;
703 
704 	if ((data.device_status & OP_STATUS_SRC) != OP_STATUS_SRC ||
705 	    (data.device_status & OP_STATUS_DEV) != CYAPA_DEV_NORMAL ||
706 	    (data.finger_btn & OP_DATA_VALID) != OP_DATA_VALID) {
707 		goto out;
708 	}
709 
710 	num_fingers = (data.finger_btn >> 4) & 0x0f;
711 	for (i = 0; i < num_fingers; i++) {
712 		const struct cyapa_touch *touch = &data.touches[i];
713 		/* Note: touch->id range is 1 to 15; slots are 0 to 14. */
714 		int slot = touch->id - 1;
715 
716 		input_mt_slot(input, slot);
717 		input_mt_report_slot_state(input, MT_TOOL_FINGER, true);
718 		input_report_abs(input, ABS_MT_POSITION_X,
719 				 ((touch->xy_hi & 0xf0) << 4) | touch->x_lo);
720 		input_report_abs(input, ABS_MT_POSITION_Y,
721 				 ((touch->xy_hi & 0x0f) << 8) | touch->y_lo);
722 		input_report_abs(input, ABS_MT_PRESSURE, touch->pressure);
723 	}
724 
725 	input_mt_sync_frame(input);
726 
727 	if (cyapa->btn_capability & CAPABILITY_LEFT_BTN_MASK)
728 		input_report_key(input, BTN_LEFT,
729 				 data.finger_btn & OP_DATA_LEFT_BTN);
730 
731 	if (cyapa->btn_capability & CAPABILITY_MIDDLE_BTN_MASK)
732 		input_report_key(input, BTN_MIDDLE,
733 				 data.finger_btn & OP_DATA_MIDDLE_BTN);
734 
735 	if (cyapa->btn_capability & CAPABILITY_RIGHT_BTN_MASK)
736 		input_report_key(input, BTN_RIGHT,
737 				 data.finger_btn & OP_DATA_RIGHT_BTN);
738 
739 	input_sync(input);
740 
741 out:
742 	return IRQ_HANDLED;
743 }
744 
745 static u8 cyapa_check_adapter_functionality(struct i2c_client *client)
746 {
747 	u8 ret = CYAPA_ADAPTER_FUNC_NONE;
748 
749 	if (i2c_check_functionality(client->adapter, I2C_FUNC_I2C))
750 		ret |= CYAPA_ADAPTER_FUNC_I2C;
751 	if (i2c_check_functionality(client->adapter, I2C_FUNC_SMBUS_BYTE_DATA |
752 				     I2C_FUNC_SMBUS_BLOCK_DATA |
753 				     I2C_FUNC_SMBUS_I2C_BLOCK))
754 		ret |= CYAPA_ADAPTER_FUNC_SMBUS;
755 	return ret;
756 }
757 
758 static int cyapa_open(struct input_dev *input)
759 {
760 	struct cyapa *cyapa = input_get_drvdata(input);
761 	struct i2c_client *client = cyapa->client;
762 	int error;
763 
764 	error = cyapa_set_power_mode(cyapa, PWR_MODE_FULL_ACTIVE);
765 	if (error) {
766 		dev_err(&client->dev, "set active power failed: %d\n", error);
767 		return error;
768 	}
769 
770 	enable_irq(client->irq);
771 	return 0;
772 }
773 
774 static void cyapa_close(struct input_dev *input)
775 {
776 	struct cyapa *cyapa = input_get_drvdata(input);
777 
778 	disable_irq(cyapa->client->irq);
779 	cyapa_set_power_mode(cyapa, PWR_MODE_OFF);
780 }
781 
782 static int cyapa_create_input_dev(struct cyapa *cyapa)
783 {
784 	struct device *dev = &cyapa->client->dev;
785 	struct input_dev *input;
786 	int error;
787 
788 	if (!cyapa->physical_size_x || !cyapa->physical_size_y)
789 		return -EINVAL;
790 
791 	input = devm_input_allocate_device(dev);
792 	if (!input) {
793 		dev_err(dev, "failed to allocate memory for input device.\n");
794 		return -ENOMEM;
795 	}
796 
797 	input->name = CYAPA_NAME;
798 	input->phys = cyapa->phys;
799 	input->id.bustype = BUS_I2C;
800 	input->id.version = 1;
801 	input->id.product = 0;  /* Means any product in eventcomm. */
802 	input->dev.parent = &cyapa->client->dev;
803 
804 	input->open = cyapa_open;
805 	input->close = cyapa_close;
806 
807 	input_set_drvdata(input, cyapa);
808 
809 	__set_bit(EV_ABS, input->evbit);
810 
811 	/* Finger position */
812 	input_set_abs_params(input, ABS_MT_POSITION_X, 0, cyapa->max_abs_x, 0,
813 			     0);
814 	input_set_abs_params(input, ABS_MT_POSITION_Y, 0, cyapa->max_abs_y, 0,
815 			     0);
816 	input_set_abs_params(input, ABS_MT_PRESSURE, 0, 255, 0, 0);
817 
818 	input_abs_set_res(input, ABS_MT_POSITION_X,
819 			  cyapa->max_abs_x / cyapa->physical_size_x);
820 	input_abs_set_res(input, ABS_MT_POSITION_Y,
821 			  cyapa->max_abs_y / cyapa->physical_size_y);
822 
823 	if (cyapa->btn_capability & CAPABILITY_LEFT_BTN_MASK)
824 		__set_bit(BTN_LEFT, input->keybit);
825 	if (cyapa->btn_capability & CAPABILITY_MIDDLE_BTN_MASK)
826 		__set_bit(BTN_MIDDLE, input->keybit);
827 	if (cyapa->btn_capability & CAPABILITY_RIGHT_BTN_MASK)
828 		__set_bit(BTN_RIGHT, input->keybit);
829 
830 	if (cyapa->btn_capability == CAPABILITY_LEFT_BTN_MASK)
831 		__set_bit(INPUT_PROP_BUTTONPAD, input->propbit);
832 
833 	/* Handle pointer emulation and unused slots in core */
834 	error = input_mt_init_slots(input, CYAPA_MAX_MT_SLOTS,
835 				    INPUT_MT_POINTER | INPUT_MT_DROP_UNUSED);
836 	if (error) {
837 		dev_err(dev, "failed to initialize MT slots: %d\n", error);
838 		return error;
839 	}
840 
841 	cyapa->input = input;
842 	return 0;
843 }
844 
845 static int cyapa_probe(struct i2c_client *client,
846 		       const struct i2c_device_id *dev_id)
847 {
848 	struct device *dev = &client->dev;
849 	struct cyapa *cyapa;
850 	u8 adapter_func;
851 	int error;
852 
853 	adapter_func = cyapa_check_adapter_functionality(client);
854 	if (adapter_func == CYAPA_ADAPTER_FUNC_NONE) {
855 		dev_err(dev, "not a supported I2C/SMBus adapter\n");
856 		return -EIO;
857 	}
858 
859 	cyapa = devm_kzalloc(dev, sizeof(struct cyapa), GFP_KERNEL);
860 	if (!cyapa)
861 		return -ENOMEM;
862 
863 	cyapa->gen = CYAPA_GEN3;
864 	cyapa->client = client;
865 	i2c_set_clientdata(client, cyapa);
866 	sprintf(cyapa->phys, "i2c-%d-%04x/input0", client->adapter->nr,
867 		client->addr);
868 
869 	/* i2c isn't supported, use smbus */
870 	if (adapter_func == CYAPA_ADAPTER_FUNC_SMBUS)
871 		cyapa->smbus = true;
872 
873 	cyapa->state = CYAPA_STATE_NO_DEVICE;
874 
875 	error = cyapa_check_is_operational(cyapa);
876 	if (error) {
877 		dev_err(dev, "device not operational, %d\n", error);
878 		return error;
879 	}
880 
881 	/* Power down the device until we need it */
882 	error = cyapa_set_power_mode(cyapa, PWR_MODE_OFF);
883 	if (error) {
884 		dev_err(dev, "failed to quiesce the device: %d\n", error);
885 		return error;
886 	}
887 
888 	error = cyapa_create_input_dev(cyapa);
889 	if (error)
890 		return error;
891 
892 	error = devm_request_threaded_irq(dev, client->irq,
893 					  NULL, cyapa_irq,
894 					  IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
895 					  "cyapa", cyapa);
896 	if (error) {
897 		dev_err(dev, "failed to request threaded irq: %d\n", error);
898 		return error;
899 	}
900 
901 	/* Disable IRQ until the device is opened */
902 	disable_irq(client->irq);
903 
904 	/* Register the device in input subsystem */
905 	error = input_register_device(cyapa->input);
906 	if (error) {
907 		dev_err(dev, "failed to register input device: %d\n", error);
908 		return error;
909 	}
910 
911 	return 0;
912 }
913 
914 static int __maybe_unused cyapa_suspend(struct device *dev)
915 {
916 	struct i2c_client *client = to_i2c_client(dev);
917 	struct cyapa *cyapa = i2c_get_clientdata(client);
918 	struct input_dev *input = cyapa->input;
919 	u8 power_mode;
920 	int error;
921 
922 	error = mutex_lock_interruptible(&input->mutex);
923 	if (error)
924 		return error;
925 
926 	disable_irq(client->irq);
927 
928 	/*
929 	 * Set trackpad device to idle mode if wakeup is allowed,
930 	 * otherwise turn off.
931 	 */
932 	power_mode = device_may_wakeup(dev) ? PWR_MODE_IDLE
933 					    : PWR_MODE_OFF;
934 	error = cyapa_set_power_mode(cyapa, power_mode);
935 	if (error)
936 		dev_err(dev, "resume: set power mode to %d failed: %d\n",
937 			 power_mode, error);
938 
939 	if (device_may_wakeup(dev))
940 		cyapa->irq_wake = (enable_irq_wake(client->irq) == 0);
941 
942 	mutex_unlock(&input->mutex);
943 
944 	return 0;
945 }
946 
947 static int __maybe_unused cyapa_resume(struct device *dev)
948 {
949 	struct i2c_client *client = to_i2c_client(dev);
950 	struct cyapa *cyapa = i2c_get_clientdata(client);
951 	struct input_dev *input = cyapa->input;
952 	u8 power_mode;
953 	int error;
954 
955 	mutex_lock(&input->mutex);
956 
957 	if (device_may_wakeup(dev) && cyapa->irq_wake)
958 		disable_irq_wake(client->irq);
959 
960 	power_mode = input->users ? PWR_MODE_FULL_ACTIVE : PWR_MODE_OFF;
961 	error = cyapa_set_power_mode(cyapa, PWR_MODE_FULL_ACTIVE);
962 	if (error)
963 		dev_warn(dev, "resume: set power mode to %d failed: %d\n",
964 			 power_mode, error);
965 
966 	enable_irq(client->irq);
967 
968 	mutex_unlock(&input->mutex);
969 
970 	return 0;
971 }
972 
973 static SIMPLE_DEV_PM_OPS(cyapa_pm_ops, cyapa_suspend, cyapa_resume);
974 
975 static const struct i2c_device_id cyapa_id_table[] = {
976 	{ "cyapa", 0 },
977 	{ },
978 };
979 MODULE_DEVICE_TABLE(i2c, cyapa_id_table);
980 
981 static struct i2c_driver cyapa_driver = {
982 	.driver = {
983 		.name = "cyapa",
984 		.owner = THIS_MODULE,
985 		.pm = &cyapa_pm_ops,
986 	},
987 
988 	.probe = cyapa_probe,
989 	.id_table = cyapa_id_table,
990 };
991 
992 module_i2c_driver(cyapa_driver);
993 
994 MODULE_DESCRIPTION("Cypress APA I2C Trackpad Driver");
995 MODULE_AUTHOR("Dudley Du <dudl@cypress.com>");
996 MODULE_LICENSE("GPL");
997