#define ENTRY_CURRENT_TABLE_GET U_STRINGIFY(u_current_get_table_internal)
#endif
-/* REALLY_INITIAL_EXEC implies USE_ELF_TLS and __GNUC__ */
+/* REALLY_INITIAL_EXEC implies __GLIBC__ */
#if defined(USE_X86_ASM) && defined(REALLY_INITIAL_EXEC)
#include "entry_x86_tls.h"
-#elif defined(USE_X86_ASM) && !defined(GLX_X86_READONLY_TEXT) && defined(__GNUC__)
-#include "entry_x86_tsd.h"
#elif defined(USE_X86_64_ASM) && defined(REALLY_INITIAL_EXEC)
#include "entry_x86-64_tls.h"
#elif defined(USE_PPC64LE_ASM) && UTIL_ARCH_LITTLE_ENDIAN && defined(REALLY_INITIAL_EXEC)
#include "entry_ppc64le_tls.h"
-/* ppc64le non-IE TSD stubs are possible but not currently implemented */
-#elif defined(USE_PPC64LE_ASM) && UTIL_ARCH_LITTLE_ENDIAN && !defined(USE_ELF_TLS) && defined(__GNUC__)
-#include "entry_ppc64le_tsd.h"
#else
static inline const struct _glapi_table *
+++ /dev/null
-/*
- * Mesa 3-D graphics library
- *
- * Copyright (C) 2017 Red Hat
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included
- * in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
- * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- * DEALINGS IN THE SOFTWARE.
- *
- * Authors:
- * Ben Crocker <bcrocker@redhat.com>
- */
-
-#ifdef HAVE_FUNC_ATTRIBUTE_VISIBILITY
-#define HIDDEN __attribute__((visibility("hidden")))
-#else
-#define HIDDEN
-#endif
-
-// NOTE: These must be powers of two:
-#define PPC64LE_ENTRY_SIZE 256
-#define PPC64LE_PAGE_ALIGN 65536
-#if ((PPC64LE_ENTRY_SIZE & (PPC64LE_ENTRY_SIZE - 1)) != 0)
-#error PPC64LE_ENTRY_SIZE must be a power of two!
-#endif
-#if ((PPC64LE_PAGE_ALIGN & (PPC64LE_PAGE_ALIGN - 1)) != 0)
-#error PPC64LE_PAGE_ALIGN must be a power of two!
-#endif
-
-__asm__(".text\n"
- ".balign " U_STRINGIFY(PPC64LE_ENTRY_SIZE) "\n"
- "ppc64le_entry_start:");
-
-#define STUB_ASM_ENTRY(func) \
- ".globl " func "\n" \
- ".type " func ", @function\n" \
- ".balign " U_STRINGIFY(PPC64LE_ENTRY_SIZE) "\n" \
- func ":\n\t" \
- " addis 2, 12, .TOC.-" func "@ha\n\t" \
- " addi 2, 2, .TOC.-" func "@l\n\t" \
- " .localentry " func ", .-" func "\n\t"
-
-#define STUB_ASM_CODE(slot) \
- " addis 11, 2, " ENTRY_CURRENT_TABLE "@got@ha\n\t" \
- " ld 11, " ENTRY_CURRENT_TABLE "@got@l(11)\n\t" \
- " ld 11, 0(11)\n\t" \
- " cmpldi 11, 0\n\t" \
- " beq 2000f\n" \
- "1050:\n\t" \
- " ld 12, " slot "*8(11)\n\t" \
- " mtctr 12\n\t" \
- " bctr\n" \
- "2000:\n\t" \
- " mflr 0\n\t" \
- " std 0, 16(1)\n\t" \
- " std 2, 40(1)\n\t" \
- " stdu 1, -144(1)\n\t" \
- " std 3, 56(1)\n\t" \
- " std 4, 64(1)\n\t" \
- " std 5, 72(1)\n\t" \
- " std 6, 80(1)\n\t" \
- " std 7, 88(1)\n\t" \
- " std 8, 96(1)\n\t" \
- " std 9, 104(1)\n\t" \
- " std 10, 112(1)\n\t" \
- " std 12, 128(1)\n\t" \
- " addis 12, 2, " ENTRY_CURRENT_TABLE_GET "@got@ha\n\t" \
- " ld 12, " ENTRY_CURRENT_TABLE_GET "@got@l(12)\n\t" \
- " mtctr 12\n\t" \
- " bctrl\n\t" \
- " ld 2, 144+40(1)\n\t" \
- " mr 11, 3\n\t" \
- " ld 3, 56(1)\n\t" \
- " ld 4, 64(1)\n\t" \
- " ld 5, 72(1)\n\t" \
- " ld 6, 80(1)\n\t" \
- " ld 7, 88(1)\n\t" \
- " ld 8, 96(1)\n\t" \
- " ld 9, 104(1)\n\t" \
- " ld 10, 112(1)\n\t" \
- " ld 12, 128(1)\n\t" \
- " addi 1, 1, 144\n\t" \
- " ld 0, 16(1)\n\t" \
- " mtlr 0\n\t" \
- " b 1050b\n"
-
-#define MAPI_TMP_STUB_ASM_GCC
-#include "mapi_tmp.h"
-
-#ifndef MAPI_MODE_BRIDGE
-
-#include <string.h>
-#include "u_execmem.h"
-
-void
-entry_patch_public(void)
-{
-}
-
-extern char
-ppc64le_entry_start[] HIDDEN;
-
-mapi_func
-entry_get_public(int slot)
-{
- return (mapi_func) (ppc64le_entry_start + slot * PPC64LE_ENTRY_SIZE);
-}
-
-static const uint32_t code_templ[] = {
- // This should be functionally the same code as would be generated from
- // the STUB_ASM_CODE macro, but defined as a buffer.
- // This is used to generate new dispatch stubs. Mesa will copy this
- // data to the dispatch stub, and then it will patch the slot number and
- // any addresses that it needs to.
- // NOTE!!! NOTE!!! NOTE!!!
- // This representation is correct for both little- and big-endian systems.
- // However, more work needs to be done for big-endian Linux because it
- // adheres to an older, AIX-compatible ABI that uses function descriptors.
- // 1000:
- 0x7C0802A6, // <ENTRY+000>: mflr 0
- 0xF8010010, // <ENTRY+004>: std 0, 16(1)
- 0xE96C0098, // <ENTRY+008>: ld 11, 9000f-1000b+0(12)
- 0xE96B0000, // <ENTRY+012>: ld 11, 0(11)
- 0x282B0000, // <ENTRY+016>: cmpldi 11, 0
- 0x41820014, // <ENTRY+020>: beq 2000f
- // 1050:
- 0xE80C00A8, // <ENTRY+024>: ld 0, 9000f-1000b+16(12)
- 0x7D8B002A, // <ENTRY+028>: ldx 12, 11, 0
- 0x7D8903A6, // <ENTRY+032>: mtctr 12
- 0x4E800420, // <ENTRY+036>: bctr
- // 2000:
- 0xF8410028, // <ENTRY+040>: std 2, 40(1)
- 0xF821FF71, // <ENTRY+044>: stdu 1, -144(1)
- 0xF8610038, // <ENTRY+048>: std 3, 56(1)
- 0xF8810040, // <ENTRY+052>: std 4, 64(1)
- 0xF8A10048, // <ENTRY+056>: std 5, 72(1)
- 0xF8C10050, // <ENTRY+060>: std 6, 80(1)
- 0xF8E10058, // <ENTRY+064>: std 7, 88(1)
- 0xF9010060, // <ENTRY+068>: std 8, 96(1)
- 0xF9210068, // <ENTRY+072>: std 9, 104(1)
- 0xF9410070, // <ENTRY+076>: std 10, 112(1)
- 0xF9810080, // <ENTRY+080>: std 12, 128(1)
- 0xE98C00A0, // <ENTRY+084>: ld 12, 9000f-1000b+8(12)
- 0x7D8903A6, // <ENTRY+088>: mtctr 12
- 0x4E800421, // <ENTRY+092>: bctrl
- 0x7C6B1B78, // <ENTRY+096>: mr 11, 3
- 0xE8610038, // <ENTRY+100>: ld 3, 56(1)
- 0xE8810040, // <ENTRY+104>: ld 4, 64(1)
- 0xE8A10048, // <ENTRY+108>: ld 5, 72(1)
- 0xE8C10050, // <ENTRY+112>: ld 6, 80(1)
- 0xE8E10058, // <ENTRY+116>: ld 7, 88(1)
- 0xE9010060, // <ENTRY+120>: ld 8, 96(1)
- 0xE9210068, // <ENTRY+124>: ld 9, 104(1)
- 0xE9410070, // <ENTRY+128>: ld 10, 112(1)
- 0xE9810080, // <ENTRY+132>: ld 12, 128(1)
- 0x38210090, // <ENTRY+136>: addi 1, 1, 144
- 0xE8010010, // <ENTRY+140>: ld 0, 16(1)
- 0x7C0803A6, // <ENTRY+144>: mtlr 0
- 0x4BFFFF84, // <ENTRY+148>: b 1050b
- // 9000:
- 0, 0, // <ENTRY+152>: .quad ENTRY_CURRENT_TABLE
- 0, 0, // <ENTRY+160>: .quad ENTRY_CURRENT_TABLE_GET
- 0, 0 // <ENTRY+168>: .quad <slot>*8
-};
-static const uint64_t TEMPLATE_OFFSET_CURRENT_TABLE = sizeof(code_templ) - 3*8;
-static const uint64_t TEMPLATE_OFFSET_CURRENT_TABLE_GET = sizeof(code_templ) - 2*8;
-static const uint64_t TEMPLATE_OFFSET_SLOT = sizeof(code_templ) - 1*8;
-
-void
-entry_patch(mapi_func entry, int slot)
-{
- char *code = (char *) entry;
- *((uint64_t *) (code + TEMPLATE_OFFSET_CURRENT_TABLE)) = (uint64_t) ENTRY_CURRENT_TABLE;
- *((uint64_t *) (code + TEMPLATE_OFFSET_CURRENT_TABLE_GET)) = (uint64_t) ENTRY_CURRENT_TABLE_GET;
- *((uint64_t *) (code + TEMPLATE_OFFSET_SLOT)) = slot * sizeof(mapi_func);
-}
-
-mapi_func
-entry_generate(int slot)
-{
- char *code;
- mapi_func entry;
-
- code = u_execmem_alloc(sizeof(code_templ));
- if (!code)
- return NULL;
-
- memcpy(code, code_templ, sizeof(code_templ));
-
- entry = (mapi_func) code;
- entry_patch(entry, slot);
-
- return entry;
-}
-
-#endif /* MAPI_MODE_BRIDGE */
+++ /dev/null
-/*
- * Mesa 3-D graphics library
- *
- * Copyright (C) 2010 LunarG Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included
- * in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
- * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- * DEALINGS IN THE SOFTWARE.
- *
- * Authors:
- * Chia-I Wu <olv@lunarg.com>
- */
-
-#ifdef __CET__
-#define ENDBR "endbr32\n\t"
-#else
-#define ENDBR
-#endif
-
-#ifdef HAVE_FUNC_ATTRIBUTE_VISIBILITY
-#define HIDDEN __attribute__((visibility("hidden")))
-#else
-#define HIDDEN
-#endif
-
-#define X86_ENTRY_SIZE 64
-
-__asm__(".text\n");
-
-__asm__("x86_got:\n\t"
- "call 1f\n"
- "1:\n\t"
- "popl %eax\n\t"
- "addl $_GLOBAL_OFFSET_TABLE_+[.-1b], %eax\n\t"
- "ret");
-
-__asm__(".balign 32\n"
- "x86_entry_start:");
-
-#define STUB_ASM_ENTRY(func) \
- ".globl " func "\n" \
- ".type " func ", @function\n" \
- ".balign 32\n" \
- func ":"
-
-#define LOC_BEGIN_SET_ECX
-#define LOC_END_SET_ECX
-#define LOC_END_JMP
-
-#define STUB_ASM_CODE(slot) \
- ENDBR \
- LOC_BEGIN_SET_ECX \
- "call 1f\n\t" \
- "1:\n\t" \
- "popl %ecx\n\t" \
- "addl $_GLOBAL_OFFSET_TABLE_+[.-1b], %ecx\n\t" \
- LOC_END_SET_ECX \
- "movl _glapi_Dispatch@GOT(%ecx), %eax\n\t" \
- "mov (%eax), %eax\n\t" \
- "testl %eax, %eax\n\t" \
- "jne 1f\n\t" \
- "push %ebx\n\t" \
- "movl %ecx, %ebx\n\t" \
- "call " ENTRY_CURRENT_TABLE_GET "@PLT\n\t" \
- "popl %ebx\n\t" \
- "1:\n\t" \
- "jmp *(4 * " slot ")(%eax)\n\t" \
- LOC_END_JMP
-
-#define MAPI_TMP_STUB_ASM_GCC
-#include "mapi_tmp.h"
-
-#ifndef MAPI_MODE_BRIDGE
-
-__asm__(".balign 32\n"
- "x86_entry_end:");
-
-#undef LOC_BEGIN_SET_ECX
-#undef LOC_END_SET_ECX
-#undef LOC_END_JMP
-#define LOC_BEGIN_SET_ECX "jmp set_ecx\n\t"
-#define LOC_END_SET_ECX "set_ecx:movl $0x12345678, %ecx\n\tloc_end_set_ecx:\n\t"
-#define LOC_END_JMP "loc_end_jmp:"
-
-/* Any number big enough works. This is to make sure the final
- * jmp is a long jmp */
-__asm__(STUB_ASM_CODE("10000"));
-
-extern const char loc_end_set_ecx[] HIDDEN;
-extern const char loc_end_jmp[] HIDDEN;
-
-#include <string.h>
-#include "u_execmem.h"
-
-extern unsigned long
-x86_got();
-
-extern const char x86_entry_start[] HIDDEN;
-extern const char x86_entry_end[] HIDDEN;
-
-void
-entry_patch_public(void)
-{
-}
-
-mapi_func
-entry_get_public(int slot)
-{
- return (mapi_func) (x86_entry_start + slot * X86_ENTRY_SIZE);
-}
-
-void
-entry_patch(mapi_func entry, int slot)
-{
- char *code = (char *) entry;
- int offset = loc_end_jmp - x86_entry_end - sizeof(unsigned long);
- *((unsigned long *) (code + offset)) = slot * sizeof(mapi_func);
-}
-
-mapi_func
-entry_generate(int slot)
-{
- const char *code_templ = x86_entry_end;
- char *code;
- mapi_func entry;
-
- code = u_execmem_alloc(X86_ENTRY_SIZE);
- if (!code)
- return NULL;
-
- memcpy(code, code_templ, X86_ENTRY_SIZE);
- entry = (mapi_func) code;
- int ecx_value_off = loc_end_set_ecx - x86_entry_end - sizeof(unsigned long);
- *((unsigned long *) (code + ecx_value_off)) = x86_got();
-
- entry_patch(entry, slot);
-
- return entry;
-}
-
-#endif /* MAPI_MODE_BRIDGE */
print('\t add\t%o7, %g2, %g2')
print('\t.size\t__glapi_sparc_get_pc, .-__glapi_sparc_get_pc')
print('')
- print('#ifdef USE_ELF_TLS')
print('')
print('\tGLOBL_FN(__glapi_sparc_get_dispatch)')
print('\tHIDDEN(__glapi_sparc_get_dispatch)')
print('\t sethi\tGL_OFF(off), %g3;\t\t\t\\')
print('\t.size\tfn,.-fn;')
print('')
- print('#elif defined(HAVE_PTHREAD)')
- print('')
- print('\t/* 64-bit 0x00 --> sethi %hh(_glapi_Dispatch), %g1 */')
- print('\t/* 64-bit 0x04 --> sethi %lm(_glapi_Dispatch), %g2 */')
- print('\t/* 64-bit 0x08 --> or %g1, %hm(_glapi_Dispatch), %g1 */')
- print('\t/* 64-bit 0x0c --> sllx %g1, 32, %g1 */')
- print('\t/* 64-bit 0x10 --> add %g1, %g2, %g1 */')
- print('\t/* 64-bit 0x14 --> ldx [%g1 + %lo(_glapi_Dispatch)], %g1 */')
- print('')
- print('\t/* 32-bit 0x00 --> sethi %hi(_glapi_Dispatch), %g1 */')
- print('\t/* 32-bit 0x04 --> ld [%g1 + %lo(_glapi_Dispatch)], %g1 */')
- print('')
- print('\t.data')
- print('\t.align\t32')
- print('')
- print('\tGLOBL_FN(__glapi_sparc_pthread_stub)')
- print('\tHIDDEN(__glapi_sparc_pthread_stub)')
- print('__glapi_sparc_pthread_stub: /* Call offset in %g3 */')
- print('\tmov\t%o7, %g1')
- print('\tsethi\t%hi(_GLOBAL_OFFSET_TABLE_-4), %g2')
- print('\tcall\t__glapi_sparc_get_pc')
- print('\t add\t%g2, %lo(_GLOBAL_OFFSET_TABLE_+4), %g2')
- print('\tmov\t%g1, %o7')
- print('\tsethi\t%hi(_glapi_Dispatch), %g1')
- print('\tor\t%g1, %lo(_glapi_Dispatch), %g1')
- print('\tsrl\t%g3, 10, %g3')
- print('\tGL_LL\t[%g2+%g1], %g2')
- print('\tGL_LL\t[%g2], %g1')
- print('\tcmp\t%g1, 0')
- print('\tbe\t2f')
- print('\t nop')
- print('1:\tGL_LL\t[%g1 + %g3], %g1')
- print('\tjmp\t%g1')
- print('\t nop')
- print('2:\tsave\t%sp, GL_STACK_SIZE, %sp')
- print('\tmov\t%g3, %l0')
- print('\tcall\t_glapi_get_dispatch')
- print('\t nop')
- print('\tmov\t%o0, %g1')
- print('\tmov\t%l0, %g3')
- print('\tba\t1b')
- print('\t restore %g0, %g0, %g0')
- print('\t.size\t__glapi_sparc_pthread_stub, .-__glapi_sparc_pthread_stub')
- print('')
- print('#define GL_STUB(fn, off)\t\t\t\\')
- print('\tGLOBL_FN(fn);\t\t\t\t\\')
- print('fn:\tba\t__glapi_sparc_pthread_stub;\t\\')
- print('\t sethi\tGL_OFF(off), %g3;\t\t\\')
- print('\t.size\tfn,.-fn;')
- print('')
- print('#else /* Non-threaded version. */')
- print('')
- print('\t.type __glapi_sparc_nothread_stub, @function')
- print('__glapi_sparc_nothread_stub: /* Call offset in %g3 */')
- print('\tmov\t%o7, %g1')
- print('\tsethi\t%hi(_GLOBAL_OFFSET_TABLE_-4), %g2')
- print('\tcall\t__glapi_sparc_get_pc')
- print('\t add\t%g2, %lo(_GLOBAL_OFFSET_TABLE_+4), %g2')
- print('\tmov\t%g1, %o7')
- print('\tsrl\t%g3, 10, %g3')
- print('\tsethi\t%hi(_glapi_Dispatch), %g1')
- print('\tor\t%g1, %lo(_glapi_Dispatch), %g1')
- print('\tGL_LL\t[%g2+%g1], %g2')
- print('\tGL_LL\t[%g2], %g1')
- print('\tGL_LL\t[%g1 + %g3], %g1')
- print('\tjmp\t%g1')
- print('\t nop')
- print('\t.size\t__glapi_sparc_nothread_stub, .-__glapi_sparc_nothread_stub')
- print('')
- print('#define GL_STUB(fn, off)\t\t\t\\')
- print('\tGLOBL_FN(fn);\t\t\t\t\\')
- print('fn:\tba\t__glapi_sparc_nothread_stub;\t\\')
- print('\t sethi\tGL_OFF(off), %g3;\t\t\\')
- print('\t.size\tfn,.-fn;')
- print('')
- print('#endif')
- print('')
print('#define GL_STUB_ALIAS(fn, alias) \\')
print(' .globl fn; \\')
print(' .set fn, alias')
print('')
print('\t.text')
print('')
- print('#ifdef USE_ELF_TLS')
- print('')
print('_x86_64_get_dispatch:')
print('\tmovq\t_glapi_tls_Dispatch@GOTTPOFF(%rip), %rax')
print('\tmovq\t%fs:(%rax), %rax')
print('\tret')
print('\t.size\t_x86_64_get_dispatch, .-_x86_64_get_dispatch')
print('')
- print('#elif defined(HAVE_PTHREAD)')
- print('')
- print('\t.extern\t_glapi_Dispatch')
- print('\t.extern\t_gl_DispatchTSD')
- print('\t.extern\tpthread_getspecific')
- print('')
- print('\t.p2align\t4,,15')
- print('_x86_64_get_dispatch:')
- print('\tmovq\t_gl_DispatchTSD@GOTPCREL(%rip), %rax')
- print('\tmovl\t(%rax), %edi')
- print('\tjmp\tpthread_getspecific@PLT')
- print('')
- print('#else')
- print('')
- print('\t.extern\t_glapi_get_dispatch')
- print('')
- print('#endif')
- print('')
return
if not f.is_static_entry_point(f.name):
print('\tHIDDEN(GL_PREFIX(%s))' % (name))
print('GL_PREFIX(%s):' % (name))
- print('#if defined(USE_ELF_TLS)')
print('\tcall\t_x86_64_get_dispatch@PLT')
print('\tmovq\t%u(%%rax), %%r11' % (f.offset * 8))
print('\tjmp\t*%r11')
- print('#elif defined(HAVE_PTHREAD)')
-
- save_all_regs(registers)
- print('\tcall\t_x86_64_get_dispatch@PLT')
- restore_all_regs(registers)
-
- if f.offset == 0:
- print('\tmovq\t(%rax), %r11')
- else:
- print('\tmovq\t%u(%%rax), %%r11' % (f.offset * 8))
-
- print('\tjmp\t*%r11')
-
- print('#else')
- print('\tmovq\t_glapi_Dispatch(%rip), %rax')
- print('\ttestq\t%rax, %rax')
- print('\tje\t1f')
- print('\tmovq\t%u(%%rax), %%r11' % (f.offset * 8))
- print('\tjmp\t*%r11')
- print('1:')
-
- save_all_regs(registers)
- print('\tcall\t_glapi_get_dispatch')
- restore_all_regs(registers)
-
- print('\tmovq\t%u(%%rax), %%r11' % (f.offset * 8))
- print('\tjmp\t*%r11')
- print('#endif /* defined(USE_ELF_TLS) */')
print('\t.size\tGL_PREFIX(%s), .-GL_PREFIX(%s)' % (name, name))
print('')
print('#endif')
print('')
- print('#if defined( USE_ELF_TLS ) && !defined( GLX_X86_READONLY_TEXT )')
+ print('#if !defined( GLX_X86_READONLY_TEXT )')
print('\t\t.section\twtext, "awx", @progbits')
- print('#endif /* defined( USE_ELF_TLS ) */')
+ print('#endif /* !defined( GLX_X86_READONLY_TEXT ) */')
print('')
print('\t\tALIGNTEXT16')
* u_current.c.
*/
-#ifdef USE_ELF_TLS
/* not used, but defined for compatibility */
const struct _glapi_table *_glapi_Dispatch;
const void *_glapi_Context;
-#endif /* USE_ELF_TLS */
void
_glapi_destroy_multithread(void)
{
- u_current_destroy();
}
void
_glapi_check_multithread(void)
{
- u_current_init();
}
void
struct _glapi_table;
-
-#if defined (USE_ELF_TLS)
-
#if DETECT_OS_WINDOWS
extern __THREAD_INITIAL_EXEC struct _glapi_table * _glapi_tls_Dispatch;
extern __THREAD_INITIAL_EXEC void * _glapi_tls_Context;
# define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) _glapi_tls_Context
#endif
-#else
-
-_GLAPI_EXPORT extern struct _glapi_table *_glapi_Dispatch;
-_GLAPI_EXPORT extern void *_glapi_Context;
-
-#define GET_DISPATCH() \
- (likely(_glapi_Dispatch) ? _glapi_Dispatch : _glapi_get_dispatch())
-
-#define GET_CURRENT_CONTEXT(C) struct gl_context *C = (struct gl_context *) \
- (likely(_glapi_Context) ? _glapi_Context : _glapi_get_context())
-
-#endif /* defined (USE_ELF_TLS) */
-
-
_GLAPI_EXPORT void
_glapi_destroy_multithread(void);
#ifdef USE_X86_ASM
-#if defined( USE_ELF_TLS )
extern GLubyte gl_dispatch_functions_start[];
extern GLubyte gl_dispatch_functions_end[];
-#else
-extern const GLubyte gl_dispatch_functions_start[];
-#endif
#endif /* USE_X86_ASM */
static void
init_glapi_relocs( void )
{
-#if defined(USE_ELF_TLS) && !defined(GLX_X86_READONLY_TEXT)
+#if !defined(GLX_X86_READONLY_TEXT)
extern unsigned long _x86_get_dispatch(void);
char run_time_patch[] = {
0x65, 0xa1, 0, 0, 0, 0 /* movl %gs:0,%eax */
{
GLubyte * const code = (GLubyte *) entrypoint;
-#if defined(USE_ELF_TLS)
*((unsigned int *)(code + 8)) = 4 * offset;
-#else
- *((unsigned int *)(code + 11)) = 4 * offset;
- *((unsigned int *)(code + 22)) = 4 * offset;
-#endif
}
static void
init_glapi_relocs( void )
{
-#if defined(HAVE_PTHREAD) || defined(USE_ELF_TLS)
static const unsigned int template[] = {
-#ifdef USE_ELF_TLS
0x05000000, /* sethi %hi(_glapi_tls_Dispatch), %g2 */
0x8730e00a, /* srl %g3, 10, %g3 */
0x8410a000, /* or %g2, %lo(_glapi_tls_Dispatch), %g2 */
#endif
0x81c04000, /* jmp %g1 */
0x01000000, /* nop */
-#else
-#ifdef __arch64__
- 0x03000000, /* 64-bit 0x00 --> sethi %hh(_glapi_Dispatch), %g1 */
- 0x05000000, /* 64-bit 0x04 --> sethi %lm(_glapi_Dispatch), %g2 */
- 0x82106000, /* 64-bit 0x08 --> or %g1, %hm(_glapi_Dispatch), %g1 */
- 0x8730e00a, /* 64-bit 0x0c --> srl %g3, 10, %g3 */
- 0x83287020, /* 64-bit 0x10 --> sllx %g1, 32, %g1 */
- 0x82004002, /* 64-bit 0x14 --> add %g1, %g2, %g1 */
- 0xc2586000, /* 64-bit 0x18 --> ldx [%g1 + %lo(_glapi_Dispatch)], %g1 */
-#else
- 0x03000000, /* 32-bit 0x00 --> sethi %hi(_glapi_Dispatch), %g1 */
- 0x8730e00a, /* 32-bit 0x04 --> srl %g3, 10, %g3 */
- 0xc2006000, /* 32-bit 0x08 --> ld [%g1 + %lo(_glapi_Dispatch)], %g1 */
-#endif
- 0x80a06000, /* --> cmp %g1, 0 */
- 0x02800005, /* --> be +4*5 */
- 0x01000000, /* --> nop */
-#ifdef __arch64__
- 0xc2584003, /* 64-bit --> ldx [%g1 + %g3], %g1 */
-#else
- 0xc2004003, /* 32-bit --> ld [%g1 + %g3], %g1 */
-#endif
- 0x81c04000, /* --> jmp %g1 */
- 0x01000000, /* --> nop */
-#ifdef __arch64__
- 0x9de3bf80, /* 64-bit --> save %sp, -128, %sp */
-#else
- 0x9de3bfc0, /* 32-bit --> save %sp, -64, %sp */
-#endif
- 0xa0100003, /* --> mov %g3, %l0 */
- 0x40000000, /* --> call _glapi_get_dispatch */
- 0x01000000, /* --> nop */
- 0x82100008, /* --> mov %o0, %g1 */
- 0x86100010, /* --> mov %l0, %g3 */
- 0x10bffff7, /* --> ba -4*9 */
- 0x81e80000, /* --> restore */
-#endif
};
-#ifdef USE_ELF_TLS
extern unsigned int __glapi_sparc_tls_stub;
extern unsigned long __glapi_sparc_get_dispatch(void);
unsigned int *code = &__glapi_sparc_tls_stub;
unsigned long dispatch = __glapi_sparc_get_dispatch();
-#else
- extern unsigned int __glapi_sparc_pthread_stub;
- unsigned int *code = &__glapi_sparc_pthread_stub;
- unsigned long dispatch = (unsigned long) &_glapi_Dispatch;
- unsigned long call_dest = (unsigned long ) &_glapi_get_dispatch;
- int idx;
-#endif
-#ifdef USE_ELF_TLS
code[0] = template[0] | (dispatch >> 10);
code[1] = template[1];
__glapi_sparc_icache_flush(&code[0]);
__glapi_sparc_icache_flush(&code[4]);
code[6] = template[6];
__glapi_sparc_icache_flush(&code[6]);
-#else
-#if defined(__arch64__)
- code[0] = template[0] | (dispatch >> (32 + 10));
- code[1] = template[1] | ((dispatch & 0xffffffff) >> 10);
- __glapi_sparc_icache_flush(&code[0]);
- code[2] = template[2] | ((dispatch >> 32) & 0x3ff);
- code[3] = template[3];
- __glapi_sparc_icache_flush(&code[2]);
- code[4] = template[4];
- code[5] = template[5];
- __glapi_sparc_icache_flush(&code[4]);
- code[6] = template[6] | (dispatch & 0x3ff);
- idx = 7;
-#else
- code[0] = template[0] | (dispatch >> 10);
- code[1] = template[1];
- __glapi_sparc_icache_flush(&code[0]);
- code[2] = template[2] | (dispatch & 0x3ff);
- idx = 3;
-#endif
- code[idx + 0] = template[idx + 0];
- __glapi_sparc_icache_flush(&code[idx - 1]);
- code[idx + 1] = template[idx + 1];
- code[idx + 2] = template[idx + 2];
- __glapi_sparc_icache_flush(&code[idx + 1]);
- code[idx + 3] = template[idx + 3];
- code[idx + 4] = template[idx + 4];
- __glapi_sparc_icache_flush(&code[idx + 3]);
- code[idx + 5] = template[idx + 5];
- code[idx + 6] = template[idx + 6];
- __glapi_sparc_icache_flush(&code[idx + 5]);
- code[idx + 7] = template[idx + 7];
- code[idx + 8] = template[idx + 8] |
- (((call_dest - ((unsigned long) &code[idx + 8]))
- >> 2) & 0x3fffffff);
- __glapi_sparc_icache_flush(&code[idx + 7]);
- code[idx + 9] = template[idx + 9];
- code[idx + 10] = template[idx + 10];
- __glapi_sparc_icache_flush(&code[idx + 9]);
- code[idx + 11] = template[idx + 11];
- code[idx + 12] = template[idx + 12];
- __glapi_sparc_icache_flush(&code[idx + 11]);
- code[idx + 13] = template[idx + 13];
- __glapi_sparc_icache_flush(&code[idx + 13]);
-#endif
-#endif
}
_glapi_proc
generate_entrypoint(GLuint functionOffset)
{
-#if defined(HAVE_PTHREAD) || defined(USE_ELF_TLS)
static const unsigned int template[] = {
0x07000000, /* sethi %hi(0), %g3 */
0x8210000f, /* mov %o7, %g1 */
0x40000000, /* call */
0x9e100001, /* mov %g1, %o7 */
};
-#ifdef USE_ELF_TLS
extern unsigned int __glapi_sparc_tls_stub;
unsigned long call_dest = (unsigned long ) &__glapi_sparc_tls_stub;
-#else
- extern unsigned int __glapi_sparc_pthread_stub;
- unsigned long call_dest = (unsigned long ) &__glapi_sparc_pthread_stub;
-#endif
unsigned int *code = (unsigned int *) u_execmem_alloc(sizeof(template));
if (code) {
code[0] = template[0] | (functionOffset & 0x3fffff);
__glapi_sparc_icache_flush(&code[2]);
}
return (_glapi_proc) code;
-#endif
}
#else /* USE_*_ASM */
-#if defined(HAVE_PTHREAD) || defined(USE_ELF_TLS)
static void
init_glapi_relocs( void )
{
}
-#endif
_glapi_proc
void
init_glapi_relocs_once( void )
{
-#if defined(HAVE_PTHREAD) || defined(USE_ELF_TLS)
static once_flag flag = ONCE_FLAG_INIT;
call_once(&flag, init_glapi_relocs);
-#endif
}
* Size (in bytes) of dispatch function (entrypoint).
*/
#if defined(USE_X86_ASM)
-# if defined(USE_ELF_TLS)
-# define DISPATCH_FUNCTION_SIZE 16
-# else
-# define DISPATCH_FUNCTION_SIZE 32
-# endif
+#define DISPATCH_FUNCTION_SIZE 16
#endif
#if defined(USE_X64_64_ASM)
-# if defined(USE_ELF_TLS)
-# define DISPATCH_FUNCTION_SIZE 16
-# endif
+#define DISPATCH_FUNCTION_SIZE 16
#endif
'../entry.h',
'../entry_x86-64_tls.h',
'../entry_x86_tls.h',
- '../entry_x86_tsd.h',
'../entry_ppc64le_tls.h',
- '../entry_ppc64le_tsd.h',
'../mapi_tmp.h',
)
bridge_glapi_files += glapi_mapi_tmp_h
* u_current.c.
*/
-#ifdef USE_ELF_TLS
/* not used, but defined for compatibility */
const struct _glapi_table *_glapi_Dispatch;
const void *_glapi_Context;
-#endif /* USE_ELF_TLS */
void
_glapi_destroy_multithread(void)
{
- u_current_destroy();
}
void
_glapi_check_multithread(void)
{
- u_current_init();
}
void
* static dispatch functions access these variables via \c _glapi_get_dispatch
* and \c _glapi_get_context.
*
- * There is a race condition in setting \c _glapi_Dispatch to \c NULL. It is
- * possible for the original thread to be setting it at the same instant a new
- * thread, perhaps running on a different processor, is clearing it. Because
- * of that, \c ThreadSafe, which can only ever be changed to \c GL_TRUE, is
- * used to determine whether or not the application is multithreaded.
*
* In the TLS case, the variables \c _glapi_Dispatch and \c _glapi_Context are
* hardcoded to \c NULL. Instead the TLS variables \c _glapi_tls_Dispatch and
* between TLS enabled loaders and non-TLS DRI drivers.
*/
/*@{*/
-#if defined(USE_ELF_TLS)
__THREAD_INITIAL_EXEC struct _glapi_table *u_current_table
= (struct _glapi_table *) table_noop_array;
__THREAD_INITIAL_EXEC void *u_current_context;
-#else
-
-struct _glapi_table *u_current_table =
- (struct _glapi_table *) table_noop_array;
-void *u_current_context;
-
-tss_t u_current_table_tsd;
-static tss_t u_current_context_tsd;
-static int ThreadSafe;
-
-#endif /* defined(USE_ELF_TLS) */
/*@}*/
-
-void
-u_current_destroy(void)
-{
-#if !defined(USE_ELF_TLS)
- tss_delete(u_current_table_tsd);
- tss_delete(u_current_context_tsd);
-#endif
-}
-
-
-#if !defined(USE_ELF_TLS)
-
-static void
-u_current_init_tsd(void)
-{
- tss_create(&u_current_table_tsd, NULL);
- tss_create(&u_current_context_tsd, NULL);
-}
-
-/**
- * Mutex for multithread check.
- */
-static mtx_t ThreadCheckMutex = _MTX_INITIALIZER_NP;
-
-static thread_id knownID;
-
-/**
- * We should call this periodically from a function such as glXMakeCurrent
- * in order to test if multiple threads are being used.
- */
-void
-u_current_init(void)
-{
- static int firstCall = 1;
-
- if (ThreadSafe)
- return;
-
- mtx_lock(&ThreadCheckMutex);
- if (firstCall) {
- u_current_init_tsd();
-
- knownID = util_get_thread_id();
- firstCall = 0;
- }
- else if (!util_thread_id_equal(knownID, util_get_thread_id())) {
- ThreadSafe = 1;
- u_current_set_table(NULL);
- u_current_set_context(NULL);
- }
- mtx_unlock(&ThreadCheckMutex);
-}
-
-#else
-
-void
-u_current_init(void)
-{
-}
-
-#endif
-
-
-
/**
* Set the current context pointer for this thread.
* The context pointer is an opaque type which should be cast to
void
u_current_set_context(const void *ptr)
{
- u_current_init();
-
-#if defined(USE_ELF_TLS)
u_current_context = (void *) ptr;
-#else
- tss_set(u_current_context_tsd, (void *) ptr);
- u_current_context = (ThreadSafe) ? NULL : (void *) ptr;
-#endif
}
/**
void *
u_current_get_context_internal(void)
{
-#if defined(USE_ELF_TLS)
return u_current_context;
-#else
- if (ThreadSafe)
- return tss_get(u_current_context_tsd);
- else if (!util_thread_id_equal(knownID, util_get_thread_id()))
- return NULL;
- else
- return u_current_context;
-#endif
}
/**
void
u_current_set_table(const struct _glapi_table *tbl)
{
- u_current_init();
-
stub_init_once();
if (!tbl)
tbl = (const struct _glapi_table *) table_noop_array;
-#if defined(USE_ELF_TLS)
u_current_table = (struct _glapi_table *) tbl;
-#else
- tss_set(u_current_table_tsd, (void *) tbl);
- u_current_table = (ThreadSafe) ? NULL : (void *) tbl;
-#endif
}
/**
struct _glapi_table *
u_current_get_table_internal(void)
{
-#if defined(USE_ELF_TLS)
return u_current_table;
-#else
- if (ThreadSafe)
- return (struct _glapi_table *) tss_get(u_current_table_tsd);
- else if (!util_thread_id_equal(knownID, util_get_thread_id()))
- return (struct _glapi_table *) table_noop_array;
- else
- return (struct _glapi_table *) u_current_table;
-#endif
}
#include "glapi/glapi.h"
-#ifdef USE_ELF_TLS
#define u_current_table _glapi_tls_Dispatch
#define u_current_context _glapi_tls_Context
-#else
-#define u_current_table _glapi_Dispatch
-#define u_current_context _glapi_Context
-#endif
#define u_current_get_table_internal _glapi_get_dispatch
#define u_current_get_context_internal _glapi_get_context
struct _glapi_table;
-#ifdef USE_ELF_TLS
-
extern __THREAD_INITIAL_EXEC struct _glapi_table *u_current_table;
extern __THREAD_INITIAL_EXEC void *u_current_context;
-#else /* USE_ELF_TLS */
-
-extern struct _glapi_table *u_current_table;
-extern void *u_current_context;
-
-#endif /* USE_ELF_TLS */
-
#endif /* MAPI_MODE_UTIL || MAPI_MODE_GLAPI || MAPI_MODE_BRIDGE */
void
-u_current_init(void);
-
-void
-u_current_destroy(void);
-
-void
u_current_set_table(const struct _glapi_table *tbl);
_GLAPI_EXPORT struct _glapi_table *