From cea2781318c9a24b25d3f4a43e2efccc32a5e371 Mon Sep 17 00:00:00 2001 From: Aleix Pol Date: Fri, 27 Nov 2020 02:24:16 +0100 Subject: [PATCH] screencating: query for dmabuf availability before we start streaming As things are right now, we can only do 32bit textures for dmabuf (see gbm_bo_format in gbm.h). This means that we were lying to our receivers when we had 24bit textures by then giving a 32bit texture instead. This changes it so we request a dummy texture before starting and if we are offered one we assume they're available and offer a 32bits stream directly (i.e. BGRA). --- plugins/screencast/pipewirestream.cpp | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/plugins/screencast/pipewirestream.cpp b/plugins/screencast/pipewirestream.cpp index 47af041c7d..825eaff973 100644 --- a/plugins/screencast/pipewirestream.cpp +++ b/plugins/screencast/pipewirestream.cpp @@ -236,7 +236,10 @@ bool PipeWireStream::createStream() spa_rectangle resolution = SPA_RECTANGLE(uint32_t(m_resolution.width()), uint32_t(m_resolution.height())); - const auto format = m_hasAlpha ? SPA_VIDEO_FORMAT_BGRA : SPA_VIDEO_FORMAT_BGR; + auto canCreateDmaBuf = [this] () -> bool { + return QSharedPointer(kwinApp()->platform()->createDmaBufTexture(m_resolution)); + }; + const auto format = m_hasAlpha || canCreateDmaBuf() ? SPA_VIDEO_FORMAT_BGRA : SPA_VIDEO_FORMAT_BGR; const spa_pod *param = (spa_pod*)spa_pod_builder_add_object(&podBuilder, SPA_TYPE_OBJECT_Format, SPA_PARAM_EnumFormat,