2 * Driver for Ntrig/Microsoft Touchscreens over SPI
4 * Copyright (c) 2016 Red Hat Inc.
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the Free
10 * Software Foundation; version 2 of the License.
13 #include <linux/kernel.h>
15 #include <linux/delay.h>
16 #include <linux/gpio/consumer.h>
17 #include <linux/input.h>
18 #include <linux/input/mt.h>
19 #include <linux/interrupt.h>
20 #include <linux/module.h>
21 #include <linux/slab.h>
22 #include <linux/spi/spi.h>
23 #include <linux/acpi.h>
25 #include <asm/unaligned.h>
27 #define SURFACE3_PACKET_SIZE 264
29 #define SURFACE3_REPORT_TOUCH 0xd2
30 #define SURFACE3_REPORT_PEN 0x16
32 struct surface3_ts_data
{
33 struct spi_device
*spi
;
34 struct gpio_desc
*gpiod_rst
[2];
35 struct input_dev
*input_dev
;
36 struct input_dev
*pen_input_dev
;
39 u8 rd_buf
[SURFACE3_PACKET_SIZE
] ____cacheline_aligned
;
42 struct surface3_ts_data_finger
{
54 struct surface3_ts_data_pen
{
62 static int surface3_spi_read(struct surface3_ts_data
*ts_data
)
64 struct spi_device
*spi
= ts_data
->spi
;
66 memset(ts_data
->rd_buf
, 0, sizeof(ts_data
->rd_buf
));
67 return spi_read(spi
, ts_data
->rd_buf
, sizeof(ts_data
->rd_buf
));
70 static void surface3_spi_report_touch(struct surface3_ts_data
*ts_data
,
71 struct surface3_ts_data_finger
*finger
)
73 int st
= finger
->status
& 0x01;
76 slot
= input_mt_get_slot_by_key(ts_data
->input_dev
,
77 get_unaligned_le16(&finger
->tracking_id
));
81 input_mt_slot(ts_data
->input_dev
, slot
);
82 input_mt_report_slot_state(ts_data
->input_dev
, MT_TOOL_FINGER
, st
);
84 input_report_abs(ts_data
->input_dev
,
86 get_unaligned_le16(&finger
->x
));
87 input_report_abs(ts_data
->input_dev
,
89 get_unaligned_le16(&finger
->y
));
90 input_report_abs(ts_data
->input_dev
,
92 get_unaligned_le16(&finger
->width
));
93 input_report_abs(ts_data
->input_dev
,
95 get_unaligned_le16(&finger
->height
));
99 static void surface3_spi_process_touch(struct surface3_ts_data
*ts_data
, u8
*data
)
103 timestamp
= get_unaligned_le16(&data
[15]);
105 for (i
= 0; i
< 13; i
++) {
106 struct surface3_ts_data_finger
*finger
;
108 finger
= (struct surface3_ts_data_finger
*)&data
[17 +
109 i
* sizeof(struct surface3_ts_data_finger
)];
112 * When bit 5 of status is 1, it marks the end of the report:
113 * - touch present: 0xe7
114 * - touch released: 0xe4
115 * - nothing valuable: 0xff
117 if (finger
->status
& 0x10)
120 surface3_spi_report_touch(ts_data
, finger
);
123 input_mt_sync_frame(ts_data
->input_dev
);
124 input_sync(ts_data
->input_dev
);
127 static void surface3_spi_report_pen(struct surface3_ts_data
*ts_data
,
128 struct surface3_ts_data_pen
*pen
)
130 struct input_dev
*dev
= ts_data
->pen_input_dev
;
131 int st
= pen
->status
;
132 int prox
= st
& 0x01;
133 int rubber
= st
& 0x18;
134 int tool
= (prox
&& rubber
) ? BTN_TOOL_RUBBER
: BTN_TOOL_PEN
;
136 /* fake proximity out to switch tools */
137 if (ts_data
->pen_tool
!= tool
) {
138 input_report_key(dev
, ts_data
->pen_tool
, 0);
140 ts_data
->pen_tool
= tool
;
143 input_report_key(dev
, BTN_TOUCH
, st
& 0x12);
145 input_report_key(dev
, ts_data
->pen_tool
, prox
);
148 input_report_key(dev
,
152 input_report_abs(dev
,
154 get_unaligned_le16(&pen
->x
));
155 input_report_abs(dev
,
157 get_unaligned_le16(&pen
->y
));
158 input_report_abs(dev
,
160 get_unaligned_le16(&pen
->pressure
));
164 static void surface3_spi_process_pen(struct surface3_ts_data
*ts_data
, u8
*data
)
166 struct surface3_ts_data_pen
*pen
;
168 pen
= (struct surface3_ts_data_pen
*)&data
[15];
170 surface3_spi_report_pen(ts_data
, pen
);
171 input_sync(ts_data
->pen_input_dev
);
174 static void surface3_spi_process(struct surface3_ts_data
*ts_data
)
176 const char header
[] = {
177 0xff, 0xff, 0xff, 0xff, 0xa5, 0x5a, 0xe7, 0x7e, 0x01
179 u8
*data
= ts_data
->rd_buf
;
181 if (memcmp(header
, data
, sizeof(header
)))
182 dev_err(&ts_data
->spi
->dev
,
183 "%s header error: %*ph, ignoring...\n",
184 __func__
, (int)sizeof(header
), data
);
187 case SURFACE3_REPORT_TOUCH
:
188 surface3_spi_process_touch(ts_data
, data
);
190 case SURFACE3_REPORT_PEN
:
191 surface3_spi_process_pen(ts_data
, data
);
194 dev_err(&ts_data
->spi
->dev
,
195 "%s unknown packet type: %x, ignoring...\n",
201 static irqreturn_t
surface3_spi_irq_handler(int irq
, void *dev_id
)
203 struct surface3_ts_data
*data
= dev_id
;
205 if (surface3_spi_read(data
))
208 dev_dbg(&data
->spi
->dev
, "%s received -> %*ph\n",
209 __func__
, SURFACE3_PACKET_SIZE
, data
->rd_buf
);
210 surface3_spi_process(data
);
215 static void surface3_spi_power(struct surface3_ts_data
*data
, bool on
)
217 gpiod_set_value(data
->gpiod_rst
[0], on
);
218 gpiod_set_value(data
->gpiod_rst
[1], on
);
219 /* let the device settle a little */
224 * surface3_spi_get_gpio_config - Get GPIO config from ACPI/DT
226 * @ts: surface3_spi_ts_data pointer
228 static int surface3_spi_get_gpio_config(struct surface3_ts_data
*data
)
232 struct gpio_desc
*gpiod
;
235 dev
= &data
->spi
->dev
;
237 /* Get the reset lines GPIO pin number */
238 for (i
= 0; i
< 2; i
++) {
239 gpiod
= devm_gpiod_get_index(dev
, NULL
, i
, GPIOD_OUT_LOW
);
241 error
= PTR_ERR(gpiod
);
242 if (error
!= -EPROBE_DEFER
)
244 "Failed to get power GPIO %d: %d\n",
250 data
->gpiod_rst
[i
] = gpiod
;
256 static int surface3_spi_create_touch_input(struct surface3_ts_data
*data
)
258 struct input_dev
*input
;
261 input
= devm_input_allocate_device(&data
->spi
->dev
);
265 data
->input_dev
= input
;
267 input_set_abs_params(input
, ABS_MT_POSITION_X
, 0, 9600, 0, 0);
268 input_abs_set_res(input
, ABS_MT_POSITION_X
, 40);
269 input_set_abs_params(input
, ABS_MT_POSITION_Y
, 0, 7200, 0, 0);
270 input_abs_set_res(input
, ABS_MT_POSITION_Y
, 48);
271 input_set_abs_params(input
, ABS_MT_WIDTH_MAJOR
, 0, 1024, 0, 0);
272 input_set_abs_params(input
, ABS_MT_WIDTH_MINOR
, 0, 1024, 0, 0);
273 input_mt_init_slots(input
, 10, INPUT_MT_DIRECT
);
275 input
->name
= "Surface3 SPI Capacitive TouchScreen";
276 input
->phys
= "input/ts";
277 input
->id
.bustype
= BUS_SPI
;
278 input
->id
.vendor
= 0x045e; /* Microsoft */
279 input
->id
.product
= 0x0001;
280 input
->id
.version
= 0x0000;
282 error
= input_register_device(input
);
284 dev_err(&data
->spi
->dev
,
285 "Failed to register input device: %d", error
);
292 static int surface3_spi_create_pen_input(struct surface3_ts_data
*data
)
294 struct input_dev
*input
;
297 input
= devm_input_allocate_device(&data
->spi
->dev
);
301 data
->pen_input_dev
= input
;
302 data
->pen_tool
= BTN_TOOL_PEN
;
304 __set_bit(INPUT_PROP_DIRECT
, input
->propbit
);
305 __set_bit(INPUT_PROP_POINTER
, input
->propbit
);
306 input_set_abs_params(input
, ABS_X
, 0, 9600, 0, 0);
307 input_abs_set_res(input
, ABS_X
, 40);
308 input_set_abs_params(input
, ABS_Y
, 0, 7200, 0, 0);
309 input_abs_set_res(input
, ABS_Y
, 48);
310 input_set_abs_params(input
, ABS_PRESSURE
, 0, 1024, 0, 0);
311 input_set_capability(input
, EV_KEY
, BTN_TOUCH
);
312 input_set_capability(input
, EV_KEY
, BTN_STYLUS
);
313 input_set_capability(input
, EV_KEY
, BTN_TOOL_PEN
);
314 input_set_capability(input
, EV_KEY
, BTN_TOOL_RUBBER
);
316 input
->name
= "Surface3 SPI Pen Input";
317 input
->phys
= "input/ts";
318 input
->id
.bustype
= BUS_SPI
;
319 input
->id
.vendor
= 0x045e; /* Microsoft */
320 input
->id
.product
= 0x0002;
321 input
->id
.version
= 0x0000;
323 error
= input_register_device(input
);
325 dev_err(&data
->spi
->dev
,
326 "Failed to register input device: %d", error
);
333 static int surface3_spi_probe(struct spi_device
*spi
)
335 struct surface3_ts_data
*data
;
339 spi
->bits_per_word
= 8;
340 spi
->mode
= SPI_MODE_0
;
341 error
= spi_setup(spi
);
345 data
= devm_kzalloc(&spi
->dev
, sizeof(*data
), GFP_KERNEL
);
350 spi_set_drvdata(spi
, data
);
352 error
= surface3_spi_get_gpio_config(data
);
356 surface3_spi_power(data
, true);
357 surface3_spi_power(data
, false);
358 surface3_spi_power(data
, true);
360 error
= surface3_spi_create_touch_input(data
);
364 error
= surface3_spi_create_pen_input(data
);
368 error
= devm_request_threaded_irq(&spi
->dev
, spi
->irq
,
369 NULL
, surface3_spi_irq_handler
,
371 "Surface3-irq", data
);
378 static int __maybe_unused
surface3_spi_suspend(struct device
*dev
)
380 struct spi_device
*spi
= to_spi_device(dev
);
381 struct surface3_ts_data
*data
= spi_get_drvdata(spi
);
383 disable_irq(data
->spi
->irq
);
385 surface3_spi_power(data
, false);
390 static int __maybe_unused
surface3_spi_resume(struct device
*dev
)
392 struct spi_device
*spi
= to_spi_device(dev
);
393 struct surface3_ts_data
*data
= spi_get_drvdata(spi
);
395 surface3_spi_power(data
, true);
397 enable_irq(data
->spi
->irq
);
402 static SIMPLE_DEV_PM_OPS(surface3_spi_pm_ops
,
403 surface3_spi_suspend
,
404 surface3_spi_resume
);
407 static const struct acpi_device_id surface3_spi_acpi_match
[] = {
411 MODULE_DEVICE_TABLE(acpi
, surface3_spi_acpi_match
);
414 static struct spi_driver surface3_spi_driver
= {
416 .name
= "Surface3-spi",
417 .acpi_match_table
= ACPI_PTR(surface3_spi_acpi_match
),
418 .pm
= &surface3_spi_pm_ops
,
420 .probe
= surface3_spi_probe
,
423 module_spi_driver(surface3_spi_driver
);
425 MODULE_AUTHOR("Benjamin Tissoires <benjamin.tissoires@gmail.com>");
426 MODULE_DESCRIPTION("Surface 3 SPI touchscreen driver");
427 MODULE_LICENSE("GPL v2");