summaryrefslogtreecommitdiffstats
path: root/src/plugins/platforms/xcb/qxcbwindow.cpp
diff options
context:
space:
mode:
authorAlexander Volkov <a.volkov@rusbitech.ru>2019-11-18 19:34:07 +0300
committerAlexander Volkov <avolkov@astralinux.ru>2020-09-16 21:22:15 +0300
commit7aacc8144e7da6b1ec48ab7c1e5c431d78c99c5f (patch)
tree3c9f9168d1f1d8e9faf537b178e8d62d96db29b3 /src/plugins/platforms/xcb/qxcbwindow.cpp
parentbf075da8004718e6a7e8d3870b912e89cea8d08c (diff)
xcb: Reduce number of created colormaps
Create a colormap per visual, not per window. Pick-to: 5.15 Change-Id: I97d94618f159b4beaffd4a1afe0611233ced6676 Reviewed-by: Liang Qi <liang.qi@qt.io> Reviewed-by: Shawn Rutledge <shawn.rutledge@qt.io> Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
Diffstat (limited to 'src/plugins/platforms/xcb/qxcbwindow.cpp')
-rw-r--r--src/plugins/platforms/xcb/qxcbwindow.cpp15
1 files changed, 4 insertions, 11 deletions
diff --git a/src/plugins/platforms/xcb/qxcbwindow.cpp b/src/plugins/platforms/xcb/qxcbwindow.cpp
index 0dba120e30..147bac01dd 100644
--- a/src/plugins/platforms/xcb/qxcbwindow.cpp
+++ b/src/plugins/platforms/xcb/qxcbwindow.cpp
@@ -363,14 +363,9 @@ void QXcbWindow::create()
return result;
};
+ xcb_colormap_t cmap = XCB_COLORMAP_NONE;
if ((window()->supportsOpenGL() && haveOpenGL()) || m_format.hasAlpha()) {
- m_cmap = xcb_generate_id(xcb_connection());
- xcb_create_colormap(xcb_connection(),
- XCB_COLORMAP_ALLOC_NONE,
- m_cmap,
- xcb_parent_id,
- m_visualId);
-
+ cmap = platformScreen->colormapForVisual(m_visualId);
mask |= XCB_CW_COLORMAP;
}
@@ -381,7 +376,7 @@ void QXcbWindow::create()
type == Qt::Popup || type == Qt::ToolTip || (window()->flags() & Qt::BypassWindowManagerHint),
type == Qt::Popup || type == Qt::Tool || type == Qt::SplashScreen || type == Qt::ToolTip || type == Qt::Drawer,
defaultEventMask,
- m_cmap
+ cmap
};
m_window = xcb_generate_id(xcb_connection());
@@ -552,9 +547,7 @@ void QXcbWindow::destroy()
xcb_destroy_window(xcb_connection(), m_window);
m_window = 0;
}
- if (m_cmap) {
- xcb_free_colormap(xcb_connection(), m_cmap);
- }
+
m_mapped = false;
if (m_pendingSyncRequest)