Input: byd - convert to using timer_setup()

In preparation for unconditionally passing the struct timer_list pointer to
all timer callbacks, switch to using the new timer_setup() and from_timer()
to pass the timer pointer explicitly.

Signed-off-by: Kees Cook <keescook@chromium.org>
Reviewed-by: Pali Rohár <pali.rohar@gmail.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
This commit is contained in:
Kees Cook 2017-10-19 17:22:46 -07:00 committed by Dmitry Torokhov
parent 91de76e661
commit ce23cbc857

View File

@ -227,6 +227,7 @@
struct byd_data { struct byd_data {
struct timer_list timer; struct timer_list timer;
struct psmouse *psmouse;
s32 abs_x; s32 abs_x;
s32 abs_y; s32 abs_y;
typeof(jiffies) last_touch_time; typeof(jiffies) last_touch_time;
@ -251,10 +252,10 @@ static void byd_report_input(struct psmouse *psmouse)
input_sync(dev); input_sync(dev);
} }
static void byd_clear_touch(unsigned long data) static void byd_clear_touch(struct timer_list *t)
{ {
struct psmouse *psmouse = (struct psmouse *)data; struct byd_data *priv = from_timer(priv, t, timer);
struct byd_data *priv = psmouse->private; struct psmouse *psmouse = priv->psmouse;
serio_pause_rx(psmouse->ps2dev.serio); serio_pause_rx(psmouse->ps2dev.serio);
priv->touch = false; priv->touch = false;
@ -478,7 +479,8 @@ int byd_init(struct psmouse *psmouse)
if (!priv) if (!priv)
return -ENOMEM; return -ENOMEM;
setup_timer(&priv->timer, byd_clear_touch, (unsigned long) psmouse); priv->psmouse = psmouse;
timer_setup(&priv->timer, byd_clear_touch, 0);
psmouse->private = priv; psmouse->private = priv;
psmouse->disconnect = byd_disconnect; psmouse->disconnect = byd_disconnect;