Lines Matching +full:resistive +full:- +full:adc +full:- +full:touch

1 // SPDX-License-Identifier: GPL-2.0
3 * ADC generic resistive touchscreen (GRTS)
4 * This is a generic input driver that connects to an ADC
21 #define DRIVER_NAME "resistive-adc-touch"
37 * struct grts_state - generic resistive touch screen information struct
64 x = touch_info[st->ch_map[GRTS_CH_X]]; in grts_cb()
65 y = touch_info[st->ch_map[GRTS_CH_Y]]; in grts_cb()
67 if (st->ch_map[GRTS_CH_PRESSURE] < GRTS_MAX_CHANNELS) { in grts_cb()
68 press = touch_info[st->ch_map[GRTS_CH_PRESSURE]]; in grts_cb()
69 } else if (st->ch_map[GRTS_CH_Z1] < GRTS_MAX_CHANNELS) { in grts_cb()
70 unsigned int z1 = touch_info[st->ch_map[GRTS_CH_Z1]]; in grts_cb()
71 unsigned int z2 = touch_info[st->ch_map[GRTS_CH_Z2]]; in grts_cb()
76 Rt -= z1; in grts_cb()
77 Rt *= st->x_plate_ohms; in grts_cb()
88 press = GRTS_DEFAULT_PRESSURE_MAX - Rt; in grts_cb()
92 if ((!x && !y) || (st->pressure && (press < st->pressure_min))) { in grts_cb()
93 /* report end of touch */ in grts_cb()
94 input_report_key(st->input, BTN_TOUCH, 0); in grts_cb()
95 input_sync(st->input); in grts_cb()
99 /* report proper touch to subsystem*/ in grts_cb()
100 touchscreen_report_pos(st->input, &st->prop, x, y, false); in grts_cb()
101 if (st->pressure) in grts_cb()
102 input_report_abs(st->input, ABS_PRESSURE, press); in grts_cb()
103 input_report_key(st->input, BTN_TOUCH, 1); in grts_cb()
104 input_sync(st->input); in grts_cb()
114 error = iio_channel_start_all_cb(st->iio_cb); in grts_open()
116 dev_err(dev->dev.parent, "failed to start callback buffer.\n"); in grts_open()
126 iio_channel_stop_all_cb(st->iio_cb); in grts_close()
140 idx = device_property_match_string(dev, "io-channel-names", name); in grts_map_channel()
146 return -EOVERFLOW; in grts_map_channel()
149 st->ch_map[type] = idx; in grts_map_channel()
170 if (st->ch_map[GRTS_CH_PRESSURE] < GRTS_MAX_CHANNELS) { in grts_get_properties()
171 st->pressure = true; in grts_get_properties()
180 if (st->ch_map[GRTS_CH_Z1] >= GRTS_MAX_CHANNELS) in grts_get_properties()
189 "touchscreen-x-plate-ohms", in grts_get_properties()
190 &st->x_plate_ohms); in grts_get_properties()
192 dev_err(dev, "can't get touchscreen-x-plate-ohms property\n"); in grts_get_properties()
196 st->pressure = true; in grts_get_properties()
204 struct device *dev = &pdev->dev; in grts_probe()
209 return -ENOMEM; in grts_probe()
212 st->iio_chans = devm_iio_channel_get_all(dev); in grts_probe()
213 if (IS_ERR(st->iio_chans)) { in grts_probe()
214 error = PTR_ERR(st->iio_chans); in grts_probe()
215 if (error != -EPROBE_DEFER) in grts_probe()
220 if (!device_property_present(dev, "io-channel-names")) in grts_probe()
221 return -ENODEV; in grts_probe()
229 if (st->pressure) { in grts_probe()
231 "touchscreen-min-pressure", in grts_probe()
232 &st->pressure_min); in grts_probe()
234 dev_dbg(dev, "can't get touchscreen-min-pressure property.\n"); in grts_probe()
235 st->pressure_min = GRTS_DEFAULT_PRESSURE_MIN; in grts_probe()
242 return -ENOMEM; in grts_probe()
245 input->name = DRIVER_NAME; in grts_probe()
246 input->id.bustype = BUS_HOST; in grts_probe()
247 input->open = grts_open; in grts_probe()
248 input->close = grts_close; in grts_probe()
250 input_set_abs_params(input, ABS_X, 0, GRTS_MAX_POS_MASK - 1, 0, 0); in grts_probe()
251 input_set_abs_params(input, ABS_Y, 0, GRTS_MAX_POS_MASK - 1, 0, 0); in grts_probe()
252 if (st->pressure) in grts_probe()
253 input_set_abs_params(input, ABS_PRESSURE, st->pressure_min, in grts_probe()
259 touchscreen_parse_properties(input, false, &st->prop); in grts_probe()
261 st->input = input; in grts_probe()
270 st->iio_cb = iio_channel_get_all_cb(dev, grts_cb, st); in grts_probe()
271 if (IS_ERR(st->iio_cb)) { in grts_probe()
273 return PTR_ERR(st->iio_cb); in grts_probe()
276 error = devm_add_action_or_reset(dev, grts_disable, st->iio_cb); in grts_probe()
287 .compatible = "resistive-adc-touch",
306 MODULE_DESCRIPTION("Generic ADC Resistive Touch Driver");