From e4695325a666fcb442e0fbd744bb7f39d3c16e42 Mon Sep 17 00:00:00 2001 From: Xaver Hugl Date: Sun, 8 May 2022 21:23:08 +0200 Subject: [PATCH] backends/drm: store gbm buffer for screen recording --- src/backends/drm/egl_gbm_layer_surface.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/backends/drm/egl_gbm_layer_surface.cpp b/src/backends/drm/egl_gbm_layer_surface.cpp index c02121def4..a9c08c4cc3 100644 --- a/src/backends/drm/egl_gbm_layer_surface.cpp +++ b/src/backends/drm/egl_gbm_layer_surface.cpp @@ -123,12 +123,13 @@ std::optional, QRegion>> EglGbmLayerS } GLFramebuffer::popFramebuffer(); if (m_gpu == m_eglBackend->gpu()) { - const auto buffer = m_gbmSurface->swapBuffers(damagedRegion); - if (buffer) { + if (const auto buffer = m_gbmSurface->swapBuffers(damagedRegion)) { + m_currentBuffer = buffer; return std::tuple(DrmFramebuffer::createFramebuffer(buffer), damagedRegion); } } else { - if (m_gbmSurface->swapBuffers(damagedRegion)) { + if (const auto gbmBuffer = m_gbmSurface->swapBuffers(damagedRegion)) { + m_currentBuffer = gbmBuffer; const auto buffer = importBuffer(); if (buffer) { return std::tuple(buffer, damagedRegion);