diff options
author | Jesse Hall <jessehall@google.com> | 2014-06-07 00:19:53 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-06-07 00:19:53 +0000 |
commit | 0d7271527fa48c26b657d689faffbc94c93e5b3c (patch) | |
tree | e0df94bc2ff326eebd918d393169c24ed4da4abd | |
parent | 1bc1761d36b75c7df41a56de486c94953ea2f3b5 (diff) | |
parent | 17cbadf0f598b0d02179262ad5b6b270850ccb94 (diff) | |
download | frameworks_native-0d7271527fa48c26b657d689faffbc94c93e5b3c.zip frameworks_native-0d7271527fa48c26b657d689faffbc94c93e5b3c.tar.gz frameworks_native-0d7271527fa48c26b657d689faffbc94c93e5b3c.tar.bz2 |
am 17cbadf0: am 6fa169fa: Merge "Add aarch64 EGL/GLES trampolines"
* commit '17cbadf0f598b0d02179262ad5b6b270850ccb94':
Add aarch64 EGL/GLES trampolines
-rw-r--r-- | opengl/libs/EGL/getProcAddress.cpp | 22 | ||||
-rw-r--r-- | opengl/libs/GLES2/gl2.cpp | 44 | ||||
-rw-r--r-- | opengl/libs/GLES_CM/gl.cpp | 44 |
3 files changed, 83 insertions, 27 deletions
diff --git a/opengl/libs/EGL/getProcAddress.cpp b/opengl/libs/EGL/getProcAddress.cpp index 5470d81..fc61134 100644 --- a/opengl/libs/EGL/getProcAddress.cpp +++ b/opengl/libs/EGL/getProcAddress.cpp @@ -53,9 +53,29 @@ namespace android { : [tls] "J"(TLS_SLOT_OPENGL_API*4), \ [api] "J"(__builtin_offsetof(gl_hooks_t, \ ext.extensions[_api])) \ - : \ + : "r12" \ ); +#elif defined(__aarch64__) + + #define API_ENTRY(_api) __attribute__((noinline)) _api + + #define CALL_GL_EXTENSION_API(_api) \ + asm volatile( \ + "mrs x16, tpidr_el0\n" \ + "ldr x16, [x16, %[tls]]\n" \ + "cbz x16, 1f\n" \ + "ldr x16, [x16, %[api]]\n" \ + "cbz x16, 1f\n" \ + "br x16\n" \ + "1:\n" \ + : \ + : [tls] "i" (TLS_SLOT_OPENGL_API * sizeof(void*)), \ + [api] "i" (__builtin_offsetof(gl_hooks_t, \ + ext.extensions[_api])) \ + : "x16" \ + ); + #elif defined(__i386__) #define API_ENTRY(_api) __attribute__((noinline)) _api diff --git a/opengl/libs/GLES2/gl2.cpp b/opengl/libs/GLES2/gl2.cpp index 1aef9f3..b07228f 100644 --- a/opengl/libs/GLES2/gl2.cpp +++ b/opengl/libs/GLES2/gl2.cpp @@ -36,7 +36,15 @@ using namespace android; #undef CALL_GL_API #undef CALL_GL_API_RETURN -#if defined(__arm__) && !USE_SLOW_BINDING +#if USE_SLOW_BINDING + + #define API_ENTRY(_api) _api + + #define CALL_GL_API(_api, ...) \ + gl_hooks_t::gl_t const * const _c = &getGlThreadSpecific()->gl; \ + if (_c) return _c->_api(__VA_ARGS__); + +#elif defined(__arm__) #define GET_TLS(reg) "mrc p15, 0, " #reg ", c13, c0, 3 \n" @@ -51,10 +59,28 @@ using namespace android; : \ : [tls] "J"(TLS_SLOT_OPENGL_API*4), \ [api] "J"(__builtin_offsetof(gl_hooks_t, gl._api)) \ - : \ + : "r12" \ ); -#elif defined(__i386__) && !USE_SLOW_BINDING +#elif defined(__aarch64__) + + #define API_ENTRY(_api) __attribute__((noinline)) _api + + #define CALL_GL_API(_api, ...) \ + asm volatile( \ + "mrs x16, tpidr_el0\n" \ + "ldr x16, [x16, %[tls]]\n" \ + "cbz x16, 1f\n" \ + "ldr x16, [x16, %[api]]\n" \ + "br x16\n" \ + "1:\n" \ + : \ + : [tls] "i" (TLS_SLOT_OPENGL_API * sizeof(void*)), \ + [api] "i" (__builtin_offsetof(gl_hooks_t, gl._api)) \ + : "x16" \ + ); + +#elif defined(__i386__) #define API_ENTRY(_api) __attribute__((noinline)) _api @@ -73,7 +99,7 @@ using namespace android; : "cc" \ ); -#elif defined(__x86_64__) && !USE_SLOW_BINDING +#elif defined(__x86_64__) #define API_ENTRY(_api) __attribute__((noinline)) _api @@ -92,7 +118,7 @@ using namespace android; : "cc" \ ); -#elif defined(__mips__) && !USE_SLOW_BINDING +#elif defined(__mips__) #define API_ENTRY(_api) __attribute__((noinline)) _api @@ -124,14 +150,6 @@ using namespace android; : \ ); -#else - - #define API_ENTRY(_api) _api - - #define CALL_GL_API(_api, ...) \ - gl_hooks_t::gl_t const * const _c = &getGlThreadSpecific()->gl; \ - if (_c) return _c->_api(__VA_ARGS__); - #endif #define CALL_GL_API_RETURN(_api, ...) \ diff --git a/opengl/libs/GLES_CM/gl.cpp b/opengl/libs/GLES_CM/gl.cpp index b18c95c..f05983c 100644 --- a/opengl/libs/GLES_CM/gl.cpp +++ b/opengl/libs/GLES_CM/gl.cpp @@ -92,7 +92,15 @@ GL_API void GL_APIENTRY glWeightPointerOESBounds(GLint size, GLenum type, #undef CALL_GL_API #undef CALL_GL_API_RETURN -#if defined(__arm__) && !USE_SLOW_BINDING +#if USE_SLOW_BINDING + + #define API_ENTRY(_api) _api + + #define CALL_GL_API(_api, ...) \ + gl_hooks_t::gl_t const * const _c = &getGlThreadSpecific()->gl; \ + if (_c) return _c->_api(__VA_ARGS__); + +#elif defined(__arm__) #define GET_TLS(reg) "mrc p15, 0, " #reg ", c13, c0, 3 \n" @@ -107,10 +115,28 @@ GL_API void GL_APIENTRY glWeightPointerOESBounds(GLint size, GLenum type, : \ : [tls] "J"(TLS_SLOT_OPENGL_API*4), \ [api] "J"(__builtin_offsetof(gl_hooks_t, gl._api)) \ - : \ + : "r12" \ ); -#elif defined(__i386__) && !USE_SLOW_BINDING +#elif defined(__aarch64__) + + #define API_ENTRY(_api) __attribute__((noinline)) _api + + #define CALL_GL_API(_api, ...) \ + asm volatile( \ + "mrs x16, tpidr_el0\n" \ + "ldr x16, [x16, %[tls]]\n" \ + "cbz x16, 1f\n" \ + "ldr x16, [x16, %[api]]\n" \ + "br x16\n" \ + "1:\n" \ + : \ + : [tls] "i" (TLS_SLOT_OPENGL_API * sizeof(void*)), \ + [api] "i" (__builtin_offsetof(gl_hooks_t, gl._api)) \ + : "x16" \ + ); + +#elif defined(__i386__) #define API_ENTRY(_api) __attribute__((noinline)) _api @@ -129,7 +155,7 @@ GL_API void GL_APIENTRY glWeightPointerOESBounds(GLint size, GLenum type, : "cc" \ ); -#elif defined(__x86_64__) && !USE_SLOW_BINDING +#elif defined(__x86_64__) #define API_ENTRY(_api) __attribute__((noinline)) _api @@ -148,7 +174,7 @@ GL_API void GL_APIENTRY glWeightPointerOESBounds(GLint size, GLenum type, : "cc" \ ); -#elif defined(__mips__) && !USE_SLOW_BINDING +#elif defined(__mips__) #define API_ENTRY(_api) __attribute__((noinline)) _api @@ -180,14 +206,6 @@ GL_API void GL_APIENTRY glWeightPointerOESBounds(GLint size, GLenum type, : \ ); -#else - - #define API_ENTRY(_api) _api - - #define CALL_GL_API(_api, ...) \ - gl_hooks_t::gl_t const * const _c = &getGlThreadSpecific()->gl; \ - if (_c) return _c->_api(__VA_ARGS__); - #endif #define CALL_GL_API_RETURN(_api, ...) \ |