Lines Matching +full:timeout +full:- +full:touch +full:- +full:ms

1 // SPDX-License-Identifier: GPL-2.0-only
38 * Absolute coordinate packets are in the range 0-255 for both X and Y
53 /* Time in jiffies used to timeout various touch events (64 ms) */
59 * Swipe gesture from off-pad to on-pad
67 * 1 - 8 : least to most delay
113 * Touch sensitivity
114 * 1 - 7 : least to most sensitive
135 * 1 - 5 : slowest to fastest
147 * 0 - 7 : smallest to largest width
152 * 0 - 9 : smallest to largest height
157 * 1 - 6 : smallest to largest
162 * 0 - 7 : smallest to largest width
167 * 0 - 9 : smallest to largest height
179 * 1 - 9 : slowest to fastest
233 bool touch; member
238 struct byd_data *priv = psmouse->private; in byd_report_input()
239 struct input_dev *dev = psmouse->dev; in byd_report_input()
241 input_report_key(dev, BTN_TOUCH, priv->touch); in byd_report_input()
242 input_report_key(dev, BTN_TOOL_FINGER, priv->touch); in byd_report_input()
244 input_report_abs(dev, ABS_X, priv->abs_x); in byd_report_input()
245 input_report_abs(dev, ABS_Y, priv->abs_y); in byd_report_input()
246 input_report_key(dev, BTN_LEFT, priv->btn_left); in byd_report_input()
247 input_report_key(dev, BTN_RIGHT, priv->btn_right); in byd_report_input()
255 struct psmouse *psmouse = priv->psmouse; in byd_clear_touch()
257 serio_pause_rx(psmouse->ps2dev.serio); in byd_clear_touch()
258 priv->touch = false; in byd_clear_touch()
262 serio_continue_rx(psmouse->ps2dev.serio); in byd_clear_touch()
265 * Move cursor back to center of pad when we lose touch - this in byd_clear_touch()
269 priv->abs_x = BYD_PAD_WIDTH / 2; in byd_clear_touch()
270 priv->abs_y = BYD_PAD_HEIGHT / 2; in byd_clear_touch()
275 struct byd_data *priv = psmouse->private; in byd_process_byte()
276 u8 *pkt = psmouse->packet; in byd_process_byte()
278 if (psmouse->pktcnt > 0 && !(pkt[0] & PS2_ALWAYS_1)) { in byd_process_byte()
284 if (psmouse->pktcnt < psmouse->pktsize) in byd_process_byte()
291 if (!priv->touch) { in byd_process_byte()
294 priv->last_touch_time + BYD_TOUCH_TIMEOUT; in byd_process_byte()
295 priv->touch = time_after(jiffies, tap_time); in byd_process_byte()
298 priv->abs_x = pkt[1] * (BYD_PAD_WIDTH / 256); in byd_process_byte()
299 priv->abs_y = (255 - pkt[2]) * (BYD_PAD_HEIGHT / 256); in byd_process_byte()
304 /* Sign-extend if a sign bit is set. */ in byd_process_byte()
311 priv->abs_x += dx * BYD_DT; in byd_process_byte()
312 priv->abs_y -= dy * BYD_DT; in byd_process_byte()
314 priv->touch = true; in byd_process_byte()
320 psmouse->packet[0], psmouse->packet[1], in byd_process_byte()
321 psmouse->packet[2], psmouse->packet[3]); in byd_process_byte()
325 priv->btn_left = pkt[0] & PS2_LEFT; in byd_process_byte()
326 priv->btn_right = pkt[0] & PS2_RIGHT; in byd_process_byte()
330 /* Reset time since last touch. */ in byd_process_byte()
331 if (priv->touch) { in byd_process_byte()
332 priv->last_touch_time = jiffies; in byd_process_byte()
333 mod_timer(&priv->timer, jiffies + BYD_TOUCH_TIMEOUT); in byd_process_byte()
341 struct ps2dev *ps2dev = &psmouse->ps2dev; in byd_reset_touchpad()
350 * Intellimouse initialization sequence, to get 4-byte instead in byd_reset_touchpad()
351 * of 3-byte packets. in byd_reset_touchpad()
359 * BYD-specific initialization, which enables absolute mode and in byd_reset_touchpad()
360 * (if desired), the touchpad's built-in gesture detection. in byd_reset_touchpad()
364 /* The touchpad should reply with 4 seemingly-random bytes */ in byd_reset_touchpad()
391 return -EIO; in byd_reset_touchpad()
426 struct byd_data *priv = psmouse->private; in byd_disconnect()
429 del_timer(&priv->timer); in byd_disconnect()
430 kfree(psmouse->private); in byd_disconnect()
431 psmouse->private = NULL; in byd_disconnect()
437 struct ps2dev *ps2dev = &psmouse->ps2dev; in byd_detect()
441 return -1; in byd_detect()
443 return -1; in byd_detect()
445 return -1; in byd_detect()
447 return -1; in byd_detect()
449 return -1; in byd_detect()
452 return -ENODEV; in byd_detect()
457 psmouse->vendor = "BYD"; in byd_detect()
458 psmouse->name = "TouchPad"; in byd_detect()
466 struct input_dev *dev = psmouse->dev; in byd_init()
470 return -EIO; in byd_init()
473 return -EIO; in byd_init()
477 return -ENOMEM; in byd_init()
479 priv->psmouse = psmouse; in byd_init()
480 timer_setup(&priv->timer, byd_clear_touch, 0); in byd_init()
482 psmouse->private = priv; in byd_init()
483 psmouse->disconnect = byd_disconnect; in byd_init()
484 psmouse->reconnect = byd_reconnect; in byd_init()
485 psmouse->protocol_handler = byd_process_byte; in byd_init()
486 psmouse->pktsize = 4; in byd_init()
487 psmouse->resync_time = 0; in byd_init()
489 __set_bit(INPUT_PROP_POINTER, dev->propbit); in byd_init()
491 __set_bit(BTN_TOUCH, dev->keybit); in byd_init()
492 __set_bit(BTN_TOOL_FINGER, dev->keybit); in byd_init()
494 __set_bit(BTN_LEFT, dev->keybit); in byd_init()
495 __set_bit(BTN_RIGHT, dev->keybit); in byd_init()
496 __clear_bit(BTN_MIDDLE, dev->keybit); in byd_init()
499 __set_bit(EV_ABS, dev->evbit); in byd_init()
505 __clear_bit(EV_REL, dev->evbit); in byd_init()
506 __clear_bit(REL_X, dev->relbit); in byd_init()
507 __clear_bit(REL_Y, dev->relbit); in byd_init()