Source code
Revision control
Copy as Markdown
Other Tools
// 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
///////////////////
/// 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",
}
}