From e93d41d24f15491415538c82959f0d511bb40813 Mon Sep 17 00:00:00 2001 From: Jakob Bornecrantz Date: Thu, 20 Aug 2009 17:33:56 +0200 Subject: [PATCH] st/egl: Open the first drm node At least its better then hardcoded to i915 --- src/gallium/state_trackers/egl/egl_tracker.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) 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; -- 2.30.2