aboutsummaryrefslogtreecommitdiff
path: root/include/backend/drm
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2020-12-22 18:42:59 +0100
committerSimon Ser <contact@emersion.fr>2021-01-10 11:24:35 +0100
commitd9bbc416a62c2d280e6921da6b25128a1b3a9e22 (patch)
tree5d59bb0dbe6c6c2c6031e6cb768155c70f96b6d7 /include/backend/drm
parent91cb0fc4432592a8c0806d3e63dc77ce16c73cb6 (diff)
backend/drm: re-use FBs
Instead of importing buffers to GBM and KMS at each frame, cache them and re-use them while the wlr_buffer is alive. This is the same as [1] and [2] but for the DRM backend. [1]: https://github.com/swaywm/wlroots/pull/2538 [2]: https://github.com/swaywm/wlroots/pull/2539
Diffstat (limited to 'include/backend/drm')
-rw-r--r--include/backend/drm/drm.h1
-rw-r--r--include/backend/drm/renderer.h5
2 files changed, 6 insertions, 0 deletions
diff --git a/include/backend/drm/drm.h b/include/backend/drm/drm.h
index 23b06847..52aacf39 100644
--- a/include/backend/drm/drm.h
+++ b/include/backend/drm/drm.h
@@ -86,6 +86,7 @@ struct wlr_drm_backend {
struct wl_listener session_active;
struct wl_listener dev_change;
+ struct wl_list fbs; // wlr_drm_fb.link
struct wl_list outputs;
struct wlr_drm_renderer renderer;
diff --git a/include/backend/drm/renderer.h b/include/backend/drm/renderer.h
index 8316a070..fdc8a75d 100644
--- a/include/backend/drm/renderer.h
+++ b/include/backend/drm/renderer.h
@@ -31,8 +31,12 @@ struct wlr_drm_surface {
struct wlr_drm_fb {
struct wlr_buffer *wlr_buf;
+ struct wl_list link; // wlr_drm_backend.fbs
+
struct gbm_bo *bo;
uint32_t id;
+
+ struct wl_listener wlr_buf_destroy;
};
bool init_drm_renderer(struct wlr_drm_backend *drm,
@@ -47,6 +51,7 @@ bool drm_fb_lock_surface(struct wlr_drm_fb **fb, struct wlr_drm_backend *drm,
bool drm_fb_import(struct wlr_drm_fb **fb, struct wlr_drm_backend *drm,
struct wlr_buffer *buf, struct wlr_drm_surface *mgpu,
const struct wlr_drm_format_set *formats);
+void drm_fb_destroy(struct wlr_drm_fb *fb);
void drm_fb_clear(struct wlr_drm_fb **fb);
void drm_fb_move(struct wlr_drm_fb **new, struct wlr_drm_fb **old);