From 27606cf1fb8eb7e17bc28a5422d5eb6adae7b243 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jonas=20=C3=85dahl?= Date: Mon, 12 Jun 2023 16:44:02 +0200 Subject: [PATCH] seat/native/impl: Start reading input device events when starting This opens up for a possibility to handle initial events (devices discovered on startup) during initialization, meaning we can figure out a more correct initial state that depends on available input devices. Part-of: --- src/backends/native/meta-backend-native.c | 16 ++++++++++ src/backends/native/meta-seat-impl.c | 38 +++++++++++++++++++++-- src/backends/native/meta-seat-impl.h | 2 ++ src/backends/native/meta-seat-native.c | 6 ++++ src/backends/native/meta-seat-native.h | 2 ++ 5 files changed, 61 insertions(+), 3 deletions(-) diff --git a/src/backends/native/meta-backend-native.c b/src/backends/native/meta-backend-native.c index 66ff7d0b3..3da8d9859 100644 --- a/src/backends/native/meta-backend-native.c +++ b/src/backends/native/meta-backend-native.c @@ -756,6 +756,17 @@ init_gpus (MetaBackendNative *native, return TRUE; } +static void +on_started (MetaContext *context, + MetaBackend *backend) +{ + ClutterBackend *clutter_backend = meta_backend_get_clutter_backend (backend); + ClutterSeat *seat; + + seat = clutter_backend_get_default_seat (clutter_backend); + meta_seat_native_start (META_SEAT_NATIVE (seat)); +} + static gboolean meta_backend_native_initable_init (GInitable *initable, GCancellable *cancellable, @@ -804,6 +815,11 @@ meta_backend_native_initable_init (GInitable *initable, if (!init_gpus (native, error)) return FALSE; + g_signal_connect (meta_backend_get_context (backend), + "started", + G_CALLBACK (on_started), + backend); + return initable_parent_iface->init (initable, cancellable, error); } diff --git a/src/backends/native/meta-seat-impl.c b/src/backends/native/meta-seat-impl.c index b70c785fa..1955c29fb 100644 --- a/src/backends/native/meta-seat-impl.c +++ b/src/backends/native/meta-seat-impl.c @@ -2809,7 +2809,6 @@ static gboolean init_libinput (MetaSeatImpl *seat_impl, GError **error) { - MetaEventSource *source; struct udev *udev; struct libinput *libinput; @@ -2841,12 +2840,19 @@ init_libinput (MetaSeatImpl *seat_impl, } seat_impl->libinput = libinput; - source = meta_event_source_new (seat_impl); - seat_impl->event_source = source; return TRUE; } +static void +init_libinput_source (MetaSeatImpl *seat_impl) +{ + MetaEventSource *source; + + source = meta_event_source_new (seat_impl); + seat_impl->event_source = source; +} + static gpointer input_thread (MetaSeatImpl *seat_impl) { @@ -3773,6 +3779,32 @@ meta_seat_impl_new (MetaSeatNative *seat_native, NULL); } +static gboolean +start_in_impl (GTask *task) +{ + MetaSeatImpl *seat_impl = g_task_get_source_object (task); + + if (seat_impl->libinput) + init_libinput_source (seat_impl); + + g_task_return_boolean (task, TRUE); + + return G_SOURCE_REMOVE; +} + +void +meta_seat_impl_start (MetaSeatImpl *seat_impl) +{ + GTask *task; + + g_return_if_fail (META_IS_SEAT_IMPL (seat_impl)); + + task = g_task_new (seat_impl, NULL, NULL, NULL); + meta_seat_impl_run_input_task (seat_impl, task, + (GSourceFunc) start_in_impl); + g_object_unref (task); +} + void meta_seat_impl_notify_kbd_a11y_flags_changed_in_impl (MetaSeatImpl *seat_impl, MetaKeyboardA11yFlags new_flags, diff --git a/src/backends/native/meta-seat-impl.h b/src/backends/native/meta-seat-impl.h index 3bc8837d3..53a2ed76a 100644 --- a/src/backends/native/meta-seat-impl.h +++ b/src/backends/native/meta-seat-impl.h @@ -131,6 +131,8 @@ MetaSeatImpl * meta_seat_impl_new (MetaSeatNative *seat_native, const char *seat_id, MetaSeatNativeFlag flags); +void meta_seat_impl_start (MetaSeatImpl *seat_impl); + void meta_seat_impl_destroy (MetaSeatImpl *seat_impl); META_EXPORT_TEST diff --git a/src/backends/native/meta-seat-native.c b/src/backends/native/meta-seat-native.c index 539f4a5bb..0265a01bc 100644 --- a/src/backends/native/meta-seat-native.c +++ b/src/backends/native/meta-seat-native.c @@ -425,6 +425,12 @@ meta_seat_native_init (MetaSeatNative *seat) seat->reserved_virtual_slots = g_hash_table_new (NULL, NULL); } +void +meta_seat_native_start (MetaSeatNative *seat_native) +{ + meta_seat_impl_start (seat_native->impl); +} + /** * meta_seat_native_release_devices: * diff --git a/src/backends/native/meta-seat-native.h b/src/backends/native/meta-seat-native.h index 750d3c14c..75a44269f 100644 --- a/src/backends/native/meta-seat-native.h +++ b/src/backends/native/meta-seat-native.h @@ -71,6 +71,8 @@ META_EXPORT_TEST G_DECLARE_FINAL_TYPE (MetaSeatNative, meta_seat_native, META, SEAT_NATIVE, ClutterSeat) +void meta_seat_native_start (MetaSeatNative *seat_native); + void meta_seat_native_set_libinput_seat (MetaSeatNative *seat, struct libinput_seat *libinput_seat);