Lines Matching refs:wm
107 static void wm97xx_acc_pen_up(struct wm97xx *wm)
115 static void wm97xx_acc_pen_up(struct wm97xx *wm)
126 static int wm97xx_acc_pen_down(struct wm97xx *wm)
156 dev_dbg(wm->dev, "Raw coordinates: x=%x, y=%x, p=%x\n",
167 input_report_abs(wm->input_dev, ABS_X, x & 0xfff);
168 input_report_abs(wm->input_dev, ABS_Y, y & 0xfff);
169 input_report_abs(wm->input_dev, ABS_PRESSURE, p & 0xfff);
170 input_report_key(wm->input_dev, BTN_TOUCH, (p != 0));
171 input_sync(wm->input_dev);
178 static int wm97xx_acc_startup(struct wm97xx *wm)
183 if (wm->ac97 == NULL)
188 if (wm->id != cinfo[idx].id)
194 wm->acc_rate = cinfo[sp_idx].code;
195 wm->acc_slot = ac97_touch_slot;
196 dev_info(wm->dev,
206 wm->variant = WM97xx_WM1613;
221 wm->pen_irq = gpio_to_irq(irq);
222 set_irq_type(wm->pen_irq, IRQ_TYPE_EDGE_BOTH);
228 switch (wm->id) {
234 wm97xx_config_gpio(wm, WM97XX_GPIO_13, WM97XX_GPIO_IN,
238 wm97xx_config_gpio(wm, WM97XX_GPIO_2, WM97XX_GPIO_OUT,
244 dev_err(wm->dev,
255 static void wm97xx_acc_shutdown(struct wm97xx *wm)
261 wm->pen_irq = 0;
265 static void wm97xx_irq_enable(struct wm97xx *wm, int enable)
268 enable_irq(wm->pen_irq);
270 disable_irq_nosync(wm->pen_irq);
285 struct wm97xx *wm = platform_get_drvdata(pdev);
287 return wm97xx_register_mach_ops(wm, &mainstone_mach_ops);
292 struct wm97xx *wm = platform_get_drvdata(pdev);
294 wm97xx_unregister_mach_ops(wm);