diff options
author | Quanxian Wang <[email protected]> | 2013-12-18 22:11:00 -0700 |
---|---|---|
committer | Brian Paul <[email protected]> | 2013-12-19 12:44:11 -0700 |
commit | 1413a09f346f7b0765b303f7770ec597c78bff2f (patch) | |
tree | f35ed11aa3963417742d34096bcc489d5bd15c01 /src | |
parent | 22bf0f3eb4668044042cdf326ccee29fa44f850a (diff) |
egl: break instead of looping after driver is found
Stop searching for a driver after success.
Signed-off-by: Quanxian Wang <[email protected]>
Reviewed-By: Gong, Zhigang <[email protected]>
Reviewed-by: Brian Paul <[email protected]>
Diffstat (limited to 'src')
-rw-r--r-- | src/egl/drivers/dri2/egl_dri2.c | 3 | ||||
-rw-r--r-- | src/gbm/backends/dri/gbm_dri.c | 5 |
2 files changed, 6 insertions, 2 deletions
diff --git a/src/egl/drivers/dri2/egl_dri2.c b/src/egl/drivers/dri2/egl_dri2.c index e703f282c92..892f1f4def7 100644 --- a/src/egl/drivers/dri2/egl_dri2.c +++ b/src/egl/drivers/dri2/egl_dri2.c @@ -403,6 +403,9 @@ dri2_open_driver(_EGLDisplay *disp) if (dri2_dpy->driver == NULL) _eglLog(_EGL_DEBUG, "failed to open %s: %s\n", path, dlerror()); } + /* not need continue to loop all paths once the driver is found */ + if (dri2_dpy->driver != NULL) + break; } if (dri2_dpy->driver == NULL) { diff --git a/src/gbm/backends/dri/gbm_dri.c b/src/gbm/backends/dri/gbm_dri.c index b4b97ac6a97..cd3122199eb 100644 --- a/src/gbm/backends/dri/gbm_dri.c +++ b/src/gbm/backends/dri/gbm_dri.c @@ -224,9 +224,10 @@ dri_load_driver(struct gbm_dri_device *dri) snprintf(path, sizeof path, "%.*s/%s_dri.so", len, p, dri->base.driver_name); dri->driver = dlopen(path, RTLD_NOW | RTLD_GLOBAL); - if (dri->driver == NULL) - fprintf(stderr, "failed to open %s: %s\n", path, dlerror()); } + /* not need continue to loop all paths once the driver is found */ + if (dri->driver != NULL) + break; } if (dri->driver == NULL) { |