]> git.cworth.org Git - apitrace/commitdiff
gles: fix lookup for GLESv1 functions
authorImre Deak <imre.deak@intel.com>
Mon, 2 Apr 2012 13:47:48 +0000 (16:47 +0300)
committerJosé Fonseca <jose.r.fonseca@gmail.com>
Thu, 12 Apr 2012 22:18:15 +0000 (23:18 +0100)
Get the function from the GLESv1 library in case it's not found in
GLESv2.

Signed-off-by: Imre Deak <imre.deak@intel.com>
Signed-off-by: José Fonseca <jose.r.fonseca@gmail.com>
glproc_egl.cpp

index 53dd7145ecd5b39dfa03c6e416a74cdc6ed9fda9..8a0fb347082182547bf01755cf0a0500845c60a4 100644 (file)
@@ -78,24 +78,45 @@ __getPublicProcAddress(const char *procName)
      * Android does not support LD_PRELOAD.  It is assumed that applications
      * are explicitely loading egltrace.so.
      */
-    void *lib = NULL;
+
     if (procName[0] == 'e' && procName[1] == 'g' && procName[2] == 'l') {
         static void *libEGL = NULL;
         if (!libEGL) {
             libEGL = dlopen("libEGL.so", RTLD_LOCAL | RTLD_LAZY);
+            if (!libEGL) {
+                return NULL;
+            }
         }
-        lib = libEGL;
-    } else if (procName[0] == 'g' && procName[1] == 'l') {
-        /* TODO: Support libGLESv1_CM.so too somehow. */
+        return dlsym(libEGL, procName);
+    }
+
+    if (procName[0] == 'g' && procName[1] == 'l') {
+        /* TODO: Use GLESv1/GLESv2 on a per-context basis. */
+        static void *sym = NULL;
+
         static void *libGLESv2 = NULL;
         if (!libGLESv2) {
             libGLESv2 = dlopen("libGLESv2.so", RTLD_LOCAL | RTLD_LAZY);
         }
-        lib = libGLESv2;
-    }
-    if (lib) {
-        return dlsym(lib, procName);
+        if (libGLESv2) {
+            sym = dlsym(libGLESv2, procName);
+        }
+        if (sym) {
+            return sym;
+        }
+
+        static void *libGLESv1 = NULL;
+        if (!libGLESv1) {
+            libGLESv1 = dlopen("libGLESv1_CM.so", RTLD_LOCAL | RTLD_LAZY);
+        }
+        if (libGLESv1) {
+            sym = dlsym(libGLESv1, procName);
+        }
+        if (sym) {
+            return sym;
+        }
     }
+
     return NULL;
 #else
     return dlsym(RTLD_NEXT, procName);