shared-glapi: implement _glapi_get_proc_name().
authorPaul Berry <stereotype441@gmail.com>
Tue, 23 Oct 2012 17:49:33 +0000 (10:49 -0700)
committerPaul Berry <stereotype441@gmail.com>
Thu, 25 Oct 2012 21:23:01 +0000 (14:23 -0700)
Previously this function was only implemented for non-shared-glapi
builds.  Since the function is only intended for debugging purposes we
use a simple O(n) algorithm.

Acked-by: Kenneth Graunke <kenneth@whitecape.org>
Reviewed-by: Matt Turner <mattst88@gmail.com>
src/mapi/mapi/mapi_glapi.c
src/mapi/mapi/stub.c
src/mapi/mapi/stub.h

index adfc0cbcc9fd2150774d6110faf81a2656315797..4627c4de02b3aa25e7611649ce57409bc2a3d291 100644 (file)
@@ -219,8 +219,8 @@ _glapi_get_proc_address(const char *funcName)
 const char *
 _glapi_get_proc_name(unsigned int offset)
 {
-   /* not implemented */
-   return NULL;
+   const struct mapi_stub *stub = stub_find_by_slot(offset);
+   return stub ? stub_get_name(stub) : NULL;
 }
 
 unsigned long
index 6fb8556d140850e76a451afb79862f3e56e86ed3..688dc8143a43c7fd0b5536ef0139ec212a2705f8 100644 (file)
@@ -153,6 +153,28 @@ stub_find_dynamic(const char *name, int generate)
    return stub;
 }
 
+static const struct mapi_stub *
+search_table_by_slot(const struct mapi_stub *table, size_t num_entries,
+                     int slot)
+{
+   size_t i;
+   for (i = 0; i < num_entries; ++i) {
+      if (table[i].slot == slot)
+         return &table[i];
+   }
+   return NULL;
+}
+
+const struct mapi_stub *
+stub_find_by_slot(int slot)
+{
+   const struct mapi_stub *stub =
+      search_table_by_slot(public_stubs, ARRAY_SIZE(public_stubs), slot);
+   if (stub)
+      return stub;
+   return search_table_by_slot(dynamic_stubs, num_dynamic_stubs, slot);
+}
+
 void
 stub_fix_dynamic(struct mapi_stub *stub, const struct mapi_stub *alias)
 {
index b2b6f1839c607e12afa05b0567742ecb6a7c9f93..98e2553ecddbcaff676e81fc595c71f708c956cb 100644 (file)
@@ -42,6 +42,9 @@ stub_find_public(const char *name);
 struct mapi_stub *
 stub_find_dynamic(const char *name, int generate);
 
+const struct mapi_stub *
+stub_find_by_slot(int slot);
+
 void
 stub_fix_dynamic(struct mapi_stub *stub, const struct mapi_stub *alias);