Lines Matching refs:wm

100 static void wm97xx_acc_pen_up(struct wm97xx *wm)  in wm97xx_acc_pen_up()  argument
115 static int wm97xx_acc_pen_down(struct wm97xx *wm) in wm97xx_acc_pen_down() argument
146 dev_dbg(wm->dev, "Raw coordinates: x=%x, y=%x, p=%x\n", in wm97xx_acc_pen_down()
157 input_report_abs(wm->input_dev, ABS_X, x & 0xfff); in wm97xx_acc_pen_down()
158 input_report_abs(wm->input_dev, ABS_Y, y & 0xfff); in wm97xx_acc_pen_down()
159 input_report_abs(wm->input_dev, ABS_PRESSURE, p & 0xfff); in wm97xx_acc_pen_down()
160 input_report_key(wm->input_dev, BTN_TOUCH, (p != 0)); in wm97xx_acc_pen_down()
161 input_sync(wm->input_dev); in wm97xx_acc_pen_down()
168 static int wm97xx_acc_startup(struct wm97xx *wm) in wm97xx_acc_startup() argument
173 if (wm->ac97 == NULL) in wm97xx_acc_startup()
178 if (wm->id != cinfo[idx].id) in wm97xx_acc_startup()
184 wm->acc_rate = cinfo[sp_idx].code; in wm97xx_acc_startup()
185 wm->acc_slot = ac97_touch_slot; in wm97xx_acc_startup()
186 dev_info(wm->dev, in wm97xx_acc_startup()
191 gpiod_irq = gpiod_get(wm->dev, "touch", GPIOD_IN); in wm97xx_acc_startup()
197 wm->pen_irq = gpiod_to_irq(gpiod_irq); in wm97xx_acc_startup()
198 irq_set_irq_type(wm->pen_irq, IRQ_TYPE_EDGE_BOTH); in wm97xx_acc_startup()
203 switch (wm->id) { in wm97xx_acc_startup()
209 wm97xx_config_gpio(wm, WM97XX_GPIO_13, WM97XX_GPIO_IN, in wm97xx_acc_startup()
213 wm97xx_config_gpio(wm, WM97XX_GPIO_2, WM97XX_GPIO_OUT, in wm97xx_acc_startup()
219 dev_err(wm->dev, in wm97xx_acc_startup()
229 static void wm97xx_acc_shutdown(struct wm97xx *wm) in wm97xx_acc_shutdown() argument
235 wm->pen_irq = 0; in wm97xx_acc_shutdown()
250 struct wm97xx *wm = platform_get_drvdata(pdev); in mainstone_wm97xx_probe() local
252 return wm97xx_register_mach_ops(wm, &mainstone_mach_ops); in mainstone_wm97xx_probe()
257 struct wm97xx *wm = platform_get_drvdata(pdev); in mainstone_wm97xx_remove() local
259 wm97xx_unregister_mach_ops(wm); in mainstone_wm97xx_remove()