diff options
author | Mathias Agopian <mathias@google.com> | 2009-10-14 02:06:37 -0700 |
---|---|---|
committer | Mathias Agopian <mathias@google.com> | 2009-10-14 02:06:37 -0700 |
commit | 6fc569971faa342b2e2da46c55fbfbba3a2a7814 (patch) | |
tree | 56b790ce3ac8aa81b4481f7b6a4e9384aee7c84e /opengl/libs/EGL/Loader.h | |
parent | b10e2f1a861933f50d9ad8ea24b5dfa5643a2c11 (diff) | |
download | frameworks_base-6fc569971faa342b2e2da46c55fbfbba3a2a7814.zip frameworks_base-6fc569971faa342b2e2da46c55fbfbba3a2a7814.tar.gz frameworks_base-6fc569971faa342b2e2da46c55fbfbba3a2a7814.tar.bz2 |
fix [2187212] add support for GLESv2 dispatch based on TLS
Instead of using a different function pointer table for ES 1.x and ES 2.x,
we use a single one that is the union (sort|uniq) of both tables. Two
instances of this table are initialized with pointers to GL ES 1.x and GL ES 2.x
entry-points.
When a context is created, we store its version number and when it is bound to a
thread we set the approruiate table based on the stored version.
This introduce no penalty while dispatching gl calls to the right API version.
[Pending Dr No approval for MR1]
Diffstat (limited to 'opengl/libs/EGL/Loader.h')
-rw-r--r-- | opengl/libs/EGL/Loader.h | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/opengl/libs/EGL/Loader.h b/opengl/libs/EGL/Loader.h index 69f6dd5..8659b0b 100644 --- a/opengl/libs/EGL/Loader.h +++ b/opengl/libs/EGL/Loader.h @@ -32,7 +32,7 @@ namespace android { // ---------------------------------------------------------------------------- -struct gl_hooks_t; +struct egl_connection_t; class Loader : public Singleton<Loader> { @@ -69,12 +69,12 @@ class Loader : public Singleton<Loader> public: ~Loader(); - void* open(EGLNativeDisplayType display, int impl, gl_hooks_t* hooks); + void* open(EGLNativeDisplayType display, int impl, egl_connection_t* cnx); status_t close(void* driver); private: Loader(); - void *load_driver(const char* driver, gl_hooks_t* hooks, uint32_t mask); + void *load_driver(const char* driver, egl_connection_t* cnx, uint32_t mask); static __attribute__((noinline)) void init_api(void* dso, |