aboutsummaryrefslogtreecommitdiff
path: root/backend/drm
diff options
context:
space:
mode:
authoremersion <contact@emersion.fr>2017-09-09 11:32:03 +0200
committeremersion <contact@emersion.fr>2017-10-07 16:22:02 +0200
commitd0db6a80ab64ee1f5d090677c18f57109b36575a (patch)
tree79b6f3ec9abbfa494b777ff41a63d0e30c86b991 /backend/drm
parent35f970025133dc5ad627936a3cdeacb37b532072 (diff)
Add post_frame event to wlr_output, use wlr_drm_plane_make_current in wlr_drm_output_read_pixels
Diffstat (limited to 'backend/drm')
-rw-r--r--backend/drm/drm.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/backend/drm/drm.c b/backend/drm/drm.c
index 117e5749..ec0c29f7 100644
--- a/backend/drm/drm.c
+++ b/backend/drm/drm.c
@@ -636,9 +636,9 @@ static bool wlr_drm_connector_move_cursor(struct wlr_output *output,
static void wlr_drm_connector_read_pixels(struct wlr_output *_output,
void *out_data) {
- struct wlr_drm_output *output = (struct wlr_drm_output *)_output;
- struct wlr_drm_crtc *crtc = output->crtc;
- struct wlr_drm_plane *plane = crtc->primary;
+ struct wlr_drm_connector *conn = (struct wlr_drm_connector *)output;
+ struct wlr_drm_plane *plane = conn->crtc->primary;
+ wlr_drm_plane_make_current(conn->renderer, plane);
glReadPixels(0, 0, plane->width, plane->height, GL_BGRA_EXT, GL_UNSIGNED_BYTE,
out_data);
}
@@ -846,6 +846,7 @@ static void page_flip_handler(int fd, unsigned seq,
if (drm->session->active) {
wl_signal_emit(&conn->output.events.frame, &conn->output);
+ wl_signal_emit(&conn->output.events.post_frame, &conn->output);
}
}