aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/managers/PointerManager.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/managers/PointerManager.cpp b/src/managers/PointerManager.cpp
index b1542fed..55bd0509 100644
--- a/src/managers/PointerManager.cpp
+++ b/src/managers/PointerManager.cpp
@@ -373,7 +373,10 @@ SP<Aquamarine::IBuffer> CPointerManager::renderHWCursorBuffer(SP<CPointerManager
auto options = state->monitor->cursorSwapchain->currentOptions();
options.size = maxSize;
- options.length = 2;
+ // TODO: this is a band-aid. If the current cursor image has not yet been committed (no rendering has yet been done)
+ // we should revert the swapchain and avoid rendering to the front buffer.
+ // as a band-aid, extend the swapchain to 3 as we sometimes double-render on a cursor shape change.
+ options.length = 3;
options.scanout = true;
options.cursor = true;
options.multigpu = state->monitor->output->getBackend()->preferredAllocator()->drmFD() != g_pCompositor->m_iDRMFD;