File: ARMFixupKinds.h

package info (click to toggle)
llvm-toolchain-17 1%3A17.0.6-22
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,799,624 kB
  • sloc: cpp: 6,428,607; ansic: 1,383,196; asm: 793,408; python: 223,504; objc: 75,364; f90: 60,502; lisp: 33,869; pascal: 15,282; sh: 9,684; perl: 7,453; ml: 4,937; awk: 3,523; makefile: 2,889; javascript: 2,149; xml: 888; fortran: 619; cs: 573
file content (130 lines) | stat: -rw-r--r-- 4,483 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
//===-- ARMFixupKinds.h - ARM Specific Fixup Entries ------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//

#ifndef LLVM_LIB_TARGET_ARM_MCTARGETDESC_ARMFIXUPKINDS_H
#define LLVM_LIB_TARGET_ARM_MCTARGETDESC_ARMFIXUPKINDS_H

#include "llvm/MC/MCFixup.h"

namespace llvm {
namespace ARM {
enum Fixups {
  // 12-bit PC relative relocation for symbol addresses
  fixup_arm_ldst_pcrel_12 = FirstTargetFixupKind,

  // Equivalent to fixup_arm_ldst_pcrel_12, with the 16-bit halfwords reordered.
  fixup_t2_ldst_pcrel_12,

  // 10-bit PC relative relocation for symbol addresses used in
  // LDRD/LDRH/LDRB/etc. instructions. All bits are encoded.
  fixup_arm_pcrel_10_unscaled,
  // 10-bit PC relative relocation for symbol addresses used in VFP instructions
  // where the lower 2 bits are not encoded (so it's encoded as an 8-bit
  // immediate).
  fixup_arm_pcrel_10,
  // Equivalent to fixup_arm_pcrel_10, accounting for the short-swapped encoding
  // of Thumb2 instructions.
  fixup_t2_pcrel_10,
  // 9-bit PC relative relocation for symbol addresses used in VFP instructions
  // where bit 0 not encoded (so it's encoded as an 8-bit immediate).
  fixup_arm_pcrel_9,
  // Equivalent to fixup_arm_pcrel_9, accounting for the short-swapped encoding
  // of Thumb2 instructions.
  fixup_t2_pcrel_9,
  // 12-bit immediate value.
  fixup_arm_ldst_abs_12,
  // 10-bit PC relative relocation for symbol addresses where the lower 2 bits
  // are not encoded (so it's encoded as an 8-bit immediate).
  fixup_thumb_adr_pcrel_10,
  // 12-bit PC relative relocation for the ADR instruction.
  fixup_arm_adr_pcrel_12,
  // 12-bit PC relative relocation for the ADR instruction.
  fixup_t2_adr_pcrel_12,
  // 24-bit PC relative relocation for conditional branch instructions.
  fixup_arm_condbranch,
  // 24-bit PC relative relocation for branch instructions. (unconditional)
  fixup_arm_uncondbranch,
  // 20-bit PC relative relocation for Thumb2 direct uconditional branch
  // instructions.
  fixup_t2_condbranch,
  // 20-bit PC relative relocation for Thumb2 direct branch unconditional branch
  // instructions.
  fixup_t2_uncondbranch,

  // 12-bit fixup for Thumb B instructions.
  fixup_arm_thumb_br,

  // The following fixups handle the ARM BL instructions. These can be
  // conditionalised; however, the ARM ELF ABI requires a different relocation
  // in that case: R_ARM_JUMP24 instead of R_ARM_CALL. The difference is that
  // R_ARM_CALL is allowed to change the instruction to a BLX inline, which has
  // no conditional version; R_ARM_JUMP24 would have to insert a veneer.
  //
  // MachO does not draw a distinction between the two cases, so it will treat
  // fixup_arm_uncondbl and fixup_arm_condbl as identical fixups.

  // Fixup for unconditional ARM BL instructions.
  fixup_arm_uncondbl,

  // Fixup for ARM BL instructions with nontrivial conditionalisation.
  fixup_arm_condbl,

  // Fixup for ARM BLX instructions.
  fixup_arm_blx,

  // Fixup for Thumb BL instructions.
  fixup_arm_thumb_bl,

  // Fixup for Thumb BLX instructions.
  fixup_arm_thumb_blx,

  // Fixup for Thumb branch instructions.
  fixup_arm_thumb_cb,

  // Fixup for Thumb load/store from constant pool instrs.
  fixup_arm_thumb_cp,

  // Fixup for Thumb conditional branching instructions.
  fixup_arm_thumb_bcc,

  // The next two are for the movt/movw pair
  // the 16bit imm field are split into imm{15-12} and imm{11-0}
  fixup_arm_movt_hi16, // :upper16:
  fixup_arm_movw_lo16, // :lower16:
  fixup_t2_movt_hi16,  // :upper16:
  fixup_t2_movw_lo16,  // :lower16:

  // Fixup for Thumb movs (enc T1) and adds (enc T2) 8-bit immediate field (7-0)
  fixup_arm_thumb_upper_8_15, // :upper8_15:
  fixup_arm_thumb_upper_0_7,  // :upper0_7:
  fixup_arm_thumb_lower_8_15, // :lower8_15:
  fixup_arm_thumb_lower_0_7,  // :lower0_7:

  // Fixup for mod_imm
  fixup_arm_mod_imm,

  // Fixup for Thumb2 8-bit rotated operand
  fixup_t2_so_imm,

  // Fixups for Branch Future.
  fixup_bf_branch,
  fixup_bf_target,
  fixup_bfl_target,
  fixup_bfc_target,
  fixup_bfcsel_else_target,
  fixup_wls,
  fixup_le,

  // Marker
  LastTargetFixupKind,
  NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind
};
}
} // namespace llvm

#endif