summaryrefslogtreecommitdiffstats
path: root/third_party/rust/goblin/src/elf/constants_relocation.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /third_party/rust/goblin/src/elf/constants_relocation.rs
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'third_party/rust/goblin/src/elf/constants_relocation.rs')
-rw-r--r--third_party/rust/goblin/src/elf/constants_relocation.rs1417
1 files changed, 1417 insertions, 0 deletions
diff --git a/third_party/rust/goblin/src/elf/constants_relocation.rs b/third_party/rust/goblin/src/elf/constants_relocation.rs
new file mode 100644
index 0000000000..6339de5434
--- /dev/null
+++ b/third_party/rust/goblin/src/elf/constants_relocation.rs
@@ -0,0 +1,1417 @@
+// x86_64 relocations
+/// No reloc.
+pub const R_X86_64_NONE: u32 = 0;
+/// Direct 64 bit.
+pub const R_X86_64_64: u32 = 1;
+/// PC relative 32 bit signed.
+pub const R_X86_64_PC32: u32 = 2;
+/// 32 bit GOT entry.
+pub const R_X86_64_GOT32: u32 = 3;
+/// 32 bit PLT address.
+pub const R_X86_64_PLT32: u32 = 4;
+/// Copy symbol at runtime.
+pub const R_X86_64_COPY: u32 = 5;
+/// Create GOT entry.
+pub const R_X86_64_GLOB_DAT: u32 = 6;
+/// Create PLT entry.
+pub const R_X86_64_JUMP_SLOT: u32 = 7;
+/// Adjust by program base.
+pub const R_X86_64_RELATIVE: u32 = 8;
+/// 32 bit signed PC relative offset to GOT.
+pub const R_X86_64_GOTPCREL: u32 = 9;
+/// Direct 32 bit zero extended.
+pub const R_X86_64_32: u32 = 10;
+/// Direct 32 bit sign extended.
+pub const R_X86_64_32S: u32 = 11;
+/// Direct 16 bit zero extended.
+pub const R_X86_64_16: u32 = 12;
+/// 16 bit sign extended pc relative.
+pub const R_X86_64_PC16: u32 = 13;
+/// Direct 8 bit sign extended.
+pub const R_X86_64_8: u32 = 14;
+/// 8 bit sign extended pc relative.
+pub const R_X86_64_PC8: u32 = 15;
+/// ID of module containing symbol.
+pub const R_X86_64_DTPMOD64: u32 = 16;
+/// Offset in module's TLS block.
+pub const R_X86_64_DTPOFF64: u32 = 17;
+/// Offset in initial TLS block.
+pub const R_X86_64_TPOFF64: u32 = 18;
+/// 32 bit signed PC relative offset to two GOT entries for GD symbol.
+pub const R_X86_64_TLSGD: u32 = 19;
+/// 32 bit signed PC relative offset to two GOT entries for LD symbol.
+pub const R_X86_64_TLSLD: u32 = 20;
+/// Offset in TLS block.
+pub const R_X86_64_DTPOFF32: u32 = 21;
+/// 32 bit signed PC relative offset to GOT entry for IE symbol.
+pub const R_X86_64_GOTTPOFF: u32 = 22;
+/// Offset in initial TLS block.
+pub const R_X86_64_TPOFF32: u32 = 23;
+/// PC relative 64 bit.
+pub const R_X86_64_PC64: u32 = 24;
+/// 64 bit offset to GOT.
+pub const R_X86_64_GOTOFF64: u32 = 25;
+/// 32 bit signed pc relative offset to GOT.
+pub const R_X86_64_GOTPC32: u32 = 26;
+/// 64-bit GOT entry offset.
+pub const R_X86_64_GOT64: u32 = 27;
+/// 64-bit PC relative offset to GOT entry.
+pub const R_X86_64_GOTPCREL64: u32 = 28;
+/// 64-bit PC relative offset to GOT.
+pub const R_X86_64_GOTPC64: u32 = 29;
+/// like GOT64, says PLT entry needed.
+pub const R_X86_64_GOTPLT64: u32 = 30;
+/// 64-bit GOT relative offset to PLT entry.
+pub const R_X86_64_PLTOFF64: u32 = 31;
+/// Size of symbol plus 32-bit addend.
+pub const R_X86_64_SIZE32: u32 = 32;
+/// Size of symbol plus 64-bit addend.
+pub const R_X86_64_SIZE64: u32 = 33;
+/// GOT offset for TLS descriptor..
+pub const R_X86_64_GOTPC32_TLSDESC: u32 = 34;
+/// Marker for call through TLS descriptor..
+pub const R_X86_64_TLSDESC_CALL: u32 = 35;
+/// TLS descriptor..
+pub const R_X86_64_TLSDESC: u32 = 36;
+/// Adjust indirectly by program base.
+pub const R_X86_64_IRELATIVE: u32 = 37;
+/// 64-bit adjust by program base.
+pub const R_X86_64_RELATIVE64: u32 = 38;
+///Load from 32 bit signed pc relative offset to GOT entry without REX prefix, relaxable.
+pub const R_X86_64_GOTPCRELX: u32 = 41;
+/// Load from 32 bit signed pc relative offset to GOT entry with REX prefix, relaxable.
+pub const R_X86_64_REX_GOTPCRELX: u32 = 42;
+pub const R_X86_64_NUM: u32 = 43;
+
+// Intel 80386 specific definitions
+
+// i386 relocs
+/// No reloc
+pub const R_386_NONE: u32 = 0;
+/// Direct 32 bit
+pub const R_386_32: u32 = 1;
+/// PC relative 32 bit
+pub const R_386_PC32: u32 = 2;
+/// 32 bit GOT entry
+pub const R_386_GOT32: u32 = 3;
+/// 32 bit PLT address
+pub const R_386_PLT32: u32 = 4;
+/// Copy symbol at runtime
+pub const R_386_COPY: u32 = 5;
+/// Create GOT entry
+pub const R_386_GLOB_DAT: u32 = 6;
+/// Create PLT entry
+pub const R_386_JMP_SLOT: u32 = 7;
+/// Adjust by program base
+pub const R_386_RELATIVE: u32 = 8;
+/// 32 bit offset to GOT
+pub const R_386_GOTOFF: u32 = 9;
+/// 32 bit PC relative offset to GOT
+pub const R_386_GOTPC: u32 = 10;
+pub const R_386_32PLT: u32 = 11;
+/// Offset in static TLS block
+pub const R_386_TLS_TPOFF: u32 = 14;
+/// Address of GOT entry for static TLS block offset
+pub const R_386_TLS_IE: u32 = 15;
+/// GOT entry for static TLS block offset
+pub const R_386_TLS_GOTIE: u32 = 16;
+/// Offset relative to static TLS block
+pub const R_386_TLS_LE: u32 = 17;
+/// Direct 32 bit for GNU version of general dynamic thread local data
+pub const R_386_TLS_GD: u32 = 18;
+/// Direct 32 bit for GNU version of local dynamic thread local data in LE code
+pub const R_386_TLS_LDM: u32 = 19;
+pub const R_386_16: u32 = 20;
+pub const R_386_PC16: u32 = 21;
+pub const R_386_8: u32 = 22;
+pub const R_386_PC8: u32 = 23;
+/// Direct 32 bit for general dynamic thread local data
+pub const R_386_TLS_GD_32: u32 = 24;
+/// Tag for pushl in GD TLS code
+pub const R_386_TLS_GD_PUSH: u32 = 25;
+/// Relocation for call to __tls_get_addr()
+pub const R_386_TLS_GD_CALL: u32 = 26;
+/// Tag for popl in GD TLS code
+pub const R_386_TLS_GD_POP: u32 = 27;
+/// Direct 32 bit for local dynamic thread local data in LE code
+pub const R_386_TLS_LDM_32: u32 = 28;
+/// Tag for pushl in LDM TLS code
+pub const R_386_TLS_LDM_PUSH: u32 = 29;
+/// Relocation for call to __tls_get_addr() in LDM code
+pub const R_386_TLS_LDM_CALL: u32 = 30;
+/// Tag for popl in LDM TLS code
+pub const R_386_TLS_LDM_POP: u32 = 31;
+/// Offset relative to TLS block
+pub const R_386_TLS_LDO_32: u32 = 32;
+/// GOT entry for negated static TLS block offset
+pub const R_386_TLS_IE_32: u32 = 33;
+/// Negated offset relative to static TLS block
+pub const R_386_TLS_LE_32: u32 = 34;
+/// ID of module containing symbol
+pub const R_386_TLS_DTPMOD32: u32 = 35;
+/// Offset in TLS block
+pub const R_386_TLS_DTPOFF32: u32 = 36;
+/// Negated offset in static TLS block
+pub const R_386_TLS_TPOFF32: u32 = 37;
+/// 32-bit symbol size
+pub const R_386_SIZE32: u32 = 38;
+/// GOT offset for TLS descriptor.
+pub const R_386_TLS_GOTDESC: u32 = 39;
+/// Marker of call through TLS descriptor for relaxation
+pub const R_386_TLS_DESC_CALL: u32 = 40;
+/// TLS descriptor containing pointer to code and to argument, returning the TLS offset for the symbol
+pub const R_386_TLS_DESC: u32 = 41;
+/// Adjust indirectly by program base
+pub const R_386_IRELATIVE: u32 = 42;
+/// Load from 32 bit GOT entry, relaxable
+pub const R_386_GOT32X: u32 = 43;
+/// Keep this the last entry
+pub const R_386_NUM: u32 = 44;
+
+// AArch64 relocs
+/// No relocation
+pub const R_AARCH64_NONE: u32 = 0;
+
+// ILP32 AArch64 relocs
+/// Direct 32 bit
+pub const R_AARCH64_P32_ABS32: u32 = 1;
+/// Copy symbol at runtime
+pub const R_AARCH64_P32_COPY: u32 = 180;
+/// Create GOT entry
+pub const R_AARCH64_P32_GLOB_DAT: u32 = 181;
+/// Create PLT entry
+pub const R_AARCH64_P32_JUMP_SLOT: u32 = 182;
+/// Adjust by program base
+pub const R_AARCH64_P32_RELATIVE: u32 = 183;
+/// Module number, 32 bit
+pub const R_AARCH64_P32_TLS_DTPMOD: u32 = 184;
+/// Module-relative offset, 32 bit
+pub const R_AARCH64_P32_TLS_DTPREL: u32 = 185;
+/// TP-relative offset, 32 bit
+pub const R_AARCH64_P32_TLS_TPREL: u32 = 186;
+/// TLS Descriptor
+pub const R_AARCH64_P32_TLSDESC: u32 = 187;
+/// STT_GNU_IFUNC relocation
+pub const R_AARCH64_P32_IRELATIVE: u32 = 188;
+
+// LP64 AArch64 relocs
+/// Direct 64 bit
+pub const R_AARCH64_ABS64: u32 = 257;
+/// Direct 32 bit
+pub const R_AARCH64_ABS32: u32 = 258;
+/// Direct 16-bit
+pub const R_AARCH64_ABS16: u32 = 259;
+/// PC-relative 64-bit
+pub const R_AARCH64_PREL64: u32 = 260;
+/// PC-relative 32-bit
+pub const R_AARCH64_PREL32: u32 = 261;
+/// PC-relative 16-bit
+pub const R_AARCH64_PREL16: u32 = 262;
+/// Dir. MOVZ imm. from bits 15:0
+pub const R_AARCH64_MOVW_UABS_G0: u32 = 263;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_UABS_G0_NC: u32 = 264;
+/// Dir. MOVZ imm. from bits 31:16
+pub const R_AARCH64_MOVW_UABS_G1: u32 = 265;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_UABS_G1_NC: u32 = 266;
+/// Dir. MOVZ imm. from bits 47:32
+pub const R_AARCH64_MOVW_UABS_G2: u32 = 267;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_UABS_G2_NC: u32 = 268;
+/// Dir. MOV{K,Z} imm. from 63:48
+pub const R_AARCH64_MOVW_UABS_G3: u32 = 269;
+/// Dir. MOV{N,Z} imm. from 15:0
+pub const R_AARCH64_MOVW_SABS_G0: u32 = 270;
+/// Dir. MOV{N,Z} imm. from 31:16
+pub const R_AARCH64_MOVW_SABS_G1: u32 = 271;
+/// Dir. MOV{N,Z} imm. from 47:32
+pub const R_AARCH64_MOVW_SABS_G2: u32 = 272;
+/// PC-rel. LD imm. from bits 20:2
+pub const R_AARCH64_LD_PREL_LO19: u32 = 273;
+/// PC-rel. ADR imm. from bits 20:0
+pub const R_AARCH64_ADR_PREL_LO21: u32 = 274;
+/// Page-rel. ADRP imm. from 32:12
+pub const R_AARCH64_ADR_PREL_PG_HI21: u32 = 275;
+/// Likewise; no overflow check
+pub const R_AARCH64_ADR_PREL_PG_HI21_NC: u32 = 276;
+/// Dir. ADD imm. from bits 11:0
+pub const R_AARCH64_ADD_ABS_LO12_NC: u32 = 277;
+/// Likewise for LD/ST; no check.
+pub const R_AARCH64_LDST8_ABS_LO12_NC: u32 = 278;
+/// PC-rel. TBZ/TBNZ imm. from 15:2
+pub const R_AARCH64_TSTBR14: u32 = 279;
+/// PC-rel. cond. br. imm. from 20:2.
+pub const R_AARCH64_CONDBR19: u32 = 280;
+/// PC-rel. B imm. from bits 27:2
+pub const R_AARCH64_JUMP26: u32 = 282;
+/// Likewise for CALL
+pub const R_AARCH64_CALL26: u32 = 283;
+/// Dir. ADD imm. from bits 11:1
+pub const R_AARCH64_LDST16_ABS_LO12_NC: u32 = 284;
+/// Likewise for bits 11:2
+pub const R_AARCH64_LDST32_ABS_LO12_NC: u32 = 285;
+/// Likewise for bits 11:3
+pub const R_AARCH64_LDST64_ABS_LO12_NC: u32 = 286;
+/// PC-rel. MOV{N,Z} imm. from 15:0
+pub const R_AARCH64_MOVW_PREL_G0: u32 = 287;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_PREL_G0_NC: u32 = 288;
+/// PC-rel. MOV{N,Z} imm. from 31:16.
+pub const R_AARCH64_MOVW_PREL_G1: u32 = 289;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_PREL_G1_NC: u32 = 290;
+/// PC-rel. MOV{N,Z} imm. from 47:32.
+pub const R_AARCH64_MOVW_PREL_G2: u32 = 291;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_PREL_G2_NC: u32 = 292;
+/// PC-rel. MOV{N,Z} imm. from 63:48.
+pub const R_AARCH64_MOVW_PREL_G3: u32 = 293;
+/// Dir. ADD imm. from bits 11:4
+pub const R_AARCH64_LDST128_ABS_LO12_NC: u32 = 299;
+/// GOT-rel. off. MOV{N,Z} imm. 15:0.
+pub const R_AARCH64_MOVW_GOTOFF_G0: u32 = 300;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_GOTOFF_G0_NC: u32 = 301;
+/// GOT-rel. o. MOV{N,Z} imm. 31:16
+pub const R_AARCH64_MOVW_GOTOFF_G1: u32 = 302;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_GOTOFF_G1_NC: u32 = 303;
+/// GOT-rel. o. MOV{N,Z} imm. 47:32
+pub const R_AARCH64_MOVW_GOTOFF_G2: u32 = 304;
+/// Likewise for MOVK; no check
+pub const R_AARCH64_MOVW_GOTOFF_G2_NC: u32 = 305;
+/// GOT-rel. o. MOV{N,Z} imm. 63:48
+pub const R_AARCH64_MOVW_GOTOFF_G3: u32 = 306;
+/// GOT-relative 64-bit
+pub const R_AARCH64_GOTREL64: u32 = 307;
+/// GOT-relative 32-bit
+pub const R_AARCH64_GOTREL32: u32 = 308;
+/// PC-rel. GOT off. load imm. 20:2
+pub const R_AARCH64_GOT_LD_PREL19: u32 = 309;
+/// GOT-rel. off. LD/ST imm. 14:3
+pub const R_AARCH64_LD64_GOTOFF_LO15: u32 = 310;
+/// P-page-rel. GOT off. ADRP 32:12
+pub const R_AARCH64_ADR_GOT_PAGE: u32 = 311;
+/// Dir. GOT off. LD/ST imm. 11:3
+pub const R_AARCH64_LD64_GOT_LO12_NC: u32 = 312;
+/// GOT-page-rel. GOT off. LD/ST 14:3
+pub const R_AARCH64_LD64_GOTPAGE_LO15: u32 = 313;
+/// PC-relative ADR imm. 20:0
+pub const R_AARCH64_TLSGD_ADR_PREL21: u32 = 512;
+/// page-rel. ADRP imm. 32:12
+pub const R_AARCH64_TLSGD_ADR_PAGE21: u32 = 513;
+/// direct ADD imm. from 11:0
+pub const R_AARCH64_TLSGD_ADD_LO12_NC: u32 = 514;
+/// GOT-rel. MOV{N,Z} 31:16
+pub const R_AARCH64_TLSGD_MOVW_G1: u32 = 515;
+/// GOT-rel. MOVK imm. 15:0
+pub const R_AARCH64_TLSGD_MOVW_G0_NC: u32 = 516;
+/// Like 512; local dynamic model
+pub const R_AARCH64_TLSLD_ADR_PREL21: u32 = 517;
+/// Like 513; local dynamic model
+pub const R_AARCH64_TLSLD_ADR_PAGE21: u32 = 518;
+/// Like 514; local dynamic model
+pub const R_AARCH64_TLSLD_ADD_LO12_NC: u32 = 519;
+/// Like 515; local dynamic model
+pub const R_AARCH64_TLSLD_MOVW_G1: u32 = 520;
+/// Like 516; local dynamic model
+pub const R_AARCH64_TLSLD_MOVW_G0_NC: u32 = 521;
+/// TLS PC-rel. load imm. 20:2
+pub const R_AARCH64_TLSLD_LD_PREL19: u32 = 522;
+/// TLS DTP-rel. MOV{N,Z} 47:32
+pub const R_AARCH64_TLSLD_MOVW_DTPREL_G2: u32 = 523;
+/// TLS DTP-rel. MOV{N,Z} 31:16
+pub const R_AARCH64_TLSLD_MOVW_DTPREL_G1: u32 = 524;
+/// Likewise; MOVK; no check
+pub const R_AARCH64_TLSLD_MOVW_DTPREL_G1_NC: u32 = 525;
+/// TLS DTP-rel. MOV{N,Z} 15:0
+pub const R_AARCH64_TLSLD_MOVW_DTPREL_G0: u32 = 526;
+/// Likewise; MOVK; no check
+pub const R_AARCH64_TLSLD_MOVW_DTPREL_G0_NC: u32 = 527;
+/// DTP-rel. ADD imm. from 23:12.
+pub const R_AARCH64_TLSLD_ADD_DTPREL_HI12: u32 = 528;
+/// DTP-rel. ADD imm. from 11:0
+pub const R_AARCH64_TLSLD_ADD_DTPREL_LO12: u32 = 529;
+/// Likewise; no ovfl. check
+pub const R_AARCH64_TLSLD_ADD_DTPREL_LO12_NC: u32 = 530;
+/// DTP-rel. LD/ST imm. 11:0
+pub const R_AARCH64_TLSLD_LDST8_DTPREL_LO12: u32 = 531;
+/// Likewise; no check
+pub const R_AARCH64_TLSLD_LDST8_DTPREL_LO12_NC: u32 = 532;
+/// DTP-rel. LD/ST imm. 11:1
+pub const R_AARCH64_TLSLD_LDST16_DTPREL_LO12: u32 = 533;
+/// Likewise; no check
+pub const R_AARCH64_TLSLD_LDST16_DTPREL_LO12_NC: u32 = 534;
+/// DTP-rel. LD/ST imm. 11:2
+pub const R_AARCH64_TLSLD_LDST32_DTPREL_LO12: u32 = 535;
+/// Likewise; no check
+pub const R_AARCH64_TLSLD_LDST32_DTPREL_LO12_NC: u32 = 536;
+/// DTP-rel. LD/ST imm. 11:3
+pub const R_AARCH64_TLSLD_LDST64_DTPREL_LO12: u32 = 537;
+/// Likewise; no check
+pub const R_AARCH64_TLSLD_LDST64_DTPREL_LO12_NC: u32 = 538;
+/// GOT-rel. MOV{N,Z} 31:16
+pub const R_AARCH64_TLSIE_MOVW_GOTTPREL_G1: u32 = 539;
+/// GOT-rel. MOVK 15:0
+pub const R_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC: u32 = 540;
+/// Page-rel. ADRP 32:12
+pub const R_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21: u32 = 541;
+/// Direct LD off. 11:3
+pub const R_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC: u32 = 542;
+/// PC-rel. load imm. 20:2
+pub const R_AARCH64_TLSIE_LD_GOTTPREL_PREL19: u32 = 543;
+/// TLS TP-rel. MOV{N,Z} 47:32
+pub const R_AARCH64_TLSLE_MOVW_TPREL_G2: u32 = 544;
+/// TLS TP-rel. MOV{N,Z} 31:16
+pub const R_AARCH64_TLSLE_MOVW_TPREL_G1: u32 = 545;
+/// Likewise; MOVK; no check
+pub const R_AARCH64_TLSLE_MOVW_TPREL_G1_NC: u32 = 546;
+/// TLS TP-rel. MOV{N,Z} 15:0
+pub const R_AARCH64_TLSLE_MOVW_TPREL_G0: u32 = 547;
+/// Likewise; MOVK; no check
+pub const R_AARCH64_TLSLE_MOVW_TPREL_G0_NC: u32 = 548;
+/// TP-rel. ADD imm. 23:12
+pub const R_AARCH64_TLSLE_ADD_TPREL_HI12: u32 = 549;
+/// TP-rel. ADD imm. 11:0
+pub const R_AARCH64_TLSLE_ADD_TPREL_LO12: u32 = 550;
+/// Likewise; no ovfl. check
+pub const R_AARCH64_TLSLE_ADD_TPREL_LO12_NC: u32 = 551;
+/// TP-rel. LD/ST off. 11:0
+pub const R_AARCH64_TLSLE_LDST8_TPREL_LO12: u32 = 552;
+/// Likewise; no ovfl. check.
+pub const R_AARCH64_TLSLE_LDST8_TPREL_LO12_NC: u32 = 553;
+/// TP-rel. LD/ST off. 11:1
+pub const R_AARCH64_TLSLE_LDST16_TPREL_LO12: u32 = 554;
+/// Likewise; no check
+pub const R_AARCH64_TLSLE_LDST16_TPREL_LO12_NC: u32 = 555;
+/// TP-rel. LD/ST off. 11:2
+pub const R_AARCH64_TLSLE_LDST32_TPREL_LO12: u32 = 556;
+/// Likewise; no check
+pub const R_AARCH64_TLSLE_LDST32_TPREL_LO12_NC: u32 = 557;
+/// TP-rel. LD/ST off. 11:3
+pub const R_AARCH64_TLSLE_LDST64_TPREL_LO12: u32 = 558;
+/// Likewise; no check
+pub const R_AARCH64_TLSLE_LDST64_TPREL_LO12_NC: u32 = 559;
+/// PC-rel. load immediate 20:2
+pub const R_AARCH64_TLSDESC_LD_PREL19: u32 = 560;
+/// PC-rel. ADR immediate 20:0
+pub const R_AARCH64_TLSDESC_ADR_PREL21: u32 = 561;
+/// Page-rel. ADRP imm. 32:12
+pub const R_AARCH64_TLSDESC_ADR_PAGE21: u32 = 562;
+/// Direct LD off. from 11:3
+pub const R_AARCH64_TLSDESC_LD64_LO12: u32 = 563;
+/// Direct ADD imm. from 11:0
+pub const R_AARCH64_TLSDESC_ADD_LO12: u32 = 564;
+/// GOT-rel. MOV{N,Z} imm. 31:16
+pub const R_AARCH64_TLSDESC_OFF_G1: u32 = 565;
+/// GOT-rel. MOVK imm. 15:0; no ck
+pub const R_AARCH64_TLSDESC_OFF_G0_NC: u32 = 566;
+/// Relax LDR
+pub const R_AARCH64_TLSDESC_LDR: u32 = 567;
+/// Relax ADD
+pub const R_AARCH64_TLSDESC_ADD: u32 = 568;
+/// Relax BLR
+pub const R_AARCH64_TLSDESC_CALL: u32 = 569;
+/// TP-rel. LD/ST off. 11:4
+pub const R_AARCH64_TLSLE_LDST128_TPREL_LO12: u32 = 570;
+/// Likewise; no check
+pub const R_AARCH64_TLSLE_LDST128_TPREL_LO12_NC: u32 = 571;
+/// DTP-rel. LD/ST imm. 11:4.
+pub const R_AARCH64_TLSLD_LDST128_DTPREL_LO12: u32 = 572;
+/// Likewise; no check
+pub const R_AARCH64_TLSLD_LDST128_DTPREL_LO12_NC: u32 = 573;
+/// Copy symbol at runtime
+pub const R_AARCH64_COPY: u32 = 1024;
+/// Create GOT entry
+pub const R_AARCH64_GLOB_DAT: u32 = 1025;
+/// Create PLT entry
+pub const R_AARCH64_JUMP_SLOT: u32 = 1026;
+/// Adjust by program base
+pub const R_AARCH64_RELATIVE: u32 = 1027;
+/// Module number, 64 bit
+pub const R_AARCH64_TLS_DTPMOD: u32 = 1028;
+/// Module-relative offset, 64 bit
+pub const R_AARCH64_TLS_DTPREL: u32 = 1029;
+/// TP-relative offset, 64 bit
+pub const R_AARCH64_TLS_TPREL: u32 = 1030;
+/// TLS Descriptor
+pub const R_AARCH64_TLSDESC: u32 = 1031;
+/// STT_GNU_IFUNC relocation
+pub const R_AARCH64_IRELATIVE: u32 = 1032;
+
+// ARM relocs
+/// No reloc
+pub const R_ARM_NONE: u32 = 0;
+/// Deprecated PC relative 26 bit branch
+pub const R_ARM_PC24: u32 = 1;
+/// Direct 32 bit
+pub const R_ARM_ABS32: u32 = 2;
+/// PC relative 32 bit
+pub const R_ARM_REL32: u32 = 3;
+pub const R_ARM_PC13: u32 = 4;
+/// Direct 16 bit
+pub const R_ARM_ABS16: u32 = 5;
+/// Direct 12 bit
+pub const R_ARM_ABS12: u32 = 6;
+/// Direct & 0x7C (LDR, STR)
+pub const R_ARM_THM_ABS5: u32 = 7;
+/// Direct 8 bit
+pub const R_ARM_ABS8: u32 = 8;
+pub const R_ARM_SBREL32: u32 = 9;
+/// PC relative 24 bit (Thumb32 BL)
+pub const R_ARM_THM_PC22: u32 = 10;
+/// PC relative & 0x3FC(Thumb16 LDR, ADD, ADR).
+pub const R_ARM_THM_PC8: u32 = 11;
+pub const R_ARM_AMP_VCALL9: u32 = 12;
+/// Obsolete static relocation
+pub const R_ARM_SWI24: u32 = 13;
+/// Dynamic relocation
+pub const R_ARM_TLS_DESC: u32 = 13;
+/// Reserved
+pub const R_ARM_THM_SWI8: u32 = 14;
+/// Reserved
+pub const R_ARM_XPC25: u32 = 15;
+/// Reserved
+pub const R_ARM_THM_XPC22: u32 = 16;
+/// ID of module containing symbol
+pub const R_ARM_TLS_DTPMOD32: u32 = 17;
+/// Offset in TLS block
+pub const R_ARM_TLS_DTPOFF32: u32 = 18;
+/// Offset in static TLS block
+pub const R_ARM_TLS_TPOFF32: u32 = 19;
+/// Copy symbol at runtime
+pub const R_ARM_COPY: u32 = 20;
+/// Create GOT entry
+pub const R_ARM_GLOB_DAT: u32 = 21;
+/// Create PLT entry
+pub const R_ARM_JUMP_SLOT: u32 = 22;
+/// Adjust by program base
+pub const R_ARM_RELATIVE: u32 = 23;
+/// 32 bit offset to GOT
+pub const R_ARM_GOTOFF: u32 = 24;
+/// 32 bit PC relative offset to GOT
+pub const R_ARM_GOTPC: u32 = 25;
+/// 32 bit GOT entry
+pub const R_ARM_GOT32: u32 = 26;
+/// Deprecated, 32 bit PLT address
+pub const R_ARM_PLT32: u32 = 27;
+/// PC relative 24 bit (BL, BLX)
+pub const R_ARM_CALL: u32 = 28;
+/// PC relative 24 bit (B, BL<cond>)
+pub const R_ARM_JUMP24: u32 = 29;
+/// PC relative 24 bit (Thumb32 B.W)
+pub const R_ARM_THM_JUMP24: u32 = 30;
+/// Adjust by program base
+pub const R_ARM_BASE_ABS: u32 = 31;
+/// Obsolete
+pub const R_ARM_ALU_PCREL_7_0: u32 = 32;
+/// Obsolete
+pub const R_ARM_ALU_PCREL_15_8: u32 = 33;
+/// Obsolete
+pub const R_ARM_ALU_PCREL_23_15: u32 = 34;
+/// Deprecated, prog. base relative
+pub const R_ARM_LDR_SBREL_11_0: u32 = 35;
+/// Deprecated, prog. base relative
+pub const R_ARM_ALU_SBREL_19_12: u32 = 36;
+/// Deprecated, prog. base relative
+pub const R_ARM_ALU_SBREL_27_20: u32 = 37;
+pub const R_ARM_TARGET1: u32 = 38;
+/// Program base relative
+pub const R_ARM_SBREL31: u32 = 39;
+pub const R_ARM_V4BX: u32 = 40;
+pub const R_ARM_TARGET2: u32 = 41;
+/// 32 bit PC relative
+pub const R_ARM_PREL31: u32 = 42;
+/// Direct 16-bit (MOVW)
+pub const R_ARM_MOVW_ABS_NC: u32 = 43;
+/// Direct high 16-bit (MOVT)
+pub const R_ARM_MOVT_ABS: u32 = 44;
+/// PC relative 16-bit (MOVW)
+pub const R_ARM_MOVW_PREL_NC: u32 = 45;
+/// PC relative (MOVT)
+pub const R_ARM_MOVT_PREL: u32 = 46;
+/// Direct 16 bit (Thumb32 MOVW)
+pub const R_ARM_THM_MOVW_ABS_NC: u32 = 47;
+/// Direct high 16 bit (Thumb32 MOVT)
+pub const R_ARM_THM_MOVT_ABS: u32 = 48;
+/// PC relative 16 bit (Thumb32 MOVW)
+pub const R_ARM_THM_MOVW_PREL_NC: u32 = 49;
+/// PC relative high 16 bit (Thumb32 MOVT)
+pub const R_ARM_THM_MOVT_PREL: u32 = 50;
+/// PC relative 20 bit (Thumb32 B<cond>.W)
+pub const R_ARM_THM_JUMP19: u32 = 51;
+/// PC relative X & 0x7E (Thumb16 CBZ, CBNZ)
+pub const R_ARM_THM_JUMP6: u32 = 52;
+/// PC relative 12 bit (Thumb32 ADR.W)
+pub const R_ARM_THM_ALU_PREL_11_0: u32 = 53;
+/// PC relative 12 bit (Thumb32 LDR{D,SB,H,SH})
+pub const R_ARM_THM_PC12: u32 = 54;
+/// Direct 32-bit
+pub const R_ARM_ABS32_NOI: u32 = 55;
+/// PC relative 32-bit
+pub const R_ARM_REL32_NOI: u32 = 56;
+/// PC relative (ADD, SUB)
+pub const R_ARM_ALU_PC_G0_NC: u32 = 57;
+/// PC relative (ADD, SUB)
+pub const R_ARM_ALU_PC_G0: u32 = 58;
+/// PC relative (ADD, SUB)
+pub const R_ARM_ALU_PC_G1_NC: u32 = 59;
+/// PC relative (ADD, SUB)
+pub const R_ARM_ALU_PC_G1: u32 = 60;
+/// PC relative (ADD, SUB)
+pub const R_ARM_ALU_PC_G2: u32 = 61;
+/// PC relative (LDR,STR,LDRB,STRB)
+pub const R_ARM_LDR_PC_G1: u32 = 62;
+/// PC relative (LDR,STR,LDRB,STRB)
+pub const R_ARM_LDR_PC_G2: u32 = 63;
+/// PC relative (STR{D,H},LDR{D,SB,H,SH})
+pub const R_ARM_LDRS_PC_G0: u32 = 64;
+/// PC relative (STR{D,H},LDR{D,SB,H,SH})
+pub const R_ARM_LDRS_PC_G1: u32 = 65;
+/// PC relative (STR{D,H},LDR{D,SB,H,SH})
+pub const R_ARM_LDRS_PC_G2: u32 = 66;
+/// PC relative (LDC, STC)
+pub const R_ARM_LDC_PC_G0: u32 = 67;
+/// PC relative (LDC, STC)
+pub const R_ARM_LDC_PC_G1: u32 = 68;
+/// PC relative (LDC, STC)
+pub const R_ARM_LDC_PC_G2: u32 = 69;
+/// Program base relative (ADD,SUB)
+pub const R_ARM_ALU_SB_G0_NC: u32 = 70;
+/// Program base relative (ADD,SUB)
+pub const R_ARM_ALU_SB_G0: u32 = 71;
+/// Program base relative (ADD,SUB)
+pub const R_ARM_ALU_SB_G1_NC: u32 = 72;
+/// Program base relative (ADD,SUB)
+pub const R_ARM_ALU_SB_G1: u32 = 73;
+/// Program base relative (ADD,SUB)
+pub const R_ARM_ALU_SB_G2: u32 = 74;
+/// Program base relative (LDR,STR, LDRB, STRB)
+pub const R_ARM_LDR_SB_G0: u32 = 75;
+/// Program base relative (LDR, STR, LDRB, STRB)
+pub const R_ARM_LDR_SB_G1: u32 = 76;
+/// Program base relative (LDR, STR, LDRB, STRB)
+pub const R_ARM_LDR_SB_G2: u32 = 77;
+/// Program base relative (LDR, STR, LDRB, STRB)
+pub const R_ARM_LDRS_SB_G0: u32 = 78;
+/// Program base relative (LDR, STR, LDRB, STRB)
+pub const R_ARM_LDRS_SB_G1: u32 = 79;
+/// Program base relative (LDR, STR, LDRB, STRB)
+pub const R_ARM_LDRS_SB_G2: u32 = 80;
+/// Program base relative (LDC,STC)
+pub const R_ARM_LDC_SB_G0: u32 = 81;
+/// Program base relative (LDC,STC)
+pub const R_ARM_LDC_SB_G1: u32 = 82;
+/// Program base relative (LDC,STC)
+pub const R_ARM_LDC_SB_G2: u32 = 83;
+/// Program base relative 16 bit (MOVW)
+pub const R_ARM_MOVW_BREL_NC: u32 = 84;
+/// Program base relative high 16 bit (MOVT)
+pub const R_ARM_MOVT_BREL: u32 = 85;
+/// Program base relative 16 bit (MOVW)
+pub const R_ARM_MOVW_BREL: u32 = 86;
+/// Program base relative 16 bit (Thumb32 MOVW)
+pub const R_ARM_THM_MOVW_BREL_NC: u32 = 87;
+/// Program base relative high 16 bit (Thumb32 MOVT)
+pub const R_ARM_THM_MOVT_BREL: u32 = 88;
+/// Program base relative 16 bit (Thumb32 MOVW)
+pub const R_ARM_THM_MOVW_BREL: u32 = 89;
+pub const R_ARM_TLS_GOTDESC: u32 = 90;
+pub const R_ARM_TLS_CALL: u32 = 91;
+/// TLS relaxation
+pub const R_ARM_TLS_DESCSEQ: u32 = 92;
+pub const R_ARM_THM_TLS_CALL: u32 = 93;
+pub const R_ARM_PLT32_ABS: u32 = 94;
+/// GOT entry
+pub const R_ARM_GOT_ABS: u32 = 95;
+/// PC relative GOT entry
+pub const R_ARM_GOT_PREL: u32 = 96;
+/// GOT entry relative to GOT origin (LDR)
+pub const R_ARM_GOT_BREL12: u32 = 97;
+/// 12 bit, GOT entry relative to GOT origin (LDR, STR)
+pub const R_ARM_GOTOFF12: u32 = 98;
+pub const R_ARM_GOTRELAX: u32 = 99;
+pub const R_ARM_GNU_VTENTRY: u32 = 100;
+pub const R_ARM_GNU_VTINHERIT: u32 = 101;
+/// PC relative & 0xFFE (Thumb16 B)
+pub const R_ARM_THM_PC11: u32 = 102;
+/// PC relative & 0x1FE (Thumb16 B/B<cond>)
+pub const R_ARM_THM_PC9: u32 = 103;
+/// PC-rel 32 bit for global dynamic thread local data
+pub const R_ARM_TLS_GD32: u32 = 104;
+/// PC-rel 32 bit for local dynamic thread local data
+pub const R_ARM_TLS_LDM32: u32 = 105;
+/// 32 bit offset relative to TLS block
+pub const R_ARM_TLS_LDO32: u32 = 106;
+/// PC-rel 32 bit for GOT entry of static TLS block offset
+pub const R_ARM_TLS_IE32: u32 = 107;
+/// 32 bit offset relative to static TLS block
+pub const R_ARM_TLS_LE32: u32 = 108;
+/// 12 bit relative to TLS block (LDR, STR)
+pub const R_ARM_TLS_LDO12: u32 = 109;
+/// 12 bit relative to static TLS block (LDR, STR)
+pub const R_ARM_TLS_LE12: u32 = 110;
+/// 12 bit GOT entry relative to GOT origin (LDR)
+pub const R_ARM_TLS_IE12GP: u32 = 111;
+/// Obsolete
+pub const R_ARM_ME_TOO: u32 = 128;
+pub const R_ARM_THM_TLS_DESCSEQ: u32 = 129;
+pub const R_ARM_THM_TLS_DESCSEQ16: u32 = 129;
+pub const R_ARM_THM_TLS_DESCSEQ32: u32 = 130;
+/// GOT entry relative to GOT origin, 12 bit (Thumb32 LDR)
+pub const R_ARM_THM_GOT_BREL12: u32 = 131;
+pub const R_ARM_IRELATIVE: u32 = 160;
+pub const R_ARM_RXPC25: u32 = 249;
+pub const R_ARM_RSBREL32: u32 = 250;
+pub const R_ARM_THM_RPC22: u32 = 251;
+pub const R_ARM_RREL32: u32 = 252;
+pub const R_ARM_RABS22: u32 = 253;
+pub const R_ARM_RPC24: u32 = 254;
+pub const R_ARM_RBASE: u32 = 255;
+/// Keep this the last entry
+pub const R_ARM_NUM: u32 = 256;
+
+///////////////////
+// OpenRisc
+///////////////////
+pub const R_OR1K_NONE: u32 = 0;
+pub const R_OR1K_32: u32 = 1;
+pub const R_OR1K_16: u32 = 2;
+pub const R_OR1K_8: u32 = 3;
+pub const R_OR1K_LO_16_IN_INSN: u32 = 4;
+pub const R_OR1K_HI_16_IN_INSN: u32 = 5;
+pub const R_OR1K_INSN_REL_26: u32 = 6;
+pub const R_OR1K_GNU_VTENTRY: u32 = 7;
+pub const R_OR1K_GNU_VTINHERIT: u32 = 8;
+pub const R_OR1K_32_PCREL: u32 = 9;
+pub const R_OR1K_16_PCREL: u32 = 10;
+pub const R_OR1K_8_PCREL: u32 = 11;
+pub const R_OR1K_GOTPC_HI16: u32 = 12;
+pub const R_OR1K_GOTPC_LO16: u32 = 13;
+pub const R_OR1K_GOT16: u32 = 14;
+pub const R_OR1K_PLT26: u32 = 15;
+pub const R_OR1K_GOTOFF_HI16: u32 = 16;
+pub const R_OR1K_GOTOFF_LO16: u32 = 17;
+pub const R_OR1K_COPY: u32 = 18;
+pub const R_OR1K_GLOB_DAT: u32 = 19;
+pub const R_OR1K_JMP_SLOT: u32 = 20;
+pub const R_OR1K_RELATIVE: u32 = 21;
+pub const R_OR1K_TLS_GD_HI16: u32 = 22;
+pub const R_OR1K_TLS_GD_LO16: u32 = 23;
+pub const R_OR1K_TLS_LDM_HI16: u32 = 24;
+pub const R_OR1K_TLS_LDM_LO16: u32 = 25;
+pub const R_OR1K_TLS_LDO_HI16: u32 = 26;
+pub const R_OR1K_TLS_LDO_LO16: u32 = 27;
+pub const R_OR1K_TLS_IE_HI16: u32 = 28;
+pub const R_OR1K_TLS_IE_LO16: u32 = 29;
+pub const R_OR1K_TLS_LE_HI16: u32 = 30;
+pub const R_OR1K_TLS_LE_LO16: u32 = 31;
+pub const R_OR1K_TLS_TPOFF: u32 = 32;
+pub const R_OR1K_TLS_DTPOFF: u32 = 33;
+pub const R_OR1K_TLS_DTPMOD: u32 = 34;
+pub const R_OR1K_NUM: u32 = 35;
+
+/////////////////////
+// MIPS
+/////////////////////
+/// No reloc
+pub const R_MIPS_NONE: u32 = 0;
+/// Direct 16 bit
+pub const R_MIPS_16: u32 = 1;
+/// Direct 32 bit
+pub const R_MIPS_32: u32 = 2;
+/// PC relative 32 bit
+pub const R_MIPS_REL32: u32 = 3;
+/// Direct 26 bit shifted
+pub const R_MIPS_26: u32 = 4;
+/// High 16 bit
+pub const R_MIPS_HI16: u32 = 5;
+/// Low 16 bit
+pub const R_MIPS_LO16: u32 = 6;
+/// GP relative 16 bit
+pub const R_MIPS_GPREL16: u32 = 7;
+/// 16 bit literal entry
+pub const R_MIPS_LITERAL: u32 = 8;
+/// 16 bit GOT entry
+pub const R_MIPS_GOT16: u32 = 9;
+/// PC relative 16 bit
+pub const R_MIPS_PC16: u32 = 10;
+/// 16 bit GOT entry for function
+pub const R_MIPS_CALL16: u32 = 11;
+/// GP relative 32 bit
+pub const R_MIPS_GPREL32: u32 = 12;
+pub const R_MIPS_SHIFT5: u32 = 16;
+pub const R_MIPS_SHIFT6: u32 = 17;
+pub const R_MIPS_64: u32 = 18;
+pub const R_MIPS_GOT_DISP: u32 = 19;
+pub const R_MIPS_GOT_PAGE: u32 = 20;
+pub const R_MIPS_GOT_OFST: u32 = 21;
+pub const R_MIPS_GOT_HI16: u32 = 22;
+pub const R_MIPS_GOT_LO16: u32 = 23;
+pub const R_MIPS_SUB: u32 = 24;
+pub const R_MIPS_INSERT_A: u32 = 25;
+pub const R_MIPS_INSERT_B: u32 = 26;
+pub const R_MIPS_DELETE: u32 = 27;
+pub const R_MIPS_HIGHER: u32 = 28;
+pub const R_MIPS_HIGHEST: u32 = 29;
+pub const R_MIPS_CALL_HI16: u32 = 30;
+pub const R_MIPS_CALL_LO16: u32 = 31;
+pub const R_MIPS_SCN_DISP: u32 = 32;
+pub const R_MIPS_REL16: u32 = 33;
+pub const R_MIPS_ADD_IMMEDIATE: u32 = 34;
+pub const R_MIPS_PJUMP: u32 = 35;
+pub const R_MIPS_RELGOT: u32 = 36;
+pub const R_MIPS_JALR: u32 = 37;
+/// Module number 32 bit
+pub const R_MIPS_TLS_DTPMOD32: u32 = 38;
+/// Module-relative offset 32 bit
+pub const R_MIPS_TLS_DTPREL32: u32 = 39;
+/// Module number 64 bit
+pub const R_MIPS_TLS_DTPMOD64: u32 = 40;
+/// Module-relative offset 64 bit
+pub const R_MIPS_TLS_DTPREL64: u32 = 41;
+/// 16 bit GOT offset for GD
+pub const R_MIPS_TLS_GD: u32 = 42;
+/// 16 bit GOT offset for LDM
+pub const R_MIPS_TLS_LDM: u32 = 43;
+/// Module-relative offset, high 16 bits
+pub const R_MIPS_TLS_DTPREL_HI16: u32 = 44;
+/// Module-relative offset, low 16 bits
+pub const R_MIPS_TLS_DTPREL_LO16: u32 = 45;
+/// 16 bit GOT offset for IE
+pub const R_MIPS_TLS_GOTTPREL: u32 = 46;
+/// TP-relative offset, 32 bit6
+pub const R_MIPS_TLS_TPREL32: u32 = 47;
+/// TP-relative offset, 64 bit
+pub const R_MIPS_TLS_TPREL64: u32 = 48;
+/// TP-relative offset, high 16 bits
+pub const R_MIPS_TLS_TPREL_HI16: u32 = 49;
+/// TP-relative offset, low 16 bits
+pub const R_MIPS_TLS_TPREL_LO16: u32 = 50;
+pub const R_MIPS_GLOB_DAT: u32 = 51;
+pub const R_MIPS_COPY: u32 = 126;
+pub const R_MIPS_JUMP_SLOT: u32 = 127;
+pub const R_MIPS_NUM: u32 = 128;
+
+///////////////////
+// RISC-V
+// See https://github.com/riscv/riscv-elf-psabi-doc
+///////////////////
+/// None
+pub const R_RISCV_NONE: u32 = 0;
+/// Runtime relocation: word32 = S + A
+pub const R_RISCV_32: u32 = 1;
+/// Runtime relocation: word64 = S + A
+pub const R_RISCV_64: u32 = 2;
+/// Runtime relocation: word32,64 = B + A
+pub const R_RISCV_RELATIVE: u32 = 3;
+/// Runtime relocation: must be in executable, not allowed in shared library
+pub const R_RISCV_COPY: u32 = 4;
+/// Runtime relocation: word32,64 = S; handled by PLT unless LD_BIND_NOW
+pub const R_RISCV_JUMP_SLOT: u32 = 5;
+/// TLS relocation: word32 = S->TLSINDEX
+pub const R_RISCV_TLS_DTPMOD32: u32 = 6;
+/// TLS relocation: word64 = S->TLSINDEX
+pub const R_RISCV_TLS_DTPMOD64: u32 = 7;
+/// TLS relocation: word32 = TLS + S + A - TLS_TP_OFFSET
+pub const R_RISCV_TLS_DTPREL32: u32 = 8;
+/// TLS relocation: word64 = TLS + S + A - TLS_TP_OFFSET
+pub const R_RISCV_TLS_DTPREL64: u32 = 9;
+/// TLS relocation: word32 = TLS + S + A + S_TLS_OFFSET - TLS_DTV_OFFSET
+pub const R_RISCV_TLS_TPREL32: u32 = 10;
+/// TLS relocation: word64 = TLS + S + A + S_TLS_OFFSET - TLS_DTV_OFFSET
+pub const R_RISCV_TLS_TPREL64: u32 = 11;
+/// PC-relative branch (SB-Type)
+pub const R_RISCV_BRANCH: u32 = 16;
+/// PC-relative jump (UJ-Type)
+pub const R_RISCV_JAL: u32 = 17;
+/// PC-relative call: MACRO call,tail (auipc+jalr pair)
+pub const R_RISCV_CALL: u32 = 18;
+/// PC-relative call (PLT): MACRO call,tail (auipc+jalr pair) PIC
+pub const R_RISCV_CALL_PLT: u32 = 19;
+/// PC-relative GOT reference: MACRO la
+pub const R_RISCV_GOT_HI20: u32 = 20;
+/// PC-relative TLS IE GOT offset: MACRO la.tls.ie
+pub const R_RISCV_TLS_GOT_HI20: u32 = 21;
+/// PC-relative TLS GD reference: MACRO la.tls.gd
+pub const R_RISCV_TLS_GD_HI20: u32 = 22;
+/// PC-relative reference: %pcrel_hi(symbol) (U-Type)
+pub const R_RISCV_PCREL_HI20: u32 = 23;
+/// PC-relative reference: %pcrel_lo(symbol) (I-Type)
+pub const R_RISCV_PCREL_LO12_I: u32 = 24;
+/// PC-relative reference: %pcrel_lo(symbol) (S-Type)
+pub const R_RISCV_PCREL_LO12_S: u32 = 25;
+/// Absolute address: %hi(symbol) (U-Type)
+pub const R_RISCV_HI20: u32 = 26;
+/// Absolute address: %lo(symbol) (I-Type)
+pub const R_RISCV_LO12_I: u32 = 27;
+/// Absolute address: %lo(symbol) (S-Type)
+pub const R_RISCV_LO12_S: u32 = 28;
+/// TLS LE thread offset: %tprel_hi(symbol) (U-Type)
+pub const R_RISCV_TPREL_HI20: u32 = 29;
+/// TLS LE thread offset: %tprel_lo(symbol) (I-Type)
+pub const R_RISCV_TPREL_LO12_I: u32 = 30;
+/// TLS LE thread offset: %tprel_lo(symbol) (S-Type)
+pub const R_RISCV_TPREL_LO12_S: u32 = 31;
+/// TLS LE thread usage: %tprel_add(symbol)
+pub const R_RISCV_TPREL_ADD: u32 = 32;
+/// 8-bit label addition: word8 = S + A
+pub const R_RISCV_ADD8: u32 = 33;
+/// 16-bit label addition: word16 = S + A
+pub const R_RISCV_ADD16: u32 = 34;
+/// 32-bit label addition: word32 = S + A
+pub const R_RISCV_ADD32: u32 = 35;
+/// 64-bit label addition: word64 = S + A
+pub const R_RISCV_ADD64: u32 = 36;
+/// 8-bit label subtraction: word8 = S - A
+pub const R_RISCV_SUB8: u32 = 37;
+/// 16-bit label subtraction: word16 = S - A
+pub const R_RISCV_SUB16: u32 = 38;
+/// 32-bit label subtraction: word32 = S - A
+pub const R_RISCV_SUB32: u32 = 39;
+/// 64-bit label subtraction: word64 = S - A
+pub const R_RISCV_SUB64: u32 = 40;
+/// GNU C++ vtable hierarchy
+pub const R_RISCV_GNU_VTINHERIT: u32 = 41;
+/// GNU C++ vtable member usage
+pub const R_RISCV_GNU_VTENTRY: u32 = 42;
+/// Alignment statement
+pub const R_RISCV_ALIGN: u32 = 43;
+/// PC-relative branch offset (CB-Type)
+pub const R_RISCV_RVC_BRANCH: u32 = 44;
+/// PC-relative jump offset (CJ-Type)
+pub const R_RISCV_RVC_JUMP: u32 = 45;
+/// Absolute address (CI-Type)
+pub const R_RISCV_RVC_LUI: u32 = 46;
+/// GP-relative reference (I-Type)
+pub const R_RISCV_GPREL_I: u32 = 47;
+/// GP-relative reference (S-Type)
+pub const R_RISCV_GPREL_S: u32 = 48;
+/// TP-relative TLS LE load (I-Type)
+pub const R_RISCV_TPREL_I: u32 = 49;
+/// TP-relative TLS LE store (S-Type)
+pub const R_RISCV_TPREL_S: u32 = 50;
+/// Instruction pair can be relaxed
+pub const R_RISCV_RELAX: u32 = 51;
+/// Local label subtraction
+pub const R_RISCV_SUB6: u32 = 52;
+/// Local label subtraction
+pub const R_RISCV_SET6: u32 = 53;
+/// Local label subtraction
+pub const R_RISCV_SET8: u32 = 54;
+/// Local label subtraction
+pub const R_RISCV_SET16: u32 = 55;
+/// Local label subtraction
+pub const R_RISCV_SET32: u32 = 56;
+
+#[inline]
+pub fn r_to_str(typ: u32, machine: u16) -> &'static str {
+ use crate::elf::header::*;
+ match machine {
+ // x86
+ EM_386 => { match typ {
+ R_386_NONE => "386_NONE",
+ R_386_32 => "386_32",
+ R_386_PC32 => "386_PC32",
+ R_386_GOT32 => "386_GOT32",
+ R_386_PLT32 => "386_PLT32",
+ R_386_COPY => "386_COPY",
+ R_386_GLOB_DAT => "386_GLOB_DAT",
+ R_386_JMP_SLOT => "386_JMP_SLOT",
+ R_386_RELATIVE => "386_RELATIVE",
+ R_386_GOTOFF => "386_GOTOFF",
+ R_386_GOTPC => "386_GOTPC",
+ R_386_32PLT => "386_32PLT",
+ R_386_TLS_TPOFF => "386_TLS_TPOFF",
+ R_386_TLS_IE => "386_TLS_IE",
+ R_386_TLS_GOTIE => "386_TLS_GOTIE",
+ R_386_TLS_LE => "386_TLS_LE",
+ R_386_TLS_GD => "386_TLS_GD",
+ R_386_TLS_LDM => "386_TLS_LDM",
+ R_386_16 => "386_16",
+ R_386_PC16 => "386_PC16",
+ R_386_8 => "386_8",
+ R_386_PC8 => "386_PC8",
+ R_386_TLS_GD_32 => "386_TLS_GD_32",
+ R_386_TLS_GD_PUSH => "386_TLS_GD_PUSH",
+ R_386_TLS_GD_CALL => "386_TLS_GD_CALL",
+ R_386_TLS_GD_POP => "386_TLS_GD_POP",
+ R_386_TLS_LDM_32 => "386_TLS_LDM_32",
+ R_386_TLS_LDM_PUSH => "386_TLS_LDM_PUSH",
+ R_386_TLS_LDM_CALL => "386_TLS_LDM_CALL",
+ R_386_TLS_LDM_POP => "386_TLS_LDM_POP",
+ R_386_TLS_LDO_32 => "386_TLS_LDO_32",
+ R_386_TLS_IE_32 => "386_TLS_IE_32",
+ R_386_TLS_LE_32 => "386_TLS_LE_32",
+ R_386_TLS_DTPMOD32 => "386_TLS_DTPMOD32",
+ R_386_TLS_DTPOFF32 => "386_TLS_DTPOFF32",
+ R_386_TLS_TPOFF32 => "386_TLS_TPOFF32",
+ R_386_SIZE32 => "386_SIZE32",
+ R_386_TLS_GOTDESC => "386_TLS_GOTDESC",
+ R_386_TLS_DESC_CALL => "386_TLS_DESC_CALL",
+ R_386_TLS_DESC => "386_TLS_DESC",
+ R_386_IRELATIVE => "386_IRELATIVE",
+ R_386_GOT32X => "386_GOT32X",
+ _ => "R_UNKNOWN_386",
+ }},
+ EM_X86_64 => { match typ {
+ R_X86_64_64 => "X86_64_64",
+ R_X86_64_PC32 => "X86_64_PC32",
+ R_X86_64_GOT32 => "X86_64_GOT32",
+ R_X86_64_PLT32 => "X86_64_PLT32",
+ R_X86_64_COPY => "X86_64_COPY",
+ R_X86_64_GLOB_DAT => "X86_64_GLOB_DAT",
+ R_X86_64_JUMP_SLOT => "X86_64_JUMP_SLOT",
+ R_X86_64_RELATIVE => "X86_64_RELATIVE",
+ R_X86_64_GOTPCREL => "X86_64_GOTPCREL",
+ R_X86_64_32 => "X86_64_32",
+ R_X86_64_32S => "X86_64_32S",
+ R_X86_64_16 => "X86_64_16",
+ R_X86_64_PC16 => "X86_64_PC16",
+ R_X86_64_8 => "X86_64_8",
+ R_X86_64_PC8 => "X86_64_PC8",
+ R_X86_64_DTPMOD64 => "X86_64_DTPMOD64",
+ R_X86_64_DTPOFF64 => "X86_64_DTPOFF64",
+ R_X86_64_TPOFF64 => "X86_64_TPOFF64",
+ R_X86_64_TLSGD => "X86_64_TLSGD",
+ R_X86_64_TLSLD => "X86_64_TLSLD",
+ R_X86_64_DTPOFF32 => "X86_64_DTPOFF32",
+ R_X86_64_GOTTPOFF => "X86_64_GOTTPOFF",
+ R_X86_64_TPOFF32 => "X86_64_TPOFF32",
+ R_X86_64_PC64 => "X86_64_PC64",
+ R_X86_64_GOTOFF64 => "X86_64_GOTOFF64",
+ R_X86_64_GOTPC32 => "X86_64_GOTPC32",
+ R_X86_64_GOT64 => "X86_64_GOT64",
+ R_X86_64_GOTPCREL64 => "X86_64_GOTPCREL64",
+ R_X86_64_GOTPC64 => "X86_64_GOTPC64",
+ R_X86_64_GOTPLT64 => "X86_64_GOTPLT64",
+ R_X86_64_PLTOFF64 => "X86_64_PLTOFF64",
+ R_X86_64_SIZE32 => "X86_64_SIZE32",
+ R_X86_64_SIZE64 => "X86_64_SIZE64",
+ R_X86_64_GOTPC32_TLSDESC => "X86_64_GOTPC32_TLSDESC",
+ R_X86_64_TLSDESC_CALL => "X86_64_TLSDESC_CALL",
+ R_X86_64_TLSDESC => "X86_64_TLSDESC",
+ R_X86_64_IRELATIVE => "X86_64_IRELATIVE",
+ R_X86_64_RELATIVE64 => "X86_64_RELATIVE64",
+ R_X86_64_GOTPCRELX => "R_X86_64_GOTPCRELX",
+ R_X86_64_REX_GOTPCRELX => "R_X86_64_REX_GOTPCRELX",
+ _ => "R_UNKNOWN_X86_64",
+ }},
+ // openrisc
+ EM_OPENRISC => { match typ {
+ R_OR1K_NONE => "OR1K_NONE",
+ R_OR1K_32 => "OR1K_32",
+ R_OR1K_16 => "OR1K_16",
+ R_OR1K_8 => "OR1K_8",
+ R_OR1K_LO_16_IN_INSN => "OR1K_LO_16_IN_INSN",
+ R_OR1K_HI_16_IN_INSN => "OR1K_HI_16_IN_INSN",
+ R_OR1K_INSN_REL_26 => "OR1K_INSN_REL_26",
+ R_OR1K_GNU_VTENTRY => "OR1K_GNU_VTENTRY",
+ R_OR1K_GNU_VTINHERIT => "OR1K_GNU_VTINHERIT",
+ R_OR1K_32_PCREL => "OR1K_32_PCREL",
+ R_OR1K_16_PCREL => "OR1K_16_PCREL",
+ R_OR1K_8_PCREL => "OR1K_8_PCREL",
+ R_OR1K_GOTPC_HI16 => "OR1K_GOTPC_HI16",
+ R_OR1K_GOTPC_LO16 => "OR1K_GOTPC_LO16",
+ R_OR1K_GOT16 => "OR1K_GOT16",
+ R_OR1K_PLT26 => "OR1K_PLT26",
+ R_OR1K_GOTOFF_HI16 => "OR1K_GOTOFF_HI16",
+ R_OR1K_GOTOFF_LO16 => "OR1K_GOTOFF_LO16",
+ R_OR1K_COPY => "OR1K_COPY",
+ R_OR1K_GLOB_DAT => "OR1K_GLOB_DAT",
+ R_OR1K_JMP_SLOT => "OR1K_JMP_SLOT",
+ R_OR1K_RELATIVE => "OR1K_RELATIVE",
+ R_OR1K_TLS_GD_HI16 => "OR1K_TLS_GD_HI16",
+ R_OR1K_TLS_GD_LO16 => "OR1K_TLS_GD_LO16",
+ R_OR1K_TLS_LDM_HI16 => "OR1K_TLS_LDM_HI16",
+ R_OR1K_TLS_LDM_LO16 => "OR1K_TLS_LDM_LO16",
+ R_OR1K_TLS_LDO_HI16 => "OR1K_TLS_LDO_HI16",
+ R_OR1K_TLS_LDO_LO16 => "OR1K_TLS_LDO_LO16",
+ R_OR1K_TLS_IE_HI16 => "OR1K_TLS_IE_HI16",
+ R_OR1K_TLS_IE_LO16 => "OR1K_TLS_IE_LO16",
+ R_OR1K_TLS_LE_HI16 => "OR1K_TLS_LE_HI16",
+ R_OR1K_TLS_LE_LO16 => "OR1K_TLS_LE_LO16",
+ R_OR1K_TLS_TPOFF => "OR1K_TLS_TPOFF",
+ R_OR1K_TLS_DTPOFF => "OR1K_TLS_DTPOFF",
+ R_OR1K_TLS_DTPMOD => "OR1K_TLS_DTPMOD",
+ _ => "R_UNKNOWN_OR1K",
+ }},
+ // arm64
+ EM_AARCH64 => { match typ {
+ R_AARCH64_P32_ABS32 => "AARCH64_P32_ABS32",
+ R_AARCH64_P32_COPY => "AARCH64_P32_COPY",
+ R_AARCH64_P32_GLOB_DAT => "AARCH64_P32_GLOB_DAT",
+ R_AARCH64_P32_JUMP_SLOT => "AARCH64_P32_JUMP_SLOT",
+ R_AARCH64_P32_RELATIVE => "AARCH64_P32_RELATIVE",
+ R_AARCH64_P32_TLS_DTPMOD => "AARCH64_P32_TLS_DTPMOD",
+ R_AARCH64_P32_TLS_DTPREL => "AARCH64_P32_TLS_DTPREL",
+ R_AARCH64_P32_TLS_TPREL => "AARCH64_P32_TLS_TPREL",
+ R_AARCH64_P32_TLSDESC => "AARCH64_P32_TLSDESC",
+ R_AARCH64_P32_IRELATIVE => "AARCH64_P32_IRELATIVE",
+ R_AARCH64_ABS64 => "AARCH64_ABS64",
+ R_AARCH64_ABS32 => "AARCH64_ABS32",
+ R_AARCH64_ABS16 => "AARCH64_ABS16",
+ R_AARCH64_PREL64 => "AARCH64_PREL64",
+ R_AARCH64_PREL32 => "AARCH64_PREL32",
+ R_AARCH64_PREL16 => "AARCH64_PREL16",
+ R_AARCH64_MOVW_UABS_G0 => "AARCH64_MOVW_UABS_G0",
+ R_AARCH64_MOVW_UABS_G0_NC => "AARCH64_MOVW_UABS_G0_NC",
+ R_AARCH64_MOVW_UABS_G1 => "AARCH64_MOVW_UABS_G1",
+ R_AARCH64_MOVW_UABS_G1_NC => "AARCH64_MOVW_UABS_G1_NC",
+ R_AARCH64_MOVW_UABS_G2 => "AARCH64_MOVW_UABS_G2",
+ R_AARCH64_MOVW_UABS_G2_NC => "AARCH64_MOVW_UABS_G2_NC",
+ R_AARCH64_MOVW_UABS_G3 => "AARCH64_MOVW_UABS_G3",
+ R_AARCH64_MOVW_SABS_G0 => "AARCH64_MOVW_SABS_G0",
+ R_AARCH64_MOVW_SABS_G1 => "AARCH64_MOVW_SABS_G1",
+ R_AARCH64_MOVW_SABS_G2 => "AARCH64_MOVW_SABS_G2",
+ R_AARCH64_LD_PREL_LO19 => "AARCH64_LD_PREL_LO19",
+ R_AARCH64_ADR_PREL_LO21 => "AARCH64_ADR_PREL_LO21",
+ R_AARCH64_ADR_PREL_PG_HI21 => "AARCH64_ADR_PREL_PG_HI21",
+ R_AARCH64_ADR_PREL_PG_HI21_NC => "AARCH64_ADR_PREL_PG_HI21_NC",
+ R_AARCH64_ADD_ABS_LO12_NC => "AARCH64_ADD_ABS_LO12_NC",
+ R_AARCH64_LDST8_ABS_LO12_NC => "AARCH64_LDST8_ABS_LO12_NC",
+ R_AARCH64_TSTBR14 => "AARCH64_TSTBR14",
+ R_AARCH64_CONDBR19 => "AARCH64_CONDBR19",
+ R_AARCH64_JUMP26 => "AARCH64_JUMP26",
+ R_AARCH64_CALL26 => "AARCH64_CALL26",
+ R_AARCH64_LDST16_ABS_LO12_NC => "AARCH64_LDST16_ABS_LO12_NC",
+ R_AARCH64_LDST32_ABS_LO12_NC => "AARCH64_LDST32_ABS_LO12_NC",
+ R_AARCH64_LDST64_ABS_LO12_NC => "AARCH64_LDST64_ABS_LO12_NC",
+ R_AARCH64_MOVW_PREL_G0 => "AARCH64_MOVW_PREL_G0",
+ R_AARCH64_MOVW_PREL_G0_NC => "AARCH64_MOVW_PREL_G0_NC",
+ R_AARCH64_MOVW_PREL_G1 => "AARCH64_MOVW_PREL_G1",
+ R_AARCH64_MOVW_PREL_G1_NC => "AARCH64_MOVW_PREL_G1_NC",
+ R_AARCH64_MOVW_PREL_G2 => "AARCH64_MOVW_PREL_G2",
+ R_AARCH64_MOVW_PREL_G2_NC => "AARCH64_MOVW_PREL_G2_NC",
+ R_AARCH64_MOVW_PREL_G3 => "AARCH64_MOVW_PREL_G3",
+ R_AARCH64_LDST128_ABS_LO12_NC => "AARCH64_LDST128_ABS_LO12_NC",
+ R_AARCH64_MOVW_GOTOFF_G0 => "AARCH64_MOVW_GOTOFF_G0",
+ R_AARCH64_MOVW_GOTOFF_G0_NC => "AARCH64_MOVW_GOTOFF_G0_NC",
+ R_AARCH64_MOVW_GOTOFF_G1 => "AARCH64_MOVW_GOTOFF_G1",
+ R_AARCH64_MOVW_GOTOFF_G1_NC => "AARCH64_MOVW_GOTOFF_G1_NC",
+ R_AARCH64_MOVW_GOTOFF_G2 => "AARCH64_MOVW_GOTOFF_G2",
+ R_AARCH64_MOVW_GOTOFF_G2_NC => "AARCH64_MOVW_GOTOFF_G2_NC",
+ R_AARCH64_MOVW_GOTOFF_G3 => "AARCH64_MOVW_GOTOFF_G3",
+ R_AARCH64_GOTREL64 => "AARCH64_GOTREL64",
+ R_AARCH64_GOTREL32 => "AARCH64_GOTREL32",
+ R_AARCH64_GOT_LD_PREL19 => "AARCH64_GOT_LD_PREL19",
+ R_AARCH64_LD64_GOTOFF_LO15 => "AARCH64_LD64_GOTOFF_LO15",
+ R_AARCH64_ADR_GOT_PAGE => "AARCH64_ADR_GOT_PAGE",
+ R_AARCH64_LD64_GOT_LO12_NC => "AARCH64_LD64_GOT_LO12_NC",
+ R_AARCH64_LD64_GOTPAGE_LO15 => "AARCH64_LD64_GOTPAGE_LO15",
+ R_AARCH64_TLSGD_ADR_PREL21 => "AARCH64_TLSGD_ADR_PREL21",
+ R_AARCH64_TLSGD_ADR_PAGE21 => "AARCH64_TLSGD_ADR_PAGE21",
+ R_AARCH64_TLSGD_ADD_LO12_NC => "AARCH64_TLSGD_ADD_LO12_NC",
+ R_AARCH64_TLSGD_MOVW_G1 => "AARCH64_TLSGD_MOVW_G1",
+ R_AARCH64_TLSGD_MOVW_G0_NC => "AARCH64_TLSGD_MOVW_G0_NC",
+ R_AARCH64_TLSLD_ADR_PREL21 => "AARCH64_TLSLD_ADR_PREL21",
+ R_AARCH64_TLSLD_ADR_PAGE21 => "AARCH64_TLSLD_ADR_PAGE21",
+ R_AARCH64_TLSLD_ADD_LO12_NC => "AARCH64_TLSLD_ADD_LO12_NC",
+ R_AARCH64_TLSLD_MOVW_G1 => "AARCH64_TLSLD_MOVW_G1",
+ R_AARCH64_TLSLD_MOVW_G0_NC => "AARCH64_TLSLD_MOVW_G0_NC",
+ R_AARCH64_TLSLD_LD_PREL19 => "AARCH64_TLSLD_LD_PREL19",
+ R_AARCH64_TLSLD_MOVW_DTPREL_G2 => "AARCH64_TLSLD_MOVW_DTPREL_G2",
+ R_AARCH64_TLSLD_MOVW_DTPREL_G1 => "AARCH64_TLSLD_MOVW_DTPREL_G1",
+ R_AARCH64_TLSLD_MOVW_DTPREL_G1_NC => "AARCH64_TLSLD_MOVW_DTPREL_G1_NC",
+ R_AARCH64_TLSLD_MOVW_DTPREL_G0 => "AARCH64_TLSLD_MOVW_DTPREL_G0",
+ R_AARCH64_TLSLD_MOVW_DTPREL_G0_NC => "AARCH64_TLSLD_MOVW_DTPREL_G0_NC",
+ R_AARCH64_TLSLD_ADD_DTPREL_HI12 => "AARCH64_TLSLD_ADD_DTPREL_HI12",
+ R_AARCH64_TLSLD_ADD_DTPREL_LO12 => "AARCH64_TLSLD_ADD_DTPREL_LO12",
+ R_AARCH64_TLSLD_ADD_DTPREL_LO12_NC => "AARCH64_TLSLD_ADD_DTPREL_LO12_NC",
+ R_AARCH64_TLSLD_LDST8_DTPREL_LO12 => "AARCH64_TLSLD_LDST8_DTPREL_LO12",
+ R_AARCH64_TLSLD_LDST8_DTPREL_LO12_NC => "AARCH64_TLSLD_LDST8_DTPREL_LO12_NC",
+ R_AARCH64_TLSLD_LDST16_DTPREL_LO12 => "AARCH64_TLSLD_LDST16_DTPREL_LO12",
+ R_AARCH64_TLSLD_LDST16_DTPREL_LO12_NC => "AARCH64_TLSLD_LDST16_DTPREL_LO12_NC",
+ R_AARCH64_TLSLD_LDST32_DTPREL_LO12 => "AARCH64_TLSLD_LDST32_DTPREL_LO12",
+ R_AARCH64_TLSLD_LDST32_DTPREL_LO12_NC => "AARCH64_TLSLD_LDST32_DTPREL_LO12_NC",
+ R_AARCH64_TLSLD_LDST64_DTPREL_LO12 => "AARCH64_TLSLD_LDST64_DTPREL_LO12",
+ R_AARCH64_TLSLD_LDST64_DTPREL_LO12_NC => "AARCH64_TLSLD_LDST64_DTPREL_LO12_NC",
+ R_AARCH64_TLSIE_MOVW_GOTTPREL_G1 => "AARCH64_TLSIE_MOVW_GOTTPREL_G1",
+ R_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC => "AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC",
+ R_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21 => "AARCH64_TLSIE_ADR_GOTTPREL_PAGE21",
+ R_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC => "AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC",
+ R_AARCH64_TLSIE_LD_GOTTPREL_PREL19 => "AARCH64_TLSIE_LD_GOTTPREL_PREL19",
+ R_AARCH64_TLSLE_MOVW_TPREL_G2 => "AARCH64_TLSLE_MOVW_TPREL_G2",
+ R_AARCH64_TLSLE_MOVW_TPREL_G1 => "AARCH64_TLSLE_MOVW_TPREL_G1",
+ R_AARCH64_TLSLE_MOVW_TPREL_G1_NC => "AARCH64_TLSLE_MOVW_TPREL_G1_NC",
+ R_AARCH64_TLSLE_MOVW_TPREL_G0 => "AARCH64_TLSLE_MOVW_TPREL_G0",
+ R_AARCH64_TLSLE_MOVW_TPREL_G0_NC => "AARCH64_TLSLE_MOVW_TPREL_G0_NC",
+ R_AARCH64_TLSLE_ADD_TPREL_HI12 => "AARCH64_TLSLE_ADD_TPREL_HI12",
+ R_AARCH64_TLSLE_ADD_TPREL_LO12 => "AARCH64_TLSLE_ADD_TPREL_LO12",
+ R_AARCH64_TLSLE_ADD_TPREL_LO12_NC => "AARCH64_TLSLE_ADD_TPREL_LO12_NC",
+ R_AARCH64_TLSLE_LDST8_TPREL_LO12 => "AARCH64_TLSLE_LDST8_TPREL_LO12",
+ R_AARCH64_TLSLE_LDST8_TPREL_LO12_NC => "AARCH64_TLSLE_LDST8_TPREL_LO12_NC",
+ R_AARCH64_TLSLE_LDST16_TPREL_LO12 => "AARCH64_TLSLE_LDST16_TPREL_LO12",
+ R_AARCH64_TLSLE_LDST16_TPREL_LO12_NC => "AARCH64_TLSLE_LDST16_TPREL_LO12_NC",
+ R_AARCH64_TLSLE_LDST32_TPREL_LO12 => "AARCH64_TLSLE_LDST32_TPREL_LO12",
+ R_AARCH64_TLSLE_LDST32_TPREL_LO12_NC => "AARCH64_TLSLE_LDST32_TPREL_LO12_NC",
+ R_AARCH64_TLSLE_LDST64_TPREL_LO12 => "AARCH64_TLSLE_LDST64_TPREL_LO12",
+ R_AARCH64_TLSLE_LDST64_TPREL_LO12_NC => "AARCH64_TLSLE_LDST64_TPREL_LO12_NC",
+ R_AARCH64_TLSDESC_LD_PREL19 => "AARCH64_TLSDESC_LD_PREL19",
+ R_AARCH64_TLSDESC_ADR_PREL21 => "AARCH64_TLSDESC_ADR_PREL21",
+ R_AARCH64_TLSDESC_ADR_PAGE21 => "AARCH64_TLSDESC_ADR_PAGE21",
+ R_AARCH64_TLSDESC_LD64_LO12 => "AARCH64_TLSDESC_LD64_LO12",
+ R_AARCH64_TLSDESC_ADD_LO12 => "AARCH64_TLSDESC_ADD_LO12",
+ R_AARCH64_TLSDESC_OFF_G1 => "AARCH64_TLSDESC_OFF_G1",
+ R_AARCH64_TLSDESC_OFF_G0_NC => "AARCH64_TLSDESC_OFF_G0_NC",
+ R_AARCH64_TLSDESC_LDR => "AARCH64_TLSDESC_LDR",
+ R_AARCH64_TLSDESC_ADD => "AARCH64_TLSDESC_ADD",
+ R_AARCH64_TLSDESC_CALL => "AARCH64_TLSDESC_CALL",
+ R_AARCH64_TLSLE_LDST128_TPREL_LO12 => "AARCH64_TLSLE_LDST128_TPREL_LO12",
+ R_AARCH64_TLSLE_LDST128_TPREL_LO12_NC => "AARCH64_TLSLE_LDST128_TPREL_LO12_NC",
+ R_AARCH64_TLSLD_LDST128_DTPREL_LO12 => "AARCH64_TLSLD_LDST128_DTPREL_LO12",
+ R_AARCH64_TLSLD_LDST128_DTPREL_LO12_NC => "AARCH64_TLSLD_LDST128_DTPREL_LO12_NC",
+ R_AARCH64_COPY => "AARCH64_COPY",
+ R_AARCH64_GLOB_DAT => "AARCH64_GLOB_DAT",
+ R_AARCH64_JUMP_SLOT => "AARCH64_JUMP_SLOT",
+ R_AARCH64_RELATIVE => "AARCH64_RELATIVE",
+ R_AARCH64_TLS_DTPMOD => "AARCH64_TLS_DTPMOD",
+ R_AARCH64_TLS_DTPREL => "AARCH64_TLS_DTPREL",
+ R_AARCH64_TLS_TPREL => "AARCH64_TLS_TPREL",
+ R_AARCH64_TLSDESC => "AARCH64_TLSDESC",
+ R_AARCH64_IRELATIVE => "AARCH64_IRELATIVE",
+ _ => "R_UNKNOWN_AARCH64",
+ }},
+ // arm
+ EM_ARM => { match typ {
+ R_ARM_PC24 => "ARM_PC24",
+ R_ARM_ABS32 => "ARM_ABS32",
+ R_ARM_REL32 => "ARM_REL32",
+ R_ARM_PC13 => "ARM_PC13",
+ R_ARM_ABS16 => "ARM_ABS16",
+ R_ARM_ABS12 => "ARM_ABS12",
+ R_ARM_THM_ABS5 => "ARM_THM_ABS5",
+ R_ARM_ABS8 => "ARM_ABS8",
+ R_ARM_SBREL32 => "ARM_SBREL32",
+ R_ARM_THM_PC22 => "ARM_THM_PC22",
+ R_ARM_THM_PC8 => "ARM_THM_PC8",
+ R_ARM_AMP_VCALL9 => "ARM_AMP_VCALL9",
+ R_ARM_TLS_DESC => "ARM_TLS_DESC",
+ R_ARM_THM_SWI8 => "ARM_THM_SWI8",
+ R_ARM_XPC25 => "ARM_XPC25",
+ R_ARM_THM_XPC22 => "ARM_THM_XPC22",
+ R_ARM_TLS_DTPMOD32 => "ARM_TLS_DTPMOD32",
+ R_ARM_TLS_DTPOFF32 => "ARM_TLS_DTPOFF32",
+ R_ARM_TLS_TPOFF32 => "ARM_TLS_TPOFF32",
+ R_ARM_COPY => "ARM_COPY",
+ R_ARM_GLOB_DAT => "ARM_GLOB_DAT",
+ R_ARM_JUMP_SLOT => "ARM_JUMP_SLOT",
+ R_ARM_RELATIVE => "ARM_RELATIVE",
+ R_ARM_GOTOFF => "ARM_GOTOFF",
+ R_ARM_GOTPC => "ARM_GOTPC",
+ R_ARM_GOT32 => "ARM_GOT32",
+ R_ARM_PLT32 => "ARM_PLT32",
+ R_ARM_CALL => "ARM_CALL",
+ R_ARM_JUMP24 => "ARM_JUMP24",
+ R_ARM_THM_JUMP24 => "ARM_THM_JUMP24",
+ R_ARM_BASE_ABS => "ARM_BASE_ABS",
+ R_ARM_ALU_PCREL_7_0 => "ARM_ALU_PCREL_7_0",
+ R_ARM_ALU_PCREL_15_8 => "ARM_ALU_PCREL_15_8",
+ R_ARM_ALU_PCREL_23_15 => "ARM_ALU_PCREL_23_15",
+ R_ARM_LDR_SBREL_11_0 => "ARM_LDR_SBREL_11_0",
+ R_ARM_ALU_SBREL_19_12 => "ARM_ALU_SBREL_19_12",
+ R_ARM_ALU_SBREL_27_20 => "ARM_ALU_SBREL_27_20",
+ R_ARM_TARGET1 => "ARM_TARGET1",
+ R_ARM_SBREL31 => "ARM_SBREL31",
+ R_ARM_V4BX => "ARM_V4BX",
+ R_ARM_TARGET2 => "ARM_TARGET2",
+ R_ARM_PREL31 => "ARM_PREL31",
+ R_ARM_MOVW_ABS_NC => "ARM_MOVW_ABS_NC",
+ R_ARM_MOVT_ABS => "ARM_MOVT_ABS",
+ R_ARM_MOVW_PREL_NC => "ARM_MOVW_PREL_NC",
+ R_ARM_MOVT_PREL => "ARM_MOVT_PREL",
+ R_ARM_THM_MOVW_ABS_NC => "ARM_THM_MOVW_ABS_NC",
+ R_ARM_THM_MOVT_ABS => "ARM_THM_MOVT_ABS",
+ R_ARM_THM_MOVW_PREL_NC => "ARM_THM_MOVW_PREL_NC",
+ R_ARM_THM_MOVT_PREL => "ARM_THM_MOVT_PREL",
+ R_ARM_THM_JUMP19 => "ARM_THM_JUMP19",
+ R_ARM_THM_JUMP6 => "ARM_THM_JUMP6",
+ R_ARM_THM_ALU_PREL_11_0 => "ARM_THM_ALU_PREL_11_0",
+ R_ARM_THM_PC12 => "ARM_THM_PC12",
+ R_ARM_ABS32_NOI => "ARM_ABS32_NOI",
+ R_ARM_REL32_NOI => "ARM_REL32_NOI",
+ R_ARM_ALU_PC_G0_NC => "ARM_ALU_PC_G0_NC",
+ R_ARM_ALU_PC_G0 => "ARM_ALU_PC_G0",
+ R_ARM_ALU_PC_G1_NC => "ARM_ALU_PC_G1_NC",
+ R_ARM_ALU_PC_G1 => "ARM_ALU_PC_G1",
+ R_ARM_ALU_PC_G2 => "ARM_ALU_PC_G2",
+ R_ARM_LDR_PC_G1 => "ARM_LDR_PC_G1",
+ R_ARM_LDR_PC_G2 => "ARM_LDR_PC_G2",
+ R_ARM_LDRS_PC_G0 => "ARM_LDRS_PC_G0",
+ R_ARM_LDRS_PC_G1 => "ARM_LDRS_PC_G1",
+ R_ARM_LDRS_PC_G2 => "ARM_LDRS_PC_G2",
+ R_ARM_LDC_PC_G0 => "ARM_LDC_PC_G0",
+ R_ARM_LDC_PC_G1 => "ARM_LDC_PC_G1",
+ R_ARM_LDC_PC_G2 => "ARM_LDC_PC_G2",
+ R_ARM_ALU_SB_G0_NC => "ARM_ALU_SB_G0_NC",
+ R_ARM_ALU_SB_G0 => "ARM_ALU_SB_G0",
+ R_ARM_ALU_SB_G1_NC => "ARM_ALU_SB_G1_NC",
+ R_ARM_ALU_SB_G1 => "ARM_ALU_SB_G1",
+ R_ARM_ALU_SB_G2 => "ARM_ALU_SB_G2",
+ R_ARM_LDR_SB_G0 => "ARM_LDR_SB_G0",
+ R_ARM_LDR_SB_G1 => "ARM_LDR_SB_G1",
+ R_ARM_LDR_SB_G2 => "ARM_LDR_SB_G2",
+ R_ARM_LDRS_SB_G0 => "ARM_LDRS_SB_G0",
+ R_ARM_LDRS_SB_G1 => "ARM_LDRS_SB_G1",
+ R_ARM_LDRS_SB_G2 => "ARM_LDRS_SB_G2",
+ R_ARM_LDC_SB_G0 => "ARM_LDC_SB_G0",
+ R_ARM_LDC_SB_G1 => "ARM_LDC_SB_G1",
+ R_ARM_LDC_SB_G2 => "ARM_LDC_SB_G2",
+ R_ARM_MOVW_BREL_NC => "ARM_MOVW_BREL_NC",
+ R_ARM_MOVT_BREL => "ARM_MOVT_BREL",
+ R_ARM_MOVW_BREL => "ARM_MOVW_BREL",
+ R_ARM_THM_MOVW_BREL_NC => "ARM_THM_MOVW_BREL_NC",
+ R_ARM_THM_MOVT_BREL => "ARM_THM_MOVT_BREL",
+ R_ARM_THM_MOVW_BREL => "ARM_THM_MOVW_BREL",
+ R_ARM_TLS_GOTDESC => "ARM_TLS_GOTDESC",
+ R_ARM_TLS_CALL => "ARM_TLS_CALL",
+ R_ARM_TLS_DESCSEQ => "ARM_TLS_DESCSEQ",
+ R_ARM_THM_TLS_CALL => "ARM_THM_TLS_CALL",
+ R_ARM_PLT32_ABS => "ARM_PLT32_ABS",
+ R_ARM_GOT_ABS => "ARM_GOT_ABS",
+ R_ARM_GOT_PREL => "ARM_GOT_PREL",
+ R_ARM_GOT_BREL12 => "ARM_GOT_BREL12",
+ R_ARM_GOTOFF12 => "ARM_GOTOFF12",
+ R_ARM_GOTRELAX => "ARM_GOTRELAX",
+ R_ARM_GNU_VTENTRY => "ARM_GNU_VTENTRY",
+ R_ARM_GNU_VTINHERIT => "ARM_GNU_VTINHERIT",
+ R_ARM_THM_PC11 => "ARM_THM_PC11",
+ R_ARM_THM_PC9 => "ARM_THM_PC9",
+ R_ARM_TLS_GD32 => "ARM_TLS_GD32",
+ R_ARM_TLS_LDM32 => "ARM_TLS_LDM32",
+ R_ARM_TLS_LDO32 => "ARM_TLS_LDO32",
+ R_ARM_TLS_IE32 => "ARM_TLS_IE32",
+ R_ARM_TLS_LE32 => "ARM_TLS_LE32",
+ R_ARM_TLS_LDO12 => "ARM_TLS_LDO12",
+ R_ARM_TLS_LE12 => "ARM_TLS_LE12",
+ R_ARM_TLS_IE12GP => "ARM_TLS_IE12GP",
+ R_ARM_ME_TOO => "ARM_ME_TOO",
+ R_ARM_THM_TLS_DESCSEQ16 => "ARM_THM_TLS_DESCSEQ16",
+ R_ARM_THM_TLS_DESCSEQ32 => "ARM_THM_TLS_DESCSEQ32",
+ R_ARM_THM_GOT_BREL12 => "ARM_THM_GOT_BREL12",
+ R_ARM_IRELATIVE => "ARM_IRELATIVE",
+ R_ARM_RXPC25 => "ARM_RXPC25",
+ R_ARM_RSBREL32 => "ARM_RSBREL32",
+ R_ARM_THM_RPC22 => "ARM_THM_RPC22",
+ R_ARM_RREL32 => "ARM_RREL32",
+ R_ARM_RABS22 => "ARM_RABS22",
+ R_ARM_RPC24 => "ARM_RPC24",
+ R_ARM_RBASE => "ARM_RBASE",
+ _ => "R_UNKNOWN_ARM",
+ }},
+ // MIPS
+ EM_MIPS | EM_MIPS_RS3_LE | EM_MIPS_X => { match typ {
+ R_MIPS_NONE => "R_MIPS_NONE",
+ R_MIPS_16 => "R_MIPS_16",
+ R_MIPS_32 => "R_MIPS_32",
+ R_MIPS_REL32 => "R_MIPS_REL32",
+ R_MIPS_26 => "R_MIPS_26",
+ R_MIPS_HI16 => "R_MIPS_HI16",
+ R_MIPS_LO16 => "R_MIPS_LO16",
+ R_MIPS_GPREL16 => "R_MIPS_GPREL16",
+ R_MIPS_LITERAL => "R_MIPS_LITERAL",
+ R_MIPS_GOT16 => "R_MIPS_GOT16",
+ R_MIPS_PC16 => "R_MIPS_PC16",
+ R_MIPS_CALL16 => "R_MIPS_CALL16",
+ R_MIPS_GPREL32 => "R_MIPS_GPREL32",
+ R_MIPS_SHIFT5 => "R_MIPS_SHIFT5",
+ R_MIPS_SHIFT6 => "R_MIPS_SHIFT6",
+ R_MIPS_64 => "R_MIPS_64",
+ R_MIPS_GOT_DISP => "R_MIPS_GOT_DISP",
+ R_MIPS_GOT_PAGE => "R_MIPS_GOT_PAGE",
+ R_MIPS_GOT_OFST => "R_MIPS_GOT_OFST",
+ R_MIPS_GOT_HI16 => "R_MIPS_GOT_HI16",
+ R_MIPS_GOT_LO16 => "R_MIPS_GOT_LO16",
+ R_MIPS_SUB => "R_MIPS_SUB",
+ R_MIPS_INSERT_A => "R_MIPS_INSERT_A",
+ R_MIPS_INSERT_B => "R_MIPS_INSERT_B",
+ R_MIPS_DELETE => "R_MIPS_DELETE",
+ R_MIPS_HIGHER => "R_MIPS_HIGHER",
+ R_MIPS_HIGHEST => "R_MIPS_HIGHEST",
+ R_MIPS_CALL_HI16 => "R_MIPS_CALL_HI16",
+ R_MIPS_CALL_LO16 => "R_MIPS_CALL_LO16",
+ R_MIPS_SCN_DISP => "R_MIPS_SCN_DISP",
+ R_MIPS_REL16 => "R_MIPS_REL16",
+ R_MIPS_ADD_IMMEDIATE => "R_MIPS_ADD_IMMEDIATE",
+ R_MIPS_PJUMP => "R_MIPS_PJUMP",
+ R_MIPS_RELGOT => "R_MIPS_RELGOT",
+ R_MIPS_JALR => "R_MIPS_JALR",
+ R_MIPS_TLS_DTPMOD32 => "R_MIPS_TLS_DTPMOD32",
+ R_MIPS_TLS_DTPREL32 => "R_MIPS_TLS_DTPREL32",
+ R_MIPS_TLS_DTPMOD64 => "R_MIPS_TLS_DTPMOD64",
+ R_MIPS_TLS_DTPREL64 => "R_MIPS_TLS_DTPREL64",
+ R_MIPS_TLS_GD => "R_MIPS_TLS_GD",
+ R_MIPS_TLS_LDM => "R_MIPS_TLS_LDM",
+ R_MIPS_TLS_DTPREL_HI16 => "R_MIPS_TLS_DTPREL_HI16",
+ R_MIPS_TLS_DTPREL_LO16 => "R_MIPS_TLS_DTPREL_LO16",
+ R_MIPS_TLS_GOTTPREL => "R_MIPS_TLS_GOTTPREL",
+ R_MIPS_TLS_TPREL32 => "R_MIPS_TLS_TPREL32",
+ R_MIPS_TLS_TPREL64 => "R_MIPS_TLS_TPREL64",
+ R_MIPS_TLS_TPREL_HI16 => "R_MIPS_TLS_TPREL_HI16",
+ R_MIPS_TLS_TPREL_LO16 => "R_MIPS_TLS_TPREL_LO16",
+ R_MIPS_GLOB_DAT => "R_MIPS_GLOB_DAT",
+ R_MIPS_COPY => "R_MIPS_COPY",
+ R_MIPS_JUMP_SLOT => "R_MIPS_JUMP_SLOT",
+ _ => "R_UNKNOWN_MIPS",
+ }},
+ // RISC-V
+ EM_RISCV => { match typ {
+ R_RISCV_NONE => "R_RISCV_NONE",
+ R_RISCV_32 => "R_RISCV_32",
+ R_RISCV_64 => "R_RISCV_64",
+ R_RISCV_RELATIVE => "R_RISCV_RELATIVE",
+ R_RISCV_COPY => "R_RISCV_COPY",
+ R_RISCV_JUMP_SLOT => "R_RISCV_JUMP_SLOT",
+ R_RISCV_TLS_DTPMOD32 => "R_RISCV_TLS_DTPMOD32",
+ R_RISCV_TLS_DTPMOD64 => "R_RISCV_TLS_DTPMOD64",
+ R_RISCV_TLS_DTPREL32 => "R_RISCV_TLS_DTPREL32",
+ R_RISCV_TLS_DTPREL64 => "R_RISCV_TLS_DTPREL64",
+ R_RISCV_TLS_TPREL32 => "R_RISCV_TLS_TPREL32",
+ R_RISCV_TLS_TPREL64 => "R_RISCV_TLS_TPREL64",
+ R_RISCV_BRANCH => "R_RISCV_BRANCH",
+ R_RISCV_JAL => "R_RISCV_JAL",
+ R_RISCV_CALL => "R_RISCV_CALL",
+ R_RISCV_CALL_PLT => "R_RISCV_CALL_PLT",
+ R_RISCV_GOT_HI20 => "R_RISCV_GOT_HI20",
+ R_RISCV_TLS_GOT_HI20 => "R_RISCV_TLS_GOT_HI20",
+ R_RISCV_TLS_GD_HI20 => "R_RISCV_TLS_GD_HI20",
+ R_RISCV_PCREL_HI20 => "R_RISCV_PCREL_HI20",
+ R_RISCV_PCREL_LO12_I => "R_RISCV_PCREL_LO12_I",
+ R_RISCV_PCREL_LO12_S => "R_RISCV_PCREL_LO12_S",
+ R_RISCV_HI20 => "R_RISCV_HI20",
+ R_RISCV_LO12_I => "R_RISCV_LO12_I",
+ R_RISCV_LO12_S => "R_RISCV_LO12_S",
+ R_RISCV_TPREL_HI20 => "R_RISCV_TPREL_HI20",
+ R_RISCV_TPREL_LO12_I => "R_RISCV_TPREL_LO12_I",
+ R_RISCV_TPREL_LO12_S => "R_RISCV_TPREL_LO12_S",
+ R_RISCV_TPREL_ADD => "R_RISCV_TPREL_ADD",
+ R_RISCV_ADD8 => "R_RISCV_ADD8",
+ R_RISCV_ADD16 => "R_RISCV_ADD16",
+ R_RISCV_ADD32 => "R_RISCV_ADD32",
+ R_RISCV_ADD64 => "R_RISCV_ADD64",
+ R_RISCV_SUB8 => "R_RISCV_SUB8",
+ R_RISCV_SUB16 => "R_RISCV_SUB16",
+ R_RISCV_SUB32 => "R_RISCV_SUB32",
+ R_RISCV_SUB64 => "R_RISCV_SUB64",
+ R_RISCV_GNU_VTINHERIT => "R_RISCV_GNU_VTINHERIT",
+ R_RISCV_GNU_VTENTRY => "R_RISCV_GNU_VTENTRY",
+ R_RISCV_ALIGN => "R_RISCV_ALIGN",
+ R_RISCV_RVC_BRANCH => "R_RISCV_RVC_BRANCH",
+ R_RISCV_RVC_JUMP => "R_RISCV_RVC_JUMP",
+ R_RISCV_RVC_LUI => "R_RISCV_RVC_LUI",
+ R_RISCV_GPREL_I => "R_RISCV_GPREL_I",
+ R_RISCV_GPREL_S => "R_RISCV_GPREL_S",
+ R_RISCV_TPREL_I => "R_RISCV_TPREL_I",
+ R_RISCV_TPREL_S => "R_RISCV_TPREL_S",
+ R_RISCV_RELAX => "R_RISCV_RELAX",
+ R_RISCV_SUB6 => "R_RISCV_SUB6",
+ R_RISCV_SET6 => "R_RISCV_SET6",
+ R_RISCV_SET8 => "R_RISCV_SET8",
+ R_RISCV_SET16 => "R_RISCV_SET16",
+ R_RISCV_SET32 => "R_RISCV_SET32",
+ _ => "R_UNKNOWN_RISCV",
+ }},
+ _ => "R_UNKNOWN",
+ }
+}