From: Jakob Bornecrantz Date: Thu, 20 Aug 2009 15:33:56 +0000 (+0200) Subject: st/egl: Open the first drm node X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e93d41d24f15491415538c82959f0d511bb40813;p=mesa.git st/egl: Open the first drm node At least its better then hardcoded to i915 --- diff --git a/src/gallium/state_trackers/egl/egl_tracker.c b/src/gallium/state_trackers/egl/egl_tracker.c index ced002c5359..57c81da767a 100644 --- a/src/gallium/state_trackers/egl/egl_tracker.c +++ b/src/gallium/state_trackers/egl/egl_tracker.c @@ -6,6 +6,8 @@ #include #include "egl_tracker.h" +#include + #include "egllog.h" #include "state_tracker/drm_api.h" @@ -132,6 +134,14 @@ drm_find_dpms(struct drm_device *dev, struct drm_screen *screen) screen->dpms = p; } +static int drm_open_minor(int minor) +{ + char buf[64]; + + sprintf(buf, DRM_DEV_NAME, DRM_DIR_NAME, minor); + return open(buf, O_RDWR, 0); +} + EGLBoolean drm_initialize(_EGLDriver *drv, _EGLDisplay *disp, EGLint *major, EGLint *minor) { @@ -144,7 +154,8 @@ drm_initialize(_EGLDriver *drv, _EGLDisplay *disp, EGLint *major, EGLint *minor) EGLint i; int fd; - fd = drmOpen("i915", NULL); + /* try the first node */ + fd = drm_open_minor(0); if (fd < 0) goto err_fd;