2 * Copyright © 2013 Jonas Ådahl
4 * Permission to use, copy, modify, distribute, and sell this software and
5 * its documentation for any purpose is hereby granted without fee, provided
6 * that the above copyright notice appear in all copies and that both that
7 * copyright notice and this permission notice appear in supporting
8 * documentation, and that the name of the copyright holders not be used in
9 * advertising or publicity pertaining to distribution of the software
10 * without specific, written prior permission. The copyright holders make
11 * no representations about the suitability of this software for any
12 * purpose. It is provided "as is" without express or implied warranty.
14 * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
15 * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
16 * FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
17 * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
18 * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
19 * CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
20 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
29 #include <sys/epoll.h>
34 #include "libinput-private.h"
36 #include "udev-seat.h"
38 enum libinput_event_class {
39 LIBINPUT_EVENT_CLASS_BASE,
40 LIBINPUT_EVENT_CLASS_SEAT,
41 LIBINPUT_EVENT_CLASS_DEVICE,
44 struct libinput_source {
45 libinput_source_dispatch_t dispatch;
51 struct libinput_event {
52 enum libinput_event_type type;
53 union libinput_event_target target;
56 struct libinput_event_added_seat {
57 struct libinput_event base;
58 struct libinput_seat *seat;
61 struct libinput_event_removed_seat {
62 struct libinput_event base;
63 struct libinput_seat *seat;
66 struct libinput_event_added_device {
67 struct libinput_event base;
68 struct libinput_device *device;
71 struct libinput_event_removed_device {
72 struct libinput_event base;
73 struct libinput_device *device;
76 struct libinput_event_device_register_capability {
77 struct libinput_event base;
78 enum libinput_device_capability capability;
81 struct libinput_event_device_unregister_capability {
82 struct libinput_event base;
83 enum libinput_device_capability capability;
86 struct libinput_event_keyboard_key {
87 struct libinput_event base;
90 enum libinput_keyboard_key_state state;
93 struct libinput_event_pointer_motion {
94 struct libinput_event base;
100 struct libinput_event_pointer_motion_absolute {
101 struct libinput_event base;
107 struct libinput_event_pointer_button {
108 struct libinput_event base;
111 enum libinput_pointer_button_state state;
114 struct libinput_event_pointer_axis {
115 struct libinput_event base;
117 enum libinput_pointer_axis axis;
121 struct libinput_event_touch_touch {
122 struct libinput_event base;
127 enum libinput_touch_type touch_type;
131 libinput_post_event(struct libinput *libinput,
132 struct libinput_event *event);
134 LIBINPUT_EXPORT enum libinput_event_type
135 libinput_event_get_type(struct libinput_event *event)
140 LIBINPUT_EXPORT union libinput_event_target
141 libinput_event_get_target(struct libinput_event *event)
143 return event->target;
146 LIBINPUT_EXPORT struct libinput_seat *
147 libinput_event_added_seat_get_seat(struct libinput_event_added_seat *event)
152 LIBINPUT_EXPORT struct libinput_seat *
153 libinput_event_removed_seat_get_seat(struct libinput_event_removed_seat *event)
158 LIBINPUT_EXPORT struct libinput_device *
159 libinput_event_added_device_get_device(
160 struct libinput_event_added_device *event)
162 return event->device;
165 LIBINPUT_EXPORT struct libinput_device *
166 libinput_event_removed_device_get_device(
167 struct libinput_event_removed_device *event)
169 return event->device;
172 LIBINPUT_EXPORT enum libinput_device_capability
173 libinput_event_device_register_capability_get_capability(
174 struct libinput_event_device_register_capability *event)
176 return event->capability;
179 LIBINPUT_EXPORT enum libinput_device_capability
180 libinput_event_device_unregister_capability_get_capability(
181 struct libinput_event_device_unregister_capability *event)
183 return event->capability;
186 LIBINPUT_EXPORT uint32_t
187 libinput_event_keyboard_key_get_time(
188 struct libinput_event_keyboard_key *event)
193 LIBINPUT_EXPORT uint32_t
194 libinput_event_keyboard_key_get_key(
195 struct libinput_event_keyboard_key *event)
200 LIBINPUT_EXPORT enum libinput_keyboard_key_state
201 libinput_event_keyboard_key_get_state(
202 struct libinput_event_keyboard_key *event)
207 LIBINPUT_EXPORT uint32_t
208 libinput_event_pointer_motion_get_time(
209 struct libinput_event_pointer_motion *event)
214 LIBINPUT_EXPORT li_fixed_t
215 libinput_event_pointer_motion_get_dx(
216 struct libinput_event_pointer_motion *event)
221 LIBINPUT_EXPORT li_fixed_t
222 libinput_event_pointer_motion_get_dy(
223 struct libinput_event_pointer_motion *event)
228 LIBINPUT_EXPORT uint32_t
229 libinput_event_pointer_motion_absolute_get_time(
230 struct libinput_event_pointer_motion_absolute *event)
235 LIBINPUT_EXPORT li_fixed_t
236 libinput_event_pointer_motion_absolute_get_x(
237 struct libinput_event_pointer_motion_absolute *event)
242 LIBINPUT_EXPORT li_fixed_t
243 libinput_event_pointer_motion_absolute_get_y(
244 struct libinput_event_pointer_motion_absolute *event)
249 LIBINPUT_EXPORT uint32_t
250 libinput_event_pointer_button_get_time(
251 struct libinput_event_pointer_button *event)
256 LIBINPUT_EXPORT uint32_t
257 libinput_event_pointer_button_get_button(
258 struct libinput_event_pointer_button *event)
260 return event->button;
263 LIBINPUT_EXPORT enum libinput_pointer_button_state
264 libinput_event_pointer_button_get_state(
265 struct libinput_event_pointer_button *event)
270 LIBINPUT_EXPORT uint32_t
271 libinput_event_pointer_axis_get_time(
272 struct libinput_event_pointer_axis *event)
277 LIBINPUT_EXPORT enum libinput_pointer_axis
278 libinput_event_pointer_axis_get_axis(
279 struct libinput_event_pointer_axis *event)
284 LIBINPUT_EXPORT li_fixed_t
285 libinput_event_pointer_axis_get_value(
286 struct libinput_event_pointer_axis *event)
291 LIBINPUT_EXPORT uint32_t
292 libinput_event_touch_touch_get_time(
293 struct libinput_event_touch_touch *event)
298 LIBINPUT_EXPORT uint32_t
299 libinput_event_touch_touch_get_slot(
300 struct libinput_event_touch_touch *event)
305 LIBINPUT_EXPORT li_fixed_t
306 libinput_event_touch_touch_get_x(
307 struct libinput_event_touch_touch *event)
312 LIBINPUT_EXPORT li_fixed_t
313 libinput_event_touch_touch_get_y(
314 struct libinput_event_touch_touch *event)
319 LIBINPUT_EXPORT enum libinput_touch_type
320 libinput_event_touch_touch_get_touch_type(
321 struct libinput_event_touch_touch *event)
323 return event->touch_type;
326 struct libinput_source *
327 libinput_add_fd(struct libinput *libinput,
329 libinput_source_dispatch_t dispatch,
332 struct libinput_source *source;
333 struct epoll_event ep;
335 source = malloc(sizeof *source);
339 source->dispatch = dispatch;
340 source->user_data = user_data;
343 memset(&ep, 0, sizeof ep);
345 ep.data.ptr = source;
347 if (epoll_ctl(libinput->epoll_fd, EPOLL_CTL_ADD, fd, &ep) < 0) {
357 libinput_remove_source(struct libinput *libinput,
358 struct libinput_source *source)
360 epoll_ctl(libinput->epoll_fd, EPOLL_CTL_DEL, source->fd, NULL);
363 list_insert(&libinput->source_destroy_list, &source->link);
367 libinput_init(struct libinput *libinput,
368 const struct libinput_interface *interface,
371 libinput->epoll_fd = epoll_create1(EPOLL_CLOEXEC);;
372 if (libinput->epoll_fd < 0)
375 libinput->events_len = 4;
376 libinput->events = zalloc(libinput->events_len * sizeof(*libinput->events));
377 if (!libinput->events) {
378 close(libinput->epoll_fd);
382 libinput->interface = interface;
383 libinput->user_data = user_data;
384 list_init(&libinput->source_destroy_list);
385 list_init(&libinput->seat_list);
391 libinput_device_destroy(struct libinput_device *device);
394 libinput_seat_destroy(struct libinput_seat *seat);
397 libinput_destroy(struct libinput *libinput)
399 struct libinput_event *event;
400 struct libinput_device *device, *next_device;
401 struct libinput_seat *seat, *next_seat;
403 if (libinput == NULL)
406 while ((event = libinput_get_event(libinput)))
407 libinput_event_destroy(event);
408 free(libinput->events);
410 list_for_each_safe(seat, next_seat, &libinput->seat_list, link) {
411 list_for_each_safe(device, next_device,
414 libinput_device_destroy(device);
416 libinput_seat_destroy(seat);
419 close(libinput->epoll_fd);
423 static enum libinput_event_class
424 libinput_event_get_class(struct libinput_event *event)
426 switch (event->type) {
427 case LIBINPUT_EVENT_ADDED_SEAT:
428 case LIBINPUT_EVENT_REMOVED_SEAT:
429 case LIBINPUT_EVENT_ADDED_DEVICE:
430 case LIBINPUT_EVENT_REMOVED_DEVICE:
431 return LIBINPUT_EVENT_CLASS_BASE;
433 case LIBINPUT_EVENT_DEVICE_REGISTER_CAPABILITY:
434 case LIBINPUT_EVENT_DEVICE_UNREGISTER_CAPABILITY:
435 case LIBINPUT_EVENT_KEYBOARD_KEY:
436 case LIBINPUT_EVENT_POINTER_MOTION:
437 case LIBINPUT_EVENT_POINTER_MOTION_ABSOLUTE:
438 case LIBINPUT_EVENT_POINTER_BUTTON:
439 case LIBINPUT_EVENT_POINTER_AXIS:
440 case LIBINPUT_EVENT_TOUCH_TOUCH:
441 return LIBINPUT_EVENT_CLASS_DEVICE;
444 /* We should never end up here. */
449 libinput_event_destroy(struct libinput_event *event)
454 switch (libinput_event_get_class(event)) {
455 case LIBINPUT_EVENT_CLASS_BASE:
457 case LIBINPUT_EVENT_CLASS_SEAT:
458 libinput_seat_unref(event->target.seat);
460 case LIBINPUT_EVENT_CLASS_DEVICE:
461 libinput_device_unref(event->target.device);
469 open_restricted(struct libinput *libinput,
470 const char *path, int flags)
472 return libinput->interface->open_restricted(path,
474 libinput->user_data);
478 close_restricted(struct libinput *libinput, int fd)
480 return libinput->interface->close_restricted(fd, libinput->user_data);
484 libinput_seat_init(struct libinput_seat *seat,
485 struct libinput *libinput,
489 seat->libinput = libinput;
490 seat->name = strdup(name);
491 list_init(&seat->devices_list);
495 libinput_seat_ref(struct libinput_seat *seat)
501 libinput_seat_destroy(struct libinput_seat *seat)
504 udev_seat_destroy((struct udev_seat *) seat);
508 libinput_seat_unref(struct libinput_seat *seat)
510 assert(seat->refcount > 0);
512 if (seat->refcount == 0)
513 libinput_seat_destroy(seat);
517 libinput_seat_set_user_data(struct libinput_seat *seat, void *user_data)
519 seat->user_data = user_data;
522 LIBINPUT_EXPORT void *
523 libinput_seat_get_user_data(struct libinput_seat *seat)
525 return seat->user_data;
528 LIBINPUT_EXPORT const char *
529 libinput_seat_get_name(struct libinput_seat *seat)
535 libinput_device_init(struct libinput_device *device,
536 struct libinput_seat *seat)
539 device->refcount = 1;
543 libinput_device_ref(struct libinput_device *device)
549 libinput_device_destroy(struct libinput_device *device)
551 evdev_device_destroy((struct evdev_device *) device);
555 libinput_device_unref(struct libinput_device *device)
557 assert(device->refcount > 0);
559 if (device->refcount == 0)
560 libinput_device_destroy(device);
564 libinput_get_fd(struct libinput *libinput)
566 return libinput->epoll_fd;
570 libinput_dispatch(struct libinput *libinput)
572 struct libinput_source *source, *next;
573 struct epoll_event ep[32];
576 count = epoll_wait(libinput->epoll_fd, ep, ARRAY_LENGTH(ep), 0);
580 for (i = 0; i < count; ++i) {
581 source = ep[i].data.ptr;
582 if (source->fd == -1)
585 source->dispatch(source->user_data);
588 list_for_each_safe(source, next, &libinput->source_destroy_list, link)
590 list_init(&libinput->source_destroy_list);
596 init_event_base(struct libinput_event *event,
597 enum libinput_event_type type,
598 union libinput_event_target target)
601 event->target = target;
605 post_base_event(struct libinput *libinput,
606 enum libinput_event_type type,
607 struct libinput_event *event)
609 init_event_base(event, type,
610 (union libinput_event_target) { .libinput = libinput });
611 libinput_post_event(libinput, event);
615 post_device_event(struct libinput_device *device,
616 enum libinput_event_type type,
617 struct libinput_event *event)
619 init_event_base(event, type,
620 (union libinput_event_target) { .device = device });
621 libinput_post_event(device->seat->libinput, event);
625 notify_added_seat(struct libinput_seat *seat)
627 struct libinput_event_added_seat *added_seat_event;
629 added_seat_event = malloc(sizeof *added_seat_event);
630 if (!added_seat_event)
633 *added_seat_event = (struct libinput_event_added_seat) {
637 post_base_event(seat->libinput,
638 LIBINPUT_EVENT_ADDED_SEAT,
639 &added_seat_event->base);
643 notify_removed_seat(struct libinput_seat *seat)
645 struct libinput_event_removed_seat *removed_seat_event;
647 removed_seat_event = malloc(sizeof *removed_seat_event);
648 if (!removed_seat_event)
651 *removed_seat_event = (struct libinput_event_removed_seat) {
655 post_base_event(seat->libinput,
656 LIBINPUT_EVENT_REMOVED_SEAT,
657 &removed_seat_event->base);
661 notify_added_device(struct libinput_device *device)
663 struct libinput_event_added_device *added_device_event;
665 added_device_event = malloc(sizeof *added_device_event);
666 if (!added_device_event)
669 *added_device_event = (struct libinput_event_added_device) {
673 post_base_event(device->seat->libinput,
674 LIBINPUT_EVENT_ADDED_DEVICE,
675 &added_device_event->base);
679 notify_removed_device(struct libinput_device *device)
681 struct libinput_event_removed_device *removed_device_event;
683 removed_device_event = malloc(sizeof *removed_device_event);
684 if (!removed_device_event)
687 *removed_device_event = (struct libinput_event_removed_device) {
691 post_base_event(device->seat->libinput,
692 LIBINPUT_EVENT_REMOVED_DEVICE,
693 &removed_device_event->base);
697 device_register_capability(struct libinput_device *device,
698 enum libinput_device_capability capability)
700 struct libinput_event_device_register_capability *capability_event;
702 capability_event = malloc(sizeof *capability_event);
704 *capability_event = (struct libinput_event_device_register_capability) {
705 .capability = capability,
708 post_device_event(device,
709 LIBINPUT_EVENT_DEVICE_REGISTER_CAPABILITY,
710 &capability_event->base);
714 device_unregister_capability(struct libinput_device *device,
715 enum libinput_device_capability capability)
717 struct libinput_event_device_unregister_capability *capability_event;
719 capability_event = malloc(sizeof *capability_event);
721 *capability_event = (struct libinput_event_device_unregister_capability) {
722 .capability = capability,
725 post_device_event(device,
726 LIBINPUT_EVENT_DEVICE_UNREGISTER_CAPABILITY,
727 &capability_event->base);
731 keyboard_notify_key(struct libinput_device *device,
734 enum libinput_keyboard_key_state state)
736 struct libinput_event_keyboard_key *key_event;
738 key_event = malloc(sizeof *key_event);
742 *key_event = (struct libinput_event_keyboard_key) {
748 post_device_event(device,
749 LIBINPUT_EVENT_KEYBOARD_KEY,
754 pointer_notify_motion(struct libinput_device *device,
759 struct libinput_event_pointer_motion *motion_event;
761 motion_event = malloc(sizeof *motion_event);
765 *motion_event = (struct libinput_event_pointer_motion) {
771 post_device_event(device,
772 LIBINPUT_EVENT_POINTER_MOTION,
773 &motion_event->base);
777 pointer_notify_motion_absolute(struct libinput_device *device,
782 struct libinput_event_pointer_motion_absolute *motion_absolute_event;
784 motion_absolute_event = malloc(sizeof *motion_absolute_event);
785 if (!motion_absolute_event)
788 *motion_absolute_event = (struct libinput_event_pointer_motion_absolute) {
794 post_device_event(device,
795 LIBINPUT_EVENT_POINTER_MOTION_ABSOLUTE,
796 &motion_absolute_event->base);
800 pointer_notify_button(struct libinput_device *device,
803 enum libinput_pointer_button_state state)
805 struct libinput_event_pointer_button *button_event;
807 button_event = malloc(sizeof *button_event);
811 *button_event = (struct libinput_event_pointer_button) {
817 post_device_event(device,
818 LIBINPUT_EVENT_POINTER_BUTTON,
819 &button_event->base);
823 pointer_notify_axis(struct libinput_device *device,
825 enum libinput_pointer_axis axis,
828 struct libinput_event_pointer_axis *axis_event;
830 axis_event = malloc(sizeof *axis_event);
834 *axis_event = (struct libinput_event_pointer_axis) {
840 post_device_event(device,
841 LIBINPUT_EVENT_POINTER_AXIS,
846 touch_notify_touch(struct libinput_device *device,
851 enum libinput_touch_type touch_type)
853 struct libinput_event_touch_touch *touch_event;
855 touch_event = malloc(sizeof *touch_event);
859 *touch_event = (struct libinput_event_touch_touch) {
864 .touch_type = touch_type,
867 post_device_event(device,
868 LIBINPUT_EVENT_TOUCH_TOUCH,
873 libinput_post_event(struct libinput *libinput,
874 struct libinput_event *event)
876 struct libinput_event **events = libinput->events;
877 size_t events_len = libinput->events_len;
878 size_t events_count = libinput->events_count;
883 if (events_count > events_len) {
885 events = realloc(events, events_len * sizeof *events);
887 fprintf(stderr, "Failed to reallocate event ring "
892 if (libinput->events_count > 0 && libinput->events_in == 0) {
893 libinput->events_in = libinput->events_len;
894 } else if (libinput->events_count > 0 &&
895 libinput->events_out >= libinput->events_in) {
896 move_len = libinput->events_len - libinput->events_out;
897 new_out = events_len - move_len;
898 memmove(events + new_out,
899 events + libinput->events_out,
900 move_len * sizeof *events);
901 libinput->events_out = new_out;
904 libinput->events = events;
905 libinput->events_len = events_len;
908 switch (libinput_event_get_class(event)) {
909 case LIBINPUT_EVENT_CLASS_BASE:
911 case LIBINPUT_EVENT_CLASS_SEAT:
912 libinput_seat_ref(event->target.seat);
914 case LIBINPUT_EVENT_CLASS_DEVICE:
915 libinput_device_ref(event->target.device);
919 libinput->events_count = events_count;
920 events[libinput->events_in] = event;
921 libinput->events_in = (libinput->events_in + 1) % libinput->events_len;
924 LIBINPUT_EXPORT struct libinput_event *
925 libinput_get_event(struct libinput *libinput)
927 struct libinput_event *event;
929 if (libinput->events_count == 0)
932 event = libinput->events[libinput->events_out];
933 libinput->events_out =
934 (libinput->events_out + 1) % libinput->events_len;
935 libinput->events_count--;
940 LIBINPUT_EXPORT void *
941 libinput_get_user_data(struct libinput *libinput)
943 return libinput->user_data;
947 libinput_resume(struct libinput *libinput)
949 return udev_input_enable((struct udev_input *) libinput);
953 libinput_suspend(struct libinput *libinput)
955 udev_input_disable((struct udev_input *) libinput);
959 libinput_device_set_user_data(struct libinput_device *device, void *user_data)
961 device->user_data = user_data;
964 LIBINPUT_EXPORT void *
965 libinput_device_get_user_data(struct libinput_device *device)
967 return device->user_data;
970 LIBINPUT_EXPORT const char *
971 libinput_device_get_sysname(struct libinput_device *device)
973 return evdev_device_get_sysname((struct evdev_device *) device);
976 LIBINPUT_EXPORT const char *
977 libinput_device_get_output_name(struct libinput_device *device)
979 return evdev_device_get_output((struct evdev_device *) device);
982 LIBINPUT_EXPORT struct libinput_seat *
983 libinput_device_get_seat(struct libinput_device *device)
989 libinput_device_led_update(struct libinput_device *device,
990 enum libinput_led leds)
992 evdev_device_led_update((struct evdev_device *) device, leds);
996 libinput_device_get_keys(struct libinput_device *device,
997 char *keys, size_t size)
999 return evdev_device_get_keys((struct evdev_device *) device,
1004 LIBINPUT_EXPORT void
1005 libinput_device_calibrate(struct libinput_device *device,
1006 float calibration[6])
1008 evdev_device_calibrate((struct evdev_device *) device, calibration);
1012 libinput_device_has_capability(struct libinput_device *device,
1013 enum libinput_device_capability capability)
1015 return evdev_device_has_capability((struct evdev_device *) device,