@@ -1257,7 +1257,7 @@ ETEXI
DEF("display", HAS_ARG, QEMU_OPTION_display,
"-display sdl[,frame=on|off][,alt_grab=on|off][,ctrl_grab=on|off]\n"
- " [,window_close=on|off][,gl=on|off]\n"
+ " [,window_close=on|off][,gl=on|off][,gles=on|off]\n"
"-display gtk[,grab_on_hover=on|off][,gl=on|off]|\n"
"-display vnc=<display>[,<optargs>]\n"
"-display curses\n"
@@ -1492,6 +1492,9 @@ Enable/disable spice seamless migration. Default is off.
@item gl=[on|off]
Enable/disable OpenGL context. Default is off.
+@item gles=[on|off]
+Enable/disable OpenGL ES context. Default is off.
+
@item rendernode=<file>
DRM render node for OpenGL rendering. If not specified, it will pick
the first available. (Since 2.9)
@@ -762,6 +762,7 @@ void sdl_display_early_init(int opengl)
case 0: /* off */
break;
case 1: /* on */
+ case 2: /* gles = on */
#ifdef CONFIG_OPENGL
display_opengl = 1;
#endif
@@ -2154,6 +2154,15 @@ static DisplayType select_display(const char *p)
} else {
goto invalid_sdl_args;
}
+ } else if (strstart(opts, ",gles=", &nextopt)) {
+ opts = nextopt;
+ if (strstart(opts, "on", &nextopt)) {
+ request_opengl = 2;
+ } else if (strstart(opts, "off", &nextopt)) {
+ request_opengl = 0;
+ } else {
+ goto invalid_sdl_args;
+ }
} else if (strstart(opts, ",gl=", &nextopt)) {
opts = nextopt;
if (strstart(opts, "on", &nextopt)) {
@@ -4364,7 +4373,7 @@ int main(int argc, char **argv, char **envp)
qemu_console_early_init();
- if (request_opengl == 1 && display_opengl == 0) {
+ if ((request_opengl == 1 || request_opengl == 2) && display_opengl == 0) {
#if defined(CONFIG_OPENGL)
error_report("OpenGL is not supported by the display");
#else
This commit add an option to the sdl display: `-display sdl,gles=on` This will allow the user to create an OpenGL ES context. Signed-off-by: Elie Tournier <elie.tournier@collabora.com> --- qemu-options.hx | 5 ++++- ui/sdl2.c | 1 + vl.c | 11 ++++++++++- 3 files changed, 15 insertions(+), 2 deletions(-)