xref: /aosp_15_r20/external/mesa3d/src/mapi/entry_ppc64le_tls.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Mesa 3-D graphics library
3*61046927SAndroid Build Coastguard Worker  *
4*61046927SAndroid Build Coastguard Worker  * Copyright (C) 2017 Red Hat
5*61046927SAndroid Build Coastguard Worker  *
6*61046927SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
7*61046927SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
8*61046927SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
9*61046927SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10*61046927SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
11*61046927SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
12*61046927SAndroid Build Coastguard Worker  *
13*61046927SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice shall be included
14*61046927SAndroid Build Coastguard Worker  * in all copies or substantial portions of the Software.
15*61046927SAndroid Build Coastguard Worker  *
16*61046927SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*61046927SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*61046927SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
19*61046927SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*61046927SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21*61046927SAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22*61046927SAndroid Build Coastguard Worker  * DEALINGS IN THE SOFTWARE.
23*61046927SAndroid Build Coastguard Worker  *
24*61046927SAndroid Build Coastguard Worker  * Authors:
25*61046927SAndroid Build Coastguard Worker  *    Ben Crocker <[email protected]>
26*61046927SAndroid Build Coastguard Worker  */
27*61046927SAndroid Build Coastguard Worker 
28*61046927SAndroid Build Coastguard Worker #ifdef HAVE_FUNC_ATTRIBUTE_VISIBILITY
29*61046927SAndroid Build Coastguard Worker #define HIDDEN __attribute__((visibility("hidden")))
30*61046927SAndroid Build Coastguard Worker #else
31*61046927SAndroid Build Coastguard Worker #define HIDDEN
32*61046927SAndroid Build Coastguard Worker #endif
33*61046927SAndroid Build Coastguard Worker 
34*61046927SAndroid Build Coastguard Worker // NOTE: These must be powers of two:
35*61046927SAndroid Build Coastguard Worker #define PPC64LE_ENTRY_SIZE 64
36*61046927SAndroid Build Coastguard Worker #define PPC64LE_PAGE_ALIGN 65536
37*61046927SAndroid Build Coastguard Worker #if ((PPC64LE_ENTRY_SIZE & (PPC64LE_ENTRY_SIZE - 1)) != 0)
38*61046927SAndroid Build Coastguard Worker #error PPC64LE_ENTRY_SIZE must be a power of two!
39*61046927SAndroid Build Coastguard Worker #endif
40*61046927SAndroid Build Coastguard Worker #if ((PPC64LE_PAGE_ALIGN & (PPC64LE_PAGE_ALIGN - 1)) != 0)
41*61046927SAndroid Build Coastguard Worker #error PPC64LE_PAGE_ALIGN must be a power of two!
42*61046927SAndroid Build Coastguard Worker #endif
43*61046927SAndroid Build Coastguard Worker 
44*61046927SAndroid Build Coastguard Worker __asm__(".text\n"
45*61046927SAndroid Build Coastguard Worker         ".balign " U_STRINGIFY(PPC64LE_ENTRY_SIZE) "\n"
46*61046927SAndroid Build Coastguard Worker         "ppc64le_entry_start:");
47*61046927SAndroid Build Coastguard Worker 
48*61046927SAndroid Build Coastguard Worker #define STUB_ASM_ENTRY(func)                            \
49*61046927SAndroid Build Coastguard Worker    ".globl " func "\n"                                  \
50*61046927SAndroid Build Coastguard Worker    ".type " func ", @function\n"                        \
51*61046927SAndroid Build Coastguard Worker    ".balign " U_STRINGIFY(PPC64LE_ENTRY_SIZE) "\n"        \
52*61046927SAndroid Build Coastguard Worker    func ":\n\t"                                         \
53*61046927SAndroid Build Coastguard Worker    "  addis  2, 12, .TOC.-" func "@ha\n\t"              \
54*61046927SAndroid Build Coastguard Worker    "  addi   2, 2, .TOC.-" func "@l\n\t"                \
55*61046927SAndroid Build Coastguard Worker    "  .localentry  " func ", .-" func "\n\t"
56*61046927SAndroid Build Coastguard Worker 
57*61046927SAndroid Build Coastguard Worker #define STUB_ASM_CODE(slot)                                     \
58*61046927SAndroid Build Coastguard Worker    "  addis  11, 2, _glapi_tls_Dispatch@got@tprel@ha\n\t"   \
59*61046927SAndroid Build Coastguard Worker    "  ld     11, _glapi_tls_Dispatch@got@tprel@l(11)\n\t"   \
60*61046927SAndroid Build Coastguard Worker    "  add    11, 11,_glapi_tls_Dispatch@tls\n\t"            \
61*61046927SAndroid Build Coastguard Worker    "  ld     11, 0(11)\n\t"                                     \
62*61046927SAndroid Build Coastguard Worker    "  ld     12, " slot "*8(11)\n\t"                            \
63*61046927SAndroid Build Coastguard Worker    "  mtctr  12\n\t"                                            \
64*61046927SAndroid Build Coastguard Worker    "  bctr\n"                                                   \
65*61046927SAndroid Build Coastguard Worker 
66*61046927SAndroid Build Coastguard Worker #define MAPI_TMP_STUB_ASM_GCC
67*61046927SAndroid Build Coastguard Worker #include "mapi_tmp.h"
68*61046927SAndroid Build Coastguard Worker 
69*61046927SAndroid Build Coastguard Worker #ifndef MAPI_MODE_BRIDGE
70*61046927SAndroid Build Coastguard Worker 
71*61046927SAndroid Build Coastguard Worker #include <string.h>
72*61046927SAndroid Build Coastguard Worker 
73*61046927SAndroid Build Coastguard Worker void
entry_patch_public(void)74*61046927SAndroid Build Coastguard Worker entry_patch_public(void)
75*61046927SAndroid Build Coastguard Worker {
76*61046927SAndroid Build Coastguard Worker }
77*61046927SAndroid Build Coastguard Worker 
78*61046927SAndroid Build Coastguard Worker extern char
79*61046927SAndroid Build Coastguard Worker ppc64le_entry_start[] HIDDEN;
80*61046927SAndroid Build Coastguard Worker 
81*61046927SAndroid Build Coastguard Worker mapi_func
entry_get_public(int slot)82*61046927SAndroid Build Coastguard Worker entry_get_public(int slot)
83*61046927SAndroid Build Coastguard Worker {
84*61046927SAndroid Build Coastguard Worker    return (mapi_func) (ppc64le_entry_start + slot * PPC64LE_ENTRY_SIZE);
85*61046927SAndroid Build Coastguard Worker }
86*61046927SAndroid Build Coastguard Worker 
87*61046927SAndroid Build Coastguard Worker #endif /* MAPI_MODE_BRIDGE */
88