From cda4db679e50d56b04369a74571890bffedf93fc Mon Sep 17 00:00:00 2001 From: LongChair Date: Sat, 7 Apr 2018 09:06:27 +0200 Subject: [PATCH] drm/atomic: disable video plane when unused. This patch will make sure that the video plane is hidden when unused. When using high resolution modes, typically UHD, and embedding mpv, having the video plane sitting in the back when you don't play any video is eating a lot of memory bandwidth for compositing. That patch makes sure that the video layer is just disabled before and after playback. --- video/out/opengl/hwdec_drmprime_drm.c | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/video/out/opengl/hwdec_drmprime_drm.c b/video/out/opengl/hwdec_drmprime_drm.c index 9a7f4ebd9513c..a292b4eba560b 100644 --- a/video/out/opengl/hwdec_drmprime_drm.c +++ b/video/out/opengl/hwdec_drmprime_drm.c @@ -108,6 +108,28 @@ static void scale_dst_rect(struct ra_hwdec *hw, int source_w, int source_h ,stru dst->y1 += offset_y; } +static void disable_video_plane(struct ra_hwdec *hw) +{ + struct priv *p = hw->priv; + + // Disabling video plane is needed on some devices when using the + // primary plane for video. Primary buffer can't be active with no + // framebuffer associated. So we need this function to commit it + // right away as mpv will free all framebuffers on playback end. + drmModeAtomicReqPtr request = drmModeAtomicAlloc(); + if (request) { + drm_object_set_property(request, p->ctx->video_plane, "FB_ID", 0); + drm_object_set_property(request, p->ctx->video_plane, "CRTC_ID", 0); + + int ret = drmModeAtomicCommit(p->ctx->fd, request, + DRM_MODE_ATOMIC_NONBLOCK, NULL); + + if (ret) + MP_ERR(hw, "Failed to commit disable plane request (code %d)", ret); + drmModeAtomicFree(request); + } +} + static int overlay_frame(struct ra_hwdec *hw, struct mp_image *hw_image, struct mp_rect *src, struct mp_rect *dst, bool newframe) { @@ -178,6 +200,8 @@ static int overlay_frame(struct ra_hwdec *hw, struct mp_image *hw_image, } } } else { + disable_video_plane(hw); + while (p->old_frame.fb.fb_id) set_current_frame(hw, NULL); } @@ -194,6 +218,7 @@ static void uninit(struct ra_hwdec *hw) { struct priv *p = hw->priv; + disable_video_plane(hw); set_current_frame(hw, NULL); if (p->ctx) { @@ -244,6 +269,7 @@ static int init(struct ra_hwdec *hw) goto err; } + disable_video_plane(hw); return 0; err: