From befb50ebece843e6223d59577a9e1644704ba6c1 Mon Sep 17 00:00:00 2001 From: Xaver Hugl Date: Wed, 2 Aug 2023 11:45:07 +0200 Subject: [PATCH] backends/drm: allow modesets with atomic tests if a modeset is already pending Otherwise the tests will always fail BUG: 461657 --- src/backends/drm/drm_pipeline.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/backends/drm/drm_pipeline.cpp b/src/backends/drm/drm_pipeline.cpp index e83ba06ef8..0a8ae7bb34 100644 --- a/src/backends/drm/drm_pipeline.cpp +++ b/src/backends/drm/drm_pipeline.cpp @@ -108,6 +108,16 @@ DrmPipeline::Error DrmPipeline::commitPipelines(const QVector &pi DrmPipeline::Error DrmPipeline::commitPipelinesAtomic(const QVector &pipelines, CommitMode mode, const QVector &unusedObjects) { auto commit = std::make_unique(pipelines); + if (mode == CommitMode::Test) { + // if there's a modeset pending, the tests on top of that state + // also have to allow modesets or they'll always fail + const bool wantsModeset = std::any_of(pipelines.begin(), pipelines.end(), [](DrmPipeline *pipeline) { + return pipeline->needsModeset(); + }); + if (wantsModeset) { + mode = CommitMode::TestAllowModeset; + } + } for (const auto &pipeline : pipelines) { if (pipeline->activePending()) { if (!pipeline->m_pending.layer->checkTestBuffer()) {