 154fd4d1a0
			
		
	
	
		154fd4d1a0
		
	
	
	
	
		
			
			Recent commit "qapi: Smarter camel_to_upper() to reduce need for 'prefix'" added a temporary 'prefix' to delay changing the generated code. Revert it. This improves DisplayGLMode's generated enumeration constant prefix from DISPLAYGL_MODE to DISPLAY_GL_MODE. Signed-off-by: Markus Armbruster <armbru@redhat.com> Message-ID: <20240904111836.3273842-9-armbru@redhat.com>
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "qemu/osdep.h"
 | |
| #include "qemu/error-report.h"
 | |
| #include "ui/egl-context.h"
 | |
| 
 | |
| QEMUGLContext qemu_egl_create_context(DisplayGLCtx *dgc,
 | |
|                                       QEMUGLParams *params)
 | |
| {
 | |
|    EGLContext ctx;
 | |
|    EGLint ctx_att_core[] = {
 | |
|        EGL_CONTEXT_OPENGL_PROFILE_MASK, EGL_CONTEXT_OPENGL_CORE_PROFILE_BIT,
 | |
|        EGL_CONTEXT_CLIENT_VERSION, params->major_ver,
 | |
|        EGL_CONTEXT_MINOR_VERSION_KHR, params->minor_ver,
 | |
|        EGL_NONE
 | |
|    };
 | |
|    EGLint ctx_att_gles[] = {
 | |
|        EGL_CONTEXT_CLIENT_VERSION, params->major_ver,
 | |
|        EGL_CONTEXT_MINOR_VERSION_KHR, params->minor_ver,
 | |
|        EGL_NONE
 | |
|    };
 | |
|    bool gles = (qemu_egl_mode == DISPLAY_GL_MODE_ES);
 | |
| 
 | |
|    ctx = eglCreateContext(qemu_egl_display, qemu_egl_config,
 | |
|                           eglGetCurrentContext(),
 | |
|                           gles ? ctx_att_gles : ctx_att_core);
 | |
|    return ctx;
 | |
| }
 | |
| 
 | |
| void qemu_egl_destroy_context(DisplayGLCtx *dgc, QEMUGLContext ctx)
 | |
| {
 | |
|     eglDestroyContext(qemu_egl_display, ctx);
 | |
| }
 | |
| 
 | |
| int qemu_egl_make_context_current(DisplayGLCtx *dgc,
 | |
|                                   QEMUGLContext ctx)
 | |
| {
 | |
|    if (!eglMakeCurrent(qemu_egl_display,
 | |
|                        EGL_NO_SURFACE, EGL_NO_SURFACE, ctx)) {
 | |
|         error_report("egl: eglMakeCurrent failed: %s", qemu_egl_get_error_string());
 | |
|         return -1;
 | |
|    }
 | |
| 
 | |
|    return 0;
 | |
| }
 |