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"
37 enum libinput_event_class {
38 LIBINPUT_EVENT_CLASS_BASE,
39 LIBINPUT_EVENT_CLASS_SEAT,
40 LIBINPUT_EVENT_CLASS_DEVICE,
43 struct libinput_source {
44 libinput_source_dispatch_t dispatch;
50 struct libinput_event {
51 enum libinput_event_type type;
52 union libinput_event_target target;
55 struct libinput_event_added_seat {
56 struct libinput_event base;
57 struct libinput_seat *seat;
60 struct libinput_event_removed_seat {
61 struct libinput_event base;
62 struct libinput_seat *seat;
65 struct libinput_event_added_device {
66 struct libinput_event base;
67 struct libinput_device *device;
70 struct libinput_event_removed_device {
71 struct libinput_event base;
72 struct libinput_device *device;
75 struct libinput_event_device_register_capability {
76 struct libinput_event base;
77 enum libinput_device_capability capability;
80 struct libinput_event_device_unregister_capability {
81 struct libinput_event base;
82 enum libinput_device_capability capability;
85 struct libinput_event_keyboard_key {
86 struct libinput_event base;
89 enum libinput_keyboard_key_state state;
92 struct libinput_event_pointer_motion {
93 struct libinput_event base;
99 struct libinput_event_pointer_motion_absolute {
100 struct libinput_event base;
106 struct libinput_event_pointer_button {
107 struct libinput_event base;
110 enum libinput_pointer_button_state state;
113 struct libinput_event_pointer_axis {
114 struct libinput_event base;
116 enum libinput_pointer_axis axis;
120 struct libinput_event_touch_touch {
121 struct libinput_event base;
126 enum libinput_touch_type touch_type;
130 libinput_post_event(struct libinput *libinput,
131 struct libinput_event *event);
133 LIBINPUT_EXPORT enum libinput_event_type
134 libinput_event_get_type(struct libinput_event *event)
139 LIBINPUT_EXPORT union libinput_event_target
140 libinput_event_get_target(struct libinput_event *event)
142 return event->target;
145 LIBINPUT_EXPORT struct libinput_seat *
146 libinput_event_added_seat_get_seat(struct libinput_event_added_seat *event)
151 LIBINPUT_EXPORT struct libinput_seat *
152 libinput_event_removed_seat_get_seat(struct libinput_event_removed_seat *event)
157 LIBINPUT_EXPORT struct libinput_device *
158 libinput_event_added_device_get_device(
159 struct libinput_event_added_device *event)
161 return event->device;
164 LIBINPUT_EXPORT struct libinput_device *
165 libinput_event_removed_device_get_device(
166 struct libinput_event_removed_device *event)
168 return event->device;
171 LIBINPUT_EXPORT enum libinput_device_capability
172 libinput_event_device_register_capability_get_capability(
173 struct libinput_event_device_register_capability *event)
175 return event->capability;
178 LIBINPUT_EXPORT enum libinput_device_capability
179 libinput_event_device_unregister_capability_get_capability(
180 struct libinput_event_device_unregister_capability *event)
182 return event->capability;
185 LIBINPUT_EXPORT uint32_t
186 libinput_event_keyboard_key_get_time(
187 struct libinput_event_keyboard_key *event)
192 LIBINPUT_EXPORT uint32_t
193 libinput_event_keyboard_key_get_key(
194 struct libinput_event_keyboard_key *event)
199 LIBINPUT_EXPORT enum libinput_keyboard_key_state
200 libinput_event_keyboard_key_get_state(
201 struct libinput_event_keyboard_key *event)
206 LIBINPUT_EXPORT uint32_t
207 libinput_event_pointer_motion_get_time(
208 struct libinput_event_pointer_motion *event)
213 LIBINPUT_EXPORT li_fixed_t
214 libinput_event_pointer_motion_get_dx(
215 struct libinput_event_pointer_motion *event)
220 LIBINPUT_EXPORT li_fixed_t
221 libinput_event_pointer_motion_get_dy(
222 struct libinput_event_pointer_motion *event)
227 LIBINPUT_EXPORT uint32_t
228 libinput_event_pointer_motion_absolute_get_time(
229 struct libinput_event_pointer_motion_absolute *event)
234 LIBINPUT_EXPORT li_fixed_t
235 libinput_event_pointer_motion_absolute_get_x(
236 struct libinput_event_pointer_motion_absolute *event)
241 LIBINPUT_EXPORT li_fixed_t
242 libinput_event_pointer_motion_absolute_get_y(
243 struct libinput_event_pointer_motion_absolute *event)
248 LIBINPUT_EXPORT uint32_t
249 libinput_event_pointer_button_get_time(
250 struct libinput_event_pointer_button *event)
255 LIBINPUT_EXPORT uint32_t
256 libinput_event_pointer_button_get_button(
257 struct libinput_event_pointer_button *event)
259 return event->button;
262 LIBINPUT_EXPORT enum libinput_pointer_button_state
263 libinput_event_pointer_button_get_state(
264 struct libinput_event_pointer_button *event)
269 LIBINPUT_EXPORT uint32_t
270 libinput_event_pointer_axis_get_time(
271 struct libinput_event_pointer_axis *event)
276 LIBINPUT_EXPORT enum libinput_pointer_axis
277 libinput_event_pointer_axis_get_axis(
278 struct libinput_event_pointer_axis *event)
283 LIBINPUT_EXPORT li_fixed_t
284 libinput_event_pointer_axis_get_value(
285 struct libinput_event_pointer_axis *event)
290 LIBINPUT_EXPORT uint32_t
291 libinput_event_touch_touch_get_time(
292 struct libinput_event_touch_touch *event)
297 LIBINPUT_EXPORT uint32_t
298 libinput_event_touch_touch_get_slot(
299 struct libinput_event_touch_touch *event)
304 LIBINPUT_EXPORT li_fixed_t
305 libinput_event_touch_touch_get_x(
306 struct libinput_event_touch_touch *event)
311 LIBINPUT_EXPORT li_fixed_t
312 libinput_event_touch_touch_get_y(
313 struct libinput_event_touch_touch *event)
318 LIBINPUT_EXPORT enum libinput_touch_type
319 libinput_event_touch_touch_get_touch_type(
320 struct libinput_event_touch_touch *event)
322 return event->touch_type;
325 struct libinput_source *
326 libinput_add_fd(struct libinput *libinput,
328 libinput_source_dispatch_t dispatch,
331 struct libinput_source *source;
332 struct epoll_event ep;
334 source = malloc(sizeof *source);
338 source->dispatch = dispatch;
339 source->user_data = user_data;
342 memset(&ep, 0, sizeof ep);
344 ep.data.ptr = source;
346 if (epoll_ctl(libinput->epoll_fd, EPOLL_CTL_ADD, fd, &ep) < 0) {
356 libinput_remove_source(struct libinput *libinput,
357 struct libinput_source *source)
359 epoll_ctl(libinput->epoll_fd, EPOLL_CTL_DEL, source->fd, NULL);
362 list_insert(&libinput->source_destroy_list, &source->link);
366 libinput_init(struct libinput *libinput,
367 const struct libinput_interface *interface,
368 const struct libinput_interface_backend *interface_backend,
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->interface_backend = interface_backend;
384 libinput->user_data = user_data;
385 list_init(&libinput->source_destroy_list);
386 list_init(&libinput->seat_list);
392 libinput_device_destroy(struct libinput_device *device);
395 libinput_seat_destroy(struct libinput_seat *seat);
398 libinput_drop_destroyed_sources(struct libinput *libinput)
400 struct libinput_source *source, *next;
402 list_for_each_safe(source, next, &libinput->source_destroy_list, link)
404 list_init(&libinput->source_destroy_list);
408 libinput_destroy(struct libinput *libinput)
410 struct libinput_event *event;
411 struct libinput_device *device, *next_device;
412 struct libinput_seat *seat, *next_seat;
414 if (libinput == NULL)
417 libinput_suspend(libinput);
419 libinput->interface_backend->destroy(libinput);
421 while ((event = libinput_get_event(libinput)))
422 libinput_event_destroy(event);
424 libinput_drop_destroyed_sources(libinput);
426 free(libinput->events);
428 list_for_each_safe(seat, next_seat, &libinput->seat_list, link) {
429 list_for_each_safe(device, next_device,
432 libinput_device_destroy(device);
434 libinput_seat_destroy(seat);
437 close(libinput->epoll_fd);
441 static enum libinput_event_class
442 libinput_event_get_class(struct libinput_event *event)
444 switch (event->type) {
445 case LIBINPUT_EVENT_ADDED_SEAT:
446 case LIBINPUT_EVENT_REMOVED_SEAT:
447 case LIBINPUT_EVENT_ADDED_DEVICE:
448 case LIBINPUT_EVENT_REMOVED_DEVICE:
449 return LIBINPUT_EVENT_CLASS_BASE;
451 case LIBINPUT_EVENT_DEVICE_REGISTER_CAPABILITY:
452 case LIBINPUT_EVENT_DEVICE_UNREGISTER_CAPABILITY:
453 case LIBINPUT_EVENT_KEYBOARD_KEY:
454 case LIBINPUT_EVENT_POINTER_MOTION:
455 case LIBINPUT_EVENT_POINTER_MOTION_ABSOLUTE:
456 case LIBINPUT_EVENT_POINTER_BUTTON:
457 case LIBINPUT_EVENT_POINTER_AXIS:
458 case LIBINPUT_EVENT_TOUCH_TOUCH:
459 return LIBINPUT_EVENT_CLASS_DEVICE;
462 /* We should never end up here. */
467 libinput_event_destroy(struct libinput_event *event)
472 switch (libinput_event_get_class(event)) {
473 case LIBINPUT_EVENT_CLASS_BASE:
475 case LIBINPUT_EVENT_CLASS_SEAT:
476 libinput_seat_unref(event->target.seat);
478 case LIBINPUT_EVENT_CLASS_DEVICE:
479 libinput_device_unref(event->target.device);
483 if (libinput_event_get_type(event) == LIBINPUT_EVENT_ADDED_SEAT ||
484 libinput_event_get_type(event) == LIBINPUT_EVENT_REMOVED_SEAT)
485 libinput_seat_unref(((struct libinput_event_added_seat*)event)->seat);
491 open_restricted(struct libinput *libinput,
492 const char *path, int flags)
494 return libinput->interface->open_restricted(path,
496 libinput->user_data);
500 close_restricted(struct libinput *libinput, int fd)
502 return libinput->interface->close_restricted(fd, libinput->user_data);
506 libinput_seat_init(struct libinput_seat *seat,
507 struct libinput *libinput,
509 libinput_seat_destroy_func destroy)
512 seat->libinput = libinput;
513 seat->name = strdup(name);
514 seat->destroy = destroy;
515 list_init(&seat->devices_list);
519 libinput_seat_ref(struct libinput_seat *seat)
525 libinput_seat_destroy(struct libinput_seat *seat)
527 list_remove(&seat->link);
533 libinput_seat_unref(struct libinput_seat *seat)
535 assert(seat->refcount > 0);
537 if (seat->refcount == 0)
538 libinput_seat_destroy(seat);
542 libinput_seat_set_user_data(struct libinput_seat *seat, void *user_data)
544 seat->user_data = user_data;
547 LIBINPUT_EXPORT void *
548 libinput_seat_get_user_data(struct libinput_seat *seat)
550 return seat->user_data;
553 LIBINPUT_EXPORT const char *
554 libinput_seat_get_name(struct libinput_seat *seat)
560 libinput_device_init(struct libinput_device *device,
561 struct libinput_seat *seat)
564 device->refcount = 1;
568 libinput_device_ref(struct libinput_device *device)
574 libinput_device_destroy(struct libinput_device *device)
576 evdev_device_destroy((struct evdev_device *) device);
580 libinput_device_unref(struct libinput_device *device)
582 assert(device->refcount > 0);
584 if (device->refcount == 0)
585 libinput_device_destroy(device);
589 libinput_get_fd(struct libinput *libinput)
591 return libinput->epoll_fd;
595 libinput_dispatch(struct libinput *libinput)
597 struct libinput_source *source;
598 struct epoll_event ep[32];
601 count = epoll_wait(libinput->epoll_fd, ep, ARRAY_LENGTH(ep), 0);
605 for (i = 0; i < count; ++i) {
606 source = ep[i].data.ptr;
607 if (source->fd == -1)
610 source->dispatch(source->user_data);
613 libinput_drop_destroyed_sources(libinput);
619 init_event_base(struct libinput_event *event,
620 enum libinput_event_type type,
621 union libinput_event_target target)
624 event->target = target;
628 post_base_event(struct libinput *libinput,
629 enum libinput_event_type type,
630 struct libinput_event *event)
632 init_event_base(event, type,
633 (union libinput_event_target) { .libinput = libinput });
634 libinput_post_event(libinput, event);
638 post_device_event(struct libinput_device *device,
639 enum libinput_event_type type,
640 struct libinput_event *event)
642 init_event_base(event, type,
643 (union libinput_event_target) { .device = device });
644 libinput_post_event(device->seat->libinput, event);
648 notify_added_seat(struct libinput_seat *seat)
650 struct libinput_event_added_seat *added_seat_event;
652 added_seat_event = malloc(sizeof *added_seat_event);
653 if (!added_seat_event)
656 libinput_seat_ref(seat);
658 *added_seat_event = (struct libinput_event_added_seat) {
662 post_base_event(seat->libinput,
663 LIBINPUT_EVENT_ADDED_SEAT,
664 &added_seat_event->base);
668 notify_removed_seat(struct libinput_seat *seat)
670 struct libinput_event_removed_seat *removed_seat_event;
672 removed_seat_event = malloc(sizeof *removed_seat_event);
673 if (!removed_seat_event)
676 libinput_seat_ref(seat);
678 *removed_seat_event = (struct libinput_event_removed_seat) {
682 post_base_event(seat->libinput,
683 LIBINPUT_EVENT_REMOVED_SEAT,
684 &removed_seat_event->base);
688 notify_added_device(struct libinput_device *device)
690 struct libinput_event_added_device *added_device_event;
692 added_device_event = malloc(sizeof *added_device_event);
693 if (!added_device_event)
696 *added_device_event = (struct libinput_event_added_device) {
700 post_base_event(device->seat->libinput,
701 LIBINPUT_EVENT_ADDED_DEVICE,
702 &added_device_event->base);
706 notify_removed_device(struct libinput_device *device)
708 struct libinput_event_removed_device *removed_device_event;
710 removed_device_event = malloc(sizeof *removed_device_event);
711 if (!removed_device_event)
714 *removed_device_event = (struct libinput_event_removed_device) {
718 post_base_event(device->seat->libinput,
719 LIBINPUT_EVENT_REMOVED_DEVICE,
720 &removed_device_event->base);
724 device_register_capability(struct libinput_device *device,
725 enum libinput_device_capability capability)
727 struct libinput_event_device_register_capability *capability_event;
729 capability_event = malloc(sizeof *capability_event);
731 *capability_event = (struct libinput_event_device_register_capability) {
732 .capability = capability,
735 post_device_event(device,
736 LIBINPUT_EVENT_DEVICE_REGISTER_CAPABILITY,
737 &capability_event->base);
741 device_unregister_capability(struct libinput_device *device,
742 enum libinput_device_capability capability)
744 struct libinput_event_device_unregister_capability *capability_event;
746 capability_event = malloc(sizeof *capability_event);
748 *capability_event = (struct libinput_event_device_unregister_capability) {
749 .capability = capability,
752 post_device_event(device,
753 LIBINPUT_EVENT_DEVICE_UNREGISTER_CAPABILITY,
754 &capability_event->base);
758 keyboard_notify_key(struct libinput_device *device,
761 enum libinput_keyboard_key_state state)
763 struct libinput_event_keyboard_key *key_event;
765 key_event = malloc(sizeof *key_event);
769 *key_event = (struct libinput_event_keyboard_key) {
775 post_device_event(device,
776 LIBINPUT_EVENT_KEYBOARD_KEY,
781 pointer_notify_motion(struct libinput_device *device,
786 struct libinput_event_pointer_motion *motion_event;
788 motion_event = malloc(sizeof *motion_event);
792 *motion_event = (struct libinput_event_pointer_motion) {
798 post_device_event(device,
799 LIBINPUT_EVENT_POINTER_MOTION,
800 &motion_event->base);
804 pointer_notify_motion_absolute(struct libinput_device *device,
809 struct libinput_event_pointer_motion_absolute *motion_absolute_event;
811 motion_absolute_event = malloc(sizeof *motion_absolute_event);
812 if (!motion_absolute_event)
815 *motion_absolute_event = (struct libinput_event_pointer_motion_absolute) {
821 post_device_event(device,
822 LIBINPUT_EVENT_POINTER_MOTION_ABSOLUTE,
823 &motion_absolute_event->base);
827 pointer_notify_button(struct libinput_device *device,
830 enum libinput_pointer_button_state state)
832 struct libinput_event_pointer_button *button_event;
834 button_event = malloc(sizeof *button_event);
838 *button_event = (struct libinput_event_pointer_button) {
844 post_device_event(device,
845 LIBINPUT_EVENT_POINTER_BUTTON,
846 &button_event->base);
850 pointer_notify_axis(struct libinput_device *device,
852 enum libinput_pointer_axis axis,
855 struct libinput_event_pointer_axis *axis_event;
857 axis_event = malloc(sizeof *axis_event);
861 *axis_event = (struct libinput_event_pointer_axis) {
867 post_device_event(device,
868 LIBINPUT_EVENT_POINTER_AXIS,
873 touch_notify_touch(struct libinput_device *device,
878 enum libinput_touch_type touch_type)
880 struct libinput_event_touch_touch *touch_event;
882 touch_event = malloc(sizeof *touch_event);
886 *touch_event = (struct libinput_event_touch_touch) {
891 .touch_type = touch_type,
894 post_device_event(device,
895 LIBINPUT_EVENT_TOUCH_TOUCH,
900 libinput_post_event(struct libinput *libinput,
901 struct libinput_event *event)
903 struct libinput_event **events = libinput->events;
904 size_t events_len = libinput->events_len;
905 size_t events_count = libinput->events_count;
910 if (events_count > events_len) {
912 events = realloc(events, events_len * sizeof *events);
914 fprintf(stderr, "Failed to reallocate event ring "
919 if (libinput->events_count > 0 && libinput->events_in == 0) {
920 libinput->events_in = libinput->events_len;
921 } else if (libinput->events_count > 0 &&
922 libinput->events_out >= libinput->events_in) {
923 move_len = libinput->events_len - libinput->events_out;
924 new_out = events_len - move_len;
925 memmove(events + new_out,
926 events + libinput->events_out,
927 move_len * sizeof *events);
928 libinput->events_out = new_out;
931 libinput->events = events;
932 libinput->events_len = events_len;
935 switch (libinput_event_get_class(event)) {
936 case LIBINPUT_EVENT_CLASS_BASE:
938 case LIBINPUT_EVENT_CLASS_SEAT:
939 libinput_seat_ref(event->target.seat);
941 case LIBINPUT_EVENT_CLASS_DEVICE:
942 libinput_device_ref(event->target.device);
946 libinput->events_count = events_count;
947 events[libinput->events_in] = event;
948 libinput->events_in = (libinput->events_in + 1) % libinput->events_len;
951 LIBINPUT_EXPORT struct libinput_event *
952 libinput_get_event(struct libinput *libinput)
954 struct libinput_event *event;
956 if (libinput->events_count == 0)
959 event = libinput->events[libinput->events_out];
960 libinput->events_out =
961 (libinput->events_out + 1) % libinput->events_len;
962 libinput->events_count--;
967 LIBINPUT_EXPORT void *
968 libinput_get_user_data(struct libinput *libinput)
970 return libinput->user_data;
974 libinput_resume(struct libinput *libinput)
976 return libinput->interface_backend->resume(libinput);
980 libinput_suspend(struct libinput *libinput)
982 libinput->interface_backend->suspend(libinput);
986 libinput_device_set_user_data(struct libinput_device *device, void *user_data)
988 device->user_data = user_data;
991 LIBINPUT_EXPORT void *
992 libinput_device_get_user_data(struct libinput_device *device)
994 return device->user_data;
997 LIBINPUT_EXPORT const char *
998 libinput_device_get_sysname(struct libinput_device *device)
1000 return evdev_device_get_sysname((struct evdev_device *) device);
1003 LIBINPUT_EXPORT const char *
1004 libinput_device_get_output_name(struct libinput_device *device)
1006 return evdev_device_get_output((struct evdev_device *) device);
1009 LIBINPUT_EXPORT struct libinput_seat *
1010 libinput_device_get_seat(struct libinput_device *device)
1012 return device->seat;
1015 LIBINPUT_EXPORT void
1016 libinput_device_led_update(struct libinput_device *device,
1017 enum libinput_led leds)
1019 evdev_device_led_update((struct evdev_device *) device, leds);
1023 libinput_device_get_keys(struct libinput_device *device,
1024 char *keys, size_t size)
1026 return evdev_device_get_keys((struct evdev_device *) device,
1031 LIBINPUT_EXPORT void
1032 libinput_device_calibrate(struct libinput_device *device,
1033 float calibration[6])
1035 evdev_device_calibrate((struct evdev_device *) device, calibration);
1039 libinput_device_has_capability(struct libinput_device *device,
1040 enum libinput_device_capability capability)
1042 return evdev_device_has_capability((struct evdev_device *) device,