new glx: create a OpenGL 3.0 context
Older version of OpenGL won't be supported by the new glx backend. Signed-off-by: Yuxuan Shui <yshuiv7@gmail.com>
This commit is contained in:
		| @ -49,6 +49,14 @@ struct _glx_data { | |||||||
| 	GLXContext ctx; | 	GLXContext ctx; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | #define glXGetFBConfigAttribChecked(a, b, attr, c)                                       \ | ||||||
|  | 	do {                                                                             \ | ||||||
|  | 		if (glXGetFBConfigAttrib(a, b, attr, c)) {                               \ | ||||||
|  | 			log_info("Cannot get FBConfig attribute " #attr);                \ | ||||||
|  | 			continue;                                                        \ | ||||||
|  | 		}                                                                        \ | ||||||
|  | 	} while (0) | ||||||
|  |  | ||||||
| struct glx_fbconfig_info *glx_find_fbconfig(Display *dpy, int screen, struct xvisual_info m) { | struct glx_fbconfig_info *glx_find_fbconfig(Display *dpy, int screen, struct xvisual_info m) { | ||||||
| 	log_debug("Looking for FBConfig for RGBA%d%d%d%d, depth %d", m.red_size, | 	log_debug("Looking for FBConfig for RGBA%d%d%d%d, depth %d", m.red_size, | ||||||
| 	          m.blue_size, m.green_size, m.alpha_size, m.visual_depth); | 	          m.blue_size, m.green_size, m.alpha_size, m.visual_depth); | ||||||
| @ -74,13 +82,6 @@ struct glx_fbconfig_info *glx_find_fbconfig(Display *dpy, int screen, struct xvi | |||||||
| 	                      }, &ncfg); | 	                      }, &ncfg); | ||||||
| 	// clang-format on | 	// clang-format on | ||||||
|  |  | ||||||
| #define glXGetFBConfigAttribChecked(a, b, attr, c)                                       \ |  | ||||||
| 	do {                                                                             \ |  | ||||||
| 		if (glXGetFBConfigAttrib(a, b, attr, c)) {                               \ |  | ||||||
| 			log_info("Cannot get FBConfig attribute " #attr);                \ |  | ||||||
| 			continue;                                                        \ |  | ||||||
| 		}                                                                        \ |  | ||||||
| 	} while (0) |  | ||||||
| 	int texture_tgts, y_inverted, texture_fmt; | 	int texture_tgts, y_inverted, texture_fmt; | ||||||
| 	bool found = false; | 	bool found = false; | ||||||
| 	int min_cost = INT_MAX; | 	int min_cost = INT_MAX; | ||||||
| @ -141,7 +142,6 @@ struct glx_fbconfig_info *glx_find_fbconfig(Display *dpy, int screen, struct xvi | |||||||
| 		} | 		} | ||||||
| 		min_cost = depthbuf + stencil + bufsize * (doublebuf + 1); | 		min_cost = depthbuf + stencil + bufsize * (doublebuf + 1); | ||||||
| 	} | 	} | ||||||
| #undef glXGetFBConfigAttribChecked |  | ||||||
| 	free(cfg); | 	free(cfg); | ||||||
| 	if (!found) { | 	if (!found) { | ||||||
| 		return NULL; | 		return NULL; | ||||||
| @ -245,19 +245,56 @@ static backend_t *glx_init(session_t *ps) { | |||||||
| 		goto end; | 		goto end; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	if (glXGetConfig(ps->dpy, pvis, GLX_RGBA, &value) || !value) { | ||||||
|  | 		log_error("Root visual is a color index visual, not supported"); | ||||||
|  | 		goto end; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	// Ensure GLX_EXT_texture_from_pixmap exists | 	// Ensure GLX_EXT_texture_from_pixmap exists | ||||||
| 	if (!glxext.has_GLX_EXT_texture_from_pixmap) { | 	if (!glxext.has_GLX_EXT_texture_from_pixmap) { | ||||||
| 		log_error("GLX_EXT_texture_from_pixmap is not supported by your driver"); | 		log_error("GLX_EXT_texture_from_pixmap is not supported by your driver"); | ||||||
| 		goto end; | 		goto end; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// Get GLX context | 	if (!glxext.has_GLX_ARB_create_context) { | ||||||
| 	gd->ctx = glXCreateContext(ps->dpy, pvis, NULL, GL_TRUE); | 		log_error("GLX_ARB_create_context is not supported by your driver"); | ||||||
|  | 		goto end; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	// Find a fbconfig with visualid matching the one from the target win, so we can | ||||||
|  | 	// be sure that the fbconfig is compatible with our target window. | ||||||
|  | 	int ncfgs; | ||||||
|  | 	GLXFBConfig *cfg = glXGetFBConfigs(gd->display, gd->screen, &ncfgs); | ||||||
|  | 	bool found = false; | ||||||
|  | 	for (int i = 0; i < ncfgs; i++) { | ||||||
|  | 		int visualid; | ||||||
|  | 		glXGetFBConfigAttribChecked(gd->display, cfg[i], GLX_VISUAL_ID, &visualid); | ||||||
|  | 		if ((VisualID)visualid != pvis->visualid) { | ||||||
|  | 			continue; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		gd->ctx = glXCreateContextAttribsARB(ps->dpy, cfg[i], 0, true, | ||||||
|  | 		                                     (int[]){ | ||||||
|  | 		                                         GLX_CONTEXT_MAJOR_VERSION_ARB, | ||||||
|  | 		                                         3, | ||||||
|  | 		                                         GLX_CONTEXT_MINOR_VERSION_ARB, | ||||||
|  | 		                                         0, | ||||||
|  | 		                                         0, | ||||||
|  | 		                                     }); | ||||||
|  | 		free(cfg); | ||||||
|  |  | ||||||
| 		if (!gd->ctx) { | 		if (!gd->ctx) { | ||||||
| 			log_error("Failed to get GLX context."); | 			log_error("Failed to get GLX context."); | ||||||
| 			goto end; | 			goto end; | ||||||
| 		} | 		} | ||||||
|  | 		found = true; | ||||||
|  | 		break; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (!found) { | ||||||
|  | 		log_error("Couldn't find a suitable fbconfig for the target window"); | ||||||
|  | 		goto end; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	// Attach GLX context | 	// Attach GLX context | ||||||
| 	GLXDrawable tgt = ps->overlay; | 	GLXDrawable tgt = ps->overlay; | ||||||
| @ -341,7 +378,7 @@ glx_bind_pixmap(backend_t *base, xcb_pixmap_t pixmap, struct xvisual_info fmt, b | |||||||
| 	else | 	else | ||||||
| 		tex_tgt = GLX_TEXTURE_2D_EXT; | 		tex_tgt = GLX_TEXTURE_2D_EXT; | ||||||
|  |  | ||||||
| 	log_debug("depth %d, tgt %#x, rgba %d\n", fmt.visual_depth, tex_tgt, | 	log_debug("depth %d, tgt %#x, rgba %d", fmt.visual_depth, tex_tgt, | ||||||
| 	          (GLX_TEXTURE_FORMAT_RGBA_EXT == fbcfg->texture_fmt)); | 	          (GLX_TEXTURE_FORMAT_RGBA_EXT == fbcfg->texture_fmt)); | ||||||
|  |  | ||||||
| 	GLint attrs[] = { | 	GLint attrs[] = { | ||||||
| @ -473,6 +510,7 @@ PFNGLXSWAPINTERVALSGIPROC glXSwapIntervalSGI; | |||||||
| PFNGLXSWAPINTERVALMESAPROC glXSwapIntervalMESA; | PFNGLXSWAPINTERVALMESAPROC glXSwapIntervalMESA; | ||||||
| PFNGLXBINDTEXIMAGEEXTPROC glXBindTexImageEXT; | PFNGLXBINDTEXIMAGEEXTPROC glXBindTexImageEXT; | ||||||
| PFNGLXRELEASETEXIMAGEEXTPROC glXReleaseTexImageEXT; | PFNGLXRELEASETEXIMAGEEXTPROC glXReleaseTexImageEXT; | ||||||
|  | PFNGLXCREATECONTEXTATTRIBSARBPROC glXCreateContextAttribsARB; | ||||||
|  |  | ||||||
| void glxext_init(Display *dpy, int screen) { | void glxext_init(Display *dpy, int screen) { | ||||||
| 	if (glxext.initialized) { | 	if (glxext.initialized) { | ||||||
| @ -486,6 +524,7 @@ void glxext_init(Display *dpy, int screen) { | |||||||
| 	check_ext(GLX_MESA_swap_control); | 	check_ext(GLX_MESA_swap_control); | ||||||
| 	check_ext(GLX_EXT_swap_control); | 	check_ext(GLX_EXT_swap_control); | ||||||
| 	check_ext(GLX_EXT_texture_from_pixmap); | 	check_ext(GLX_EXT_texture_from_pixmap); | ||||||
|  | 	check_ext(GLX_ARB_create_context); | ||||||
| 	check_ext(GLX_EXT_buffer_age); | 	check_ext(GLX_EXT_buffer_age); | ||||||
| #undef check_ext | #undef check_ext | ||||||
|  |  | ||||||
| @ -511,5 +550,8 @@ void glxext_init(Display *dpy, int screen) { | |||||||
| 	if (!lookup(glXBindTexImageEXT) || !lookup(glXReleaseTexImageEXT)) { | 	if (!lookup(glXBindTexImageEXT) || !lookup(glXReleaseTexImageEXT)) { | ||||||
| 		glxext.has_GLX_EXT_texture_from_pixmap = false; | 		glxext.has_GLX_EXT_texture_from_pixmap = false; | ||||||
| 	} | 	} | ||||||
|  | 	if (!lookup(glXCreateContextAttribsARB)) { | ||||||
|  | 		glxext.has_GLX_ARB_create_context = false; | ||||||
|  | 	} | ||||||
| #undef lookup | #undef lookup | ||||||
| } | } | ||||||
|  | |||||||
| @ -52,6 +52,7 @@ struct glxext_info { | |||||||
| 	bool has_GLX_MESA_swap_control; | 	bool has_GLX_MESA_swap_control; | ||||||
| 	bool has_GLX_EXT_swap_control; | 	bool has_GLX_EXT_swap_control; | ||||||
| 	bool has_GLX_EXT_texture_from_pixmap; | 	bool has_GLX_EXT_texture_from_pixmap; | ||||||
|  | 	bool has_GLX_ARB_create_context; | ||||||
| 	bool has_GLX_EXT_buffer_age; | 	bool has_GLX_EXT_buffer_age; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @ -66,5 +67,6 @@ extern PFNGLXSWAPINTERVALSGIPROC glXSwapIntervalSGI; | |||||||
| extern PFNGLXSWAPINTERVALMESAPROC glXSwapIntervalMESA; | extern PFNGLXSWAPINTERVALMESAPROC glXSwapIntervalMESA; | ||||||
| extern PFNGLXBINDTEXIMAGEEXTPROC glXBindTexImageEXT; | extern PFNGLXBINDTEXIMAGEEXTPROC glXBindTexImageEXT; | ||||||
| extern PFNGLXRELEASETEXIMAGEEXTPROC glXReleaseTexImageEXT; | extern PFNGLXRELEASETEXIMAGEEXTPROC glXReleaseTexImageEXT; | ||||||
|  | extern PFNGLXCREATECONTEXTATTRIBSARBPROC glXCreateContextAttribsARB; | ||||||
|  |  | ||||||
| void glxext_init(Display *, int screen); | void glxext_init(Display *, int screen); | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Yuxuan Shui
					Yuxuan Shui