Start to fix wayland backend

Starts to update the wayland backend to the new backend api.
Not yet updated to libinput branch (not yet compiling).
This commit is contained in:
nyorain 2017-06-19 17:46:50 +02:00
parent 325a331425
commit 904739c405
4 changed files with 76 additions and 52 deletions

View file

@ -5,10 +5,10 @@ include_directories(
) )
add_library(wlr-backend add_library(wlr-backend
#wayland/backend.c wayland/backend.c
#wayland/registry.c wayland/registry.c
#wayland/wl_seat.c wayland/wl_seat.c
#wayland/wl_output.c wayland/wl_output.c
drm/backend.c drm/backend.c
drm/drm.c drm/drm.c
udev.c udev.c

View file

@ -2,58 +2,84 @@
#include <stdint.h> #include <stdint.h>
#include <wayland-server.h> #include <wayland-server.h>
#include <assert.h> #include <assert.h>
#include <wlr/backend/interface.h>
#include "backend/wayland.h" #include "backend/wayland.h"
#include "common/log.h" #include "common/log.h"
void wlr_wl_backend_free(struct wlr_wl_backend *backend) {
if (!backend) {
return;
}
// TODO: Free surfaces
for (size_t i = 0; backend->outputs && i < backend->outputs->length; ++i) {
struct wlr_wl_output *output = backend->outputs->items[i];
wlr_wl_output_free(output);
}
list_free(backend->outputs);
if (backend->seat) wlr_wl_seat_free(backend->seat);
if (backend->shm) wl_shm_destroy(backend->shm);
if (backend->shell) wl_shell_destroy(backend->shell);
if (backend->compositor) wl_compositor_destroy(backend->compositor);
if (backend->registry) wl_registry_destroy(backend->registry);
if (backend->remote_display) wl_display_disconnect(backend->remote_display);
free(backend);
}
/* /*
* Initializes the wayland backend. Opens a connection to a remote wayland * Initializes the wayland backend. Opens a connection to a remote wayland
* compositor and creates surfaces for each output, then registers globals on * compositor and creates surfaces for each output, then registers globals on
* the specified display. * the specified display.
*/ */
struct wlr_wl_backend *wlr_wl_backend_init( static bool wlr_wl_backend_init(struct wlr_backend_state* state) {
struct wl_display *display, size_t outputs) { state->remote_display = wl_display_connect(getenv("_WAYLAND_DISPLAY"));
assert(display); if (!state->remote_display) {
struct wlr_wl_backend *backend; wlr_log(L_ERROR, "Could not connect to remote display");
if (!(backend = calloc(sizeof(struct wlr_wl_backend), 1))) { return false;
wlr_log(L_ERROR, "Could not allocate backend");
goto error;
} }
if (!(backend->outputs = list_create())) {
if (!(state->registry = wl_display_get_registry(state->remote_display))) {
wlr_log(L_ERROR, "Could not obtain reference to remote registry");
return false;
}
wlr_wlb_registry_poll(state);
return true;
}
static void wlr_wl_backend_destroy(struct wlr_backend_state *state) {
if (!state) {
return;
}
// TODO: Free surfaces
for (size_t i = 0; state->outputs && i < state->outputs->length; ++i) {
struct wlr_wl_output *output = state->outputs->items[i];
wlr_wl_output_free(output);
}
list_free(state->outputs);
if (state->seat) wlr_wl_seat_free(state->seat);
if (state->shm) wl_shm_destroy(state->shm);
if (state->shell) wl_shell_destroy(state->shell);
if (state->compositor) wl_compositor_destroy(state->compositor);
if (state->registry) wl_registry_destroy(state->registry);
if (state->remote_display) wl_display_disconnect(state->remote_display);
free(state);
}
static struct wlr_backend_impl backend_impl = {
.init = wlr_wl_backend_init,
.destroy = wlr_wl_backend_destroy
};
struct wlr_backend *wlr_wl_backend_create(struct wl_display *display,
size_t outputs) {
wlr_log(L_INFO, "Initalizing wayland backend");
struct wlr_backend_state *state = calloc(1, sizeof(struct wlr_backend_state));
if (!state) {
wlr_log(L_ERROR, "Allocation failed: %s", strerror(errno));
return NULL;
}
struct wlr_backend *backend = wlr_backend_create(&backend_impl, state);
if (!backend) {
wlr_log(L_ERROR, "Allocation failed: %s", strerror(errno));
return NULL;
}
if (!(state->outputs = list_create())) {
wlr_log(L_ERROR, "Could not allocate output list"); wlr_log(L_ERROR, "Could not allocate output list");
goto error; goto error;
} }
backend->local_display = display; state->local_display = display;
backend->remote_display = wl_display_connect(getenv("_WAYLAND_DISPLAY"));
if (!backend->remote_display) {
wlr_log(L_ERROR, "Could not connect to remote display");
goto error;
}
if (!(backend->registry = wl_display_get_registry(backend->remote_display))) {
wlr_log(L_ERROR, "Could not obtain reference to remote registry");
goto error;
}
wlr_wlb_registry_poll(backend);
return backend; return backend;
error: error:
wlr_wl_backend_free(backend); free(state);
free(backend);
return NULL; return NULL;
} }

View file

@ -5,8 +5,9 @@
#include <wayland-server.h> #include <wayland-server.h>
#include <wlr/common/list.h> #include <wlr/common/list.h>
#include <wlr/wayland.h> #include <wlr/wayland.h>
#include <wlr/backend/wayland.h>
struct wlr_wl_backend { struct wlr_backend_state {
/* local state */ /* local state */
struct wl_display *local_display; struct wl_display *local_display;
/* remote state */ /* remote state */
@ -19,7 +20,7 @@ struct wlr_wl_backend {
list_t *outputs; list_t *outputs;
}; };
void wlr_wlb_registry_poll(struct wlr_wl_backend *backend); void wlr_wlb_registry_poll(struct wlr_backend_state *backend);
extern const struct wl_seat_listener seat_listener; extern const struct wl_seat_listener seat_listener;
extern const struct wl_output_listener output_listener; extern const struct wl_output_listener output_listener;

View file

@ -1,14 +1,11 @@
#ifndef _WLR_BACKEND_WAYLAND_INTERNAL_H #ifndef WLR_BACKEND_WAYLAND_H
#define _WLR_BACKEND_WAYLAND_INTERNAL_H #define WLR_BACKEND_WAYLAND_H
#include <wayland-client.h> #include <wayland-client.h>
#include <wayland-server.h> #include <wayland-server.h>
#include <wlr/wayland.h> #include <wlr/backend.h>
struct wlr_wl_backend; struct wlr_backend *wlr_wl_backend_create(struct wl_display *display,
void wlr_wl_backend_free(struct wlr_wl_backend *backend);
struct wlr_wl_backend *wlr_wl_backend_init(struct wl_display *display,
size_t outputs); size_t outputs);
#endif #endif