xref: /freebsd/contrib/llvm-project/llvm/lib/Target/PowerPC/MCTargetDesc/PPCFixupKinds.h (revision 2e3507c25e42292b45a5482e116d278f5515d04d)
1 //===-- PPCFixupKinds.h - PPC Specific Fixup Entries ------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLVM_LIB_TARGET_POWERPC_MCTARGETDESC_PPCFIXUPKINDS_H
10 #define LLVM_LIB_TARGET_POWERPC_MCTARGETDESC_PPCFIXUPKINDS_H
11 
12 #include "llvm/MC/MCFixup.h"
13 
14 #undef PPC
15 
16 namespace llvm {
17 namespace PPC {
18 enum Fixups {
19   // 24-bit PC relative relocation for direct branches like 'b' and 'bl'.
20   fixup_ppc_br24 = FirstTargetFixupKind,
21 
22   // 24-bit PC relative relocation for direct branches like 'b' and 'bl' where
23   // the caller does not use the TOC.
24   fixup_ppc_br24_notoc,
25 
26   /// 14-bit PC relative relocation for conditional branches.
27   fixup_ppc_brcond14,
28 
29   /// 24-bit absolute relocation for direct branches like 'ba' and 'bla'.
30   fixup_ppc_br24abs,
31 
32   /// 14-bit absolute relocation for conditional branches.
33   fixup_ppc_brcond14abs,
34 
35   /// A 16-bit fixup corresponding to lo16(_foo) or ha16(_foo) for instrs like
36   /// 'li' or 'addis'.
37   fixup_ppc_half16,
38 
39   /// A 14-bit fixup corresponding to lo16(_foo) with implied 2 zero bits for
40   /// instrs like 'std'.
41   fixup_ppc_half16ds,
42 
43   // A 34-bit fixup corresponding to PC-relative paddi.
44   fixup_ppc_pcrel34,
45 
46   // A 34-bit fixup corresponding to Non-PC-relative paddi.
47   fixup_ppc_imm34,
48 
49   /// Not a true fixup, but ties a symbol to a call to __tls_get_addr for the
50   /// TLS general and local dynamic models, or inserts the thread-pointer
51   /// register number. It can also be used to tie the ref symbol to prevent it
52   /// from being garbage collected on AIX.
53   fixup_ppc_nofixup,
54 
55   /// A 16-bit fixup corresponding to lo16(_foo) with implied 3 zero bits for
56   /// instrs like 'lxv'. Produces the same relocation as fixup_ppc_half16ds.
57   fixup_ppc_half16dq,
58 
59   // Marker
60   LastTargetFixupKind,
61   NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind
62 };
63 }
64 }
65 
66 #endif
67