Pick a config instead of hard coding one.

dev
Kristian Høgsberg 16 years ago
parent bf9541ffa3
commit 443853cbda
  1. 63
      egl-compositor.c

@ -578,9 +578,6 @@ notify_surface_attach(struct wl_compositor *compositor,
if (es->surface != EGL_NO_SURFACE) if (es->surface != EGL_NO_SURFACE)
eglDestroySurface(ec->display, es->surface); eglDestroySurface(ec->display, es->surface);
/* FIXME: We need to use a single buffer config without depth
* or stencil buffers here to keep egl from creating auxillary
* buffers for the pixmap here. */
es->surface = eglCreateSurfaceForName(ec->display, ec->config, es->surface = eglCreateSurfaceForName(ec->display, ec->config,
name, width, height, stride, NULL); name, width, height, stride, NULL);
@ -803,14 +800,65 @@ create_frontbuffer(int fd, int *width, int *height, int *stride)
return flink.name; return flink.name;
} }
static int
pick_config(struct egl_compositor *ec)
{
EGLConfig configs[100];
EGLint value, count;
int i;
if (!eglGetConfigs(ec->display, configs, ARRAY_LENGTH(configs), &count)) {
fprintf(stderr, "failed to get configs\n");
return -1;
}
ec->config = EGL_NO_CONFIG;
for (i = 0; i < count; i++) {
eglGetConfigAttrib(ec->display,
configs[i],
EGL_DEPTH_SIZE,
&value);
if (value > 0) {
fprintf(stderr, "config %d has depth size %d\n", i, value);
continue;
}
eglGetConfigAttrib(ec->display,
configs[i],
EGL_STENCIL_SIZE,
&value);
if (value > 0) {
fprintf(stderr, "config %d has stencil size %d\n", i, value);
continue;
}
eglGetConfigAttrib(ec->display,
configs[i],
EGL_CONFIG_CAVEAT,
&value);
if (value != EGL_NONE) {
fprintf(stderr, "config %d has caveat %d\n", i, value);
continue;
}
ec->config = configs[i];
break;
}
if (ec->config == EGL_NO_CONFIG) {
fprintf(stderr, "found no config without depth or stencil buffers\n");
return -1;
}
return 0;
}
static const char gem_device[] = "/dev/dri/card0"; static const char gem_device[] = "/dev/dri/card0";
WL_EXPORT struct wl_compositor * WL_EXPORT struct wl_compositor *
wl_compositor_create(struct wl_display *display) wl_compositor_create(struct wl_display *display)
{ {
EGLConfig configs[64]; EGLint major, minor;
EGLint major, minor, count;
struct egl_compositor *ec; struct egl_compositor *ec;
const char *filename; const char *filename;
struct screenshooter *shooter; struct screenshooter *shooter;
@ -837,12 +885,9 @@ wl_compositor_create(struct wl_display *display)
return NULL; return NULL;
} }
if (!eglGetConfigs(ec->display, configs, ARRAY_LENGTH(configs), &count)) { if (pick_config(ec))
fprintf(stderr, "failed to get configs\n");
return NULL; return NULL;
}
ec->config = configs[24];
fb_name = create_frontbuffer(eglGetDisplayFD(ec->display), fb_name = create_frontbuffer(eglGetDisplayFD(ec->display),
&ec->width, &ec->height, &stride); &ec->width, &ec->height, &stride);
ec->surface = eglCreateSurfaceForName(ec->display, ec->config, ec->surface = eglCreateSurfaceForName(ec->display, ec->config,

Loading…
Cancel
Save