xref: /freebsd/contrib/llvm-project/libunwind/src/assembly.h (revision 5ffd83dbcc34f10e07f6d3e968ae6365869615f4)
10b57cec5SDimitry Andric /* ===-- assembly.h - libUnwind assembler support macros -------------------===
20b57cec5SDimitry Andric  *
30b57cec5SDimitry Andric  * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40b57cec5SDimitry Andric  * See https://llvm.org/LICENSE.txt for license information.
50b57cec5SDimitry Andric  * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60b57cec5SDimitry Andric  *
70b57cec5SDimitry Andric  * ===----------------------------------------------------------------------===
80b57cec5SDimitry Andric  *
90b57cec5SDimitry Andric  * This file defines macros for use in libUnwind assembler source.
100b57cec5SDimitry Andric  * This file is not part of the interface of this library.
110b57cec5SDimitry Andric  *
120b57cec5SDimitry Andric  * ===----------------------------------------------------------------------===
130b57cec5SDimitry Andric  */
140b57cec5SDimitry Andric 
150b57cec5SDimitry Andric #ifndef UNWIND_ASSEMBLY_H
160b57cec5SDimitry Andric #define UNWIND_ASSEMBLY_H
170b57cec5SDimitry Andric 
180b57cec5SDimitry Andric #if defined(__powerpc64__)
190b57cec5SDimitry Andric #define SEPARATOR ;
200b57cec5SDimitry Andric #define PPC64_OFFS_SRR0   0
210b57cec5SDimitry Andric #define PPC64_OFFS_CR     272
220b57cec5SDimitry Andric #define PPC64_OFFS_XER    280
230b57cec5SDimitry Andric #define PPC64_OFFS_LR     288
240b57cec5SDimitry Andric #define PPC64_OFFS_CTR    296
250b57cec5SDimitry Andric #define PPC64_OFFS_VRSAVE 304
260b57cec5SDimitry Andric #define PPC64_OFFS_FP     312
270b57cec5SDimitry Andric #define PPC64_OFFS_V      824
280b57cec5SDimitry Andric #ifdef _ARCH_PWR8
290b57cec5SDimitry Andric #define PPC64_HAS_VMX
300b57cec5SDimitry Andric #endif
31*5ffd83dbSDimitry Andric #elif defined(__APPLE__) && defined(__aarch64__)
320b57cec5SDimitry Andric #define SEPARATOR %%
330b57cec5SDimitry Andric #else
340b57cec5SDimitry Andric #define SEPARATOR ;
350b57cec5SDimitry Andric #endif
360b57cec5SDimitry Andric 
370b57cec5SDimitry Andric #if defined(__powerpc64__) && (!defined(_CALL_ELF) || _CALL_ELF == 1)
380b57cec5SDimitry Andric #define PPC64_OPD1 .section .opd,"aw",@progbits SEPARATOR
390b57cec5SDimitry Andric #define PPC64_OPD2 SEPARATOR \
400b57cec5SDimitry Andric   .p2align 3 SEPARATOR \
410b57cec5SDimitry Andric   .quad .Lfunc_begin0 SEPARATOR \
420b57cec5SDimitry Andric   .quad .TOC.@tocbase SEPARATOR \
430b57cec5SDimitry Andric   .quad 0 SEPARATOR \
440b57cec5SDimitry Andric   .text SEPARATOR \
450b57cec5SDimitry Andric .Lfunc_begin0:
460b57cec5SDimitry Andric #else
470b57cec5SDimitry Andric #define PPC64_OPD1
480b57cec5SDimitry Andric #define PPC64_OPD2
490b57cec5SDimitry Andric #endif
500b57cec5SDimitry Andric 
510b57cec5SDimitry Andric #define GLUE2(a, b) a ## b
520b57cec5SDimitry Andric #define GLUE(a, b) GLUE2(a, b)
530b57cec5SDimitry Andric #define SYMBOL_NAME(name) GLUE(__USER_LABEL_PREFIX__, name)
540b57cec5SDimitry Andric 
550b57cec5SDimitry Andric #if defined(__APPLE__)
560b57cec5SDimitry Andric 
570b57cec5SDimitry Andric #define SYMBOL_IS_FUNC(name)
580b57cec5SDimitry Andric #define EXPORT_SYMBOL(name)
590b57cec5SDimitry Andric #define HIDDEN_SYMBOL(name) .private_extern name
600b57cec5SDimitry Andric #define WEAK_SYMBOL(name) .weak_reference name
610b57cec5SDimitry Andric #define WEAK_ALIAS(name, aliasname)                                            \
620b57cec5SDimitry Andric   .globl SYMBOL_NAME(aliasname) SEPARATOR                                      \
630b57cec5SDimitry Andric   WEAK_SYMBOL(aliasname) SEPARATOR                                             \
640b57cec5SDimitry Andric   SYMBOL_NAME(aliasname) = SYMBOL_NAME(name)
650b57cec5SDimitry Andric 
660b57cec5SDimitry Andric #define NO_EXEC_STACK_DIRECTIVE
670b57cec5SDimitry Andric 
680b57cec5SDimitry Andric #elif defined(__ELF__)
690b57cec5SDimitry Andric 
700b57cec5SDimitry Andric #if defined(__arm__)
710b57cec5SDimitry Andric #define SYMBOL_IS_FUNC(name) .type name,%function
720b57cec5SDimitry Andric #else
730b57cec5SDimitry Andric #define SYMBOL_IS_FUNC(name) .type name,@function
740b57cec5SDimitry Andric #endif
750b57cec5SDimitry Andric #define EXPORT_SYMBOL(name)
760b57cec5SDimitry Andric #define HIDDEN_SYMBOL(name) .hidden name
770b57cec5SDimitry Andric #define WEAK_SYMBOL(name) .weak name
78*5ffd83dbSDimitry Andric 
79*5ffd83dbSDimitry Andric #if defined(__hexagon__)
80*5ffd83dbSDimitry Andric #define WEAK_ALIAS(name, aliasname) \
81*5ffd83dbSDimitry Andric   WEAK_SYMBOL(aliasname) SEPARATOR                                             \
82*5ffd83dbSDimitry Andric   .equiv SYMBOL_NAME(aliasname), SYMBOL_NAME(name)
83*5ffd83dbSDimitry Andric #else
840b57cec5SDimitry Andric #define WEAK_ALIAS(name, aliasname)                                            \
850b57cec5SDimitry Andric   WEAK_SYMBOL(aliasname) SEPARATOR                                             \
860b57cec5SDimitry Andric   SYMBOL_NAME(aliasname) = SYMBOL_NAME(name)
87*5ffd83dbSDimitry Andric #endif
880b57cec5SDimitry Andric 
890b57cec5SDimitry Andric #if defined(__GNU__) || defined(__FreeBSD__) || defined(__Fuchsia__) || \
900b57cec5SDimitry Andric     defined(__linux__)
910b57cec5SDimitry Andric #define NO_EXEC_STACK_DIRECTIVE .section .note.GNU-stack,"",%progbits
920b57cec5SDimitry Andric #else
930b57cec5SDimitry Andric #define NO_EXEC_STACK_DIRECTIVE
940b57cec5SDimitry Andric #endif
950b57cec5SDimitry Andric 
960b57cec5SDimitry Andric #elif defined(_WIN32)
970b57cec5SDimitry Andric 
980b57cec5SDimitry Andric #define SYMBOL_IS_FUNC(name)                                                   \
990b57cec5SDimitry Andric   .def name SEPARATOR                                                          \
1000b57cec5SDimitry Andric     .scl 2 SEPARATOR                                                           \
1010b57cec5SDimitry Andric     .type 32 SEPARATOR                                                         \
1020b57cec5SDimitry Andric   .endef
1030b57cec5SDimitry Andric #define EXPORT_SYMBOL2(name)                                                   \
1040b57cec5SDimitry Andric   .section .drectve,"yn" SEPARATOR                                             \
1050b57cec5SDimitry Andric   .ascii "-export:", #name, "\0" SEPARATOR                                     \
1060b57cec5SDimitry Andric   .text
1070b57cec5SDimitry Andric #if defined(_LIBUNWIND_DISABLE_VISIBILITY_ANNOTATIONS)
1080b57cec5SDimitry Andric #define EXPORT_SYMBOL(name)
1090b57cec5SDimitry Andric #else
1100b57cec5SDimitry Andric #define EXPORT_SYMBOL(name) EXPORT_SYMBOL2(name)
1110b57cec5SDimitry Andric #endif
1120b57cec5SDimitry Andric #define HIDDEN_SYMBOL(name)
1130b57cec5SDimitry Andric 
1140b57cec5SDimitry Andric #if defined(__MINGW32__)
1150b57cec5SDimitry Andric #define WEAK_ALIAS(name, aliasname)                                            \
1160b57cec5SDimitry Andric   .globl SYMBOL_NAME(aliasname) SEPARATOR                                      \
1170b57cec5SDimitry Andric   EXPORT_SYMBOL(aliasname) SEPARATOR                                           \
1180b57cec5SDimitry Andric   SYMBOL_NAME(aliasname) = SYMBOL_NAME(name)
1190b57cec5SDimitry Andric #else
1200b57cec5SDimitry Andric #define WEAK_ALIAS3(name, aliasname)                                           \
1210b57cec5SDimitry Andric   .section .drectve,"yn" SEPARATOR                                             \
1220b57cec5SDimitry Andric   .ascii "-alternatename:", #aliasname, "=", #name, "\0" SEPARATOR             \
1230b57cec5SDimitry Andric   .text
1240b57cec5SDimitry Andric #define WEAK_ALIAS2(name, aliasname)                                           \
1250b57cec5SDimitry Andric   WEAK_ALIAS3(name, aliasname)
1260b57cec5SDimitry Andric #define WEAK_ALIAS(name, aliasname)                                            \
1270b57cec5SDimitry Andric   EXPORT_SYMBOL(SYMBOL_NAME(aliasname)) SEPARATOR                              \
1280b57cec5SDimitry Andric   WEAK_ALIAS2(SYMBOL_NAME(name), SYMBOL_NAME(aliasname))
1290b57cec5SDimitry Andric #endif
1300b57cec5SDimitry Andric 
1310b57cec5SDimitry Andric #define NO_EXEC_STACK_DIRECTIVE
1320b57cec5SDimitry Andric 
1330b57cec5SDimitry Andric #elif defined(__sparc__)
1340b57cec5SDimitry Andric 
1350b57cec5SDimitry Andric #else
1360b57cec5SDimitry Andric 
1370b57cec5SDimitry Andric #error Unsupported target
1380b57cec5SDimitry Andric 
1390b57cec5SDimitry Andric #endif
1400b57cec5SDimitry Andric 
1410b57cec5SDimitry Andric #define DEFINE_LIBUNWIND_FUNCTION(name)                                        \
1420b57cec5SDimitry Andric   .globl SYMBOL_NAME(name) SEPARATOR                                           \
1430b57cec5SDimitry Andric   HIDDEN_SYMBOL(SYMBOL_NAME(name)) SEPARATOR                                   \
1440b57cec5SDimitry Andric   SYMBOL_IS_FUNC(SYMBOL_NAME(name)) SEPARATOR                                  \
1450b57cec5SDimitry Andric   PPC64_OPD1                                                                   \
1460b57cec5SDimitry Andric   SYMBOL_NAME(name):                                                           \
1470b57cec5SDimitry Andric   PPC64_OPD2
1480b57cec5SDimitry Andric 
1490b57cec5SDimitry Andric #if defined(__arm__)
1500b57cec5SDimitry Andric #if !defined(__ARM_ARCH)
1510b57cec5SDimitry Andric #define __ARM_ARCH 4
1520b57cec5SDimitry Andric #endif
1530b57cec5SDimitry Andric 
1540b57cec5SDimitry Andric #if defined(__ARM_ARCH_4T__) || __ARM_ARCH >= 5
1550b57cec5SDimitry Andric #define ARM_HAS_BX
1560b57cec5SDimitry Andric #endif
1570b57cec5SDimitry Andric 
1580b57cec5SDimitry Andric #ifdef ARM_HAS_BX
1590b57cec5SDimitry Andric #define JMP(r) bx r
1600b57cec5SDimitry Andric #else
1610b57cec5SDimitry Andric #define JMP(r) mov pc, r
1620b57cec5SDimitry Andric #endif
1630b57cec5SDimitry Andric #endif /* __arm__ */
1640b57cec5SDimitry Andric 
1650b57cec5SDimitry Andric #endif /* UNWIND_ASSEMBLY_H */
166