qpa: Fix EGL config selection
The configs returned by eglChooseConfig are sorted from highest to lowest buffer sizes. Filter the configs to find a suitable candidate that matches the requested attributes of the surface. This fixes the corrupted Aurorae window decorations on Wayland with the proprietary Nvidia driver.
This commit is contained in:
parent
38e24ecd64
commit
05af11b4ed
1 changed files with 29 additions and 6 deletions
|
@ -54,18 +54,41 @@ EGLConfig configFromFormat(EGLDisplay display, const QSurfaceFormat &surfaceForm
|
||||||
};
|
};
|
||||||
|
|
||||||
EGLint configCount;
|
EGLint configCount;
|
||||||
EGLConfig configs[1024];
|
if (!eglChooseConfig(display, attributes.data(), nullptr, 0, &configCount)) {
|
||||||
if (!eglChooseConfig(display, attributes.data(), configs, 1, &configCount)) {
|
|
||||||
// FIXME: Don't bail out yet, we should try to find the most suitable config.
|
|
||||||
qCWarning(KWIN_QPA, "eglChooseConfig failed: %x", eglGetError());
|
qCWarning(KWIN_QPA, "eglChooseConfig failed: %x", eglGetError());
|
||||||
return EGL_NO_CONFIG_KHR;
|
return EGL_NO_CONFIG_KHR;
|
||||||
}
|
}
|
||||||
|
if (configCount == 0) {
|
||||||
if (configCount != 1) {
|
qCWarning(KWIN_QPA, "eglChooseConfig did not return any configs");
|
||||||
qCWarning(KWIN_QPA) << "eglChooseConfig did not return any configs";
|
|
||||||
return EGL_NO_CONFIG_KHR;
|
return EGL_NO_CONFIG_KHR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QVector<EGLConfig> configs(configCount);
|
||||||
|
if (!eglChooseConfig(display, attributes.data(), configs.data(), configCount, &configCount)) {
|
||||||
|
qCWarning(KWIN_QPA, "eglChooseConfig failed: %x", eglGetError());
|
||||||
|
return EGL_NO_CONFIG_KHR;
|
||||||
|
}
|
||||||
|
if (configCount != configs.size()) {
|
||||||
|
qCWarning(KWIN_QPA, "eglChooseConfig did not return requested configs");
|
||||||
|
return EGL_NO_CONFIG_KHR;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (const EGLConfig &config : qAsConst(configs)) {
|
||||||
|
EGLint redConfig, greenConfig, blueConfig, alphaConfig;
|
||||||
|
eglGetConfigAttrib(display, config, EGL_RED_SIZE, &redConfig);
|
||||||
|
eglGetConfigAttrib(display, config, EGL_GREEN_SIZE, &greenConfig);
|
||||||
|
eglGetConfigAttrib(display, config, EGL_BLUE_SIZE, &blueConfig);
|
||||||
|
eglGetConfigAttrib(display, config, EGL_ALPHA_SIZE, &alphaConfig);
|
||||||
|
|
||||||
|
if ((redSize == 0 || redSize == redConfig) &&
|
||||||
|
(greenSize == 0 || greenSize == greenConfig) &&
|
||||||
|
(blueSize == 0 || blueSize == blueConfig) &&
|
||||||
|
(alphaSize == 0 || alphaSize == alphaConfig)) {
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return first config as a fallback.
|
||||||
return configs[0];
|
return configs[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue