xref: /openbmc/linux/drivers/input/keyboard/cap11xx.c (revision e961f8c6)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Input driver for Microchip CAP11xx based capacitive touch sensors
4  *
5  * (c) 2014 Daniel Mack <linux@zonque.org>
6  */
7 
8 #include <linux/kernel.h>
9 #include <linux/module.h>
10 #include <linux/interrupt.h>
11 #include <linux/input.h>
12 #include <linux/leds.h>
13 #include <linux/of_irq.h>
14 #include <linux/regmap.h>
15 #include <linux/i2c.h>
16 #include <linux/gpio/consumer.h>
17 
18 #define CAP11XX_REG_MAIN_CONTROL	0x00
19 #define CAP11XX_REG_MAIN_CONTROL_GAIN_SHIFT	(6)
20 #define CAP11XX_REG_MAIN_CONTROL_GAIN_MASK	(0xc0)
21 #define CAP11XX_REG_MAIN_CONTROL_DLSEEP		BIT(4)
22 #define CAP11XX_REG_GENERAL_STATUS	0x02
23 #define CAP11XX_REG_SENSOR_INPUT	0x03
24 #define CAP11XX_REG_NOISE_FLAG_STATUS	0x0a
25 #define CAP11XX_REG_SENOR_DELTA(X)	(0x10 + (X))
26 #define CAP11XX_REG_SENSITIVITY_CONTROL	0x1f
27 #define CAP11XX_REG_CONFIG		0x20
28 #define CAP11XX_REG_SENSOR_ENABLE	0x21
29 #define CAP11XX_REG_SENSOR_CONFIG	0x22
30 #define CAP11XX_REG_SENSOR_CONFIG2	0x23
31 #define CAP11XX_REG_SAMPLING_CONFIG	0x24
32 #define CAP11XX_REG_CALIBRATION		0x26
33 #define CAP11XX_REG_INT_ENABLE		0x27
34 #define CAP11XX_REG_REPEAT_RATE		0x28
35 #define CAP11XX_REG_MT_CONFIG		0x2a
36 #define CAP11XX_REG_MT_PATTERN_CONFIG	0x2b
37 #define CAP11XX_REG_MT_PATTERN		0x2d
38 #define CAP11XX_REG_RECALIB_CONFIG	0x2f
39 #define CAP11XX_REG_SENSOR_THRESH(X)	(0x30 + (X))
40 #define CAP11XX_REG_SENSOR_NOISE_THRESH	0x38
41 #define CAP11XX_REG_STANDBY_CHANNEL	0x40
42 #define CAP11XX_REG_STANDBY_CONFIG	0x41
43 #define CAP11XX_REG_STANDBY_SENSITIVITY	0x42
44 #define CAP11XX_REG_STANDBY_THRESH	0x43
45 #define CAP11XX_REG_CONFIG2		0x44
46 #define CAP11XX_REG_CONFIG2_ALT_POL	BIT(6)
47 #define CAP11XX_REG_SENSOR_BASE_CNT(X)	(0x50 + (X))
48 #define CAP11XX_REG_LED_POLARITY	0x73
49 #define CAP11XX_REG_LED_OUTPUT_CONTROL	0x74
50 
51 #define CAP11XX_REG_LED_DUTY_CYCLE_1	0x90
52 #define CAP11XX_REG_LED_DUTY_CYCLE_2	0x91
53 #define CAP11XX_REG_LED_DUTY_CYCLE_3	0x92
54 #define CAP11XX_REG_LED_DUTY_CYCLE_4	0x93
55 
56 #define CAP11XX_REG_LED_DUTY_MIN_MASK	(0x0f)
57 #define CAP11XX_REG_LED_DUTY_MIN_MASK_SHIFT	(0)
58 #define CAP11XX_REG_LED_DUTY_MAX_MASK	(0xf0)
59 #define CAP11XX_REG_LED_DUTY_MAX_MASK_SHIFT	(4)
60 #define CAP11XX_REG_LED_DUTY_MAX_VALUE	(15)
61 
62 #define CAP11XX_REG_SENSOR_CALIB	(0xb1 + (X))
63 #define CAP11XX_REG_SENSOR_CALIB_LSB1	0xb9
64 #define CAP11XX_REG_SENSOR_CALIB_LSB2	0xba
65 #define CAP11XX_REG_PRODUCT_ID		0xfd
66 #define CAP11XX_REG_MANUFACTURER_ID	0xfe
67 #define CAP11XX_REG_REVISION		0xff
68 
69 #define CAP11XX_MANUFACTURER_ID	0x5d
70 
71 #ifdef CONFIG_LEDS_CLASS
72 struct cap11xx_led {
73 	struct cap11xx_priv *priv;
74 	struct led_classdev cdev;
75 	u32 reg;
76 };
77 #endif
78 
79 struct cap11xx_priv {
80 	struct regmap *regmap;
81 	struct input_dev *idev;
82 
83 	struct cap11xx_led *leds;
84 	int num_leds;
85 
86 	/* config */
87 	u32 keycodes[];
88 };
89 
90 struct cap11xx_hw_model {
91 	u8 product_id;
92 	unsigned int num_channels;
93 	unsigned int num_leds;
94 	bool no_gain;
95 };
96 
97 enum {
98 	CAP1106,
99 	CAP1126,
100 	CAP1188,
101 	CAP1203,
102 	CAP1206,
103 	CAP1293,
104 	CAP1298
105 };
106 
107 static const struct cap11xx_hw_model cap11xx_devices[] = {
108 	[CAP1106] = { .product_id = 0x55, .num_channels = 6, .num_leds = 0, .no_gain = false },
109 	[CAP1126] = { .product_id = 0x53, .num_channels = 6, .num_leds = 2, .no_gain = false },
110 	[CAP1188] = { .product_id = 0x50, .num_channels = 8, .num_leds = 8, .no_gain = false },
111 	[CAP1203] = { .product_id = 0x6d, .num_channels = 3, .num_leds = 0, .no_gain = true },
112 	[CAP1206] = { .product_id = 0x67, .num_channels = 6, .num_leds = 0, .no_gain = true },
113 	[CAP1293] = { .product_id = 0x6f, .num_channels = 3, .num_leds = 0, .no_gain = false },
114 	[CAP1298] = { .product_id = 0x71, .num_channels = 8, .num_leds = 0, .no_gain = false },
115 };
116 
117 static const struct reg_default cap11xx_reg_defaults[] = {
118 	{ CAP11XX_REG_MAIN_CONTROL,		0x00 },
119 	{ CAP11XX_REG_GENERAL_STATUS,		0x00 },
120 	{ CAP11XX_REG_SENSOR_INPUT,		0x00 },
121 	{ CAP11XX_REG_NOISE_FLAG_STATUS,	0x00 },
122 	{ CAP11XX_REG_SENSITIVITY_CONTROL,	0x2f },
123 	{ CAP11XX_REG_CONFIG,			0x20 },
124 	{ CAP11XX_REG_SENSOR_ENABLE,		0x3f },
125 	{ CAP11XX_REG_SENSOR_CONFIG,		0xa4 },
126 	{ CAP11XX_REG_SENSOR_CONFIG2,		0x07 },
127 	{ CAP11XX_REG_SAMPLING_CONFIG,		0x39 },
128 	{ CAP11XX_REG_CALIBRATION,		0x00 },
129 	{ CAP11XX_REG_INT_ENABLE,		0x3f },
130 	{ CAP11XX_REG_REPEAT_RATE,		0x3f },
131 	{ CAP11XX_REG_MT_CONFIG,		0x80 },
132 	{ CAP11XX_REG_MT_PATTERN_CONFIG,	0x00 },
133 	{ CAP11XX_REG_MT_PATTERN,		0x3f },
134 	{ CAP11XX_REG_RECALIB_CONFIG,		0x8a },
135 	{ CAP11XX_REG_SENSOR_THRESH(0),		0x40 },
136 	{ CAP11XX_REG_SENSOR_THRESH(1),		0x40 },
137 	{ CAP11XX_REG_SENSOR_THRESH(2),		0x40 },
138 	{ CAP11XX_REG_SENSOR_THRESH(3),		0x40 },
139 	{ CAP11XX_REG_SENSOR_THRESH(4),		0x40 },
140 	{ CAP11XX_REG_SENSOR_THRESH(5),		0x40 },
141 	{ CAP11XX_REG_SENSOR_NOISE_THRESH,	0x01 },
142 	{ CAP11XX_REG_STANDBY_CHANNEL,		0x00 },
143 	{ CAP11XX_REG_STANDBY_CONFIG,		0x39 },
144 	{ CAP11XX_REG_STANDBY_SENSITIVITY,	0x02 },
145 	{ CAP11XX_REG_STANDBY_THRESH,		0x40 },
146 	{ CAP11XX_REG_CONFIG2,			0x40 },
147 	{ CAP11XX_REG_LED_POLARITY,		0x00 },
148 	{ CAP11XX_REG_SENSOR_CALIB_LSB1,	0x00 },
149 	{ CAP11XX_REG_SENSOR_CALIB_LSB2,	0x00 },
150 };
151 
152 static bool cap11xx_volatile_reg(struct device *dev, unsigned int reg)
153 {
154 	switch (reg) {
155 	case CAP11XX_REG_MAIN_CONTROL:
156 	case CAP11XX_REG_SENSOR_INPUT:
157 	case CAP11XX_REG_SENOR_DELTA(0):
158 	case CAP11XX_REG_SENOR_DELTA(1):
159 	case CAP11XX_REG_SENOR_DELTA(2):
160 	case CAP11XX_REG_SENOR_DELTA(3):
161 	case CAP11XX_REG_SENOR_DELTA(4):
162 	case CAP11XX_REG_SENOR_DELTA(5):
163 	case CAP11XX_REG_PRODUCT_ID:
164 	case CAP11XX_REG_MANUFACTURER_ID:
165 	case CAP11XX_REG_REVISION:
166 		return true;
167 	}
168 
169 	return false;
170 }
171 
172 static const struct regmap_config cap11xx_regmap_config = {
173 	.reg_bits = 8,
174 	.val_bits = 8,
175 
176 	.max_register = CAP11XX_REG_REVISION,
177 	.reg_defaults = cap11xx_reg_defaults,
178 
179 	.num_reg_defaults = ARRAY_SIZE(cap11xx_reg_defaults),
180 	.cache_type = REGCACHE_RBTREE,
181 	.volatile_reg = cap11xx_volatile_reg,
182 };
183 
184 static irqreturn_t cap11xx_thread_func(int irq_num, void *data)
185 {
186 	struct cap11xx_priv *priv = data;
187 	unsigned int status;
188 	int ret, i;
189 
190 	/*
191 	 * Deassert interrupt. This needs to be done before reading the status
192 	 * registers, which will not carry valid values otherwise.
193 	 */
194 	ret = regmap_update_bits(priv->regmap, CAP11XX_REG_MAIN_CONTROL, 1, 0);
195 	if (ret < 0)
196 		goto out;
197 
198 	ret = regmap_read(priv->regmap, CAP11XX_REG_SENSOR_INPUT, &status);
199 	if (ret < 0)
200 		goto out;
201 
202 	for (i = 0; i < priv->idev->keycodemax; i++)
203 		input_report_key(priv->idev, priv->keycodes[i],
204 				 status & (1 << i));
205 
206 	input_sync(priv->idev);
207 
208 out:
209 	return IRQ_HANDLED;
210 }
211 
212 static int cap11xx_set_sleep(struct cap11xx_priv *priv, bool sleep)
213 {
214 	/*
215 	 * DLSEEP mode will turn off all LEDS, prevent this
216 	 */
217 	if (IS_ENABLED(CONFIG_LEDS_CLASS) && priv->num_leds)
218 		return 0;
219 
220 	return regmap_update_bits(priv->regmap, CAP11XX_REG_MAIN_CONTROL,
221 				  CAP11XX_REG_MAIN_CONTROL_DLSEEP,
222 				  sleep ? CAP11XX_REG_MAIN_CONTROL_DLSEEP : 0);
223 }
224 
225 static int cap11xx_input_open(struct input_dev *idev)
226 {
227 	struct cap11xx_priv *priv = input_get_drvdata(idev);
228 
229 	return cap11xx_set_sleep(priv, false);
230 }
231 
232 static void cap11xx_input_close(struct input_dev *idev)
233 {
234 	struct cap11xx_priv *priv = input_get_drvdata(idev);
235 
236 	cap11xx_set_sleep(priv, true);
237 }
238 
239 #ifdef CONFIG_LEDS_CLASS
240 static int cap11xx_led_set(struct led_classdev *cdev,
241 			    enum led_brightness value)
242 {
243 	struct cap11xx_led *led = container_of(cdev, struct cap11xx_led, cdev);
244 	struct cap11xx_priv *priv = led->priv;
245 
246 	/*
247 	 * All LEDs share the same duty cycle as this is a HW
248 	 * limitation. Brightness levels per LED are either
249 	 * 0 (OFF) and 1 (ON).
250 	 */
251 	return regmap_update_bits(priv->regmap,
252 				  CAP11XX_REG_LED_OUTPUT_CONTROL,
253 				  BIT(led->reg),
254 				  value ? BIT(led->reg) : 0);
255 }
256 
257 static int cap11xx_init_leds(struct device *dev,
258 			     struct cap11xx_priv *priv, int num_leds)
259 {
260 	struct device_node *node = dev->of_node, *child;
261 	struct cap11xx_led *led;
262 	int cnt = of_get_child_count(node);
263 	int error;
264 
265 	if (!num_leds || !cnt)
266 		return 0;
267 
268 	if (cnt > num_leds)
269 		return -EINVAL;
270 
271 	led = devm_kcalloc(dev, cnt, sizeof(struct cap11xx_led), GFP_KERNEL);
272 	if (!led)
273 		return -ENOMEM;
274 
275 	priv->leds = led;
276 
277 	error = regmap_update_bits(priv->regmap,
278 				CAP11XX_REG_LED_OUTPUT_CONTROL, 0xff, 0);
279 	if (error)
280 		return error;
281 
282 	error = regmap_update_bits(priv->regmap, CAP11XX_REG_LED_DUTY_CYCLE_4,
283 				CAP11XX_REG_LED_DUTY_MAX_MASK,
284 				CAP11XX_REG_LED_DUTY_MAX_VALUE <<
285 				CAP11XX_REG_LED_DUTY_MAX_MASK_SHIFT);
286 	if (error)
287 		return error;
288 
289 	for_each_child_of_node(node, child) {
290 		u32 reg;
291 
292 		led->cdev.name =
293 			of_get_property(child, "label", NULL) ? : child->name;
294 		led->cdev.default_trigger =
295 			of_get_property(child, "linux,default-trigger", NULL);
296 		led->cdev.flags = 0;
297 		led->cdev.brightness_set_blocking = cap11xx_led_set;
298 		led->cdev.max_brightness = 1;
299 		led->cdev.brightness = LED_OFF;
300 
301 		error = of_property_read_u32(child, "reg", &reg);
302 		if (error != 0 || reg >= num_leds) {
303 			of_node_put(child);
304 			return -EINVAL;
305 		}
306 
307 		led->reg = reg;
308 		led->priv = priv;
309 
310 		error = devm_led_classdev_register(dev, &led->cdev);
311 		if (error) {
312 			of_node_put(child);
313 			return error;
314 		}
315 
316 		priv->num_leds++;
317 		led++;
318 	}
319 
320 	return 0;
321 }
322 #else
323 static int cap11xx_init_leds(struct device *dev,
324 			     struct cap11xx_priv *priv, int num_leds)
325 {
326 	return 0;
327 }
328 #endif
329 
330 static int cap11xx_i2c_probe(struct i2c_client *i2c_client)
331 {
332 	const struct i2c_device_id *id = i2c_client_get_device_id(i2c_client);
333 	struct device *dev = &i2c_client->dev;
334 	struct cap11xx_priv *priv;
335 	struct device_node *node;
336 	const struct cap11xx_hw_model *cap;
337 	int i, error, irq, gain = 0;
338 	unsigned int val, rev;
339 	u32 gain32;
340 
341 	if (id->driver_data >= ARRAY_SIZE(cap11xx_devices)) {
342 		dev_err(dev, "Invalid device ID %lu\n", id->driver_data);
343 		return -EINVAL;
344 	}
345 
346 	cap = &cap11xx_devices[id->driver_data];
347 	if (!cap || !cap->num_channels) {
348 		dev_err(dev, "Invalid device configuration\n");
349 		return -EINVAL;
350 	}
351 
352 	priv = devm_kzalloc(dev,
353 			    struct_size(priv, keycodes, cap->num_channels),
354 			    GFP_KERNEL);
355 	if (!priv)
356 		return -ENOMEM;
357 
358 	priv->regmap = devm_regmap_init_i2c(i2c_client, &cap11xx_regmap_config);
359 	if (IS_ERR(priv->regmap))
360 		return PTR_ERR(priv->regmap);
361 
362 	error = regmap_read(priv->regmap, CAP11XX_REG_PRODUCT_ID, &val);
363 	if (error)
364 		return error;
365 
366 	if (val != cap->product_id) {
367 		dev_err(dev, "Product ID: Got 0x%02x, expected 0x%02x\n",
368 			val, cap->product_id);
369 		return -ENXIO;
370 	}
371 
372 	error = regmap_read(priv->regmap, CAP11XX_REG_MANUFACTURER_ID, &val);
373 	if (error)
374 		return error;
375 
376 	if (val != CAP11XX_MANUFACTURER_ID) {
377 		dev_err(dev, "Manufacturer ID: Got 0x%02x, expected 0x%02x\n",
378 			val, CAP11XX_MANUFACTURER_ID);
379 		return -ENXIO;
380 	}
381 
382 	error = regmap_read(priv->regmap, CAP11XX_REG_REVISION, &rev);
383 	if (error < 0)
384 		return error;
385 
386 	dev_info(dev, "CAP11XX detected, model %s, revision 0x%02x\n",
387 		 id->name, rev);
388 	node = dev->of_node;
389 
390 	if (!of_property_read_u32(node, "microchip,sensor-gain", &gain32)) {
391 		if (cap->no_gain)
392 			dev_warn(dev,
393 				 "This version doesn't support sensor gain\n");
394 		else if (is_power_of_2(gain32) && gain32 <= 8)
395 			gain = ilog2(gain32);
396 		else
397 			dev_err(dev, "Invalid sensor-gain value %d\n", gain32);
398 	}
399 
400 	if (id->driver_data == CAP1106 ||
401 	    id->driver_data == CAP1126 ||
402 	    id->driver_data == CAP1188) {
403 		if (of_property_read_bool(node, "microchip,irq-active-high")) {
404 			error = regmap_update_bits(priv->regmap,
405 						   CAP11XX_REG_CONFIG2,
406 						   CAP11XX_REG_CONFIG2_ALT_POL,
407 						   0);
408 			if (error)
409 				return error;
410 		}
411 	}
412 
413 	/* Provide some useful defaults */
414 	for (i = 0; i < cap->num_channels; i++)
415 		priv->keycodes[i] = KEY_A + i;
416 
417 	of_property_read_u32_array(node, "linux,keycodes",
418 				   priv->keycodes, cap->num_channels);
419 
420 	if (!cap->no_gain) {
421 		error = regmap_update_bits(priv->regmap,
422 				CAP11XX_REG_MAIN_CONTROL,
423 				CAP11XX_REG_MAIN_CONTROL_GAIN_MASK,
424 				gain << CAP11XX_REG_MAIN_CONTROL_GAIN_SHIFT);
425 		if (error)
426 			return error;
427 	}
428 
429 	/* Disable autorepeat. The Linux input system has its own handling. */
430 	error = regmap_write(priv->regmap, CAP11XX_REG_REPEAT_RATE, 0);
431 	if (error)
432 		return error;
433 
434 	priv->idev = devm_input_allocate_device(dev);
435 	if (!priv->idev)
436 		return -ENOMEM;
437 
438 	priv->idev->name = "CAP11XX capacitive touch sensor";
439 	priv->idev->id.bustype = BUS_I2C;
440 	priv->idev->evbit[0] = BIT_MASK(EV_KEY);
441 
442 	if (of_property_read_bool(node, "autorepeat"))
443 		__set_bit(EV_REP, priv->idev->evbit);
444 
445 	for (i = 0; i < cap->num_channels; i++)
446 		__set_bit(priv->keycodes[i], priv->idev->keybit);
447 
448 	__clear_bit(KEY_RESERVED, priv->idev->keybit);
449 
450 	priv->idev->keycode = priv->keycodes;
451 	priv->idev->keycodesize = sizeof(priv->keycodes[0]);
452 	priv->idev->keycodemax = cap->num_channels;
453 
454 	priv->idev->id.vendor = CAP11XX_MANUFACTURER_ID;
455 	priv->idev->id.product = cap->product_id;
456 	priv->idev->id.version = rev;
457 
458 	priv->idev->open = cap11xx_input_open;
459 	priv->idev->close = cap11xx_input_close;
460 
461 	error = cap11xx_init_leds(dev, priv, cap->num_leds);
462 	if (error)
463 		return error;
464 
465 	input_set_drvdata(priv->idev, priv);
466 
467 	/*
468 	 * Put the device in deep sleep mode for now.
469 	 * ->open() will bring it back once the it is actually needed.
470 	 */
471 	cap11xx_set_sleep(priv, true);
472 
473 	error = input_register_device(priv->idev);
474 	if (error)
475 		return error;
476 
477 	irq = irq_of_parse_and_map(node, 0);
478 	if (!irq) {
479 		dev_err(dev, "Unable to parse or map IRQ\n");
480 		return -ENXIO;
481 	}
482 
483 	error = devm_request_threaded_irq(dev, irq, NULL, cap11xx_thread_func,
484 					  IRQF_ONESHOT, dev_name(dev), priv);
485 	if (error)
486 		return error;
487 
488 	return 0;
489 }
490 
491 static const struct of_device_id cap11xx_dt_ids[] = {
492 	{ .compatible = "microchip,cap1106", },
493 	{ .compatible = "microchip,cap1126", },
494 	{ .compatible = "microchip,cap1188", },
495 	{ .compatible = "microchip,cap1203", },
496 	{ .compatible = "microchip,cap1206", },
497 	{ .compatible = "microchip,cap1293", },
498 	{ .compatible = "microchip,cap1298", },
499 	{}
500 };
501 MODULE_DEVICE_TABLE(of, cap11xx_dt_ids);
502 
503 static const struct i2c_device_id cap11xx_i2c_ids[] = {
504 	{ "cap1106", CAP1106 },
505 	{ "cap1126", CAP1126 },
506 	{ "cap1188", CAP1188 },
507 	{ "cap1203", CAP1203 },
508 	{ "cap1206", CAP1206 },
509 	{ "cap1293", CAP1293 },
510 	{ "cap1298", CAP1298 },
511 	{}
512 };
513 MODULE_DEVICE_TABLE(i2c, cap11xx_i2c_ids);
514 
515 static struct i2c_driver cap11xx_i2c_driver = {
516 	.driver = {
517 		.name	= "cap11xx",
518 		.of_match_table = cap11xx_dt_ids,
519 	},
520 	.id_table	= cap11xx_i2c_ids,
521 	.probe		= cap11xx_i2c_probe,
522 };
523 
524 module_i2c_driver(cap11xx_i2c_driver);
525 
526 MODULE_DESCRIPTION("Microchip CAP11XX driver");
527 MODULE_AUTHOR("Daniel Mack <linux@zonque.org>");
528 MODULE_LICENSE("GPL v2");
529