int reset;
struct {
+ bool enable;
+
struct wl_array events;
enum fsm_state state;
struct wl_event_source *timer_source;
enum fsm_event *pevent;
enum fsm_event event;
+ if (!touchpad->fsm.enable)
+ return;
+
if (touchpad->fsm.events.size == 0)
return;
{
enum fsm_event *pevent;
+ if (!touchpad->fsm.enable)
+ return;
+
pevent = wl_array_add(&touchpad->fsm.events, sizeof event);
if (pevent)
*pevent = event;
struct weston_motion_filter *accel;
struct wl_event_loop *loop;
+ unsigned long prop_bits[INPUT_PROP_MAX];
struct input_absinfo absinfo;
unsigned long abs_bits[NBITS(ABS_MAX)];
+ bool has_buttonpad;
+
double width;
double height;
double diagonal;
/* Detect model */
touchpad->model = get_touchpad_model(device);
+ ioctl(device->fd, EVIOCGPROP(sizeof(prop_bits)), prop_bits);
+ has_buttonpad = TEST_BIT(prop_bits, INPUT_PROP_BUTTONPAD);
+
/* Configure pressure */
ioctl(device->fd, EVIOCGBIT(EV_ABS, sizeof(abs_bits)), abs_bits);
if (TEST_BIT(abs_bits, ABS_PRESSURE)) {
return -1;
}
+ /* Configure */
+ touchpad->fsm.enable = !has_buttonpad;
+
return 0;
}