1 //===-- SparcFixupKinds.h - Sparc 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_SPARC_MCTARGETDESC_SPARCFIXUPKINDS_H 10 #define LLVM_LIB_TARGET_SPARC_MCTARGETDESC_SPARCFIXUPKINDS_H 11 12 #include "llvm/MC/MCFixup.h" 13 14 namespace llvm { 15 namespace Sparc { 16 enum Fixups { 17 // fixup_sparc_call30 - 30-bit PC relative relocation for call 18 fixup_sparc_call30 = FirstTargetFixupKind, 19 20 /// fixup_sparc_br22 - 22-bit PC relative relocation for 21 /// branches 22 fixup_sparc_br22, 23 24 /// fixup_sparc_br19 - 19-bit PC relative relocation for 25 /// branches on icc/xcc 26 fixup_sparc_br19, 27 28 /// fixup_sparc_bpr - 16-bit fixup for bpr 29 fixup_sparc_br16_2, 30 fixup_sparc_br16_14, 31 32 /// fixup_sparc_13 - 13-bit fixup 33 fixup_sparc_13, 34 35 /// fixup_sparc_hi22 - 22-bit fixup corresponding to %hi(foo) 36 /// for sethi 37 fixup_sparc_hi22, 38 39 /// fixup_sparc_lo10 - 10-bit fixup corresponding to %lo(foo) 40 fixup_sparc_lo10, 41 42 /// fixup_sparc_h44 - 22-bit fixup corresponding to %h44(foo) 43 fixup_sparc_h44, 44 45 /// fixup_sparc_m44 - 10-bit fixup corresponding to %m44(foo) 46 fixup_sparc_m44, 47 48 /// fixup_sparc_l44 - 12-bit fixup corresponding to %l44(foo) 49 fixup_sparc_l44, 50 51 /// fixup_sparc_hh - 22-bit fixup corresponding to %hh(foo) 52 fixup_sparc_hh, 53 54 /// fixup_sparc_hm - 10-bit fixup corresponding to %hm(foo) 55 fixup_sparc_hm, 56 57 /// fixup_sparc_lm - 22-bit fixup corresponding to %lm(foo) 58 fixup_sparc_lm, 59 60 /// fixup_sparc_pc22 - 22-bit fixup corresponding to %pc22(foo) 61 fixup_sparc_pc22, 62 63 /// fixup_sparc_pc10 - 10-bit fixup corresponding to %pc10(foo) 64 fixup_sparc_pc10, 65 66 /// fixup_sparc_got22 - 22-bit fixup corresponding to %got22(foo) 67 fixup_sparc_got22, 68 69 /// fixup_sparc_got10 - 10-bit fixup corresponding to %got10(foo) 70 fixup_sparc_got10, 71 72 /// fixup_sparc_got13 - 13-bit fixup corresponding to %got13(foo) 73 fixup_sparc_got13, 74 75 /// fixup_sparc_wplt30 76 fixup_sparc_wplt30, 77 78 /// fixups for Thread Local Storage 79 fixup_sparc_tls_gd_hi22, 80 fixup_sparc_tls_gd_lo10, 81 fixup_sparc_tls_gd_add, 82 fixup_sparc_tls_gd_call, 83 fixup_sparc_tls_ldm_hi22, 84 fixup_sparc_tls_ldm_lo10, 85 fixup_sparc_tls_ldm_add, 86 fixup_sparc_tls_ldm_call, 87 fixup_sparc_tls_ldo_hix22, 88 fixup_sparc_tls_ldo_lox10, 89 fixup_sparc_tls_ldo_add, 90 fixup_sparc_tls_ie_hi22, 91 fixup_sparc_tls_ie_lo10, 92 fixup_sparc_tls_ie_ld, 93 fixup_sparc_tls_ie_ldx, 94 fixup_sparc_tls_ie_add, 95 fixup_sparc_tls_le_hix22, 96 fixup_sparc_tls_le_lox10, 97 98 /// 22-bit fixup corresponding to %hix(foo) 99 fixup_sparc_hix22, 100 /// 13-bit fixup corresponding to %lox(foo) 101 fixup_sparc_lox10, 102 103 /// 22-bit fixup corresponding to %gdop_hix22(foo) 104 fixup_sparc_gotdata_hix22, 105 /// 13-bit fixup corresponding to %gdop_lox10(foo) 106 fixup_sparc_gotdata_lox10, 107 /// 32-bit fixup corresponding to %gdop(foo) 108 fixup_sparc_gotdata_op, 109 110 // Marker 111 LastTargetFixupKind, 112 NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind 113 }; 114 } 115 } 116 117 #endif 118