aboutsummaryrefslogtreecommitdiff
path: root/backend/drm
diff options
context:
space:
mode:
Diffstat (limited to 'backend/drm')
-rw-r--r--backend/drm/backend.c6
-rw-r--r--backend/drm/drm.c14
2 files changed, 16 insertions, 4 deletions
diff --git a/backend/drm/backend.c b/backend/drm/backend.c
index 0da84745..39f29da5 100644
--- a/backend/drm/backend.c
+++ b/backend/drm/backend.c
@@ -6,6 +6,7 @@
#include <wayland-server.h>
#include <wlr/session.h>
+#include <wlr/wayland.h>
#include <wlr/common/list.h>
#include "backend.h"
@@ -23,7 +24,10 @@ static void wlr_drm_backend_destroy(struct wlr_backend_state *state) {
if (!state) {
return;
}
- // TODO: free outputs in shared backend code
+ for (size_t i = 0; state->outputs && i < state->outputs->length; ++i) {
+ struct wlr_output_state *output = state->outputs->items[i];
+ wlr_output_destroy(output->wlr_output);
+ }
wlr_drm_renderer_free(&state->renderer);
wlr_udev_free(&state->udev);
wlr_session_close_file(state->session, state->fd);
diff --git a/backend/drm/drm.c b/backend/drm/drm.c
index e9af9899..088539c8 100644
--- a/backend/drm/drm.c
+++ b/backend/drm/drm.c
@@ -103,8 +103,13 @@ static void wlr_drm_output_begin(struct wlr_output_state *output) {
static void wlr_drm_output_end(struct wlr_output_state *output) {
struct wlr_drm_renderer *renderer = output->renderer;
- eglSwapBuffers(renderer->egl.display, output->egl);
+ if (!eglSwapBuffers(renderer->egl.display, output->egl)) {
+ return;
+ }
struct gbm_bo *bo = gbm_surface_lock_front_buffer(output->gbm);
+ if (!bo) {
+ return;
+ }
uint32_t fb_id = get_fb_for_bo(renderer->fd, bo);
drmModePageFlip(renderer->fd, output->crtc, fb_id, DRM_MODE_PAGE_FLIP_EVENT, output);
gbm_surface_release_buffer(output->gbm, bo);
@@ -399,7 +404,6 @@ void wlr_drm_scan_connectors(struct wlr_backend_state *state) {
conn->connection != DRM_MODE_CONNECTED) {
wlr_log(L_INFO, "'%s' disconnected", output->name);
- // TODO: Destroy
wlr_drm_output_cleanup(output, false);
}
@@ -459,6 +463,11 @@ void wlr_drm_output_cleanup(struct wlr_output_state *output, bool restore) {
switch (output->state) {
case DRM_OUTPUT_CONNECTED:
+ output->state = DRM_OUTPUT_DISCONNECTED;
+ if (restore) {
+ restore_output(output, renderer->fd);
+ restore = false;
+ }
eglDestroySurface(renderer->egl.display, output->egl);
gbm_surface_destroy(output->gbm);
output->egl = EGL_NO_SURFACE;
@@ -475,5 +484,4 @@ void wlr_drm_output_cleanup(struct wlr_output_state *output, bool restore) {
case DRM_OUTPUT_DISCONNECTED:
break;
}
- // TODO: free wlr_output
}