summaryrefslogtreecommitdiff
path: root/src/modules/evas/engines/gl_x11/evas_x_main.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/modules/evas/engines/gl_x11/evas_x_main.c')
-rw-r--r--src/modules/evas/engines/gl_x11/evas_x_main.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/modules/evas/engines/gl_x11/evas_x_main.c b/src/modules/evas/engines/gl_x11/evas_x_main.c
index 10ab397c9d..b86916966b 100644
--- a/src/modules/evas/engines/gl_x11/evas_x_main.c
+++ b/src/modules/evas/engines/gl_x11/evas_x_main.c
@@ -345,6 +345,13 @@ try_gles2:
eng_window_free(gw);
return NULL;
}
+ // nvidia drivers in egl/gles mode dont need re-creating of the
+ // eglimage ... and doign so is super slow on them, so avoid the
+ // multi buffer path - as it's only for nvidia and this fixes
+ // the performance regression there, it's fairly safe to do
+ // as it's not universal across all drivers.
+ if (strstr((const char *)vendor, "NVIDIA"))
+ gw->detected.no_multi_buffer_native = 1;
eglGetConfigAttrib(gw->egl_disp, gw->egl_config, EGL_DEPTH_SIZE, &val);
gw->detected.depth_buffer_size = val;