compositor-drm: Match the EGLConfig native visual ID if it has one

We'll add the GBM format code as the native visual ID for EGLConfigs
when running on GBM.  This patch lets the drm backend pass in the
format code it's using with KMS and make sure we get a confing that
matches.  In the future, mesa will add support for 10 bpc configs
which will match the "at least 8 color bits" requirement.  By also
matching the native visual ID, we avoid rendering XRGB2101010 into a
XRGB8888 KMS framebuffer.
dev
Kristian Høgsberg 11 years ago
parent be336c8918
commit c3ea26c02d
  1. 12
      src/compositor-drm.c
  2. 2
      src/gl-renderer.c

@ -85,6 +85,7 @@ struct drm_compositor {
uint32_t crtc_allocator; uint32_t crtc_allocator;
uint32_t connector_allocator; uint32_t connector_allocator;
struct wl_listener session_listener; struct wl_listener session_listener;
uint32_t format;
/* we need these parameters in order to not fail drmModeAddFB2() /* we need these parameters in order to not fail drmModeAddFB2()
* due to out of bounds dimensions, and then mistakenly set * due to out of bounds dimensions, and then mistakenly set
@ -495,7 +496,7 @@ drm_output_render_gl(struct drm_output *output, pixman_region32_t *damage)
return; return;
} }
output->next = drm_fb_get_from_bo(bo, c, GBM_FORMAT_XRGB8888); output->next = drm_fb_get_from_bo(bo, c, c->format);
if (!output->next) { if (!output->next) {
weston_log("failed to get drm_fb for bo\n"); weston_log("failed to get drm_fb for bo\n");
gbm_surface_release_buffer(output->surface, bo); gbm_surface_release_buffer(output->surface, bo);
@ -1246,8 +1247,9 @@ init_egl(struct drm_compositor *ec)
if (!ec->gbm) if (!ec->gbm)
return -1; return -1;
if (gl_renderer_create(&ec->base, ec->gbm, gl_renderer_opaque_attribs, if (gl_renderer_create(&ec->base, ec->gbm,
NULL) < 0) { gl_renderer_opaque_attribs,
&ec->format) < 0) {
gbm_device_destroy(ec->gbm); gbm_device_destroy(ec->gbm);
return -1; return -1;
} }
@ -1441,7 +1443,7 @@ drm_output_init_egl(struct drm_output *output, struct drm_compositor *ec)
output->surface = gbm_surface_create(ec->gbm, output->surface = gbm_surface_create(ec->gbm,
output->base.current_mode->width, output->base.current_mode->width,
output->base.current_mode->height, output->base.current_mode->height,
GBM_FORMAT_XRGB8888, ec->format,
GBM_BO_USE_SCANOUT | GBM_BO_USE_SCANOUT |
GBM_BO_USE_RENDERING); GBM_BO_USE_RENDERING);
if (!output->surface) { if (!output->surface) {
@ -2552,7 +2554,7 @@ drm_compositor_create(struct wl_display *display,
/* KMS support for sprites is not complete yet, so disable the /* KMS support for sprites is not complete yet, so disable the
* functionality for now. */ * functionality for now. */
ec->sprites_are_broken = 1; ec->sprites_are_broken = 1;
ec->format = GBM_FORMAT_XRGB8888;
ec->use_pixman = pixman; ec->use_pixman = pixman;
if (weston_compositor_init(&ec->base, display, argc, argv, if (weston_compositor_init(&ec->base, display, argc, argv,

@ -1587,7 +1587,7 @@ egl_choose_config(struct gl_renderer *gr, const EGLint *attribs,
&id)) &id))
continue; continue;
if (id != *visual_id) if (id != 0 && id != *visual_id)
continue; continue;
} }

Loading…
Cancel
Save