...

Source file src/debug/elf/elf.go

     1	/*
     2	 * ELF constants and data structures
     3	 *
     4	 * Derived from:
     5	 * $FreeBSD: src/sys/sys/elf32.h,v 1.8.14.1 2005/12/30 22:13:58 marcel Exp $
     6	 * $FreeBSD: src/sys/sys/elf64.h,v 1.10.14.1 2005/12/30 22:13:58 marcel Exp $
     7	 * $FreeBSD: src/sys/sys/elf_common.h,v 1.15.8.1 2005/12/30 22:13:58 marcel Exp $
     8	 * $FreeBSD: src/sys/alpha/include/elf.h,v 1.14 2003/09/25 01:10:22 peter Exp $
     9	 * $FreeBSD: src/sys/amd64/include/elf.h,v 1.18 2004/08/03 08:21:48 dfr Exp $
    10	 * $FreeBSD: src/sys/arm/include/elf.h,v 1.5.2.1 2006/06/30 21:42:52 cognet Exp $
    11	 * $FreeBSD: src/sys/i386/include/elf.h,v 1.16 2004/08/02 19:12:17 dfr Exp $
    12	 * $FreeBSD: src/sys/powerpc/include/elf.h,v 1.7 2004/11/02 09:47:01 ssouhlal Exp $
    13	 * $FreeBSD: src/sys/sparc64/include/elf.h,v 1.12 2003/09/25 01:10:26 peter Exp $
    14	 * "System V ABI" (http://www.sco.com/developers/gabi/latest/ch4.eheader.html)
    15	 * "ELF for the ARM® 64-bit Architecture (AArch64)" (ARM IHI 0056B)
    16	 * "RISC-V ELF psABI specification" (https://github.com/riscv/riscv-elf-psabi-doc/blob/master/riscv-elf.md)
    17	 * llvm/BinaryFormat/ELF.h - ELF constants and structures
    18	 *
    19	 * Copyright (c) 1996-1998 John D. Polstra.  All rights reserved.
    20	 * Copyright (c) 2001 David E. O'Brien
    21	 * Portions Copyright 2009 The Go Authors. All rights reserved.
    22	 *
    23	 * Redistribution and use in source and binary forms, with or without
    24	 * modification, are permitted provided that the following conditions
    25	 * are met:
    26	 * 1. Redistributions of source code must retain the above copyright
    27	 *    notice, this list of conditions and the following disclaimer.
    28	 * 2. Redistributions in binary form must reproduce the above copyright
    29	 *    notice, this list of conditions and the following disclaimer in the
    30	 *    documentation and/or other materials provided with the distribution.
    31	 *
    32	 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
    33	 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
    34	 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
    35	 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
    36	 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
    37	 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
    38	 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
    39	 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
    40	 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
    41	 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
    42	 * SUCH DAMAGE.
    43	 */
    44	
    45	package elf
    46	
    47	import "strconv"
    48	
    49	/*
    50	 * Constants
    51	 */
    52	
    53	// Indexes into the Header.Ident array.
    54	const (
    55		EI_CLASS      = 4  /* Class of machine. */
    56		EI_DATA       = 5  /* Data format. */
    57		EI_VERSION    = 6  /* ELF format version. */
    58		EI_OSABI      = 7  /* Operating system / ABI identification */
    59		EI_ABIVERSION = 8  /* ABI version */
    60		EI_PAD        = 9  /* Start of padding (per SVR4 ABI). */
    61		EI_NIDENT     = 16 /* Size of e_ident array. */
    62	)
    63	
    64	// Initial magic number for ELF files.
    65	const ELFMAG = "\177ELF"
    66	
    67	// Version is found in Header.Ident[EI_VERSION] and Header.Version.
    68	type Version byte
    69	
    70	const (
    71		EV_NONE    Version = 0
    72		EV_CURRENT Version = 1
    73	)
    74	
    75	var versionStrings = []intName{
    76		{0, "EV_NONE"},
    77		{1, "EV_CURRENT"},
    78	}
    79	
    80	func (i Version) String() string   { return stringName(uint32(i), versionStrings, false) }
    81	func (i Version) GoString() string { return stringName(uint32(i), versionStrings, true) }
    82	
    83	// Class is found in Header.Ident[EI_CLASS] and Header.Class.
    84	type Class byte
    85	
    86	const (
    87		ELFCLASSNONE Class = 0 /* Unknown class. */
    88		ELFCLASS32   Class = 1 /* 32-bit architecture. */
    89		ELFCLASS64   Class = 2 /* 64-bit architecture. */
    90	)
    91	
    92	var classStrings = []intName{
    93		{0, "ELFCLASSNONE"},
    94		{1, "ELFCLASS32"},
    95		{2, "ELFCLASS64"},
    96	}
    97	
    98	func (i Class) String() string   { return stringName(uint32(i), classStrings, false) }
    99	func (i Class) GoString() string { return stringName(uint32(i), classStrings, true) }
   100	
   101	// Data is found in Header.Ident[EI_DATA] and Header.Data.
   102	type Data byte
   103	
   104	const (
   105		ELFDATANONE Data = 0 /* Unknown data format. */
   106		ELFDATA2LSB Data = 1 /* 2's complement little-endian. */
   107		ELFDATA2MSB Data = 2 /* 2's complement big-endian. */
   108	)
   109	
   110	var dataStrings = []intName{
   111		{0, "ELFDATANONE"},
   112		{1, "ELFDATA2LSB"},
   113		{2, "ELFDATA2MSB"},
   114	}
   115	
   116	func (i Data) String() string   { return stringName(uint32(i), dataStrings, false) }
   117	func (i Data) GoString() string { return stringName(uint32(i), dataStrings, true) }
   118	
   119	// OSABI is found in Header.Ident[EI_OSABI] and Header.OSABI.
   120	type OSABI byte
   121	
   122	const (
   123		ELFOSABI_NONE       OSABI = 0   /* UNIX System V ABI */
   124		ELFOSABI_HPUX       OSABI = 1   /* HP-UX operating system */
   125		ELFOSABI_NETBSD     OSABI = 2   /* NetBSD */
   126		ELFOSABI_LINUX      OSABI = 3   /* GNU/Linux */
   127		ELFOSABI_HURD       OSABI = 4   /* GNU/Hurd */
   128		ELFOSABI_86OPEN     OSABI = 5   /* 86Open common IA32 ABI */
   129		ELFOSABI_SOLARIS    OSABI = 6   /* Solaris */
   130		ELFOSABI_AIX        OSABI = 7   /* AIX */
   131		ELFOSABI_IRIX       OSABI = 8   /* IRIX */
   132		ELFOSABI_FREEBSD    OSABI = 9   /* FreeBSD */
   133		ELFOSABI_TRU64      OSABI = 10  /* TRU64 UNIX */
   134		ELFOSABI_MODESTO    OSABI = 11  /* Novell Modesto */
   135		ELFOSABI_OPENBSD    OSABI = 12  /* OpenBSD */
   136		ELFOSABI_OPENVMS    OSABI = 13  /* Open VMS */
   137		ELFOSABI_NSK        OSABI = 14  /* HP Non-Stop Kernel */
   138		ELFOSABI_AROS       OSABI = 15  /* Amiga Research OS */
   139		ELFOSABI_FENIXOS    OSABI = 16  /* The FenixOS highly scalable multi-core OS */
   140		ELFOSABI_CLOUDABI   OSABI = 17  /* Nuxi CloudABI */
   141		ELFOSABI_ARM        OSABI = 97  /* ARM */
   142		ELFOSABI_STANDALONE OSABI = 255 /* Standalone (embedded) application */
   143	)
   144	
   145	var osabiStrings = []intName{
   146		{0, "ELFOSABI_NONE"},
   147		{1, "ELFOSABI_HPUX"},
   148		{2, "ELFOSABI_NETBSD"},
   149		{3, "ELFOSABI_LINUX"},
   150		{4, "ELFOSABI_HURD"},
   151		{5, "ELFOSABI_86OPEN"},
   152		{6, "ELFOSABI_SOLARIS"},
   153		{7, "ELFOSABI_AIX"},
   154		{8, "ELFOSABI_IRIX"},
   155		{9, "ELFOSABI_FREEBSD"},
   156		{10, "ELFOSABI_TRU64"},
   157		{11, "ELFOSABI_MODESTO"},
   158		{12, "ELFOSABI_OPENBSD"},
   159		{13, "ELFOSABI_OPENVMS"},
   160		{14, "ELFOSABI_NSK"},
   161		{15, "ELFOSABI_AROS"},
   162		{16, "ELFOSABI_FENIXOS"},
   163		{17, "ELFOSABI_CLOUDABI"},
   164		{97, "ELFOSABI_ARM"},
   165		{255, "ELFOSABI_STANDALONE"},
   166	}
   167	
   168	func (i OSABI) String() string   { return stringName(uint32(i), osabiStrings, false) }
   169	func (i OSABI) GoString() string { return stringName(uint32(i), osabiStrings, true) }
   170	
   171	// Type is found in Header.Type.
   172	type Type uint16
   173	
   174	const (
   175		ET_NONE   Type = 0      /* Unknown type. */
   176		ET_REL    Type = 1      /* Relocatable. */
   177		ET_EXEC   Type = 2      /* Executable. */
   178		ET_DYN    Type = 3      /* Shared object. */
   179		ET_CORE   Type = 4      /* Core file. */
   180		ET_LOOS   Type = 0xfe00 /* First operating system specific. */
   181		ET_HIOS   Type = 0xfeff /* Last operating system-specific. */
   182		ET_LOPROC Type = 0xff00 /* First processor-specific. */
   183		ET_HIPROC Type = 0xffff /* Last processor-specific. */
   184	)
   185	
   186	var typeStrings = []intName{
   187		{0, "ET_NONE"},
   188		{1, "ET_REL"},
   189		{2, "ET_EXEC"},
   190		{3, "ET_DYN"},
   191		{4, "ET_CORE"},
   192		{0xfe00, "ET_LOOS"},
   193		{0xfeff, "ET_HIOS"},
   194		{0xff00, "ET_LOPROC"},
   195		{0xffff, "ET_HIPROC"},
   196	}
   197	
   198	func (i Type) String() string   { return stringName(uint32(i), typeStrings, false) }
   199	func (i Type) GoString() string { return stringName(uint32(i), typeStrings, true) }
   200	
   201	// Machine is found in Header.Machine.
   202	type Machine uint16
   203	
   204	const (
   205		EM_NONE          Machine = 0   /* Unknown machine. */
   206		EM_M32           Machine = 1   /* AT&T WE32100. */
   207		EM_SPARC         Machine = 2   /* Sun SPARC. */
   208		EM_386           Machine = 3   /* Intel i386. */
   209		EM_68K           Machine = 4   /* Motorola 68000. */
   210		EM_88K           Machine = 5   /* Motorola 88000. */
   211		EM_860           Machine = 7   /* Intel i860. */
   212		EM_MIPS          Machine = 8   /* MIPS R3000 Big-Endian only. */
   213		EM_S370          Machine = 9   /* IBM System/370. */
   214		EM_MIPS_RS3_LE   Machine = 10  /* MIPS R3000 Little-Endian. */
   215		EM_PARISC        Machine = 15  /* HP PA-RISC. */
   216		EM_VPP500        Machine = 17  /* Fujitsu VPP500. */
   217		EM_SPARC32PLUS   Machine = 18  /* SPARC v8plus. */
   218		EM_960           Machine = 19  /* Intel 80960. */
   219		EM_PPC           Machine = 20  /* PowerPC 32-bit. */
   220		EM_PPC64         Machine = 21  /* PowerPC 64-bit. */
   221		EM_S390          Machine = 22  /* IBM System/390. */
   222		EM_V800          Machine = 36  /* NEC V800. */
   223		EM_FR20          Machine = 37  /* Fujitsu FR20. */
   224		EM_RH32          Machine = 38  /* TRW RH-32. */
   225		EM_RCE           Machine = 39  /* Motorola RCE. */
   226		EM_ARM           Machine = 40  /* ARM. */
   227		EM_SH            Machine = 42  /* Hitachi SH. */
   228		EM_SPARCV9       Machine = 43  /* SPARC v9 64-bit. */
   229		EM_TRICORE       Machine = 44  /* Siemens TriCore embedded processor. */
   230		EM_ARC           Machine = 45  /* Argonaut RISC Core. */
   231		EM_H8_300        Machine = 46  /* Hitachi H8/300. */
   232		EM_H8_300H       Machine = 47  /* Hitachi H8/300H. */
   233		EM_H8S           Machine = 48  /* Hitachi H8S. */
   234		EM_H8_500        Machine = 49  /* Hitachi H8/500. */
   235		EM_IA_64         Machine = 50  /* Intel IA-64 Processor. */
   236		EM_MIPS_X        Machine = 51  /* Stanford MIPS-X. */
   237		EM_COLDFIRE      Machine = 52  /* Motorola ColdFire. */
   238		EM_68HC12        Machine = 53  /* Motorola M68HC12. */
   239		EM_MMA           Machine = 54  /* Fujitsu MMA. */
   240		EM_PCP           Machine = 55  /* Siemens PCP. */
   241		EM_NCPU          Machine = 56  /* Sony nCPU. */
   242		EM_NDR1          Machine = 57  /* Denso NDR1 microprocessor. */
   243		EM_STARCORE      Machine = 58  /* Motorola Star*Core processor. */
   244		EM_ME16          Machine = 59  /* Toyota ME16 processor. */
   245		EM_ST100         Machine = 60  /* STMicroelectronics ST100 processor. */
   246		EM_TINYJ         Machine = 61  /* Advanced Logic Corp. TinyJ processor. */
   247		EM_X86_64        Machine = 62  /* Advanced Micro Devices x86-64 */
   248		EM_PDSP          Machine = 63  /* Sony DSP Processor */
   249		EM_PDP10         Machine = 64  /* Digital Equipment Corp. PDP-10 */
   250		EM_PDP11         Machine = 65  /* Digital Equipment Corp. PDP-11 */
   251		EM_FX66          Machine = 66  /* Siemens FX66 microcontroller */
   252		EM_ST9PLUS       Machine = 67  /* STMicroelectronics ST9+ 8/16 bit microcontroller */
   253		EM_ST7           Machine = 68  /* STMicroelectronics ST7 8-bit microcontroller */
   254		EM_68HC16        Machine = 69  /* Motorola MC68HC16 Microcontroller */
   255		EM_68HC11        Machine = 70  /* Motorola MC68HC11 Microcontroller */
   256		EM_68HC08        Machine = 71  /* Motorola MC68HC08 Microcontroller */
   257		EM_68HC05        Machine = 72  /* Motorola MC68HC05 Microcontroller */
   258		EM_SVX           Machine = 73  /* Silicon Graphics SVx */
   259		EM_ST19          Machine = 74  /* STMicroelectronics ST19 8-bit microcontroller */
   260		EM_VAX           Machine = 75  /* Digital VAX */
   261		EM_CRIS          Machine = 76  /* Axis Communications 32-bit embedded processor */
   262		EM_JAVELIN       Machine = 77  /* Infineon Technologies 32-bit embedded processor */
   263		EM_FIREPATH      Machine = 78  /* Element 14 64-bit DSP Processor */
   264		EM_ZSP           Machine = 79  /* LSI Logic 16-bit DSP Processor */
   265		EM_MMIX          Machine = 80  /* Donald Knuth's educational 64-bit processor */
   266		EM_HUANY         Machine = 81  /* Harvard University machine-independent object files */
   267		EM_PRISM         Machine = 82  /* SiTera Prism */
   268		EM_AVR           Machine = 83  /* Atmel AVR 8-bit microcontroller */
   269		EM_FR30          Machine = 84  /* Fujitsu FR30 */
   270		EM_D10V          Machine = 85  /* Mitsubishi D10V */
   271		EM_D30V          Machine = 86  /* Mitsubishi D30V */
   272		EM_V850          Machine = 87  /* NEC v850 */
   273		EM_M32R          Machine = 88  /* Mitsubishi M32R */
   274		EM_MN10300       Machine = 89  /* Matsushita MN10300 */
   275		EM_MN10200       Machine = 90  /* Matsushita MN10200 */
   276		EM_PJ            Machine = 91  /* picoJava */
   277		EM_OPENRISC      Machine = 92  /* OpenRISC 32-bit embedded processor */
   278		EM_ARC_COMPACT   Machine = 93  /* ARC International ARCompact processor (old spelling/synonym: EM_ARC_A5) */
   279		EM_XTENSA        Machine = 94  /* Tensilica Xtensa Architecture */
   280		EM_VIDEOCORE     Machine = 95  /* Alphamosaic VideoCore processor */
   281		EM_TMM_GPP       Machine = 96  /* Thompson Multimedia General Purpose Processor */
   282		EM_NS32K         Machine = 97  /* National Semiconductor 32000 series */
   283		EM_TPC           Machine = 98  /* Tenor Network TPC processor */
   284		EM_SNP1K         Machine = 99  /* Trebia SNP 1000 processor */
   285		EM_ST200         Machine = 100 /* STMicroelectronics (www.st.com) ST200 microcontroller */
   286		EM_IP2K          Machine = 101 /* Ubicom IP2xxx microcontroller family */
   287		EM_MAX           Machine = 102 /* MAX Processor */
   288		EM_CR            Machine = 103 /* National Semiconductor CompactRISC microprocessor */
   289		EM_F2MC16        Machine = 104 /* Fujitsu F2MC16 */
   290		EM_MSP430        Machine = 105 /* Texas Instruments embedded microcontroller msp430 */
   291		EM_BLACKFIN      Machine = 106 /* Analog Devices Blackfin (DSP) processor */
   292		EM_SE_C33        Machine = 107 /* S1C33 Family of Seiko Epson processors */
   293		EM_SEP           Machine = 108 /* Sharp embedded microprocessor */
   294		EM_ARCA          Machine = 109 /* Arca RISC Microprocessor */
   295		EM_UNICORE       Machine = 110 /* Microprocessor series from PKU-Unity Ltd. and MPRC of Peking University */
   296		EM_EXCESS        Machine = 111 /* eXcess: 16/32/64-bit configurable embedded CPU */
   297		EM_DXP           Machine = 112 /* Icera Semiconductor Inc. Deep Execution Processor */
   298		EM_ALTERA_NIOS2  Machine = 113 /* Altera Nios II soft-core processor */
   299		EM_CRX           Machine = 114 /* National Semiconductor CompactRISC CRX microprocessor */
   300		EM_XGATE         Machine = 115 /* Motorola XGATE embedded processor */
   301		EM_C166          Machine = 116 /* Infineon C16x/XC16x processor */
   302		EM_M16C          Machine = 117 /* Renesas M16C series microprocessors */
   303		EM_DSPIC30F      Machine = 118 /* Microchip Technology dsPIC30F Digital Signal Controller */
   304		EM_CE            Machine = 119 /* Freescale Communication Engine RISC core */
   305		EM_M32C          Machine = 120 /* Renesas M32C series microprocessors */
   306		EM_TSK3000       Machine = 131 /* Altium TSK3000 core */
   307		EM_RS08          Machine = 132 /* Freescale RS08 embedded processor */
   308		EM_SHARC         Machine = 133 /* Analog Devices SHARC family of 32-bit DSP processors */
   309		EM_ECOG2         Machine = 134 /* Cyan Technology eCOG2 microprocessor */
   310		EM_SCORE7        Machine = 135 /* Sunplus S+core7 RISC processor */
   311		EM_DSP24         Machine = 136 /* New Japan Radio (NJR) 24-bit DSP Processor */
   312		EM_VIDEOCORE3    Machine = 137 /* Broadcom VideoCore III processor */
   313		EM_LATTICEMICO32 Machine = 138 /* RISC processor for Lattice FPGA architecture */
   314		EM_SE_C17        Machine = 139 /* Seiko Epson C17 family */
   315		EM_TI_C6000      Machine = 140 /* The Texas Instruments TMS320C6000 DSP family */
   316		EM_TI_C2000      Machine = 141 /* The Texas Instruments TMS320C2000 DSP family */
   317		EM_TI_C5500      Machine = 142 /* The Texas Instruments TMS320C55x DSP family */
   318		EM_TI_ARP32      Machine = 143 /* Texas Instruments Application Specific RISC Processor, 32bit fetch */
   319		EM_TI_PRU        Machine = 144 /* Texas Instruments Programmable Realtime Unit */
   320		EM_MMDSP_PLUS    Machine = 160 /* STMicroelectronics 64bit VLIW Data Signal Processor */
   321		EM_CYPRESS_M8C   Machine = 161 /* Cypress M8C microprocessor */
   322		EM_R32C          Machine = 162 /* Renesas R32C series microprocessors */
   323		EM_TRIMEDIA      Machine = 163 /* NXP Semiconductors TriMedia architecture family */
   324		EM_QDSP6         Machine = 164 /* QUALCOMM DSP6 Processor */
   325		EM_8051          Machine = 165 /* Intel 8051 and variants */
   326		EM_STXP7X        Machine = 166 /* STMicroelectronics STxP7x family of configurable and extensible RISC processors */
   327		EM_NDS32         Machine = 167 /* Andes Technology compact code size embedded RISC processor family */
   328		EM_ECOG1         Machine = 168 /* Cyan Technology eCOG1X family */
   329		EM_ECOG1X        Machine = 168 /* Cyan Technology eCOG1X family */
   330		EM_MAXQ30        Machine = 169 /* Dallas Semiconductor MAXQ30 Core Micro-controllers */
   331		EM_XIMO16        Machine = 170 /* New Japan Radio (NJR) 16-bit DSP Processor */
   332		EM_MANIK         Machine = 171 /* M2000 Reconfigurable RISC Microprocessor */
   333		EM_CRAYNV2       Machine = 172 /* Cray Inc. NV2 vector architecture */
   334		EM_RX            Machine = 173 /* Renesas RX family */
   335		EM_METAG         Machine = 174 /* Imagination Technologies META processor architecture */
   336		EM_MCST_ELBRUS   Machine = 175 /* MCST Elbrus general purpose hardware architecture */
   337		EM_ECOG16        Machine = 176 /* Cyan Technology eCOG16 family */
   338		EM_CR16          Machine = 177 /* National Semiconductor CompactRISC CR16 16-bit microprocessor */
   339		EM_ETPU          Machine = 178 /* Freescale Extended Time Processing Unit */
   340		EM_SLE9X         Machine = 179 /* Infineon Technologies SLE9X core */
   341		EM_L10M          Machine = 180 /* Intel L10M */
   342		EM_K10M          Machine = 181 /* Intel K10M */
   343		EM_AARCH64       Machine = 183 /* ARM 64-bit Architecture (AArch64) */
   344		EM_AVR32         Machine = 185 /* Atmel Corporation 32-bit microprocessor family */
   345		EM_STM8          Machine = 186 /* STMicroeletronics STM8 8-bit microcontroller */
   346		EM_TILE64        Machine = 187 /* Tilera TILE64 multicore architecture family */
   347		EM_TILEPRO       Machine = 188 /* Tilera TILEPro multicore architecture family */
   348		EM_MICROBLAZE    Machine = 189 /* Xilinx MicroBlaze 32-bit RISC soft processor core */
   349		EM_CUDA          Machine = 190 /* NVIDIA CUDA architecture */
   350		EM_TILEGX        Machine = 191 /* Tilera TILE-Gx multicore architecture family */
   351		EM_CLOUDSHIELD   Machine = 192 /* CloudShield architecture family */
   352		EM_COREA_1ST     Machine = 193 /* KIPO-KAIST Core-A 1st generation processor family */
   353		EM_COREA_2ND     Machine = 194 /* KIPO-KAIST Core-A 2nd generation processor family */
   354		EM_ARC_COMPACT2  Machine = 195 /* Synopsys ARCompact V2 */
   355		EM_OPEN8         Machine = 196 /* Open8 8-bit RISC soft processor core */
   356		EM_RL78          Machine = 197 /* Renesas RL78 family */
   357		EM_VIDEOCORE5    Machine = 198 /* Broadcom VideoCore V processor */
   358		EM_78KOR         Machine = 199 /* Renesas 78KOR family */
   359		EM_56800EX       Machine = 200 /* Freescale 56800EX Digital Signal Controller (DSC) */
   360		EM_BA1           Machine = 201 /* Beyond BA1 CPU architecture */
   361		EM_BA2           Machine = 202 /* Beyond BA2 CPU architecture */
   362		EM_XCORE         Machine = 203 /* XMOS xCORE processor family */
   363		EM_MCHP_PIC      Machine = 204 /* Microchip 8-bit PIC(r) family */
   364		EM_INTEL205      Machine = 205 /* Reserved by Intel */
   365		EM_INTEL206      Machine = 206 /* Reserved by Intel */
   366		EM_INTEL207      Machine = 207 /* Reserved by Intel */
   367		EM_INTEL208      Machine = 208 /* Reserved by Intel */
   368		EM_INTEL209      Machine = 209 /* Reserved by Intel */
   369		EM_KM32          Machine = 210 /* KM211 KM32 32-bit processor */
   370		EM_KMX32         Machine = 211 /* KM211 KMX32 32-bit processor */
   371		EM_KMX16         Machine = 212 /* KM211 KMX16 16-bit processor */
   372		EM_KMX8          Machine = 213 /* KM211 KMX8 8-bit processor */
   373		EM_KVARC         Machine = 214 /* KM211 KVARC processor */
   374		EM_CDP           Machine = 215 /* Paneve CDP architecture family */
   375		EM_COGE          Machine = 216 /* Cognitive Smart Memory Processor */
   376		EM_COOL          Machine = 217 /* Bluechip Systems CoolEngine */
   377		EM_NORC          Machine = 218 /* Nanoradio Optimized RISC */
   378		EM_CSR_KALIMBA   Machine = 219 /* CSR Kalimba architecture family */
   379		EM_Z80           Machine = 220 /* Zilog Z80 */
   380		EM_VISIUM        Machine = 221 /* Controls and Data Services VISIUMcore processor */
   381		EM_FT32          Machine = 222 /* FTDI Chip FT32 high performance 32-bit RISC architecture */
   382		EM_MOXIE         Machine = 223 /* Moxie processor family */
   383		EM_AMDGPU        Machine = 224 /* AMD GPU architecture */
   384		EM_RISCV         Machine = 243 /* RISC-V */
   385		EM_LANAI         Machine = 244 /* Lanai 32-bit processor */
   386		EM_BPF           Machine = 247 /* Linux BPF – in-kernel virtual machine */
   387	
   388		/* Non-standard or deprecated. */
   389		EM_486         Machine = 6      /* Intel i486. */
   390		EM_MIPS_RS4_BE Machine = 10     /* MIPS R4000 Big-Endian */
   391		EM_ALPHA_STD   Machine = 41     /* Digital Alpha (standard value). */
   392		EM_ALPHA       Machine = 0x9026 /* Alpha (written in the absence of an ABI) */
   393	)
   394	
   395	var machineStrings = []intName{
   396		{0, "EM_NONE"},
   397		{1, "EM_M32"},
   398		{2, "EM_SPARC"},
   399		{3, "EM_386"},
   400		{4, "EM_68K"},
   401		{5, "EM_88K"},
   402		{7, "EM_860"},
   403		{8, "EM_MIPS"},
   404		{9, "EM_S370"},
   405		{10, "EM_MIPS_RS3_LE"},
   406		{15, "EM_PARISC"},
   407		{17, "EM_VPP500"},
   408		{18, "EM_SPARC32PLUS"},
   409		{19, "EM_960"},
   410		{20, "EM_PPC"},
   411		{21, "EM_PPC64"},
   412		{22, "EM_S390"},
   413		{36, "EM_V800"},
   414		{37, "EM_FR20"},
   415		{38, "EM_RH32"},
   416		{39, "EM_RCE"},
   417		{40, "EM_ARM"},
   418		{42, "EM_SH"},
   419		{43, "EM_SPARCV9"},
   420		{44, "EM_TRICORE"},
   421		{45, "EM_ARC"},
   422		{46, "EM_H8_300"},
   423		{47, "EM_H8_300H"},
   424		{48, "EM_H8S"},
   425		{49, "EM_H8_500"},
   426		{50, "EM_IA_64"},
   427		{51, "EM_MIPS_X"},
   428		{52, "EM_COLDFIRE"},
   429		{53, "EM_68HC12"},
   430		{54, "EM_MMA"},
   431		{55, "EM_PCP"},
   432		{56, "EM_NCPU"},
   433		{57, "EM_NDR1"},
   434		{58, "EM_STARCORE"},
   435		{59, "EM_ME16"},
   436		{60, "EM_ST100"},
   437		{61, "EM_TINYJ"},
   438		{62, "EM_X86_64"},
   439		{63, "EM_PDSP"},
   440		{64, "EM_PDP10"},
   441		{65, "EM_PDP11"},
   442		{66, "EM_FX66"},
   443		{67, "EM_ST9PLUS"},
   444		{68, "EM_ST7"},
   445		{69, "EM_68HC16"},
   446		{70, "EM_68HC11"},
   447		{71, "EM_68HC08"},
   448		{72, "EM_68HC05"},
   449		{73, "EM_SVX"},
   450		{74, "EM_ST19"},
   451		{75, "EM_VAX"},
   452		{76, "EM_CRIS"},
   453		{77, "EM_JAVELIN"},
   454		{78, "EM_FIREPATH"},
   455		{79, "EM_ZSP"},
   456		{80, "EM_MMIX"},
   457		{81, "EM_HUANY"},
   458		{82, "EM_PRISM"},
   459		{83, "EM_AVR"},
   460		{84, "EM_FR30"},
   461		{85, "EM_D10V"},
   462		{86, "EM_D30V"},
   463		{87, "EM_V850"},
   464		{88, "EM_M32R"},
   465		{89, "EM_MN10300"},
   466		{90, "EM_MN10200"},
   467		{91, "EM_PJ"},
   468		{92, "EM_OPENRISC"},
   469		{93, "EM_ARC_COMPACT"},
   470		{94, "EM_XTENSA"},
   471		{95, "EM_VIDEOCORE"},
   472		{96, "EM_TMM_GPP"},
   473		{97, "EM_NS32K"},
   474		{98, "EM_TPC"},
   475		{99, "EM_SNP1K"},
   476		{100, "EM_ST200"},
   477		{101, "EM_IP2K"},
   478		{102, "EM_MAX"},
   479		{103, "EM_CR"},
   480		{104, "EM_F2MC16"},
   481		{105, "EM_MSP430"},
   482		{106, "EM_BLACKFIN"},
   483		{107, "EM_SE_C33"},
   484		{108, "EM_SEP"},
   485		{109, "EM_ARCA"},
   486		{110, "EM_UNICORE"},
   487		{111, "EM_EXCESS"},
   488		{112, "EM_DXP"},
   489		{113, "EM_ALTERA_NIOS2"},
   490		{114, "EM_CRX"},
   491		{115, "EM_XGATE"},
   492		{116, "EM_C166"},
   493		{117, "EM_M16C"},
   494		{118, "EM_DSPIC30F"},
   495		{119, "EM_CE"},
   496		{120, "EM_M32C"},
   497		{131, "EM_TSK3000"},
   498		{132, "EM_RS08"},
   499		{133, "EM_SHARC"},
   500		{134, "EM_ECOG2"},
   501		{135, "EM_SCORE7"},
   502		{136, "EM_DSP24"},
   503		{137, "EM_VIDEOCORE3"},
   504		{138, "EM_LATTICEMICO32"},
   505		{139, "EM_SE_C17"},
   506		{140, "EM_TI_C6000"},
   507		{141, "EM_TI_C2000"},
   508		{142, "EM_TI_C5500"},
   509		{143, "EM_TI_ARP32"},
   510		{144, "EM_TI_PRU"},
   511		{160, "EM_MMDSP_PLUS"},
   512		{161, "EM_CYPRESS_M8C"},
   513		{162, "EM_R32C"},
   514		{163, "EM_TRIMEDIA"},
   515		{164, "EM_QDSP6"},
   516		{165, "EM_8051"},
   517		{166, "EM_STXP7X"},
   518		{167, "EM_NDS32"},
   519		{168, "EM_ECOG1"},
   520		{168, "EM_ECOG1X"},
   521		{169, "EM_MAXQ30"},
   522		{170, "EM_XIMO16"},
   523		{171, "EM_MANIK"},
   524		{172, "EM_CRAYNV2"},
   525		{173, "EM_RX"},
   526		{174, "EM_METAG"},
   527		{175, "EM_MCST_ELBRUS"},
   528		{176, "EM_ECOG16"},
   529		{177, "EM_CR16"},
   530		{178, "EM_ETPU"},
   531		{179, "EM_SLE9X"},
   532		{180, "EM_L10M"},
   533		{181, "EM_K10M"},
   534		{183, "EM_AARCH64"},
   535		{185, "EM_AVR32"},
   536		{186, "EM_STM8"},
   537		{187, "EM_TILE64"},
   538		{188, "EM_TILEPRO"},
   539		{189, "EM_MICROBLAZE"},
   540		{190, "EM_CUDA"},
   541		{191, "EM_TILEGX"},
   542		{192, "EM_CLOUDSHIELD"},
   543		{193, "EM_COREA_1ST"},
   544		{194, "EM_COREA_2ND"},
   545		{195, "EM_ARC_COMPACT2"},
   546		{196, "EM_OPEN8"},
   547		{197, "EM_RL78"},
   548		{198, "EM_VIDEOCORE5"},
   549		{199, "EM_78KOR"},
   550		{200, "EM_56800EX"},
   551		{201, "EM_BA1"},
   552		{202, "EM_BA2"},
   553		{203, "EM_XCORE"},
   554		{204, "EM_MCHP_PIC"},
   555		{205, "EM_INTEL205"},
   556		{206, "EM_INTEL206"},
   557		{207, "EM_INTEL207"},
   558		{208, "EM_INTEL208"},
   559		{209, "EM_INTEL209"},
   560		{210, "EM_KM32"},
   561		{211, "EM_KMX32"},
   562		{212, "EM_KMX16"},
   563		{213, "EM_KMX8"},
   564		{214, "EM_KVARC"},
   565		{215, "EM_CDP"},
   566		{216, "EM_COGE"},
   567		{217, "EM_COOL"},
   568		{218, "EM_NORC"},
   569		{219, "EM_CSR_KALIMBA "},
   570		{220, "EM_Z80 "},
   571		{221, "EM_VISIUM "},
   572		{222, "EM_FT32 "},
   573		{223, "EM_MOXIE"},
   574		{224, "EM_AMDGPU"},
   575		{243, "EM_RISCV"},
   576		{244, "EM_LANAI"},
   577		{247, "EM_BPF"},
   578	
   579		/* Non-standard or deprecated. */
   580		{6, "EM_486"},
   581		{10, "EM_MIPS_RS4_BE"},
   582		{41, "EM_ALPHA_STD"},
   583		{0x9026, "EM_ALPHA"},
   584	}
   585	
   586	func (i Machine) String() string   { return stringName(uint32(i), machineStrings, false) }
   587	func (i Machine) GoString() string { return stringName(uint32(i), machineStrings, true) }
   588	
   589	// Special section indices.
   590	type SectionIndex int
   591	
   592	const (
   593		SHN_UNDEF     SectionIndex = 0      /* Undefined, missing, irrelevant. */
   594		SHN_LORESERVE SectionIndex = 0xff00 /* First of reserved range. */
   595		SHN_LOPROC    SectionIndex = 0xff00 /* First processor-specific. */
   596		SHN_HIPROC    SectionIndex = 0xff1f /* Last processor-specific. */
   597		SHN_LOOS      SectionIndex = 0xff20 /* First operating system-specific. */
   598		SHN_HIOS      SectionIndex = 0xff3f /* Last operating system-specific. */
   599		SHN_ABS       SectionIndex = 0xfff1 /* Absolute values. */
   600		SHN_COMMON    SectionIndex = 0xfff2 /* Common data. */
   601		SHN_XINDEX    SectionIndex = 0xffff /* Escape; index stored elsewhere. */
   602		SHN_HIRESERVE SectionIndex = 0xffff /* Last of reserved range. */
   603	)
   604	
   605	var shnStrings = []intName{
   606		{0, "SHN_UNDEF"},
   607		{0xff00, "SHN_LOPROC"},
   608		{0xff20, "SHN_LOOS"},
   609		{0xfff1, "SHN_ABS"},
   610		{0xfff2, "SHN_COMMON"},
   611		{0xffff, "SHN_XINDEX"},
   612	}
   613	
   614	func (i SectionIndex) String() string   { return stringName(uint32(i), shnStrings, false) }
   615	func (i SectionIndex) GoString() string { return stringName(uint32(i), shnStrings, true) }
   616	
   617	// Section type.
   618	type SectionType uint32
   619	
   620	const (
   621		SHT_NULL           SectionType = 0          /* inactive */
   622		SHT_PROGBITS       SectionType = 1          /* program defined information */
   623		SHT_SYMTAB         SectionType = 2          /* symbol table section */
   624		SHT_STRTAB         SectionType = 3          /* string table section */
   625		SHT_RELA           SectionType = 4          /* relocation section with addends */
   626		SHT_HASH           SectionType = 5          /* symbol hash table section */
   627		SHT_DYNAMIC        SectionType = 6          /* dynamic section */
   628		SHT_NOTE           SectionType = 7          /* note section */
   629		SHT_NOBITS         SectionType = 8          /* no space section */
   630		SHT_REL            SectionType = 9          /* relocation section - no addends */
   631		SHT_SHLIB          SectionType = 10         /* reserved - purpose unknown */
   632		SHT_DYNSYM         SectionType = 11         /* dynamic symbol table section */
   633		SHT_INIT_ARRAY     SectionType = 14         /* Initialization function pointers. */
   634		SHT_FINI_ARRAY     SectionType = 15         /* Termination function pointers. */
   635		SHT_PREINIT_ARRAY  SectionType = 16         /* Pre-initialization function ptrs. */
   636		SHT_GROUP          SectionType = 17         /* Section group. */
   637		SHT_SYMTAB_SHNDX   SectionType = 18         /* Section indexes (see SHN_XINDEX). */
   638		SHT_LOOS           SectionType = 0x60000000 /* First of OS specific semantics */
   639		SHT_GNU_ATTRIBUTES SectionType = 0x6ffffff5 /* GNU object attributes */
   640		SHT_GNU_HASH       SectionType = 0x6ffffff6 /* GNU hash table */
   641		SHT_GNU_LIBLIST    SectionType = 0x6ffffff7 /* GNU prelink library list */
   642		SHT_GNU_VERDEF     SectionType = 0x6ffffffd /* GNU version definition section */
   643		SHT_GNU_VERNEED    SectionType = 0x6ffffffe /* GNU version needs section */
   644		SHT_GNU_VERSYM     SectionType = 0x6fffffff /* GNU version symbol table */
   645		SHT_HIOS           SectionType = 0x6fffffff /* Last of OS specific semantics */
   646		SHT_LOPROC         SectionType = 0x70000000 /* reserved range for processor */
   647		SHT_HIPROC         SectionType = 0x7fffffff /* specific section header types */
   648		SHT_LOUSER         SectionType = 0x80000000 /* reserved range for application */
   649		SHT_HIUSER         SectionType = 0xffffffff /* specific indexes */
   650	)
   651	
   652	var shtStrings = []intName{
   653		{0, "SHT_NULL"},
   654		{1, "SHT_PROGBITS"},
   655		{2, "SHT_SYMTAB"},
   656		{3, "SHT_STRTAB"},
   657		{4, "SHT_RELA"},
   658		{5, "SHT_HASH"},
   659		{6, "SHT_DYNAMIC"},
   660		{7, "SHT_NOTE"},
   661		{8, "SHT_NOBITS"},
   662		{9, "SHT_REL"},
   663		{10, "SHT_SHLIB"},
   664		{11, "SHT_DYNSYM"},
   665		{14, "SHT_INIT_ARRAY"},
   666		{15, "SHT_FINI_ARRAY"},
   667		{16, "SHT_PREINIT_ARRAY"},
   668		{17, "SHT_GROUP"},
   669		{18, "SHT_SYMTAB_SHNDX"},
   670		{0x60000000, "SHT_LOOS"},
   671		{0x6ffffff5, "SHT_GNU_ATTRIBUTES"},
   672		{0x6ffffff6, "SHT_GNU_HASH"},
   673		{0x6ffffff7, "SHT_GNU_LIBLIST"},
   674		{0x6ffffffd, "SHT_GNU_VERDEF"},
   675		{0x6ffffffe, "SHT_GNU_VERNEED"},
   676		{0x6fffffff, "SHT_GNU_VERSYM"},
   677		{0x70000000, "SHT_LOPROC"},
   678		{0x7fffffff, "SHT_HIPROC"},
   679		{0x80000000, "SHT_LOUSER"},
   680		{0xffffffff, "SHT_HIUSER"},
   681	}
   682	
   683	func (i SectionType) String() string   { return stringName(uint32(i), shtStrings, false) }
   684	func (i SectionType) GoString() string { return stringName(uint32(i), shtStrings, true) }
   685	
   686	// Section flags.
   687	type SectionFlag uint32
   688	
   689	const (
   690		SHF_WRITE            SectionFlag = 0x1        /* Section contains writable data. */
   691		SHF_ALLOC            SectionFlag = 0x2        /* Section occupies memory. */
   692		SHF_EXECINSTR        SectionFlag = 0x4        /* Section contains instructions. */
   693		SHF_MERGE            SectionFlag = 0x10       /* Section may be merged. */
   694		SHF_STRINGS          SectionFlag = 0x20       /* Section contains strings. */
   695		SHF_INFO_LINK        SectionFlag = 0x40       /* sh_info holds section index. */
   696		SHF_LINK_ORDER       SectionFlag = 0x80       /* Special ordering requirements. */
   697		SHF_OS_NONCONFORMING SectionFlag = 0x100      /* OS-specific processing required. */
   698		SHF_GROUP            SectionFlag = 0x200      /* Member of section group. */
   699		SHF_TLS              SectionFlag = 0x400      /* Section contains TLS data. */
   700		SHF_COMPRESSED       SectionFlag = 0x800      /* Section is compressed. */
   701		SHF_MASKOS           SectionFlag = 0x0ff00000 /* OS-specific semantics. */
   702		SHF_MASKPROC         SectionFlag = 0xf0000000 /* Processor-specific semantics. */
   703	)
   704	
   705	var shfStrings = []intName{
   706		{0x1, "SHF_WRITE"},
   707		{0x2, "SHF_ALLOC"},
   708		{0x4, "SHF_EXECINSTR"},
   709		{0x10, "SHF_MERGE"},
   710		{0x20, "SHF_STRINGS"},
   711		{0x40, "SHF_INFO_LINK"},
   712		{0x80, "SHF_LINK_ORDER"},
   713		{0x100, "SHF_OS_NONCONFORMING"},
   714		{0x200, "SHF_GROUP"},
   715		{0x400, "SHF_TLS"},
   716		{0x800, "SHF_COMPRESSED"},
   717	}
   718	
   719	func (i SectionFlag) String() string   { return flagName(uint32(i), shfStrings, false) }
   720	func (i SectionFlag) GoString() string { return flagName(uint32(i), shfStrings, true) }
   721	
   722	// Section compression type.
   723	type CompressionType int
   724	
   725	const (
   726		COMPRESS_ZLIB   CompressionType = 1          /* ZLIB compression. */
   727		COMPRESS_LOOS   CompressionType = 0x60000000 /* First OS-specific. */
   728		COMPRESS_HIOS   CompressionType = 0x6fffffff /* Last OS-specific. */
   729		COMPRESS_LOPROC CompressionType = 0x70000000 /* First processor-specific type. */
   730		COMPRESS_HIPROC CompressionType = 0x7fffffff /* Last processor-specific type. */
   731	)
   732	
   733	var compressionStrings = []intName{
   734		{0, "COMPRESS_ZLIB"},
   735		{0x60000000, "COMPRESS_LOOS"},
   736		{0x6fffffff, "COMPRESS_HIOS"},
   737		{0x70000000, "COMPRESS_LOPROC"},
   738		{0x7fffffff, "COMPRESS_HIPROC"},
   739	}
   740	
   741	func (i CompressionType) String() string   { return stringName(uint32(i), compressionStrings, false) }
   742	func (i CompressionType) GoString() string { return stringName(uint32(i), compressionStrings, true) }
   743	
   744	// Prog.Type
   745	type ProgType int
   746	
   747	const (
   748		PT_NULL    ProgType = 0          /* Unused entry. */
   749		PT_LOAD    ProgType = 1          /* Loadable segment. */
   750		PT_DYNAMIC ProgType = 2          /* Dynamic linking information segment. */
   751		PT_INTERP  ProgType = 3          /* Pathname of interpreter. */
   752		PT_NOTE    ProgType = 4          /* Auxiliary information. */
   753		PT_SHLIB   ProgType = 5          /* Reserved (not used). */
   754		PT_PHDR    ProgType = 6          /* Location of program header itself. */
   755		PT_TLS     ProgType = 7          /* Thread local storage segment */
   756		PT_LOOS    ProgType = 0x60000000 /* First OS-specific. */
   757		PT_HIOS    ProgType = 0x6fffffff /* Last OS-specific. */
   758		PT_LOPROC  ProgType = 0x70000000 /* First processor-specific type. */
   759		PT_HIPROC  ProgType = 0x7fffffff /* Last processor-specific type. */
   760	)
   761	
   762	var ptStrings = []intName{
   763		{0, "PT_NULL"},
   764		{1, "PT_LOAD"},
   765		{2, "PT_DYNAMIC"},
   766		{3, "PT_INTERP"},
   767		{4, "PT_NOTE"},
   768		{5, "PT_SHLIB"},
   769		{6, "PT_PHDR"},
   770		{7, "PT_TLS"},
   771		{0x60000000, "PT_LOOS"},
   772		{0x6fffffff, "PT_HIOS"},
   773		{0x70000000, "PT_LOPROC"},
   774		{0x7fffffff, "PT_HIPROC"},
   775	}
   776	
   777	func (i ProgType) String() string   { return stringName(uint32(i), ptStrings, false) }
   778	func (i ProgType) GoString() string { return stringName(uint32(i), ptStrings, true) }
   779	
   780	// Prog.Flag
   781	type ProgFlag uint32
   782	
   783	const (
   784		PF_X        ProgFlag = 0x1        /* Executable. */
   785		PF_W        ProgFlag = 0x2        /* Writable. */
   786		PF_R        ProgFlag = 0x4        /* Readable. */
   787		PF_MASKOS   ProgFlag = 0x0ff00000 /* Operating system-specific. */
   788		PF_MASKPROC ProgFlag = 0xf0000000 /* Processor-specific. */
   789	)
   790	
   791	var pfStrings = []intName{
   792		{0x1, "PF_X"},
   793		{0x2, "PF_W"},
   794		{0x4, "PF_R"},
   795	}
   796	
   797	func (i ProgFlag) String() string   { return flagName(uint32(i), pfStrings, false) }
   798	func (i ProgFlag) GoString() string { return flagName(uint32(i), pfStrings, true) }
   799	
   800	// Dyn.Tag
   801	type DynTag int
   802	
   803	const (
   804		DT_NULL         DynTag = 0  /* Terminating entry. */
   805		DT_NEEDED       DynTag = 1  /* String table offset of a needed shared library. */
   806		DT_PLTRELSZ     DynTag = 2  /* Total size in bytes of PLT relocations. */
   807		DT_PLTGOT       DynTag = 3  /* Processor-dependent address. */
   808		DT_HASH         DynTag = 4  /* Address of symbol hash table. */
   809		DT_STRTAB       DynTag = 5  /* Address of string table. */
   810		DT_SYMTAB       DynTag = 6  /* Address of symbol table. */
   811		DT_RELA         DynTag = 7  /* Address of ElfNN_Rela relocations. */
   812		DT_RELASZ       DynTag = 8  /* Total size of ElfNN_Rela relocations. */
   813		DT_RELAENT      DynTag = 9  /* Size of each ElfNN_Rela relocation entry. */
   814		DT_STRSZ        DynTag = 10 /* Size of string table. */
   815		DT_SYMENT       DynTag = 11 /* Size of each symbol table entry. */
   816		DT_INIT         DynTag = 12 /* Address of initialization function. */
   817		DT_FINI         DynTag = 13 /* Address of finalization function. */
   818		DT_SONAME       DynTag = 14 /* String table offset of shared object name. */
   819		DT_RPATH        DynTag = 15 /* String table offset of library path. [sup] */
   820		DT_SYMBOLIC     DynTag = 16 /* Indicates "symbolic" linking. [sup] */
   821		DT_REL          DynTag = 17 /* Address of ElfNN_Rel relocations. */
   822		DT_RELSZ        DynTag = 18 /* Total size of ElfNN_Rel relocations. */
   823		DT_RELENT       DynTag = 19 /* Size of each ElfNN_Rel relocation. */
   824		DT_PLTREL       DynTag = 20 /* Type of relocation used for PLT. */
   825		DT_DEBUG        DynTag = 21 /* Reserved (not used). */
   826		DT_TEXTREL      DynTag = 22 /* Indicates there may be relocations in non-writable segments. [sup] */
   827		DT_JMPREL       DynTag = 23 /* Address of PLT relocations. */
   828		DT_BIND_NOW     DynTag = 24 /* [sup] */
   829		DT_INIT_ARRAY   DynTag = 25 /* Address of the array of pointers to initialization functions */
   830		DT_FINI_ARRAY   DynTag = 26 /* Address of the array of pointers to termination functions */
   831		DT_INIT_ARRAYSZ DynTag = 27 /* Size in bytes of the array of initialization functions. */
   832		DT_FINI_ARRAYSZ DynTag = 28 /* Size in bytes of the array of termination functions. */
   833		DT_RUNPATH      DynTag = 29 /* String table offset of a null-terminated library search path string. */
   834		DT_FLAGS        DynTag = 30 /* Object specific flag values. */
   835		DT_ENCODING     DynTag = 32 /* Values greater than or equal to DT_ENCODING
   836		   and less than DT_LOOS follow the rules for
   837		   the interpretation of the d_un union
   838		   as follows: even == 'd_ptr', even == 'd_val'
   839		   or none */
   840		DT_PREINIT_ARRAY   DynTag = 32         /* Address of the array of pointers to pre-initialization functions. */
   841		DT_PREINIT_ARRAYSZ DynTag = 33         /* Size in bytes of the array of pre-initialization functions. */
   842		DT_LOOS            DynTag = 0x6000000d /* First OS-specific */
   843		DT_HIOS            DynTag = 0x6ffff000 /* Last OS-specific */
   844		DT_VERSYM          DynTag = 0x6ffffff0
   845		DT_VERNEED         DynTag = 0x6ffffffe
   846		DT_VERNEEDNUM      DynTag = 0x6fffffff
   847		DT_LOPROC          DynTag = 0x70000000 /* First processor-specific type. */
   848		DT_HIPROC          DynTag = 0x7fffffff /* Last processor-specific type. */
   849	)
   850	
   851	var dtStrings = []intName{
   852		{0, "DT_NULL"},
   853		{1, "DT_NEEDED"},
   854		{2, "DT_PLTRELSZ"},
   855		{3, "DT_PLTGOT"},
   856		{4, "DT_HASH"},
   857		{5, "DT_STRTAB"},
   858		{6, "DT_SYMTAB"},
   859		{7, "DT_RELA"},
   860		{8, "DT_RELASZ"},
   861		{9, "DT_RELAENT"},
   862		{10, "DT_STRSZ"},
   863		{11, "DT_SYMENT"},
   864		{12, "DT_INIT"},
   865		{13, "DT_FINI"},
   866		{14, "DT_SONAME"},
   867		{15, "DT_RPATH"},
   868		{16, "DT_SYMBOLIC"},
   869		{17, "DT_REL"},
   870		{18, "DT_RELSZ"},
   871		{19, "DT_RELENT"},
   872		{20, "DT_PLTREL"},
   873		{21, "DT_DEBUG"},
   874		{22, "DT_TEXTREL"},
   875		{23, "DT_JMPREL"},
   876		{24, "DT_BIND_NOW"},
   877		{25, "DT_INIT_ARRAY"},
   878		{26, "DT_FINI_ARRAY"},
   879		{27, "DT_INIT_ARRAYSZ"},
   880		{28, "DT_FINI_ARRAYSZ"},
   881		{29, "DT_RUNPATH"},
   882		{30, "DT_FLAGS"},
   883		{32, "DT_ENCODING"},
   884		{32, "DT_PREINIT_ARRAY"},
   885		{33, "DT_PREINIT_ARRAYSZ"},
   886		{0x6000000d, "DT_LOOS"},
   887		{0x6ffff000, "DT_HIOS"},
   888		{0x6ffffff0, "DT_VERSYM"},
   889		{0x6ffffffe, "DT_VERNEED"},
   890		{0x6fffffff, "DT_VERNEEDNUM"},
   891		{0x70000000, "DT_LOPROC"},
   892		{0x7fffffff, "DT_HIPROC"},
   893	}
   894	
   895	func (i DynTag) String() string   { return stringName(uint32(i), dtStrings, false) }
   896	func (i DynTag) GoString() string { return stringName(uint32(i), dtStrings, true) }
   897	
   898	// DT_FLAGS values.
   899	type DynFlag int
   900	
   901	const (
   902		DF_ORIGIN DynFlag = 0x0001 /* Indicates that the object being loaded may
   903		   make reference to the
   904		   $ORIGIN substitution string */
   905		DF_SYMBOLIC DynFlag = 0x0002 /* Indicates "symbolic" linking. */
   906		DF_TEXTREL  DynFlag = 0x0004 /* Indicates there may be relocations in non-writable segments. */
   907		DF_BIND_NOW DynFlag = 0x0008 /* Indicates that the dynamic linker should
   908		   process all relocations for the object
   909		   containing this entry before transferring
   910		   control to the program. */
   911		DF_STATIC_TLS DynFlag = 0x0010 /* Indicates that the shared object or
   912		   executable contains code using a static
   913		   thread-local storage scheme. */
   914	)
   915	
   916	var dflagStrings = []intName{
   917		{0x0001, "DF_ORIGIN"},
   918		{0x0002, "DF_SYMBOLIC"},
   919		{0x0004, "DF_TEXTREL"},
   920		{0x0008, "DF_BIND_NOW"},
   921		{0x0010, "DF_STATIC_TLS"},
   922	}
   923	
   924	func (i DynFlag) String() string   { return flagName(uint32(i), dflagStrings, false) }
   925	func (i DynFlag) GoString() string { return flagName(uint32(i), dflagStrings, true) }
   926	
   927	// NType values; used in core files.
   928	type NType int
   929	
   930	const (
   931		NT_PRSTATUS NType = 1 /* Process status. */
   932		NT_FPREGSET NType = 2 /* Floating point registers. */
   933		NT_PRPSINFO NType = 3 /* Process state info. */
   934	)
   935	
   936	var ntypeStrings = []intName{
   937		{1, "NT_PRSTATUS"},
   938		{2, "NT_FPREGSET"},
   939		{3, "NT_PRPSINFO"},
   940	}
   941	
   942	func (i NType) String() string   { return stringName(uint32(i), ntypeStrings, false) }
   943	func (i NType) GoString() string { return stringName(uint32(i), ntypeStrings, true) }
   944	
   945	/* Symbol Binding - ELFNN_ST_BIND - st_info */
   946	type SymBind int
   947	
   948	const (
   949		STB_LOCAL  SymBind = 0  /* Local symbol */
   950		STB_GLOBAL SymBind = 1  /* Global symbol */
   951		STB_WEAK   SymBind = 2  /* like global - lower precedence */
   952		STB_LOOS   SymBind = 10 /* Reserved range for operating system */
   953		STB_HIOS   SymBind = 12 /*   specific semantics. */
   954		STB_LOPROC SymBind = 13 /* reserved range for processor */
   955		STB_HIPROC SymBind = 15 /*   specific semantics. */
   956	)
   957	
   958	var stbStrings = []intName{
   959		{0, "STB_LOCAL"},
   960		{1, "STB_GLOBAL"},
   961		{2, "STB_WEAK"},
   962		{10, "STB_LOOS"},
   963		{12, "STB_HIOS"},
   964		{13, "STB_LOPROC"},
   965		{15, "STB_HIPROC"},
   966	}
   967	
   968	func (i SymBind) String() string   { return stringName(uint32(i), stbStrings, false) }
   969	func (i SymBind) GoString() string { return stringName(uint32(i), stbStrings, true) }
   970	
   971	/* Symbol type - ELFNN_ST_TYPE - st_info */
   972	type SymType int
   973	
   974	const (
   975		STT_NOTYPE  SymType = 0  /* Unspecified type. */
   976		STT_OBJECT  SymType = 1  /* Data object. */
   977		STT_FUNC    SymType = 2  /* Function. */
   978		STT_SECTION SymType = 3  /* Section. */
   979		STT_FILE    SymType = 4  /* Source file. */
   980		STT_COMMON  SymType = 5  /* Uninitialized common block. */
   981		STT_TLS     SymType = 6  /* TLS object. */
   982		STT_LOOS    SymType = 10 /* Reserved range for operating system */
   983		STT_HIOS    SymType = 12 /*   specific semantics. */
   984		STT_LOPROC  SymType = 13 /* reserved range for processor */
   985		STT_HIPROC  SymType = 15 /*   specific semantics. */
   986	)
   987	
   988	var sttStrings = []intName{
   989		{0, "STT_NOTYPE"},
   990		{1, "STT_OBJECT"},
   991		{2, "STT_FUNC"},
   992		{3, "STT_SECTION"},
   993		{4, "STT_FILE"},
   994		{5, "STT_COMMON"},
   995		{6, "STT_TLS"},
   996		{10, "STT_LOOS"},
   997		{12, "STT_HIOS"},
   998		{13, "STT_LOPROC"},
   999		{15, "STT_HIPROC"},
  1000	}
  1001	
  1002	func (i SymType) String() string   { return stringName(uint32(i), sttStrings, false) }
  1003	func (i SymType) GoString() string { return stringName(uint32(i), sttStrings, true) }
  1004	
  1005	/* Symbol visibility - ELFNN_ST_VISIBILITY - st_other */
  1006	type SymVis int
  1007	
  1008	const (
  1009		STV_DEFAULT   SymVis = 0x0 /* Default visibility (see binding). */
  1010		STV_INTERNAL  SymVis = 0x1 /* Special meaning in relocatable objects. */
  1011		STV_HIDDEN    SymVis = 0x2 /* Not visible. */
  1012		STV_PROTECTED SymVis = 0x3 /* Visible but not preemptible. */
  1013	)
  1014	
  1015	var stvStrings = []intName{
  1016		{0x0, "STV_DEFAULT"},
  1017		{0x1, "STV_INTERNAL"},
  1018		{0x2, "STV_HIDDEN"},
  1019		{0x3, "STV_PROTECTED"},
  1020	}
  1021	
  1022	func (i SymVis) String() string   { return stringName(uint32(i), stvStrings, false) }
  1023	func (i SymVis) GoString() string { return stringName(uint32(i), stvStrings, true) }
  1024	
  1025	/*
  1026	 * Relocation types.
  1027	 */
  1028	
  1029	// Relocation types for x86-64.
  1030	type R_X86_64 int
  1031	
  1032	const (
  1033		R_X86_64_NONE            R_X86_64 = 0  /* No relocation. */
  1034		R_X86_64_64              R_X86_64 = 1  /* Add 64 bit symbol value. */
  1035		R_X86_64_PC32            R_X86_64 = 2  /* PC-relative 32 bit signed sym value. */
  1036		R_X86_64_GOT32           R_X86_64 = 3  /* PC-relative 32 bit GOT offset. */
  1037		R_X86_64_PLT32           R_X86_64 = 4  /* PC-relative 32 bit PLT offset. */
  1038		R_X86_64_COPY            R_X86_64 = 5  /* Copy data from shared object. */
  1039		R_X86_64_GLOB_DAT        R_X86_64 = 6  /* Set GOT entry to data address. */
  1040		R_X86_64_JMP_SLOT        R_X86_64 = 7  /* Set GOT entry to code address. */
  1041		R_X86_64_RELATIVE        R_X86_64 = 8  /* Add load address of shared object. */
  1042		R_X86_64_GOTPCREL        R_X86_64 = 9  /* Add 32 bit signed pcrel offset to GOT. */
  1043		R_X86_64_32              R_X86_64 = 10 /* Add 32 bit zero extended symbol value */
  1044		R_X86_64_32S             R_X86_64 = 11 /* Add 32 bit sign extended symbol value */
  1045		R_X86_64_16              R_X86_64 = 12 /* Add 16 bit zero extended symbol value */
  1046		R_X86_64_PC16            R_X86_64 = 13 /* Add 16 bit signed extended pc relative symbol value */
  1047		R_X86_64_8               R_X86_64 = 14 /* Add 8 bit zero extended symbol value */
  1048		R_X86_64_PC8             R_X86_64 = 15 /* Add 8 bit signed extended pc relative symbol value */
  1049		R_X86_64_DTPMOD64        R_X86_64 = 16 /* ID of module containing symbol */
  1050		R_X86_64_DTPOFF64        R_X86_64 = 17 /* Offset in TLS block */
  1051		R_X86_64_TPOFF64         R_X86_64 = 18 /* Offset in static TLS block */
  1052		R_X86_64_TLSGD           R_X86_64 = 19 /* PC relative offset to GD GOT entry */
  1053		R_X86_64_TLSLD           R_X86_64 = 20 /* PC relative offset to LD GOT entry */
  1054		R_X86_64_DTPOFF32        R_X86_64 = 21 /* Offset in TLS block */
  1055		R_X86_64_GOTTPOFF        R_X86_64 = 22 /* PC relative offset to IE GOT entry */
  1056		R_X86_64_TPOFF32         R_X86_64 = 23 /* Offset in static TLS block */
  1057		R_X86_64_PC64            R_X86_64 = 24 /* PC relative 64-bit sign extended symbol value. */
  1058		R_X86_64_GOTOFF64        R_X86_64 = 25
  1059		R_X86_64_GOTPC32         R_X86_64 = 26
  1060		R_X86_64_GOT64           R_X86_64 = 27
  1061		R_X86_64_GOTPCREL64      R_X86_64 = 28
  1062		R_X86_64_GOTPC64         R_X86_64 = 29
  1063		R_X86_64_GOTPLT64        R_X86_64 = 30
  1064		R_X86_64_PLTOFF64        R_X86_64 = 31
  1065		R_X86_64_SIZE32          R_X86_64 = 32
  1066		R_X86_64_SIZE64          R_X86_64 = 33
  1067		R_X86_64_GOTPC32_TLSDESC R_X86_64 = 34
  1068		R_X86_64_TLSDESC_CALL    R_X86_64 = 35
  1069		R_X86_64_TLSDESC         R_X86_64 = 36
  1070		R_X86_64_IRELATIVE       R_X86_64 = 37
  1071		R_X86_64_RELATIVE64      R_X86_64 = 38
  1072		R_X86_64_PC32_BND        R_X86_64 = 39
  1073		R_X86_64_PLT32_BND       R_X86_64 = 40
  1074		R_X86_64_GOTPCRELX       R_X86_64 = 41
  1075		R_X86_64_REX_GOTPCRELX   R_X86_64 = 42
  1076	)
  1077	
  1078	var rx86_64Strings = []intName{
  1079		{0, "R_X86_64_NONE"},
  1080		{1, "R_X86_64_64"},
  1081		{2, "R_X86_64_PC32"},
  1082		{3, "R_X86_64_GOT32"},
  1083		{4, "R_X86_64_PLT32"},
  1084		{5, "R_X86_64_COPY"},
  1085		{6, "R_X86_64_GLOB_DAT"},
  1086		{7, "R_X86_64_JMP_SLOT"},
  1087		{8, "R_X86_64_RELATIVE"},
  1088		{9, "R_X86_64_GOTPCREL"},
  1089		{10, "R_X86_64_32"},
  1090		{11, "R_X86_64_32S"},
  1091		{12, "R_X86_64_16"},
  1092		{13, "R_X86_64_PC16"},
  1093		{14, "R_X86_64_8"},
  1094		{15, "R_X86_64_PC8"},
  1095		{16, "R_X86_64_DTPMOD64"},
  1096		{17, "R_X86_64_DTPOFF64"},
  1097		{18, "R_X86_64_TPOFF64"},
  1098		{19, "R_X86_64_TLSGD"},
  1099		{20, "R_X86_64_TLSLD"},
  1100		{21, "R_X86_64_DTPOFF32"},
  1101		{22, "R_X86_64_GOTTPOFF"},
  1102		{23, "R_X86_64_TPOFF32"},
  1103		{24, "R_X86_64_PC64"},
  1104		{25, "R_X86_64_GOTOFF64"},
  1105		{26, "R_X86_64_GOTPC32"},
  1106		{27, "R_X86_64_GOT64"},
  1107		{28, "R_X86_64_GOTPCREL64"},
  1108		{29, "R_X86_64_GOTPC64"},
  1109		{30, "R_X86_64_GOTPLT64"},
  1110		{31, "R_X86_64_PLTOFF64"},
  1111		{32, "R_X86_64_SIZE32"},
  1112		{33, "R_X86_64_SIZE64"},
  1113		{34, "R_X86_64_GOTPC32_TLSDESC"},
  1114		{35, "R_X86_64_TLSDESC_CALL"},
  1115		{36, "R_X86_64_TLSDESC"},
  1116		{37, "R_X86_64_IRELATIVE"},
  1117		{38, "R_X86_64_RELATIVE64"},
  1118		{39, "R_X86_64_PC32_BND"},
  1119		{40, "R_X86_64_PLT32_BND"},
  1120		{41, "R_X86_64_GOTPCRELX"},
  1121		{42, "R_X86_64_REX_GOTPCRELX"},
  1122	}
  1123	
  1124	func (i R_X86_64) String() string   { return stringName(uint32(i), rx86_64Strings, false) }
  1125	func (i R_X86_64) GoString() string { return stringName(uint32(i), rx86_64Strings, true) }
  1126	
  1127	// Relocation types for AArch64 (aka arm64)
  1128	type R_AARCH64 int
  1129	
  1130	const (
  1131		R_AARCH64_NONE                            R_AARCH64 = 0
  1132		R_AARCH64_P32_ABS32                       R_AARCH64 = 1
  1133		R_AARCH64_P32_ABS16                       R_AARCH64 = 2
  1134		R_AARCH64_P32_PREL32                      R_AARCH64 = 3
  1135		R_AARCH64_P32_PREL16                      R_AARCH64 = 4
  1136		R_AARCH64_P32_MOVW_UABS_G0                R_AARCH64 = 5
  1137		R_AARCH64_P32_MOVW_UABS_G0_NC             R_AARCH64 = 6
  1138		R_AARCH64_P32_MOVW_UABS_G1                R_AARCH64 = 7
  1139		R_AARCH64_P32_MOVW_SABS_G0                R_AARCH64 = 8
  1140		R_AARCH64_P32_LD_PREL_LO19                R_AARCH64 = 9
  1141		R_AARCH64_P32_ADR_PREL_LO21               R_AARCH64 = 10
  1142		R_AARCH64_P32_ADR_PREL_PG_HI21            R_AARCH64 = 11
  1143		R_AARCH64_P32_ADD_ABS_LO12_NC             R_AARCH64 = 12
  1144		R_AARCH64_P32_LDST8_ABS_LO12_NC           R_AARCH64 = 13
  1145		R_AARCH64_P32_LDST16_ABS_LO12_NC          R_AARCH64 = 14
  1146		R_AARCH64_P32_LDST32_ABS_LO12_NC          R_AARCH64 = 15
  1147		R_AARCH64_P32_LDST64_ABS_LO12_NC          R_AARCH64 = 16
  1148		R_AARCH64_P32_LDST128_ABS_LO12_NC         R_AARCH64 = 17
  1149		R_AARCH64_P32_TSTBR14                     R_AARCH64 = 18
  1150		R_AARCH64_P32_CONDBR19                    R_AARCH64 = 19
  1151		R_AARCH64_P32_JUMP26                      R_AARCH64 = 20
  1152		R_AARCH64_P32_CALL26                      R_AARCH64 = 21
  1153		R_AARCH64_P32_GOT_LD_PREL19               R_AARCH64 = 25
  1154		R_AARCH64_P32_ADR_GOT_PAGE                R_AARCH64 = 26
  1155		R_AARCH64_P32_LD32_GOT_LO12_NC            R_AARCH64 = 27
  1156		R_AARCH64_P32_TLSGD_ADR_PAGE21            R_AARCH64 = 81
  1157		R_AARCH64_P32_TLSGD_ADD_LO12_NC           R_AARCH64 = 82
  1158		R_AARCH64_P32_TLSIE_ADR_GOTTPREL_PAGE21   R_AARCH64 = 103
  1159		R_AARCH64_P32_TLSIE_LD32_GOTTPREL_LO12_NC R_AARCH64 = 104
  1160		R_AARCH64_P32_TLSIE_LD_GOTTPREL_PREL19    R_AARCH64 = 105
  1161		R_AARCH64_P32_TLSLE_MOVW_TPREL_G1         R_AARCH64 = 106
  1162		R_AARCH64_P32_TLSLE_MOVW_TPREL_G0         R_AARCH64 = 107
  1163		R_AARCH64_P32_TLSLE_MOVW_TPREL_G0_NC      R_AARCH64 = 108
  1164		R_AARCH64_P32_TLSLE_ADD_TPREL_HI12        R_AARCH64 = 109
  1165		R_AARCH64_P32_TLSLE_ADD_TPREL_LO12        R_AARCH64 = 110
  1166		R_AARCH64_P32_TLSLE_ADD_TPREL_LO12_NC     R_AARCH64 = 111
  1167		R_AARCH64_P32_TLSDESC_LD_PREL19           R_AARCH64 = 122
  1168		R_AARCH64_P32_TLSDESC_ADR_PREL21          R_AARCH64 = 123
  1169		R_AARCH64_P32_TLSDESC_ADR_PAGE21          R_AARCH64 = 124
  1170		R_AARCH64_P32_TLSDESC_LD32_LO12_NC        R_AARCH64 = 125
  1171		R_AARCH64_P32_TLSDESC_ADD_LO12_NC         R_AARCH64 = 126
  1172		R_AARCH64_P32_TLSDESC_CALL                R_AARCH64 = 127
  1173		R_AARCH64_P32_COPY                        R_AARCH64 = 180
  1174		R_AARCH64_P32_GLOB_DAT                    R_AARCH64 = 181
  1175		R_AARCH64_P32_JUMP_SLOT                   R_AARCH64 = 182
  1176		R_AARCH64_P32_RELATIVE                    R_AARCH64 = 183
  1177		R_AARCH64_P32_TLS_DTPMOD                  R_AARCH64 = 184
  1178		R_AARCH64_P32_TLS_DTPREL                  R_AARCH64 = 185
  1179		R_AARCH64_P32_TLS_TPREL                   R_AARCH64 = 186
  1180		R_AARCH64_P32_TLSDESC                     R_AARCH64 = 187
  1181		R_AARCH64_P32_IRELATIVE                   R_AARCH64 = 188
  1182		R_AARCH64_NULL                            R_AARCH64 = 256
  1183		R_AARCH64_ABS64                           R_AARCH64 = 257
  1184		R_AARCH64_ABS32                           R_AARCH64 = 258
  1185		R_AARCH64_ABS16                           R_AARCH64 = 259
  1186		R_AARCH64_PREL64                          R_AARCH64 = 260
  1187		R_AARCH64_PREL32                          R_AARCH64 = 261
  1188		R_AARCH64_PREL16                          R_AARCH64 = 262
  1189		R_AARCH64_MOVW_UABS_G0                    R_AARCH64 = 263
  1190		R_AARCH64_MOVW_UABS_G0_NC                 R_AARCH64 = 264
  1191		R_AARCH64_MOVW_UABS_G1                    R_AARCH64 = 265
  1192		R_AARCH64_MOVW_UABS_G1_NC                 R_AARCH64 = 266
  1193		R_AARCH64_MOVW_UABS_G2                    R_AARCH64 = 267
  1194		R_AARCH64_MOVW_UABS_G2_NC                 R_AARCH64 = 268
  1195		R_AARCH64_MOVW_UABS_G3                    R_AARCH64 = 269
  1196		R_AARCH64_MOVW_SABS_G0                    R_AARCH64 = 270
  1197		R_AARCH64_MOVW_SABS_G1                    R_AARCH64 = 271
  1198		R_AARCH64_MOVW_SABS_G2                    R_AARCH64 = 272
  1199		R_AARCH64_LD_PREL_LO19                    R_AARCH64 = 273
  1200		R_AARCH64_ADR_PREL_LO21                   R_AARCH64 = 274
  1201		R_AARCH64_ADR_PREL_PG_HI21                R_AARCH64 = 275
  1202		R_AARCH64_ADR_PREL_PG_HI21_NC             R_AARCH64 = 276
  1203		R_AARCH64_ADD_ABS_LO12_NC                 R_AARCH64 = 277
  1204		R_AARCH64_LDST8_ABS_LO12_NC               R_AARCH64 = 278
  1205		R_AARCH64_TSTBR14                         R_AARCH64 = 279
  1206		R_AARCH64_CONDBR19                        R_AARCH64 = 280
  1207		R_AARCH64_JUMP26                          R_AARCH64 = 282
  1208		R_AARCH64_CALL26                          R_AARCH64 = 283
  1209		R_AARCH64_LDST16_ABS_LO12_NC              R_AARCH64 = 284
  1210		R_AARCH64_LDST32_ABS_LO12_NC              R_AARCH64 = 285
  1211		R_AARCH64_LDST64_ABS_LO12_NC              R_AARCH64 = 286
  1212		R_AARCH64_LDST128_ABS_LO12_NC             R_AARCH64 = 299
  1213		R_AARCH64_GOT_LD_PREL19                   R_AARCH64 = 309
  1214		R_AARCH64_LD64_GOTOFF_LO15                R_AARCH64 = 310
  1215		R_AARCH64_ADR_GOT_PAGE                    R_AARCH64 = 311
  1216		R_AARCH64_LD64_GOT_LO12_NC                R_AARCH64 = 312
  1217		R_AARCH64_LD64_GOTPAGE_LO15               R_AARCH64 = 313
  1218		R_AARCH64_TLSGD_ADR_PREL21                R_AARCH64 = 512
  1219		R_AARCH64_TLSGD_ADR_PAGE21                R_AARCH64 = 513
  1220		R_AARCH64_TLSGD_ADD_LO12_NC               R_AARCH64 = 514
  1221		R_AARCH64_TLSGD_MOVW_G1                   R_AARCH64 = 515
  1222		R_AARCH64_TLSGD_MOVW_G0_NC                R_AARCH64 = 516
  1223		R_AARCH64_TLSLD_ADR_PREL21                R_AARCH64 = 517
  1224		R_AARCH64_TLSLD_ADR_PAGE21                R_AARCH64 = 518
  1225		R_AARCH64_TLSIE_MOVW_GOTTPREL_G1          R_AARCH64 = 539
  1226		R_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC       R_AARCH64 = 540
  1227		R_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21       R_AARCH64 = 541
  1228		R_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC     R_AARCH64 = 542
  1229		R_AARCH64_TLSIE_LD_GOTTPREL_PREL19        R_AARCH64 = 543
  1230		R_AARCH64_TLSLE_MOVW_TPREL_G2             R_AARCH64 = 544
  1231		R_AARCH64_TLSLE_MOVW_TPREL_G1             R_AARCH64 = 545
  1232		R_AARCH64_TLSLE_MOVW_TPREL_G1_NC          R_AARCH64 = 546
  1233		R_AARCH64_TLSLE_MOVW_TPREL_G0             R_AARCH64 = 547
  1234		R_AARCH64_TLSLE_MOVW_TPREL_G0_NC          R_AARCH64 = 548
  1235		R_AARCH64_TLSLE_ADD_TPREL_HI12            R_AARCH64 = 549
  1236		R_AARCH64_TLSLE_ADD_TPREL_LO12            R_AARCH64 = 550
  1237		R_AARCH64_TLSLE_ADD_TPREL_LO12_NC         R_AARCH64 = 551
  1238		R_AARCH64_TLSDESC_LD_PREL19               R_AARCH64 = 560
  1239		R_AARCH64_TLSDESC_ADR_PREL21              R_AARCH64 = 561
  1240		R_AARCH64_TLSDESC_ADR_PAGE21              R_AARCH64 = 562
  1241		R_AARCH64_TLSDESC_LD64_LO12_NC            R_AARCH64 = 563
  1242		R_AARCH64_TLSDESC_ADD_LO12_NC             R_AARCH64 = 564
  1243		R_AARCH64_TLSDESC_OFF_G1                  R_AARCH64 = 565
  1244		R_AARCH64_TLSDESC_OFF_G0_NC               R_AARCH64 = 566
  1245		R_AARCH64_TLSDESC_LDR                     R_AARCH64 = 567
  1246		R_AARCH64_TLSDESC_ADD                     R_AARCH64 = 568
  1247		R_AARCH64_TLSDESC_CALL                    R_AARCH64 = 569
  1248		R_AARCH64_TLSLE_LDST128_TPREL_LO12        R_AARCH64 = 570
  1249		R_AARCH64_TLSLE_LDST128_TPREL_LO12_NC     R_AARCH64 = 571
  1250		R_AARCH64_TLSLD_LDST128_DTPREL_LO12       R_AARCH64 = 572
  1251		R_AARCH64_TLSLD_LDST128_DTPREL_LO12_NC    R_AARCH64 = 573
  1252		R_AARCH64_COPY                            R_AARCH64 = 1024
  1253		R_AARCH64_GLOB_DAT                        R_AARCH64 = 1025
  1254		R_AARCH64_JUMP_SLOT                       R_AARCH64 = 1026
  1255		R_AARCH64_RELATIVE                        R_AARCH64 = 1027
  1256		R_AARCH64_TLS_DTPMOD64                    R_AARCH64 = 1028
  1257		R_AARCH64_TLS_DTPREL64                    R_AARCH64 = 1029
  1258		R_AARCH64_TLS_TPREL64                     R_AARCH64 = 1030
  1259		R_AARCH64_TLSDESC                         R_AARCH64 = 1031
  1260		R_AARCH64_IRELATIVE                       R_AARCH64 = 1032
  1261	)
  1262	
  1263	var raarch64Strings = []intName{
  1264		{0, "R_AARCH64_NONE"},
  1265		{1, "R_AARCH64_P32_ABS32"},
  1266		{2, "R_AARCH64_P32_ABS16"},
  1267		{3, "R_AARCH64_P32_PREL32"},
  1268		{4, "R_AARCH64_P32_PREL16"},
  1269		{5, "R_AARCH64_P32_MOVW_UABS_G0"},
  1270		{6, "R_AARCH64_P32_MOVW_UABS_G0_NC"},
  1271		{7, "R_AARCH64_P32_MOVW_UABS_G1"},
  1272		{8, "R_AARCH64_P32_MOVW_SABS_G0"},
  1273		{9, "R_AARCH64_P32_LD_PREL_LO19"},
  1274		{10, "R_AARCH64_P32_ADR_PREL_LO21"},
  1275		{11, "R_AARCH64_P32_ADR_PREL_PG_HI21"},
  1276		{12, "R_AARCH64_P32_ADD_ABS_LO12_NC"},
  1277		{13, "R_AARCH64_P32_LDST8_ABS_LO12_NC"},
  1278		{14, "R_AARCH64_P32_LDST16_ABS_LO12_NC"},
  1279		{15, "R_AARCH64_P32_LDST32_ABS_LO12_NC"},
  1280		{16, "R_AARCH64_P32_LDST64_ABS_LO12_NC"},
  1281		{17, "R_AARCH64_P32_LDST128_ABS_LO12_NC"},
  1282		{18, "R_AARCH64_P32_TSTBR14"},
  1283		{19, "R_AARCH64_P32_CONDBR19"},
  1284		{20, "R_AARCH64_P32_JUMP26"},
  1285		{21, "R_AARCH64_P32_CALL26"},
  1286		{25, "R_AARCH64_P32_GOT_LD_PREL19"},
  1287		{26, "R_AARCH64_P32_ADR_GOT_PAGE"},
  1288		{27, "R_AARCH64_P32_LD32_GOT_LO12_NC"},
  1289		{81, "R_AARCH64_P32_TLSGD_ADR_PAGE21"},
  1290		{82, "R_AARCH64_P32_TLSGD_ADD_LO12_NC"},
  1291		{103, "R_AARCH64_P32_TLSIE_ADR_GOTTPREL_PAGE21"},
  1292		{104, "R_AARCH64_P32_TLSIE_LD32_GOTTPREL_LO12_NC"},
  1293		{105, "R_AARCH64_P32_TLSIE_LD_GOTTPREL_PREL19"},
  1294		{106, "R_AARCH64_P32_TLSLE_MOVW_TPREL_G1"},
  1295		{107, "R_AARCH64_P32_TLSLE_MOVW_TPREL_G0"},
  1296		{108, "R_AARCH64_P32_TLSLE_MOVW_TPREL_G0_NC"},
  1297		{109, "R_AARCH64_P32_TLSLE_ADD_TPREL_HI12"},
  1298		{110, "R_AARCH64_P32_TLSLE_ADD_TPREL_LO12"},
  1299		{111, "R_AARCH64_P32_TLSLE_ADD_TPREL_LO12_NC"},
  1300		{122, "R_AARCH64_P32_TLSDESC_LD_PREL19"},
  1301		{123, "R_AARCH64_P32_TLSDESC_ADR_PREL21"},
  1302		{124, "R_AARCH64_P32_TLSDESC_ADR_PAGE21"},
  1303		{125, "R_AARCH64_P32_TLSDESC_LD32_LO12_NC"},
  1304		{126, "R_AARCH64_P32_TLSDESC_ADD_LO12_NC"},
  1305		{127, "R_AARCH64_P32_TLSDESC_CALL"},
  1306		{180, "R_AARCH64_P32_COPY"},
  1307		{181, "R_AARCH64_P32_GLOB_DAT"},
  1308		{182, "R_AARCH64_P32_JUMP_SLOT"},
  1309		{183, "R_AARCH64_P32_RELATIVE"},
  1310		{184, "R_AARCH64_P32_TLS_DTPMOD"},
  1311		{185, "R_AARCH64_P32_TLS_DTPREL"},
  1312		{186, "R_AARCH64_P32_TLS_TPREL"},
  1313		{187, "R_AARCH64_P32_TLSDESC"},
  1314		{188, "R_AARCH64_P32_IRELATIVE"},
  1315		{256, "R_AARCH64_NULL"},
  1316		{257, "R_AARCH64_ABS64"},
  1317		{258, "R_AARCH64_ABS32"},
  1318		{259, "R_AARCH64_ABS16"},
  1319		{260, "R_AARCH64_PREL64"},
  1320		{261, "R_AARCH64_PREL32"},
  1321		{262, "R_AARCH64_PREL16"},
  1322		{263, "R_AARCH64_MOVW_UABS_G0"},
  1323		{264, "R_AARCH64_MOVW_UABS_G0_NC"},
  1324		{265, "R_AARCH64_MOVW_UABS_G1"},
  1325		{266, "R_AARCH64_MOVW_UABS_G1_NC"},
  1326		{267, "R_AARCH64_MOVW_UABS_G2"},
  1327		{268, "R_AARCH64_MOVW_UABS_G2_NC"},
  1328		{269, "R_AARCH64_MOVW_UABS_G3"},
  1329		{270, "R_AARCH64_MOVW_SABS_G0"},
  1330		{271, "R_AARCH64_MOVW_SABS_G1"},
  1331		{272, "R_AARCH64_MOVW_SABS_G2"},
  1332		{273, "R_AARCH64_LD_PREL_LO19"},
  1333		{274, "R_AARCH64_ADR_PREL_LO21"},
  1334		{275, "R_AARCH64_ADR_PREL_PG_HI21"},
  1335		{276, "R_AARCH64_ADR_PREL_PG_HI21_NC"},
  1336		{277, "R_AARCH64_ADD_ABS_LO12_NC"},
  1337		{278, "R_AARCH64_LDST8_ABS_LO12_NC"},
  1338		{279, "R_AARCH64_TSTBR14"},
  1339		{280, "R_AARCH64_CONDBR19"},
  1340		{282, "R_AARCH64_JUMP26"},
  1341		{283, "R_AARCH64_CALL26"},
  1342		{284, "R_AARCH64_LDST16_ABS_LO12_NC"},
  1343		{285, "R_AARCH64_LDST32_ABS_LO12_NC"},
  1344		{286, "R_AARCH64_LDST64_ABS_LO12_NC"},
  1345		{299, "R_AARCH64_LDST128_ABS_LO12_NC"},
  1346		{309, "R_AARCH64_GOT_LD_PREL19"},
  1347		{310, "R_AARCH64_LD64_GOTOFF_LO15"},
  1348		{311, "R_AARCH64_ADR_GOT_PAGE"},
  1349		{312, "R_AARCH64_LD64_GOT_LO12_NC"},
  1350		{313, "R_AARCH64_LD64_GOTPAGE_LO15"},
  1351		{512, "R_AARCH64_TLSGD_ADR_PREL21"},
  1352		{513, "R_AARCH64_TLSGD_ADR_PAGE21"},
  1353		{514, "R_AARCH64_TLSGD_ADD_LO12_NC"},
  1354		{515, "R_AARCH64_TLSGD_MOVW_G1"},
  1355		{516, "R_AARCH64_TLSGD_MOVW_G0_NC"},
  1356		{517, "R_AARCH64_TLSLD_ADR_PREL21"},
  1357		{518, "R_AARCH64_TLSLD_ADR_PAGE21"},
  1358		{539, "R_AARCH64_TLSIE_MOVW_GOTTPREL_G1"},
  1359		{540, "R_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC"},
  1360		{541, "R_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21"},
  1361		{542, "R_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC"},
  1362		{543, "R_AARCH64_TLSIE_LD_GOTTPREL_PREL19"},
  1363		{544, "R_AARCH64_TLSLE_MOVW_TPREL_G2"},
  1364		{545, "R_AARCH64_TLSLE_MOVW_TPREL_G1"},
  1365		{546, "R_AARCH64_TLSLE_MOVW_TPREL_G1_NC"},
  1366		{547, "R_AARCH64_TLSLE_MOVW_TPREL_G0"},
  1367		{548, "R_AARCH64_TLSLE_MOVW_TPREL_G0_NC"},
  1368		{549, "R_AARCH64_TLSLE_ADD_TPREL_HI12"},
  1369		{550, "R_AARCH64_TLSLE_ADD_TPREL_LO12"},
  1370		{551, "R_AARCH64_TLSLE_ADD_TPREL_LO12_NC"},
  1371		{560, "R_AARCH64_TLSDESC_LD_PREL19"},
  1372		{561, "R_AARCH64_TLSDESC_ADR_PREL21"},
  1373		{562, "R_AARCH64_TLSDESC_ADR_PAGE21"},
  1374		{563, "R_AARCH64_TLSDESC_LD64_LO12_NC"},
  1375		{564, "R_AARCH64_TLSDESC_ADD_LO12_NC"},
  1376		{565, "R_AARCH64_TLSDESC_OFF_G1"},
  1377		{566, "R_AARCH64_TLSDESC_OFF_G0_NC"},
  1378		{567, "R_AARCH64_TLSDESC_LDR"},
  1379		{568, "R_AARCH64_TLSDESC_ADD"},
  1380		{569, "R_AARCH64_TLSDESC_CALL"},
  1381		{570, "R_AARCH64_TLSLE_LDST128_TPREL_LO12"},
  1382		{571, "R_AARCH64_TLSLE_LDST128_TPREL_LO12_NC"},
  1383		{572, "R_AARCH64_TLSLD_LDST128_DTPREL_LO12"},
  1384		{573, "R_AARCH64_TLSLD_LDST128_DTPREL_LO12_NC"},
  1385		{1024, "R_AARCH64_COPY"},
  1386		{1025, "R_AARCH64_GLOB_DAT"},
  1387		{1026, "R_AARCH64_JUMP_SLOT"},
  1388		{1027, "R_AARCH64_RELATIVE"},
  1389		{1028, "R_AARCH64_TLS_DTPMOD64"},
  1390		{1029, "R_AARCH64_TLS_DTPREL64"},
  1391		{1030, "R_AARCH64_TLS_TPREL64"},
  1392		{1031, "R_AARCH64_TLSDESC"},
  1393		{1032, "R_AARCH64_IRELATIVE"},
  1394	}
  1395	
  1396	func (i R_AARCH64) String() string   { return stringName(uint32(i), raarch64Strings, false) }
  1397	func (i R_AARCH64) GoString() string { return stringName(uint32(i), raarch64Strings, true) }
  1398	
  1399	// Relocation types for Alpha.
  1400	type R_ALPHA int
  1401	
  1402	const (
  1403		R_ALPHA_NONE           R_ALPHA = 0  /* No reloc */
  1404		R_ALPHA_REFLONG        R_ALPHA = 1  /* Direct 32 bit */
  1405		R_ALPHA_REFQUAD        R_ALPHA = 2  /* Direct 64 bit */
  1406		R_ALPHA_GPREL32        R_ALPHA = 3  /* GP relative 32 bit */
  1407		R_ALPHA_LITERAL        R_ALPHA = 4  /* GP relative 16 bit w/optimization */
  1408		R_ALPHA_LITUSE         R_ALPHA = 5  /* Optimization hint for LITERAL */
  1409		R_ALPHA_GPDISP         R_ALPHA = 6  /* Add displacement to GP */
  1410		R_ALPHA_BRADDR         R_ALPHA = 7  /* PC+4 relative 23 bit shifted */
  1411		R_ALPHA_HINT           R_ALPHA = 8  /* PC+4 relative 16 bit shifted */
  1412		R_ALPHA_SREL16         R_ALPHA = 9  /* PC relative 16 bit */
  1413		R_ALPHA_SREL32         R_ALPHA = 10 /* PC relative 32 bit */
  1414		R_ALPHA_SREL64         R_ALPHA = 11 /* PC relative 64 bit */
  1415		R_ALPHA_OP_PUSH        R_ALPHA = 12 /* OP stack push */
  1416		R_ALPHA_OP_STORE       R_ALPHA = 13 /* OP stack pop and store */
  1417		R_ALPHA_OP_PSUB        R_ALPHA = 14 /* OP stack subtract */
  1418		R_ALPHA_OP_PRSHIFT     R_ALPHA = 15 /* OP stack right shift */
  1419		R_ALPHA_GPVALUE        R_ALPHA = 16
  1420		R_ALPHA_GPRELHIGH      R_ALPHA = 17
  1421		R_ALPHA_GPRELLOW       R_ALPHA = 18
  1422		R_ALPHA_IMMED_GP_16    R_ALPHA = 19
  1423		R_ALPHA_IMMED_GP_HI32  R_ALPHA = 20
  1424		R_ALPHA_IMMED_SCN_HI32 R_ALPHA = 21
  1425		R_ALPHA_IMMED_BR_HI32  R_ALPHA = 22
  1426		R_ALPHA_IMMED_LO32     R_ALPHA = 23
  1427		R_ALPHA_COPY           R_ALPHA = 24 /* Copy symbol at runtime */
  1428		R_ALPHA_GLOB_DAT       R_ALPHA = 25 /* Create GOT entry */
  1429		R_ALPHA_JMP_SLOT       R_ALPHA = 26 /* Create PLT entry */
  1430		R_ALPHA_RELATIVE       R_ALPHA = 27 /* Adjust by program base */
  1431	)
  1432	
  1433	var ralphaStrings = []intName{
  1434		{0, "R_ALPHA_NONE"},
  1435		{1, "R_ALPHA_REFLONG"},
  1436		{2, "R_ALPHA_REFQUAD"},
  1437		{3, "R_ALPHA_GPREL32"},
  1438		{4, "R_ALPHA_LITERAL"},
  1439		{5, "R_ALPHA_LITUSE"},
  1440		{6, "R_ALPHA_GPDISP"},
  1441		{7, "R_ALPHA_BRADDR"},
  1442		{8, "R_ALPHA_HINT"},
  1443		{9, "R_ALPHA_SREL16"},
  1444		{10, "R_ALPHA_SREL32"},
  1445		{11, "R_ALPHA_SREL64"},
  1446		{12, "R_ALPHA_OP_PUSH"},
  1447		{13, "R_ALPHA_OP_STORE"},
  1448		{14, "R_ALPHA_OP_PSUB"},
  1449		{15, "R_ALPHA_OP_PRSHIFT"},
  1450		{16, "R_ALPHA_GPVALUE"},
  1451		{17, "R_ALPHA_GPRELHIGH"},
  1452		{18, "R_ALPHA_GPRELLOW"},
  1453		{19, "R_ALPHA_IMMED_GP_16"},
  1454		{20, "R_ALPHA_IMMED_GP_HI32"},
  1455		{21, "R_ALPHA_IMMED_SCN_HI32"},
  1456		{22, "R_ALPHA_IMMED_BR_HI32"},
  1457		{23, "R_ALPHA_IMMED_LO32"},
  1458		{24, "R_ALPHA_COPY"},
  1459		{25, "R_ALPHA_GLOB_DAT"},
  1460		{26, "R_ALPHA_JMP_SLOT"},
  1461		{27, "R_ALPHA_RELATIVE"},
  1462	}
  1463	
  1464	func (i R_ALPHA) String() string   { return stringName(uint32(i), ralphaStrings, false) }
  1465	func (i R_ALPHA) GoString() string { return stringName(uint32(i), ralphaStrings, true) }
  1466	
  1467	// Relocation types for ARM.
  1468	type R_ARM int
  1469	
  1470	const (
  1471		R_ARM_NONE               R_ARM = 0 /* No relocation. */
  1472		R_ARM_PC24               R_ARM = 1
  1473		R_ARM_ABS32              R_ARM = 2
  1474		R_ARM_REL32              R_ARM = 3
  1475		R_ARM_PC13               R_ARM = 4
  1476		R_ARM_ABS16              R_ARM = 5
  1477		R_ARM_ABS12              R_ARM = 6
  1478		R_ARM_THM_ABS5           R_ARM = 7
  1479		R_ARM_ABS8               R_ARM = 8
  1480		R_ARM_SBREL32            R_ARM = 9
  1481		R_ARM_THM_PC22           R_ARM = 10
  1482		R_ARM_THM_PC8            R_ARM = 11
  1483		R_ARM_AMP_VCALL9         R_ARM = 12
  1484		R_ARM_SWI24              R_ARM = 13
  1485		R_ARM_THM_SWI8           R_ARM = 14
  1486		R_ARM_XPC25              R_ARM = 15
  1487		R_ARM_THM_XPC22          R_ARM = 16
  1488		R_ARM_TLS_DTPMOD32       R_ARM = 17
  1489		R_ARM_TLS_DTPOFF32       R_ARM = 18
  1490		R_ARM_TLS_TPOFF32        R_ARM = 19
  1491		R_ARM_COPY               R_ARM = 20 /* Copy data from shared object. */
  1492		R_ARM_GLOB_DAT           R_ARM = 21 /* Set GOT entry to data address. */
  1493		R_ARM_JUMP_SLOT          R_ARM = 22 /* Set GOT entry to code address. */
  1494		R_ARM_RELATIVE           R_ARM = 23 /* Add load address of shared object. */
  1495		R_ARM_GOTOFF             R_ARM = 24 /* Add GOT-relative symbol address. */
  1496		R_ARM_GOTPC              R_ARM = 25 /* Add PC-relative GOT table address. */
  1497		R_ARM_GOT32              R_ARM = 26 /* Add PC-relative GOT offset. */
  1498		R_ARM_PLT32              R_ARM = 27 /* Add PC-relative PLT offset. */
  1499		R_ARM_CALL               R_ARM = 28
  1500		R_ARM_JUMP24             R_ARM = 29
  1501		R_ARM_THM_JUMP24         R_ARM = 30
  1502		R_ARM_BASE_ABS           R_ARM = 31
  1503		R_ARM_ALU_PCREL_7_0      R_ARM = 32
  1504		R_ARM_ALU_PCREL_15_8     R_ARM = 33
  1505		R_ARM_ALU_PCREL_23_15    R_ARM = 34
  1506		R_ARM_LDR_SBREL_11_10_NC R_ARM = 35
  1507		R_ARM_ALU_SBREL_19_12_NC R_ARM = 36
  1508		R_ARM_ALU_SBREL_27_20_CK R_ARM = 37
  1509		R_ARM_TARGET1            R_ARM = 38
  1510		R_ARM_SBREL31            R_ARM = 39
  1511		R_ARM_V4BX               R_ARM = 40
  1512		R_ARM_TARGET2            R_ARM = 41
  1513		R_ARM_PREL31             R_ARM = 42
  1514		R_ARM_MOVW_ABS_NC        R_ARM = 43
  1515		R_ARM_MOVT_ABS           R_ARM = 44
  1516		R_ARM_MOVW_PREL_NC       R_ARM = 45
  1517		R_ARM_MOVT_PREL          R_ARM = 46
  1518		R_ARM_THM_MOVW_ABS_NC    R_ARM = 47
  1519		R_ARM_THM_MOVT_ABS       R_ARM = 48
  1520		R_ARM_THM_MOVW_PREL_NC   R_ARM = 49
  1521		R_ARM_THM_MOVT_PREL      R_ARM = 50
  1522		R_ARM_THM_JUMP19         R_ARM = 51
  1523		R_ARM_THM_JUMP6          R_ARM = 52
  1524		R_ARM_THM_ALU_PREL_11_0  R_ARM = 53
  1525		R_ARM_THM_PC12           R_ARM = 54
  1526		R_ARM_ABS32_NOI          R_ARM = 55
  1527		R_ARM_REL32_NOI          R_ARM = 56
  1528		R_ARM_ALU_PC_G0_NC       R_ARM = 57
  1529		R_ARM_ALU_PC_G0          R_ARM = 58
  1530		R_ARM_ALU_PC_G1_NC       R_ARM = 59
  1531		R_ARM_ALU_PC_G1          R_ARM = 60
  1532		R_ARM_ALU_PC_G2          R_ARM = 61
  1533		R_ARM_LDR_PC_G1          R_ARM = 62
  1534		R_ARM_LDR_PC_G2          R_ARM = 63
  1535		R_ARM_LDRS_PC_G0         R_ARM = 64
  1536		R_ARM_LDRS_PC_G1         R_ARM = 65
  1537		R_ARM_LDRS_PC_G2         R_ARM = 66
  1538		R_ARM_LDC_PC_G0          R_ARM = 67
  1539		R_ARM_LDC_PC_G1          R_ARM = 68
  1540		R_ARM_LDC_PC_G2          R_ARM = 69
  1541		R_ARM_ALU_SB_G0_NC       R_ARM = 70
  1542		R_ARM_ALU_SB_G0          R_ARM = 71
  1543		R_ARM_ALU_SB_G1_NC       R_ARM = 72
  1544		R_ARM_ALU_SB_G1          R_ARM = 73
  1545		R_ARM_ALU_SB_G2          R_ARM = 74
  1546		R_ARM_LDR_SB_G0          R_ARM = 75
  1547		R_ARM_LDR_SB_G1          R_ARM = 76
  1548		R_ARM_LDR_SB_G2          R_ARM = 77
  1549		R_ARM_LDRS_SB_G0         R_ARM = 78
  1550		R_ARM_LDRS_SB_G1         R_ARM = 79
  1551		R_ARM_LDRS_SB_G2         R_ARM = 80
  1552		R_ARM_LDC_SB_G0          R_ARM = 81
  1553		R_ARM_LDC_SB_G1          R_ARM = 82
  1554		R_ARM_LDC_SB_G2          R_ARM = 83
  1555		R_ARM_MOVW_BREL_NC       R_ARM = 84
  1556		R_ARM_MOVT_BREL          R_ARM = 85
  1557		R_ARM_MOVW_BREL          R_ARM = 86
  1558		R_ARM_THM_MOVW_BREL_NC   R_ARM = 87
  1559		R_ARM_THM_MOVT_BREL      R_ARM = 88
  1560		R_ARM_THM_MOVW_BREL      R_ARM = 89
  1561		R_ARM_TLS_GOTDESC        R_ARM = 90
  1562		R_ARM_TLS_CALL           R_ARM = 91
  1563		R_ARM_TLS_DESCSEQ        R_ARM = 92
  1564		R_ARM_THM_TLS_CALL       R_ARM = 93
  1565		R_ARM_PLT32_ABS          R_ARM = 94
  1566		R_ARM_GOT_ABS            R_ARM = 95
  1567		R_ARM_GOT_PREL           R_ARM = 96
  1568		R_ARM_GOT_BREL12         R_ARM = 97
  1569		R_ARM_GOTOFF12           R_ARM = 98
  1570		R_ARM_GOTRELAX           R_ARM = 99
  1571		R_ARM_GNU_VTENTRY        R_ARM = 100
  1572		R_ARM_GNU_VTINHERIT      R_ARM = 101
  1573		R_ARM_THM_JUMP11         R_ARM = 102
  1574		R_ARM_THM_JUMP8          R_ARM = 103
  1575		R_ARM_TLS_GD32           R_ARM = 104
  1576		R_ARM_TLS_LDM32          R_ARM = 105
  1577		R_ARM_TLS_LDO32          R_ARM = 106
  1578		R_ARM_TLS_IE32           R_ARM = 107
  1579		R_ARM_TLS_LE32           R_ARM = 108
  1580		R_ARM_TLS_LDO12          R_ARM = 109
  1581		R_ARM_TLS_LE12           R_ARM = 110
  1582		R_ARM_TLS_IE12GP         R_ARM = 111
  1583		R_ARM_PRIVATE_0          R_ARM = 112
  1584		R_ARM_PRIVATE_1          R_ARM = 113
  1585		R_ARM_PRIVATE_2          R_ARM = 114
  1586		R_ARM_PRIVATE_3          R_ARM = 115
  1587		R_ARM_PRIVATE_4          R_ARM = 116
  1588		R_ARM_PRIVATE_5          R_ARM = 117
  1589		R_ARM_PRIVATE_6          R_ARM = 118
  1590		R_ARM_PRIVATE_7          R_ARM = 119
  1591		R_ARM_PRIVATE_8          R_ARM = 120
  1592		R_ARM_PRIVATE_9          R_ARM = 121
  1593		R_ARM_PRIVATE_10         R_ARM = 122
  1594		R_ARM_PRIVATE_11         R_ARM = 123
  1595		R_ARM_PRIVATE_12         R_ARM = 124
  1596		R_ARM_PRIVATE_13         R_ARM = 125
  1597		R_ARM_PRIVATE_14         R_ARM = 126
  1598		R_ARM_PRIVATE_15         R_ARM = 127
  1599		R_ARM_ME_TOO             R_ARM = 128
  1600		R_ARM_THM_TLS_DESCSEQ16  R_ARM = 129
  1601		R_ARM_THM_TLS_DESCSEQ32  R_ARM = 130
  1602		R_ARM_THM_GOT_BREL12     R_ARM = 131
  1603		R_ARM_THM_ALU_ABS_G0_NC  R_ARM = 132
  1604		R_ARM_THM_ALU_ABS_G1_NC  R_ARM = 133
  1605		R_ARM_THM_ALU_ABS_G2_NC  R_ARM = 134
  1606		R_ARM_THM_ALU_ABS_G3     R_ARM = 135
  1607		R_ARM_IRELATIVE          R_ARM = 160
  1608		R_ARM_RXPC25             R_ARM = 249
  1609		R_ARM_RSBREL32           R_ARM = 250
  1610		R_ARM_THM_RPC22          R_ARM = 251
  1611		R_ARM_RREL32             R_ARM = 252
  1612		R_ARM_RABS32             R_ARM = 253
  1613		R_ARM_RPC24              R_ARM = 254
  1614		R_ARM_RBASE              R_ARM = 255
  1615	)
  1616	
  1617	var rarmStrings = []intName{
  1618		{0, "R_ARM_NONE"},
  1619		{1, "R_ARM_PC24"},
  1620		{2, "R_ARM_ABS32"},
  1621		{3, "R_ARM_REL32"},
  1622		{4, "R_ARM_PC13"},
  1623		{5, "R_ARM_ABS16"},
  1624		{6, "R_ARM_ABS12"},
  1625		{7, "R_ARM_THM_ABS5"},
  1626		{8, "R_ARM_ABS8"},
  1627		{9, "R_ARM_SBREL32"},
  1628		{10, "R_ARM_THM_PC22"},
  1629		{11, "R_ARM_THM_PC8"},
  1630		{12, "R_ARM_AMP_VCALL9"},
  1631		{13, "R_ARM_SWI24"},
  1632		{14, "R_ARM_THM_SWI8"},
  1633		{15, "R_ARM_XPC25"},
  1634		{16, "R_ARM_THM_XPC22"},
  1635		{17, "R_ARM_TLS_DTPMOD32"},
  1636		{18, "R_ARM_TLS_DTPOFF32"},
  1637		{19, "R_ARM_TLS_TPOFF32"},
  1638		{20, "R_ARM_COPY"},
  1639		{21, "R_ARM_GLOB_DAT"},
  1640		{22, "R_ARM_JUMP_SLOT"},
  1641		{23, "R_ARM_RELATIVE"},
  1642		{24, "R_ARM_GOTOFF"},
  1643		{25, "R_ARM_GOTPC"},
  1644		{26, "R_ARM_GOT32"},
  1645		{27, "R_ARM_PLT32"},
  1646		{28, "R_ARM_CALL"},
  1647		{29, "R_ARM_JUMP24"},
  1648		{30, "R_ARM_THM_JUMP24"},
  1649		{31, "R_ARM_BASE_ABS"},
  1650		{32, "R_ARM_ALU_PCREL_7_0"},
  1651		{33, "R_ARM_ALU_PCREL_15_8"},
  1652		{34, "R_ARM_ALU_PCREL_23_15"},
  1653		{35, "R_ARM_LDR_SBREL_11_10_NC"},
  1654		{36, "R_ARM_ALU_SBREL_19_12_NC"},
  1655		{37, "R_ARM_ALU_SBREL_27_20_CK"},
  1656		{38, "R_ARM_TARGET1"},
  1657		{39, "R_ARM_SBREL31"},
  1658		{40, "R_ARM_V4BX"},
  1659		{41, "R_ARM_TARGET2"},
  1660		{42, "R_ARM_PREL31"},
  1661		{43, "R_ARM_MOVW_ABS_NC"},
  1662		{44, "R_ARM_MOVT_ABS"},
  1663		{45, "R_ARM_MOVW_PREL_NC"},
  1664		{46, "R_ARM_MOVT_PREL"},
  1665		{47, "R_ARM_THM_MOVW_ABS_NC"},
  1666		{48, "R_ARM_THM_MOVT_ABS"},
  1667		{49, "R_ARM_THM_MOVW_PREL_NC"},
  1668		{50, "R_ARM_THM_MOVT_PREL"},
  1669		{51, "R_ARM_THM_JUMP19"},
  1670		{52, "R_ARM_THM_JUMP6"},
  1671		{53, "R_ARM_THM_ALU_PREL_11_0"},
  1672		{54, "R_ARM_THM_PC12"},
  1673		{55, "R_ARM_ABS32_NOI"},
  1674		{56, "R_ARM_REL32_NOI"},
  1675		{57, "R_ARM_ALU_PC_G0_NC"},
  1676		{58, "R_ARM_ALU_PC_G0"},
  1677		{59, "R_ARM_ALU_PC_G1_NC"},
  1678		{60, "R_ARM_ALU_PC_G1"},
  1679		{61, "R_ARM_ALU_PC_G2"},
  1680		{62, "R_ARM_LDR_PC_G1"},
  1681		{63, "R_ARM_LDR_PC_G2"},
  1682		{64, "R_ARM_LDRS_PC_G0"},
  1683		{65, "R_ARM_LDRS_PC_G1"},
  1684		{66, "R_ARM_LDRS_PC_G2"},
  1685		{67, "R_ARM_LDC_PC_G0"},
  1686		{68, "R_ARM_LDC_PC_G1"},
  1687		{69, "R_ARM_LDC_PC_G2"},
  1688		{70, "R_ARM_ALU_SB_G0_NC"},
  1689		{71, "R_ARM_ALU_SB_G0"},
  1690		{72, "R_ARM_ALU_SB_G1_NC"},
  1691		{73, "R_ARM_ALU_SB_G1"},
  1692		{74, "R_ARM_ALU_SB_G2"},
  1693		{75, "R_ARM_LDR_SB_G0"},
  1694		{76, "R_ARM_LDR_SB_G1"},
  1695		{77, "R_ARM_LDR_SB_G2"},
  1696		{78, "R_ARM_LDRS_SB_G0"},
  1697		{79, "R_ARM_LDRS_SB_G1"},
  1698		{80, "R_ARM_LDRS_SB_G2"},
  1699		{81, "R_ARM_LDC_SB_G0"},
  1700		{82, "R_ARM_LDC_SB_G1"},
  1701		{83, "R_ARM_LDC_SB_G2"},
  1702		{84, "R_ARM_MOVW_BREL_NC"},
  1703		{85, "R_ARM_MOVT_BREL"},
  1704		{86, "R_ARM_MOVW_BREL"},
  1705		{87, "R_ARM_THM_MOVW_BREL_NC"},
  1706		{88, "R_ARM_THM_MOVT_BREL"},
  1707		{89, "R_ARM_THM_MOVW_BREL"},
  1708		{90, "R_ARM_TLS_GOTDESC"},
  1709		{91, "R_ARM_TLS_CALL"},
  1710		{92, "R_ARM_TLS_DESCSEQ"},
  1711		{93, "R_ARM_THM_TLS_CALL"},
  1712		{94, "R_ARM_PLT32_ABS"},
  1713		{95, "R_ARM_GOT_ABS"},
  1714		{96, "R_ARM_GOT_PREL"},
  1715		{97, "R_ARM_GOT_BREL12"},
  1716		{98, "R_ARM_GOTOFF12"},
  1717		{99, "R_ARM_GOTRELAX"},
  1718		{100, "R_ARM_GNU_VTENTRY"},
  1719		{101, "R_ARM_GNU_VTINHERIT"},
  1720		{102, "R_ARM_THM_JUMP11"},
  1721		{103, "R_ARM_THM_JUMP8"},
  1722		{104, "R_ARM_TLS_GD32"},
  1723		{105, "R_ARM_TLS_LDM32"},
  1724		{106, "R_ARM_TLS_LDO32"},
  1725		{107, "R_ARM_TLS_IE32"},
  1726		{108, "R_ARM_TLS_LE32"},
  1727		{109, "R_ARM_TLS_LDO12"},
  1728		{110, "R_ARM_TLS_LE12"},
  1729		{111, "R_ARM_TLS_IE12GP"},
  1730		{112, "R_ARM_PRIVATE_0"},
  1731		{113, "R_ARM_PRIVATE_1"},
  1732		{114, "R_ARM_PRIVATE_2"},
  1733		{115, "R_ARM_PRIVATE_3"},
  1734		{116, "R_ARM_PRIVATE_4"},
  1735		{117, "R_ARM_PRIVATE_5"},
  1736		{118, "R_ARM_PRIVATE_6"},
  1737		{119, "R_ARM_PRIVATE_7"},
  1738		{120, "R_ARM_PRIVATE_8"},
  1739		{121, "R_ARM_PRIVATE_9"},
  1740		{122, "R_ARM_PRIVATE_10"},
  1741		{123, "R_ARM_PRIVATE_11"},
  1742		{124, "R_ARM_PRIVATE_12"},
  1743		{125, "R_ARM_PRIVATE_13"},
  1744		{126, "R_ARM_PRIVATE_14"},
  1745		{127, "R_ARM_PRIVATE_15"},
  1746		{128, "R_ARM_ME_TOO"},
  1747		{129, "R_ARM_THM_TLS_DESCSEQ16"},
  1748		{130, "R_ARM_THM_TLS_DESCSEQ32"},
  1749		{131, "R_ARM_THM_GOT_BREL12"},
  1750		{132, "R_ARM_THM_ALU_ABS_G0_NC"},
  1751		{133, "R_ARM_THM_ALU_ABS_G1_NC"},
  1752		{134, "R_ARM_THM_ALU_ABS_G2_NC"},
  1753		{135, "R_ARM_THM_ALU_ABS_G3"},
  1754		{160, "R_ARM_IRELATIVE"},
  1755		{249, "R_ARM_RXPC25"},
  1756		{250, "R_ARM_RSBREL32"},
  1757		{251, "R_ARM_THM_RPC22"},
  1758		{252, "R_ARM_RREL32"},
  1759		{253, "R_ARM_RABS32"},
  1760		{254, "R_ARM_RPC24"},
  1761		{255, "R_ARM_RBASE"},
  1762	}
  1763	
  1764	func (i R_ARM) String() string   { return stringName(uint32(i), rarmStrings, false) }
  1765	func (i R_ARM) GoString() string { return stringName(uint32(i), rarmStrings, true) }
  1766	
  1767	// Relocation types for 386.
  1768	type R_386 int
  1769	
  1770	const (
  1771		R_386_NONE          R_386 = 0  /* No relocation. */
  1772		R_386_32            R_386 = 1  /* Add symbol value. */
  1773		R_386_PC32          R_386 = 2  /* Add PC-relative symbol value. */
  1774		R_386_GOT32         R_386 = 3  /* Add PC-relative GOT offset. */
  1775		R_386_PLT32         R_386 = 4  /* Add PC-relative PLT offset. */
  1776		R_386_COPY          R_386 = 5  /* Copy data from shared object. */
  1777		R_386_GLOB_DAT      R_386 = 6  /* Set GOT entry to data address. */
  1778		R_386_JMP_SLOT      R_386 = 7  /* Set GOT entry to code address. */
  1779		R_386_RELATIVE      R_386 = 8  /* Add load address of shared object. */
  1780		R_386_GOTOFF        R_386 = 9  /* Add GOT-relative symbol address. */
  1781		R_386_GOTPC         R_386 = 10 /* Add PC-relative GOT table address. */
  1782		R_386_32PLT         R_386 = 11
  1783		R_386_TLS_TPOFF     R_386 = 14 /* Negative offset in static TLS block */
  1784		R_386_TLS_IE        R_386 = 15 /* Absolute address of GOT for -ve static TLS */
  1785		R_386_TLS_GOTIE     R_386 = 16 /* GOT entry for negative static TLS block */
  1786		R_386_TLS_LE        R_386 = 17 /* Negative offset relative to static TLS */
  1787		R_386_TLS_GD        R_386 = 18 /* 32 bit offset to GOT (index,off) pair */
  1788		R_386_TLS_LDM       R_386 = 19 /* 32 bit offset to GOT (index,zero) pair */
  1789		R_386_16            R_386 = 20
  1790		R_386_PC16          R_386 = 21
  1791		R_386_8             R_386 = 22
  1792		R_386_PC8           R_386 = 23
  1793		R_386_TLS_GD_32     R_386 = 24 /* 32 bit offset to GOT (index,off) pair */
  1794		R_386_TLS_GD_PUSH   R_386 = 25 /* pushl instruction for Sun ABI GD sequence */
  1795		R_386_TLS_GD_CALL   R_386 = 26 /* call instruction for Sun ABI GD sequence */
  1796		R_386_TLS_GD_POP    R_386 = 27 /* popl instruction for Sun ABI GD sequence */
  1797		R_386_TLS_LDM_32    R_386 = 28 /* 32 bit offset to GOT (index,zero) pair */
  1798		R_386_TLS_LDM_PUSH  R_386 = 29 /* pushl instruction for Sun ABI LD sequence */
  1799		R_386_TLS_LDM_CALL  R_386 = 30 /* call instruction for Sun ABI LD sequence */
  1800		R_386_TLS_LDM_POP   R_386 = 31 /* popl instruction for Sun ABI LD sequence */
  1801		R_386_TLS_LDO_32    R_386 = 32 /* 32 bit offset from start of TLS block */
  1802		R_386_TLS_IE_32     R_386 = 33 /* 32 bit offset to GOT static TLS offset entry */
  1803		R_386_TLS_LE_32     R_386 = 34 /* 32 bit offset within static TLS block */
  1804		R_386_TLS_DTPMOD32  R_386 = 35 /* GOT entry containing TLS index */
  1805		R_386_TLS_DTPOFF32  R_386 = 36 /* GOT entry containing TLS offset */
  1806		R_386_TLS_TPOFF32   R_386 = 37 /* GOT entry of -ve static TLS offset */
  1807		R_386_SIZE32        R_386 = 38
  1808		R_386_TLS_GOTDESC   R_386 = 39
  1809		R_386_TLS_DESC_CALL R_386 = 40
  1810		R_386_TLS_DESC      R_386 = 41
  1811		R_386_IRELATIVE     R_386 = 42
  1812		R_386_GOT32X        R_386 = 43
  1813	)
  1814	
  1815	var r386Strings = []intName{
  1816		{0, "R_386_NONE"},
  1817		{1, "R_386_32"},
  1818		{2, "R_386_PC32"},
  1819		{3, "R_386_GOT32"},
  1820		{4, "R_386_PLT32"},
  1821		{5, "R_386_COPY"},
  1822		{6, "R_386_GLOB_DAT"},
  1823		{7, "R_386_JMP_SLOT"},
  1824		{8, "R_386_RELATIVE"},
  1825		{9, "R_386_GOTOFF"},
  1826		{10, "R_386_GOTPC"},
  1827		{11, "R_386_32PLT"},
  1828		{14, "R_386_TLS_TPOFF"},
  1829		{15, "R_386_TLS_IE"},
  1830		{16, "R_386_TLS_GOTIE"},
  1831		{17, "R_386_TLS_LE"},
  1832		{18, "R_386_TLS_GD"},
  1833		{19, "R_386_TLS_LDM"},
  1834		{20, "R_386_16"},
  1835		{21, "R_386_PC16"},
  1836		{22, "R_386_8"},
  1837		{23, "R_386_PC8"},
  1838		{24, "R_386_TLS_GD_32"},
  1839		{25, "R_386_TLS_GD_PUSH"},
  1840		{26, "R_386_TLS_GD_CALL"},
  1841		{27, "R_386_TLS_GD_POP"},
  1842		{28, "R_386_TLS_LDM_32"},
  1843		{29, "R_386_TLS_LDM_PUSH"},
  1844		{30, "R_386_TLS_LDM_CALL"},
  1845		{31, "R_386_TLS_LDM_POP"},
  1846		{32, "R_386_TLS_LDO_32"},
  1847		{33, "R_386_TLS_IE_32"},
  1848		{34, "R_386_TLS_LE_32"},
  1849		{35, "R_386_TLS_DTPMOD32"},
  1850		{36, "R_386_TLS_DTPOFF32"},
  1851		{37, "R_386_TLS_TPOFF32"},
  1852		{38, "R_386_SIZE32"},
  1853		{39, "R_386_TLS_GOTDESC"},
  1854		{40, "R_386_TLS_DESC_CALL"},
  1855		{41, "R_386_TLS_DESC"},
  1856		{42, "R_386_IRELATIVE"},
  1857		{43, "R_386_GOT32X"},
  1858	}
  1859	
  1860	func (i R_386) String() string   { return stringName(uint32(i), r386Strings, false) }
  1861	func (i R_386) GoString() string { return stringName(uint32(i), r386Strings, true) }
  1862	
  1863	// Relocation types for MIPS.
  1864	type R_MIPS int
  1865	
  1866	const (
  1867		R_MIPS_NONE          R_MIPS = 0
  1868		R_MIPS_16            R_MIPS = 1
  1869		R_MIPS_32            R_MIPS = 2
  1870		R_MIPS_REL32         R_MIPS = 3
  1871		R_MIPS_26            R_MIPS = 4
  1872		R_MIPS_HI16          R_MIPS = 5  /* high 16 bits of symbol value */
  1873		R_MIPS_LO16          R_MIPS = 6  /* low 16 bits of symbol value */
  1874		R_MIPS_GPREL16       R_MIPS = 7  /* GP-relative reference  */
  1875		R_MIPS_LITERAL       R_MIPS = 8  /* Reference to literal section  */
  1876		R_MIPS_GOT16         R_MIPS = 9  /* Reference to global offset table */
  1877		R_MIPS_PC16          R_MIPS = 10 /* 16 bit PC relative reference */
  1878		R_MIPS_CALL16        R_MIPS = 11 /* 16 bit call through glbl offset tbl */
  1879		R_MIPS_GPREL32       R_MIPS = 12
  1880		R_MIPS_SHIFT5        R_MIPS = 16
  1881		R_MIPS_SHIFT6        R_MIPS = 17
  1882		R_MIPS_64            R_MIPS = 18
  1883		R_MIPS_GOT_DISP      R_MIPS = 19
  1884		R_MIPS_GOT_PAGE      R_MIPS = 20
  1885		R_MIPS_GOT_OFST      R_MIPS = 21
  1886		R_MIPS_GOT_HI16      R_MIPS = 22
  1887		R_MIPS_GOT_LO16      R_MIPS = 23
  1888		R_MIPS_SUB           R_MIPS = 24
  1889		R_MIPS_INSERT_A      R_MIPS = 25
  1890		R_MIPS_INSERT_B      R_MIPS = 26
  1891		R_MIPS_DELETE        R_MIPS = 27
  1892		R_MIPS_HIGHER        R_MIPS = 28
  1893		R_MIPS_HIGHEST       R_MIPS = 29
  1894		R_MIPS_CALL_HI16     R_MIPS = 30
  1895		R_MIPS_CALL_LO16     R_MIPS = 31
  1896		R_MIPS_SCN_DISP      R_MIPS = 32
  1897		R_MIPS_REL16         R_MIPS = 33
  1898		R_MIPS_ADD_IMMEDIATE R_MIPS = 34
  1899		R_MIPS_PJUMP         R_MIPS = 35
  1900		R_MIPS_RELGOT        R_MIPS = 36
  1901		R_MIPS_JALR          R_MIPS = 37
  1902	
  1903		R_MIPS_TLS_DTPMOD32    R_MIPS = 38 /* Module number 32 bit */
  1904		R_MIPS_TLS_DTPREL32    R_MIPS = 39 /* Module-relative offset 32 bit */
  1905		R_MIPS_TLS_DTPMOD64    R_MIPS = 40 /* Module number 64 bit */
  1906		R_MIPS_TLS_DTPREL64    R_MIPS = 41 /* Module-relative offset 64 bit */
  1907		R_MIPS_TLS_GD          R_MIPS = 42 /* 16 bit GOT offset for GD */
  1908		R_MIPS_TLS_LDM         R_MIPS = 43 /* 16 bit GOT offset for LDM */
  1909		R_MIPS_TLS_DTPREL_HI16 R_MIPS = 44 /* Module-relative offset, high 16 bits */
  1910		R_MIPS_TLS_DTPREL_LO16 R_MIPS = 45 /* Module-relative offset, low 16 bits */
  1911		R_MIPS_TLS_GOTTPREL    R_MIPS = 46 /* 16 bit GOT offset for IE */
  1912		R_MIPS_TLS_TPREL32     R_MIPS = 47 /* TP-relative offset, 32 bit */
  1913		R_MIPS_TLS_TPREL64     R_MIPS = 48 /* TP-relative offset, 64 bit */
  1914		R_MIPS_TLS_TPREL_HI16  R_MIPS = 49 /* TP-relative offset, high 16 bits */
  1915		R_MIPS_TLS_TPREL_LO16  R_MIPS = 50 /* TP-relative offset, low 16 bits */
  1916	)
  1917	
  1918	var rmipsStrings = []intName{
  1919		{0, "R_MIPS_NONE"},
  1920		{1, "R_MIPS_16"},
  1921		{2, "R_MIPS_32"},
  1922		{3, "R_MIPS_REL32"},
  1923		{4, "R_MIPS_26"},
  1924		{5, "R_MIPS_HI16"},
  1925		{6, "R_MIPS_LO16"},
  1926		{7, "R_MIPS_GPREL16"},
  1927		{8, "R_MIPS_LITERAL"},
  1928		{9, "R_MIPS_GOT16"},
  1929		{10, "R_MIPS_PC16"},
  1930		{11, "R_MIPS_CALL16"},
  1931		{12, "R_MIPS_GPREL32"},
  1932		{16, "R_MIPS_SHIFT5"},
  1933		{17, "R_MIPS_SHIFT6"},
  1934		{18, "R_MIPS_64"},
  1935		{19, "R_MIPS_GOT_DISP"},
  1936		{20, "R_MIPS_GOT_PAGE"},
  1937		{21, "R_MIPS_GOT_OFST"},
  1938		{22, "R_MIPS_GOT_HI16"},
  1939		{23, "R_MIPS_GOT_LO16"},
  1940		{24, "R_MIPS_SUB"},
  1941		{25, "R_MIPS_INSERT_A"},
  1942		{26, "R_MIPS_INSERT_B"},
  1943		{27, "R_MIPS_DELETE"},
  1944		{28, "R_MIPS_HIGHER"},
  1945		{29, "R_MIPS_HIGHEST"},
  1946		{30, "R_MIPS_CALL_HI16"},
  1947		{31, "R_MIPS_CALL_LO16"},
  1948		{32, "R_MIPS_SCN_DISP"},
  1949		{33, "R_MIPS_REL16"},
  1950		{34, "R_MIPS_ADD_IMMEDIATE"},
  1951		{35, "R_MIPS_PJUMP"},
  1952		{36, "R_MIPS_RELGOT"},
  1953		{37, "R_MIPS_JALR"},
  1954		{38, "R_MIPS_TLS_DTPMOD32"},
  1955		{39, "R_MIPS_TLS_DTPREL32"},
  1956		{40, "R_MIPS_TLS_DTPMOD64"},
  1957		{41, "R_MIPS_TLS_DTPREL64"},
  1958		{42, "R_MIPS_TLS_GD"},
  1959		{43, "R_MIPS_TLS_LDM"},
  1960		{44, "R_MIPS_TLS_DTPREL_HI16"},
  1961		{45, "R_MIPS_TLS_DTPREL_LO16"},
  1962		{46, "R_MIPS_TLS_GOTTPREL"},
  1963		{47, "R_MIPS_TLS_TPREL32"},
  1964		{48, "R_MIPS_TLS_TPREL64"},
  1965		{49, "R_MIPS_TLS_TPREL_HI16"},
  1966		{50, "R_MIPS_TLS_TPREL_LO16"},
  1967	}
  1968	
  1969	func (i R_MIPS) String() string   { return stringName(uint32(i), rmipsStrings, false) }
  1970	func (i R_MIPS) GoString() string { return stringName(uint32(i), rmipsStrings, true) }
  1971	
  1972	// Relocation types for PowerPC.
  1973	//
  1974	// Values that are shared by both R_PPC and R_PPC64 are prefixed with
  1975	// R_POWERPC_ in the ELF standard. For the R_PPC type, the relevant
  1976	// shared relocations have been renamed with the prefix R_PPC_.
  1977	// The original name follows the value in a comment.
  1978	type R_PPC int
  1979	
  1980	const (
  1981		R_PPC_NONE            R_PPC = 0  // R_POWERPC_NONE
  1982		R_PPC_ADDR32          R_PPC = 1  // R_POWERPC_ADDR32
  1983		R_PPC_ADDR24          R_PPC = 2  // R_POWERPC_ADDR24
  1984		R_PPC_ADDR16          R_PPC = 3  // R_POWERPC_ADDR16
  1985		R_PPC_ADDR16_LO       R_PPC = 4  // R_POWERPC_ADDR16_LO
  1986		R_PPC_ADDR16_HI       R_PPC = 5  // R_POWERPC_ADDR16_HI
  1987		R_PPC_ADDR16_HA       R_PPC = 6  // R_POWERPC_ADDR16_HA
  1988		R_PPC_ADDR14          R_PPC = 7  // R_POWERPC_ADDR14
  1989		R_PPC_ADDR14_BRTAKEN  R_PPC = 8  // R_POWERPC_ADDR14_BRTAKEN
  1990		R_PPC_ADDR14_BRNTAKEN R_PPC = 9  // R_POWERPC_ADDR14_BRNTAKEN
  1991		R_PPC_REL24           R_PPC = 10 // R_POWERPC_REL24
  1992		R_PPC_REL14           R_PPC = 11 // R_POWERPC_REL14
  1993		R_PPC_REL14_BRTAKEN   R_PPC = 12 // R_POWERPC_REL14_BRTAKEN
  1994		R_PPC_REL14_BRNTAKEN  R_PPC = 13 // R_POWERPC_REL14_BRNTAKEN
  1995		R_PPC_GOT16           R_PPC = 14 // R_POWERPC_GOT16
  1996		R_PPC_GOT16_LO        R_PPC = 15 // R_POWERPC_GOT16_LO
  1997		R_PPC_GOT16_HI        R_PPC = 16 // R_POWERPC_GOT16_HI
  1998		R_PPC_GOT16_HA        R_PPC = 17 // R_POWERPC_GOT16_HA
  1999		R_PPC_PLTREL24        R_PPC = 18
  2000		R_PPC_COPY            R_PPC = 19 // R_POWERPC_COPY
  2001		R_PPC_GLOB_DAT        R_PPC = 20 // R_POWERPC_GLOB_DAT
  2002		R_PPC_JMP_SLOT        R_PPC = 21 // R_POWERPC_JMP_SLOT
  2003		R_PPC_RELATIVE        R_PPC = 22 // R_POWERPC_RELATIVE
  2004		R_PPC_LOCAL24PC       R_PPC = 23
  2005		R_PPC_UADDR32         R_PPC = 24 // R_POWERPC_UADDR32
  2006		R_PPC_UADDR16         R_PPC = 25 // R_POWERPC_UADDR16
  2007		R_PPC_REL32           R_PPC = 26 // R_POWERPC_REL32
  2008		R_PPC_PLT32           R_PPC = 27 // R_POWERPC_PLT32
  2009		R_PPC_PLTREL32        R_PPC = 28 // R_POWERPC_PLTREL32
  2010		R_PPC_PLT16_LO        R_PPC = 29 // R_POWERPC_PLT16_LO
  2011		R_PPC_PLT16_HI        R_PPC = 30 // R_POWERPC_PLT16_HI
  2012		R_PPC_PLT16_HA        R_PPC = 31 // R_POWERPC_PLT16_HA
  2013		R_PPC_SDAREL16        R_PPC = 32
  2014		R_PPC_SECTOFF         R_PPC = 33 // R_POWERPC_SECTOFF
  2015		R_PPC_SECTOFF_LO      R_PPC = 34 // R_POWERPC_SECTOFF_LO
  2016		R_PPC_SECTOFF_HI      R_PPC = 35 // R_POWERPC_SECTOFF_HI
  2017		R_PPC_SECTOFF_HA      R_PPC = 36 // R_POWERPC_SECTOFF_HA
  2018		R_PPC_TLS             R_PPC = 67 // R_POWERPC_TLS
  2019		R_PPC_DTPMOD32        R_PPC = 68 // R_POWERPC_DTPMOD32
  2020		R_PPC_TPREL16         R_PPC = 69 // R_POWERPC_TPREL16
  2021		R_PPC_TPREL16_LO      R_PPC = 70 // R_POWERPC_TPREL16_LO
  2022		R_PPC_TPREL16_HI      R_PPC = 71 // R_POWERPC_TPREL16_HI
  2023		R_PPC_TPREL16_HA      R_PPC = 72 // R_POWERPC_TPREL16_HA
  2024		R_PPC_TPREL32         R_PPC = 73 // R_POWERPC_TPREL32
  2025		R_PPC_DTPREL16        R_PPC = 74 // R_POWERPC_DTPREL16
  2026		R_PPC_DTPREL16_LO     R_PPC = 75 // R_POWERPC_DTPREL16_LO
  2027		R_PPC_DTPREL16_HI     R_PPC = 76 // R_POWERPC_DTPREL16_HI
  2028		R_PPC_DTPREL16_HA     R_PPC = 77 // R_POWERPC_DTPREL16_HA
  2029		R_PPC_DTPREL32        R_PPC = 78 // R_POWERPC_DTPREL32
  2030		R_PPC_GOT_TLSGD16     R_PPC = 79 // R_POWERPC_GOT_TLSGD16
  2031		R_PPC_GOT_TLSGD16_LO  R_PPC = 80 // R_POWERPC_GOT_TLSGD16_LO
  2032		R_PPC_GOT_TLSGD16_HI  R_PPC = 81 // R_POWERPC_GOT_TLSGD16_HI
  2033		R_PPC_GOT_TLSGD16_HA  R_PPC = 82 // R_POWERPC_GOT_TLSGD16_HA
  2034		R_PPC_GOT_TLSLD16     R_PPC = 83 // R_POWERPC_GOT_TLSLD16
  2035		R_PPC_GOT_TLSLD16_LO  R_PPC = 84 // R_POWERPC_GOT_TLSLD16_LO
  2036		R_PPC_GOT_TLSLD16_HI  R_PPC = 85 // R_POWERPC_GOT_TLSLD16_HI
  2037		R_PPC_GOT_TLSLD16_HA  R_PPC = 86 // R_POWERPC_GOT_TLSLD16_HA
  2038		R_PPC_GOT_TPREL16     R_PPC = 87 // R_POWERPC_GOT_TPREL16
  2039		R_PPC_GOT_TPREL16_LO  R_PPC = 88 // R_POWERPC_GOT_TPREL16_LO
  2040		R_PPC_GOT_TPREL16_HI  R_PPC = 89 // R_POWERPC_GOT_TPREL16_HI
  2041		R_PPC_GOT_TPREL16_HA  R_PPC = 90 // R_POWERPC_GOT_TPREL16_HA
  2042		R_PPC_EMB_NADDR32     R_PPC = 101
  2043		R_PPC_EMB_NADDR16     R_PPC = 102
  2044		R_PPC_EMB_NADDR16_LO  R_PPC = 103
  2045		R_PPC_EMB_NADDR16_HI  R_PPC = 104
  2046		R_PPC_EMB_NADDR16_HA  R_PPC = 105
  2047		R_PPC_EMB_SDAI16      R_PPC = 106
  2048		R_PPC_EMB_SDA2I16     R_PPC = 107
  2049		R_PPC_EMB_SDA2REL     R_PPC = 108
  2050		R_PPC_EMB_SDA21       R_PPC = 109
  2051		R_PPC_EMB_MRKREF      R_PPC = 110
  2052		R_PPC_EMB_RELSEC16    R_PPC = 111
  2053		R_PPC_EMB_RELST_LO    R_PPC = 112
  2054		R_PPC_EMB_RELST_HI    R_PPC = 113
  2055		R_PPC_EMB_RELST_HA    R_PPC = 114
  2056		R_PPC_EMB_BIT_FLD     R_PPC = 115
  2057		R_PPC_EMB_RELSDA      R_PPC = 116
  2058	)
  2059	
  2060	var rppcStrings = []intName{
  2061		{0, "R_PPC_NONE"},
  2062		{1, "R_PPC_ADDR32"},
  2063		{2, "R_PPC_ADDR24"},
  2064		{3, "R_PPC_ADDR16"},
  2065		{4, "R_PPC_ADDR16_LO"},
  2066		{5, "R_PPC_ADDR16_HI"},
  2067		{6, "R_PPC_ADDR16_HA"},
  2068		{7, "R_PPC_ADDR14"},
  2069		{8, "R_PPC_ADDR14_BRTAKEN"},
  2070		{9, "R_PPC_ADDR14_BRNTAKEN"},
  2071		{10, "R_PPC_REL24"},
  2072		{11, "R_PPC_REL14"},
  2073		{12, "R_PPC_REL14_BRTAKEN"},
  2074		{13, "R_PPC_REL14_BRNTAKEN"},
  2075		{14, "R_PPC_GOT16"},
  2076		{15, "R_PPC_GOT16_LO"},
  2077		{16, "R_PPC_GOT16_HI"},
  2078		{17, "R_PPC_GOT16_HA"},
  2079		{18, "R_PPC_PLTREL24"},
  2080		{19, "R_PPC_COPY"},
  2081		{20, "R_PPC_GLOB_DAT"},
  2082		{21, "R_PPC_JMP_SLOT"},
  2083		{22, "R_PPC_RELATIVE"},
  2084		{23, "R_PPC_LOCAL24PC"},
  2085		{24, "R_PPC_UADDR32"},
  2086		{25, "R_PPC_UADDR16"},
  2087		{26, "R_PPC_REL32"},
  2088		{27, "R_PPC_PLT32"},
  2089		{28, "R_PPC_PLTREL32"},
  2090		{29, "R_PPC_PLT16_LO"},
  2091		{30, "R_PPC_PLT16_HI"},
  2092		{31, "R_PPC_PLT16_HA"},
  2093		{32, "R_PPC_SDAREL16"},
  2094		{33, "R_PPC_SECTOFF"},
  2095		{34, "R_PPC_SECTOFF_LO"},
  2096		{35, "R_PPC_SECTOFF_HI"},
  2097		{36, "R_PPC_SECTOFF_HA"},
  2098		{67, "R_PPC_TLS"},
  2099		{68, "R_PPC_DTPMOD32"},
  2100		{69, "R_PPC_TPREL16"},
  2101		{70, "R_PPC_TPREL16_LO"},
  2102		{71, "R_PPC_TPREL16_HI"},
  2103		{72, "R_PPC_TPREL16_HA"},
  2104		{73, "R_PPC_TPREL32"},
  2105		{74, "R_PPC_DTPREL16"},
  2106		{75, "R_PPC_DTPREL16_LO"},
  2107		{76, "R_PPC_DTPREL16_HI"},
  2108		{77, "R_PPC_DTPREL16_HA"},
  2109		{78, "R_PPC_DTPREL32"},
  2110		{79, "R_PPC_GOT_TLSGD16"},
  2111		{80, "R_PPC_GOT_TLSGD16_LO"},
  2112		{81, "R_PPC_GOT_TLSGD16_HI"},
  2113		{82, "R_PPC_GOT_TLSGD16_HA"},
  2114		{83, "R_PPC_GOT_TLSLD16"},
  2115		{84, "R_PPC_GOT_TLSLD16_LO"},
  2116		{85, "R_PPC_GOT_TLSLD16_HI"},
  2117		{86, "R_PPC_GOT_TLSLD16_HA"},
  2118		{87, "R_PPC_GOT_TPREL16"},
  2119		{88, "R_PPC_GOT_TPREL16_LO"},
  2120		{89, "R_PPC_GOT_TPREL16_HI"},
  2121		{90, "R_PPC_GOT_TPREL16_HA"},
  2122		{101, "R_PPC_EMB_NADDR32"},
  2123		{102, "R_PPC_EMB_NADDR16"},
  2124		{103, "R_PPC_EMB_NADDR16_LO"},
  2125		{104, "R_PPC_EMB_NADDR16_HI"},
  2126		{105, "R_PPC_EMB_NADDR16_HA"},
  2127		{106, "R_PPC_EMB_SDAI16"},
  2128		{107, "R_PPC_EMB_SDA2I16"},
  2129		{108, "R_PPC_EMB_SDA2REL"},
  2130		{109, "R_PPC_EMB_SDA21"},
  2131		{110, "R_PPC_EMB_MRKREF"},
  2132		{111, "R_PPC_EMB_RELSEC16"},
  2133		{112, "R_PPC_EMB_RELST_LO"},
  2134		{113, "R_PPC_EMB_RELST_HI"},
  2135		{114, "R_PPC_EMB_RELST_HA"},
  2136		{115, "R_PPC_EMB_BIT_FLD"},
  2137		{116, "R_PPC_EMB_RELSDA"},
  2138	}
  2139	
  2140	func (i R_PPC) String() string   { return stringName(uint32(i), rppcStrings, false) }
  2141	func (i R_PPC) GoString() string { return stringName(uint32(i), rppcStrings, true) }
  2142	
  2143	// Relocation types for 64-bit PowerPC or Power Architecture processors.
  2144	//
  2145	// Values that are shared by both R_PPC and R_PPC64 are prefixed with
  2146	// R_POWERPC_ in the ELF standard. For the R_PPC64 type, the relevant
  2147	// shared relocations have been renamed with the prefix R_PPC64_.
  2148	// The original name follows the value in a comment.
  2149	type R_PPC64 int
  2150	
  2151	const (
  2152		R_PPC64_NONE               R_PPC64 = 0  // R_POWERPC_NONE
  2153		R_PPC64_ADDR32             R_PPC64 = 1  // R_POWERPC_ADDR32
  2154		R_PPC64_ADDR24             R_PPC64 = 2  // R_POWERPC_ADDR24
  2155		R_PPC64_ADDR16             R_PPC64 = 3  // R_POWERPC_ADDR16
  2156		R_PPC64_ADDR16_LO          R_PPC64 = 4  // R_POWERPC_ADDR16_LO
  2157		R_PPC64_ADDR16_HI          R_PPC64 = 5  // R_POWERPC_ADDR16_HI
  2158		R_PPC64_ADDR16_HA          R_PPC64 = 6  // R_POWERPC_ADDR16_HA
  2159		R_PPC64_ADDR14             R_PPC64 = 7  // R_POWERPC_ADDR14
  2160		R_PPC64_ADDR14_BRTAKEN     R_PPC64 = 8  // R_POWERPC_ADDR14_BRTAKEN
  2161		R_PPC64_ADDR14_BRNTAKEN    R_PPC64 = 9  // R_POWERPC_ADDR14_BRNTAKEN
  2162		R_PPC64_REL24              R_PPC64 = 10 // R_POWERPC_REL24
  2163		R_PPC64_REL14              R_PPC64 = 11 // R_POWERPC_REL14
  2164		R_PPC64_REL14_BRTAKEN      R_PPC64 = 12 // R_POWERPC_REL14_BRTAKEN
  2165		R_PPC64_REL14_BRNTAKEN     R_PPC64 = 13 // R_POWERPC_REL14_BRNTAKEN
  2166		R_PPC64_GOT16              R_PPC64 = 14 // R_POWERPC_GOT16
  2167		R_PPC64_GOT16_LO           R_PPC64 = 15 // R_POWERPC_GOT16_LO
  2168		R_PPC64_GOT16_HI           R_PPC64 = 16 // R_POWERPC_GOT16_HI
  2169		R_PPC64_GOT16_HA           R_PPC64 = 17 // R_POWERPC_GOT16_HA
  2170		R_PPC64_JMP_SLOT           R_PPC64 = 21 // R_POWERPC_JMP_SLOT
  2171		R_PPC64_REL32              R_PPC64 = 26 // R_POWERPC_REL32
  2172		R_PPC64_ADDR64             R_PPC64 = 38
  2173		R_PPC64_ADDR16_HIGHER      R_PPC64 = 39
  2174		R_PPC64_ADDR16_HIGHERA     R_PPC64 = 40
  2175		R_PPC64_ADDR16_HIGHEST     R_PPC64 = 41
  2176		R_PPC64_ADDR16_HIGHESTA    R_PPC64 = 42
  2177		R_PPC64_REL64              R_PPC64 = 44
  2178		R_PPC64_TOC16              R_PPC64 = 47
  2179		R_PPC64_TOC16_LO           R_PPC64 = 48
  2180		R_PPC64_TOC16_HI           R_PPC64 = 49
  2181		R_PPC64_TOC16_HA           R_PPC64 = 50
  2182		R_PPC64_TOC                R_PPC64 = 51
  2183		R_PPC64_PLTGOT16           R_PPC64 = 52
  2184		R_PPC64_PLTGOT16_LO        R_PPC64 = 53
  2185		R_PPC64_PLTGOT16_HI        R_PPC64 = 54
  2186		R_PPC64_PLTGOT16_HA        R_PPC64 = 55
  2187		R_PPC64_ADDR16_DS          R_PPC64 = 56
  2188		R_PPC64_ADDR16_LO_DS       R_PPC64 = 57
  2189		R_PPC64_GOT16_DS           R_PPC64 = 58
  2190		R_PPC64_GOT16_LO_DS        R_PPC64 = 59
  2191		R_PPC64_PLT16_LO_DS        R_PPC64 = 60
  2192		R_PPC64_SECTOFF_DS         R_PPC64 = 61
  2193		R_PPC64_SECTOFF_LO_DS      R_PPC64 = 61
  2194		R_PPC64_TOC16_DS           R_PPC64 = 63
  2195		R_PPC64_TOC16_LO_DS        R_PPC64 = 64
  2196		R_PPC64_PLTGOT16_DS        R_PPC64 = 65
  2197		R_PPC64_PLTGOT_LO_DS       R_PPC64 = 66
  2198		R_PPC64_TLS                R_PPC64 = 67 // R_POWERPC_TLS
  2199		R_PPC64_DTPMOD64           R_PPC64 = 68 // R_POWERPC_DTPMOD64
  2200		R_PPC64_TPREL16            R_PPC64 = 69 // R_POWERPC_TPREL16
  2201		R_PPC64_TPREL16_LO         R_PPC64 = 70 // R_POWERPC_TPREL16_LO
  2202		R_PPC64_TPREL16_HI         R_PPC64 = 71 // R_POWERPC_TPREL16_HI
  2203		R_PPC64_TPREL16_HA         R_PPC64 = 72 // R_POWERPC_TPREL16_HA
  2204		R_PPC64_TPREL64            R_PPC64 = 73 // R_POWERPC_TPREL64
  2205		R_PPC64_DTPREL16           R_PPC64 = 74 // R_POWERPC_DTPREL16
  2206		R_PPC64_DTPREL16_LO        R_PPC64 = 75 // R_POWERPC_DTPREL16_LO
  2207		R_PPC64_DTPREL16_HI        R_PPC64 = 76 // R_POWERPC_DTPREL16_HI
  2208		R_PPC64_DTPREL16_HA        R_PPC64 = 77 // R_POWERPC_DTPREL16_HA
  2209		R_PPC64_DTPREL64           R_PPC64 = 78 // R_POWERPC_DTPREL64
  2210		R_PPC64_GOT_TLSGD16        R_PPC64 = 79 // R_POWERPC_GOT_TLSGD16
  2211		R_PPC64_GOT_TLSGD16_LO     R_PPC64 = 80 // R_POWERPC_GOT_TLSGD16_LO
  2212		R_PPC64_GOT_TLSGD16_HI     R_PPC64 = 81 // R_POWERPC_GOT_TLSGD16_HI
  2213		R_PPC64_GOT_TLSGD16_HA     R_PPC64 = 82 // R_POWERPC_GOT_TLSGD16_HA
  2214		R_PPC64_GOT_TLSLD16        R_PPC64 = 83 // R_POWERPC_GOT_TLSLD16
  2215		R_PPC64_GOT_TLSLD16_LO     R_PPC64 = 84 // R_POWERPC_GOT_TLSLD16_LO
  2216		R_PPC64_GOT_TLSLD16_HI     R_PPC64 = 85 // R_POWERPC_GOT_TLSLD16_HI
  2217		R_PPC64_GOT_TLSLD16_HA     R_PPC64 = 86 // R_POWERPC_GOT_TLSLD16_HA
  2218		R_PPC64_GOT_TPREL16_DS     R_PPC64 = 87 // R_POWERPC_GOT_TPREL16_DS
  2219		R_PPC64_GOT_TPREL16_LO_DS  R_PPC64 = 88 // R_POWERPC_GOT_TPREL16_LO_DS
  2220		R_PPC64_GOT_TPREL16_HI     R_PPC64 = 89 // R_POWERPC_GOT_TPREL16_HI
  2221		R_PPC64_GOT_TPREL16_HA     R_PPC64 = 90 // R_POWERPC_GOT_TPREL16_HA
  2222		R_PPC64_GOT_DTPREL16_DS    R_PPC64 = 91 // R_POWERPC_GOT_DTPREL16_DS
  2223		R_PPC64_GOT_DTPREL16_LO_DS R_PPC64 = 92 // R_POWERPC_GOT_DTPREL16_LO_DS
  2224		R_PPC64_GOT_DTPREL16_HI    R_PPC64 = 93 // R_POWERPC_GOT_DTPREL16_HI
  2225		R_PPC64_GOT_DTPREL16_HA    R_PPC64 = 94 // R_POWERPC_GOT_DTPREL16_HA
  2226		R_PPC64_TPREL16_DS         R_PPC64 = 95
  2227		R_PPC64_TPREL16_LO_DS      R_PPC64 = 96
  2228		R_PPC64_TPREL16_HIGHER     R_PPC64 = 97
  2229		R_PPC64_TPREL16_HIGHERA    R_PPC64 = 98
  2230		R_PPC64_TPREL16_HIGHEST    R_PPC64 = 99
  2231		R_PPC64_TPREL16_HIGHESTA   R_PPC64 = 100
  2232		R_PPC64_DTPREL16_DS        R_PPC64 = 101
  2233		R_PPC64_DTPREL16_LO_DS     R_PPC64 = 102
  2234		R_PPC64_DTPREL16_HIGHER    R_PPC64 = 103
  2235		R_PPC64_DTPREL16_HIGHERA   R_PPC64 = 104
  2236		R_PPC64_DTPREL16_HIGHEST   R_PPC64 = 105
  2237		R_PPC64_DTPREL16_HIGHESTA  R_PPC64 = 106
  2238		R_PPC64_TLSGD              R_PPC64 = 107
  2239		R_PPC64_TLSLD              R_PPC64 = 108
  2240		R_PPC64_TOCSAVE            R_PPC64 = 109
  2241		R_PPC64_ADDR16_HIGH        R_PPC64 = 110
  2242		R_PPC64_ADDR16_HIGHA       R_PPC64 = 111
  2243		R_PPC64_TPREL16_HIGH       R_PPC64 = 112
  2244		R_PPC64_TPREL16_HIGHA      R_PPC64 = 113
  2245		R_PPC64_DTPREL16_HIGH      R_PPC64 = 114
  2246		R_PPC64_DTPREL16_HIGHA     R_PPC64 = 115
  2247		R_PPC64_REL24_NOTOC        R_PPC64 = 116
  2248		R_PPC64_ADDR64_LOCAL       R_PPC64 = 117
  2249		R_PPC64_ENTRY              R_PPC64 = 118
  2250		R_PPC64_REL16DX_HA         R_PPC64 = 246 // R_POWERPC_REL16DX_HA
  2251		R_PPC64_JMP_IREL           R_PPC64 = 247
  2252		R_PPC64_IRELATIVE          R_PPC64 = 248 // R_POWERPC_IRELATIVE
  2253		R_PPC64_REL16              R_PPC64 = 249 // R_POWERPC_REL16
  2254		R_PPC64_REL16_LO           R_PPC64 = 250 // R_POWERPC_REL16_LO
  2255		R_PPC64_REL16_HI           R_PPC64 = 251 // R_POWERPC_REL16_HI
  2256		R_PPC64_REL16_HA           R_PPC64 = 252 // R_POWERPC_REL16_HA
  2257	)
  2258	
  2259	var rppc64Strings = []intName{
  2260		{0, "R_PPC64_NONE"},
  2261		{1, "R_PPC64_ADDR32"},
  2262		{2, "R_PPC64_ADDR24"},
  2263		{3, "R_PPC64_ADDR16"},
  2264		{4, "R_PPC64_ADDR16_LO"},
  2265		{5, "R_PPC64_ADDR16_HI"},
  2266		{6, "R_PPC64_ADDR16_HA"},
  2267		{7, "R_PPC64_ADDR14"},
  2268		{8, "R_PPC64_ADDR14_BRTAKEN"},
  2269		{9, "R_PPC64_ADDR14_BRNTAKEN"},
  2270		{10, "R_PPC64_REL24"},
  2271		{11, "R_PPC64_REL14"},
  2272		{12, "R_PPC64_REL14_BRTAKEN"},
  2273		{13, "R_PPC64_REL14_BRNTAKEN"},
  2274		{14, "R_PPC64_GOT16"},
  2275		{15, "R_PPC64_GOT16_LO"},
  2276		{16, "R_PPC64_GOT16_HI"},
  2277		{17, "R_PPC64_GOT16_HA"},
  2278		{21, "R_PPC64_JMP_SLOT"},
  2279		{26, "R_PPC64_REL32"},
  2280		{38, "R_PPC64_ADDR64"},
  2281		{39, "R_PPC64_ADDR16_HIGHER"},
  2282		{40, "R_PPC64_ADDR16_HIGHERA"},
  2283		{41, "R_PPC64_ADDR16_HIGHEST"},
  2284		{42, "R_PPC64_ADDR16_HIGHESTA"},
  2285		{44, "R_PPC64_REL64"},
  2286		{47, "R_PPC64_TOC16"},
  2287		{48, "R_PPC64_TOC16_LO"},
  2288		{49, "R_PPC64_TOC16_HI"},
  2289		{50, "R_PPC64_TOC16_HA"},
  2290		{51, "R_PPC64_TOC"},
  2291		{52, "R_PPC64_PLTGOT16"},
  2292		{53, "R_PPC64_PLTGOT16_LO"},
  2293		{54, "R_PPC64_PLTGOT16_HI"},
  2294		{55, "R_PPC64_PLTGOT16_HA"},
  2295		{56, "R_PPC64_ADDR16_DS"},
  2296		{57, "R_PPC64_ADDR16_LO_DS"},
  2297		{58, "R_PPC64_GOT16_DS"},
  2298		{59, "R_PPC64_GOT16_LO_DS"},
  2299		{60, "R_PPC64_PLT16_LO_DS"},
  2300		{61, "R_PPC64_SECTOFF_DS"},
  2301		{61, "R_PPC64_SECTOFF_LO_DS"},
  2302		{63, "R_PPC64_TOC16_DS"},
  2303		{64, "R_PPC64_TOC16_LO_DS"},
  2304		{65, "R_PPC64_PLTGOT16_DS"},
  2305		{66, "R_PPC64_PLTGOT_LO_DS"},
  2306		{67, "R_PPC64_TLS"},
  2307		{68, "R_PPC64_DTPMOD64"},
  2308		{69, "R_PPC64_TPREL16"},
  2309		{70, "R_PPC64_TPREL16_LO"},
  2310		{71, "R_PPC64_TPREL16_HI"},
  2311		{72, "R_PPC64_TPREL16_HA"},
  2312		{73, "R_PPC64_TPREL64"},
  2313		{74, "R_PPC64_DTPREL16"},
  2314		{75, "R_PPC64_DTPREL16_LO"},
  2315		{76, "R_PPC64_DTPREL16_HI"},
  2316		{77, "R_PPC64_DTPREL16_HA"},
  2317		{78, "R_PPC64_DTPREL64"},
  2318		{79, "R_PPC64_GOT_TLSGD16"},
  2319		{80, "R_PPC64_GOT_TLSGD16_LO"},
  2320		{81, "R_PPC64_GOT_TLSGD16_HI"},
  2321		{82, "R_PPC64_GOT_TLSGD16_HA"},
  2322		{83, "R_PPC64_GOT_TLSLD16"},
  2323		{84, "R_PPC64_GOT_TLSLD16_LO"},
  2324		{85, "R_PPC64_GOT_TLSLD16_HI"},
  2325		{86, "R_PPC64_GOT_TLSLD16_HA"},
  2326		{87, "R_PPC64_GOT_TPREL16_DS"},
  2327		{88, "R_PPC64_GOT_TPREL16_LO_DS"},
  2328		{89, "R_PPC64_GOT_TPREL16_HI"},
  2329		{90, "R_PPC64_GOT_TPREL16_HA"},
  2330		{91, "R_PPC64_GOT_DTPREL16_DS"},
  2331		{92, "R_PPC64_GOT_DTPREL16_LO_DS"},
  2332		{93, "R_PPC64_GOT_DTPREL16_HI"},
  2333		{94, "R_PPC64_GOT_DTPREL16_HA"},
  2334		{95, "R_PPC64_TPREL16_DS"},
  2335		{96, "R_PPC64_TPREL16_LO_DS"},
  2336		{97, "R_PPC64_TPREL16_HIGHER"},
  2337		{98, "R_PPC64_TPREL16_HIGHERA"},
  2338		{99, "R_PPC64_TPREL16_HIGHEST"},
  2339		{100, "R_PPC64_TPREL16_HIGHESTA"},
  2340		{101, "R_PPC64_DTPREL16_DS"},
  2341		{102, "R_PPC64_DTPREL16_LO_DS"},
  2342		{103, "R_PPC64_DTPREL16_HIGHER"},
  2343		{104, "R_PPC64_DTPREL16_HIGHERA"},
  2344		{105, "R_PPC64_DTPREL16_HIGHEST"},
  2345		{106, "R_PPC64_DTPREL16_HIGHESTA"},
  2346		{107, "R_PPC64_TLSGD"},
  2347		{108, "R_PPC64_TLSLD"},
  2348		{109, "R_PPC64_TOCSAVE"},
  2349		{110, "R_PPC64_ADDR16_HIGH"},
  2350		{111, "R_PPC64_ADDR16_HIGHA"},
  2351		{112, "R_PPC64_TPREL16_HIGH"},
  2352		{113, "R_PPC64_TPREL16_HIGHA"},
  2353		{114, "R_PPC64_DTPREL16_HIGH"},
  2354		{115, "R_PPC64_DTPREL16_HIGHA"},
  2355		{116, "R_PPC64_REL24_NOTOC"},
  2356		{117, "R_PPC64_ADDR64_LOCAL"},
  2357		{118, "R_PPC64_ENTRY"},
  2358		{246, "R_PPC64_REL16DX_HA"},
  2359		{247, "R_PPC64_JMP_IREL"},
  2360		{248, "R_PPC64_IRELATIVE"},
  2361		{249, "R_PPC64_REL16"},
  2362		{250, "R_PPC64_REL16_LO"},
  2363		{251, "R_PPC64_REL16_HI"},
  2364		{252, "R_PPC64_REL16_HA"},
  2365	}
  2366	
  2367	func (i R_PPC64) String() string   { return stringName(uint32(i), rppc64Strings, false) }
  2368	func (i R_PPC64) GoString() string { return stringName(uint32(i), rppc64Strings, true) }
  2369	
  2370	// Relocation types for RISC-V processors.
  2371	type R_RISCV int
  2372	
  2373	const (
  2374		R_RISCV_NONE          R_RISCV = 0  /* No relocation. */
  2375		R_RISCV_32            R_RISCV = 1  /* Add 32 bit zero extended symbol value */
  2376		R_RISCV_64            R_RISCV = 2  /* Add 64 bit symbol value. */
  2377		R_RISCV_RELATIVE      R_RISCV = 3  /* Add load address of shared object. */
  2378		R_RISCV_COPY          R_RISCV = 4  /* Copy data from shared object. */
  2379		R_RISCV_JUMP_SLOT     R_RISCV = 5  /* Set GOT entry to code address. */
  2380		R_RISCV_TLS_DTPMOD32  R_RISCV = 6  /* 32 bit ID of module containing symbol */
  2381		R_RISCV_TLS_DTPMOD64  R_RISCV = 7  /* ID of module containing symbol */
  2382		R_RISCV_TLS_DTPREL32  R_RISCV = 8  /* 32 bit relative offset in TLS block */
  2383		R_RISCV_TLS_DTPREL64  R_RISCV = 9  /* Relative offset in TLS block */
  2384		R_RISCV_TLS_TPREL32   R_RISCV = 10 /* 32 bit relative offset in static TLS block */
  2385		R_RISCV_TLS_TPREL64   R_RISCV = 11 /* Relative offset in static TLS block */
  2386		R_RISCV_BRANCH        R_RISCV = 16 /* PC-relative branch */
  2387		R_RISCV_JAL           R_RISCV = 17 /* PC-relative jump */
  2388		R_RISCV_CALL          R_RISCV = 18 /* PC-relative call */
  2389		R_RISCV_CALL_PLT      R_RISCV = 19 /* PC-relative call (PLT) */
  2390		R_RISCV_GOT_HI20      R_RISCV = 20 /* PC-relative GOT reference */
  2391		R_RISCV_TLS_GOT_HI20  R_RISCV = 21 /* PC-relative TLS IE GOT offset */
  2392		R_RISCV_TLS_GD_HI20   R_RISCV = 22 /* PC-relative TLS GD reference */
  2393		R_RISCV_PCREL_HI20    R_RISCV = 23 /* PC-relative reference */
  2394		R_RISCV_PCREL_LO12_I  R_RISCV = 24 /* PC-relative reference */
  2395		R_RISCV_PCREL_LO12_S  R_RISCV = 25 /* PC-relative reference */
  2396		R_RISCV_HI20          R_RISCV = 26 /* Absolute address */
  2397		R_RISCV_LO12_I        R_RISCV = 27 /* Absolute address */
  2398		R_RISCV_LO12_S        R_RISCV = 28 /* Absolute address */
  2399		R_RISCV_TPREL_HI20    R_RISCV = 29 /* TLS LE thread offset */
  2400		R_RISCV_TPREL_LO12_I  R_RISCV = 30 /* TLS LE thread offset */
  2401		R_RISCV_TPREL_LO12_S  R_RISCV = 31 /* TLS LE thread offset */
  2402		R_RISCV_TPREL_ADD     R_RISCV = 32 /* TLS LE thread usage */
  2403		R_RISCV_ADD8          R_RISCV = 33 /* 8-bit label addition */
  2404		R_RISCV_ADD16         R_RISCV = 34 /* 16-bit label addition */
  2405		R_RISCV_ADD32         R_RISCV = 35 /* 32-bit label addition */
  2406		R_RISCV_ADD64         R_RISCV = 36 /* 64-bit label addition */
  2407		R_RISCV_SUB8          R_RISCV = 37 /* 8-bit label subtraction */
  2408		R_RISCV_SUB16         R_RISCV = 38 /* 16-bit label subtraction */
  2409		R_RISCV_SUB32         R_RISCV = 39 /* 32-bit label subtraction */
  2410		R_RISCV_SUB64         R_RISCV = 40 /* 64-bit label subtraction */
  2411		R_RISCV_GNU_VTINHERIT R_RISCV = 41 /* GNU C++ vtable hierarchy */
  2412		R_RISCV_GNU_VTENTRY   R_RISCV = 42 /* GNU C++ vtable member usage */
  2413		R_RISCV_ALIGN         R_RISCV = 43 /* Alignment statement */
  2414		R_RISCV_RVC_BRANCH    R_RISCV = 44 /* PC-relative branch offset */
  2415		R_RISCV_RVC_JUMP      R_RISCV = 45 /* PC-relative jump offset */
  2416		R_RISCV_RVC_LUI       R_RISCV = 46 /* Absolute address */
  2417		R_RISCV_GPREL_I       R_RISCV = 47 /* GP-relative reference */
  2418		R_RISCV_GPREL_S       R_RISCV = 48 /* GP-relative reference */
  2419		R_RISCV_TPREL_I       R_RISCV = 49 /* TP-relative TLS LE load */
  2420		R_RISCV_TPREL_S       R_RISCV = 50 /* TP-relative TLS LE store */
  2421		R_RISCV_RELAX         R_RISCV = 51 /* Instruction pair can be relaxed */
  2422		R_RISCV_SUB6          R_RISCV = 52 /* Local label subtraction */
  2423		R_RISCV_SET6          R_RISCV = 53 /* Local label subtraction */
  2424		R_RISCV_SET8          R_RISCV = 54 /* Local label subtraction */
  2425		R_RISCV_SET16         R_RISCV = 55 /* Local label subtraction */
  2426		R_RISCV_SET32         R_RISCV = 56 /* Local label subtraction */
  2427		R_RISCV_32_PCREL      R_RISCV = 57 /* 32-bit PC relative */
  2428	)
  2429	
  2430	var rriscvStrings = []intName{
  2431		{0, "R_RISCV_NONE"},
  2432		{1, "R_RISCV_32"},
  2433		{2, "R_RISCV_64"},
  2434		{3, "R_RISCV_RELATIVE"},
  2435		{4, "R_RISCV_COPY"},
  2436		{5, "R_RISCV_JUMP_SLOT"},
  2437		{6, "R_RISCV_TLS_DTPMOD32"},
  2438		{7, "R_RISCV_TLS_DTPMOD64"},
  2439		{8, "R_RISCV_TLS_DTPREL32"},
  2440		{9, "R_RISCV_TLS_DTPREL64"},
  2441		{10, "R_RISCV_TLS_TPREL32"},
  2442		{11, "R_RISCV_TLS_TPREL64"},
  2443		{16, "R_RISCV_BRANCH"},
  2444		{17, "R_RISCV_JAL"},
  2445		{18, "R_RISCV_CALL"},
  2446		{19, "R_RISCV_CALL_PLT"},
  2447		{20, "R_RISCV_GOT_HI20"},
  2448		{21, "R_RISCV_TLS_GOT_HI20"},
  2449		{22, "R_RISCV_TLS_GD_HI20"},
  2450		{23, "R_RISCV_PCREL_HI20"},
  2451		{24, "R_RISCV_PCREL_LO12_I"},
  2452		{25, "R_RISCV_PCREL_LO12_S"},
  2453		{26, "R_RISCV_HI20"},
  2454		{27, "R_RISCV_LO12_I"},
  2455		{28, "R_RISCV_LO12_S"},
  2456		{29, "R_RISCV_TPREL_HI20"},
  2457		{30, "R_RISCV_TPREL_LO12_I"},
  2458		{31, "R_RISCV_TPREL_LO12_S"},
  2459		{32, "R_RISCV_TPREL_ADD"},
  2460		{33, "R_RISCV_ADD8"},
  2461		{34, "R_RISCV_ADD16"},
  2462		{35, "R_RISCV_ADD32"},
  2463		{36, "R_RISCV_ADD64"},
  2464		{37, "R_RISCV_SUB8"},
  2465		{38, "R_RISCV_SUB16"},
  2466		{39, "R_RISCV_SUB32"},
  2467		{40, "R_RISCV_SUB64"},
  2468		{41, "R_RISCV_GNU_VTINHERIT"},
  2469		{42, "R_RISCV_GNU_VTENTRY"},
  2470		{43, "R_RISCV_ALIGN"},
  2471		{44, "R_RISCV_RVC_BRANCH"},
  2472		{45, "R_RISCV_RVC_JUMP"},
  2473		{46, "R_RISCV_RVC_LUI"},
  2474		{47, "R_RISCV_GPREL_I"},
  2475		{48, "R_RISCV_GPREL_S"},
  2476		{49, "R_RISCV_TPREL_I"},
  2477		{50, "R_RISCV_TPREL_S"},
  2478		{51, "R_RISCV_RELAX"},
  2479		{52, "R_RISCV_SUB6"},
  2480		{53, "R_RISCV_SET6"},
  2481		{54, "R_RISCV_SET8"},
  2482		{55, "R_RISCV_SET16"},
  2483		{56, "R_RISCV_SET32"},
  2484		{57, "R_RISCV_32_PCREL"},
  2485	}
  2486	
  2487	func (i R_RISCV) String() string   { return stringName(uint32(i), rriscvStrings, false) }
  2488	func (i R_RISCV) GoString() string { return stringName(uint32(i), rriscvStrings, true) }
  2489	
  2490	// Relocation types for s390x processors.
  2491	type R_390 int
  2492	
  2493	const (
  2494		R_390_NONE        R_390 = 0
  2495		R_390_8           R_390 = 1
  2496		R_390_12          R_390 = 2
  2497		R_390_16          R_390 = 3
  2498		R_390_32          R_390 = 4
  2499		R_390_PC32        R_390 = 5
  2500		R_390_GOT12       R_390 = 6
  2501		R_390_GOT32       R_390 = 7
  2502		R_390_PLT32       R_390 = 8
  2503		R_390_COPY        R_390 = 9
  2504		R_390_GLOB_DAT    R_390 = 10
  2505		R_390_JMP_SLOT    R_390 = 11
  2506		R_390_RELATIVE    R_390 = 12
  2507		R_390_GOTOFF      R_390 = 13
  2508		R_390_GOTPC       R_390 = 14
  2509		R_390_GOT16       R_390 = 15
  2510		R_390_PC16        R_390 = 16
  2511		R_390_PC16DBL     R_390 = 17
  2512		R_390_PLT16DBL    R_390 = 18
  2513		R_390_PC32DBL     R_390 = 19
  2514		R_390_PLT32DBL    R_390 = 20
  2515		R_390_GOTPCDBL    R_390 = 21
  2516		R_390_64          R_390 = 22
  2517		R_390_PC64        R_390 = 23
  2518		R_390_GOT64       R_390 = 24
  2519		R_390_PLT64       R_390 = 25
  2520		R_390_GOTENT      R_390 = 26
  2521		R_390_GOTOFF16    R_390 = 27
  2522		R_390_GOTOFF64    R_390 = 28
  2523		R_390_GOTPLT12    R_390 = 29
  2524		R_390_GOTPLT16    R_390 = 30
  2525		R_390_GOTPLT32    R_390 = 31
  2526		R_390_GOTPLT64    R_390 = 32
  2527		R_390_GOTPLTENT   R_390 = 33
  2528		R_390_GOTPLTOFF16 R_390 = 34
  2529		R_390_GOTPLTOFF32 R_390 = 35
  2530		R_390_GOTPLTOFF64 R_390 = 36
  2531		R_390_TLS_LOAD    R_390 = 37
  2532		R_390_TLS_GDCALL  R_390 = 38
  2533		R_390_TLS_LDCALL  R_390 = 39
  2534		R_390_TLS_GD32    R_390 = 40
  2535		R_390_TLS_GD64    R_390 = 41
  2536		R_390_TLS_GOTIE12 R_390 = 42
  2537		R_390_TLS_GOTIE32 R_390 = 43
  2538		R_390_TLS_GOTIE64 R_390 = 44
  2539		R_390_TLS_LDM32   R_390 = 45
  2540		R_390_TLS_LDM64   R_390 = 46
  2541		R_390_TLS_IE32    R_390 = 47
  2542		R_390_TLS_IE64    R_390 = 48
  2543		R_390_TLS_IEENT   R_390 = 49
  2544		R_390_TLS_LE32    R_390 = 50
  2545		R_390_TLS_LE64    R_390 = 51
  2546		R_390_TLS_LDO32   R_390 = 52
  2547		R_390_TLS_LDO64   R_390 = 53
  2548		R_390_TLS_DTPMOD  R_390 = 54
  2549		R_390_TLS_DTPOFF  R_390 = 55
  2550		R_390_TLS_TPOFF   R_390 = 56
  2551		R_390_20          R_390 = 57
  2552		R_390_GOT20       R_390 = 58
  2553		R_390_GOTPLT20    R_390 = 59
  2554		R_390_TLS_GOTIE20 R_390 = 60
  2555	)
  2556	
  2557	var r390Strings = []intName{
  2558		{0, "R_390_NONE"},
  2559		{1, "R_390_8"},
  2560		{2, "R_390_12"},
  2561		{3, "R_390_16"},
  2562		{4, "R_390_32"},
  2563		{5, "R_390_PC32"},
  2564		{6, "R_390_GOT12"},
  2565		{7, "R_390_GOT32"},
  2566		{8, "R_390_PLT32"},
  2567		{9, "R_390_COPY"},
  2568		{10, "R_390_GLOB_DAT"},
  2569		{11, "R_390_JMP_SLOT"},
  2570		{12, "R_390_RELATIVE"},
  2571		{13, "R_390_GOTOFF"},
  2572		{14, "R_390_GOTPC"},
  2573		{15, "R_390_GOT16"},
  2574		{16, "R_390_PC16"},
  2575		{17, "R_390_PC16DBL"},
  2576		{18, "R_390_PLT16DBL"},
  2577		{19, "R_390_PC32DBL"},
  2578		{20, "R_390_PLT32DBL"},
  2579		{21, "R_390_GOTPCDBL"},
  2580		{22, "R_390_64"},
  2581		{23, "R_390_PC64"},
  2582		{24, "R_390_GOT64"},
  2583		{25, "R_390_PLT64"},
  2584		{26, "R_390_GOTENT"},
  2585		{27, "R_390_GOTOFF16"},
  2586		{28, "R_390_GOTOFF64"},
  2587		{29, "R_390_GOTPLT12"},
  2588		{30, "R_390_GOTPLT16"},
  2589		{31, "R_390_GOTPLT32"},
  2590		{32, "R_390_GOTPLT64"},
  2591		{33, "R_390_GOTPLTENT"},
  2592		{34, "R_390_GOTPLTOFF16"},
  2593		{35, "R_390_GOTPLTOFF32"},
  2594		{36, "R_390_GOTPLTOFF64"},
  2595		{37, "R_390_TLS_LOAD"},
  2596		{38, "R_390_TLS_GDCALL"},
  2597		{39, "R_390_TLS_LDCALL"},
  2598		{40, "R_390_TLS_GD32"},
  2599		{41, "R_390_TLS_GD64"},
  2600		{42, "R_390_TLS_GOTIE12"},
  2601		{43, "R_390_TLS_GOTIE32"},
  2602		{44, "R_390_TLS_GOTIE64"},
  2603		{45, "R_390_TLS_LDM32"},
  2604		{46, "R_390_TLS_LDM64"},
  2605		{47, "R_390_TLS_IE32"},
  2606		{48, "R_390_TLS_IE64"},
  2607		{49, "R_390_TLS_IEENT"},
  2608		{50, "R_390_TLS_LE32"},
  2609		{51, "R_390_TLS_LE64"},
  2610		{52, "R_390_TLS_LDO32"},
  2611		{53, "R_390_TLS_LDO64"},
  2612		{54, "R_390_TLS_DTPMOD"},
  2613		{55, "R_390_TLS_DTPOFF"},
  2614		{56, "R_390_TLS_TPOFF"},
  2615		{57, "R_390_20"},
  2616		{58, "R_390_GOT20"},
  2617		{59, "R_390_GOTPLT20"},
  2618		{60, "R_390_TLS_GOTIE20"},
  2619	}
  2620	
  2621	func (i R_390) String() string   { return stringName(uint32(i), r390Strings, false) }
  2622	func (i R_390) GoString() string { return stringName(uint32(i), r390Strings, true) }
  2623	
  2624	// Relocation types for SPARC.
  2625	type R_SPARC int
  2626	
  2627	const (
  2628		R_SPARC_NONE     R_SPARC = 0
  2629		R_SPARC_8        R_SPARC = 1
  2630		R_SPARC_16       R_SPARC = 2
  2631		R_SPARC_32       R_SPARC = 3
  2632		R_SPARC_DISP8    R_SPARC = 4
  2633		R_SPARC_DISP16   R_SPARC = 5
  2634		R_SPARC_DISP32   R_SPARC = 6
  2635		R_SPARC_WDISP30  R_SPARC = 7
  2636		R_SPARC_WDISP22  R_SPARC = 8
  2637		R_SPARC_HI22     R_SPARC = 9
  2638		R_SPARC_22       R_SPARC = 10
  2639		R_SPARC_13       R_SPARC = 11
  2640		R_SPARC_LO10     R_SPARC = 12
  2641		R_SPARC_GOT10    R_SPARC = 13
  2642		R_SPARC_GOT13    R_SPARC = 14
  2643		R_SPARC_GOT22    R_SPARC = 15
  2644		R_SPARC_PC10     R_SPARC = 16
  2645		R_SPARC_PC22     R_SPARC = 17
  2646		R_SPARC_WPLT30   R_SPARC = 18
  2647		R_SPARC_COPY     R_SPARC = 19
  2648		R_SPARC_GLOB_DAT R_SPARC = 20
  2649		R_SPARC_JMP_SLOT R_SPARC = 21
  2650		R_SPARC_RELATIVE R_SPARC = 22
  2651		R_SPARC_UA32     R_SPARC = 23
  2652		R_SPARC_PLT32    R_SPARC = 24
  2653		R_SPARC_HIPLT22  R_SPARC = 25
  2654		R_SPARC_LOPLT10  R_SPARC = 26
  2655		R_SPARC_PCPLT32  R_SPARC = 27
  2656		R_SPARC_PCPLT22  R_SPARC = 28
  2657		R_SPARC_PCPLT10  R_SPARC = 29
  2658		R_SPARC_10       R_SPARC = 30
  2659		R_SPARC_11       R_SPARC = 31
  2660		R_SPARC_64       R_SPARC = 32
  2661		R_SPARC_OLO10    R_SPARC = 33
  2662		R_SPARC_HH22     R_SPARC = 34
  2663		R_SPARC_HM10     R_SPARC = 35
  2664		R_SPARC_LM22     R_SPARC = 36
  2665		R_SPARC_PC_HH22  R_SPARC = 37
  2666		R_SPARC_PC_HM10  R_SPARC = 38
  2667		R_SPARC_PC_LM22  R_SPARC = 39
  2668		R_SPARC_WDISP16  R_SPARC = 40
  2669		R_SPARC_WDISP19  R_SPARC = 41
  2670		R_SPARC_GLOB_JMP R_SPARC = 42
  2671		R_SPARC_7        R_SPARC = 43
  2672		R_SPARC_5        R_SPARC = 44
  2673		R_SPARC_6        R_SPARC = 45
  2674		R_SPARC_DISP64   R_SPARC = 46
  2675		R_SPARC_PLT64    R_SPARC = 47
  2676		R_SPARC_HIX22    R_SPARC = 48
  2677		R_SPARC_LOX10    R_SPARC = 49
  2678		R_SPARC_H44      R_SPARC = 50
  2679		R_SPARC_M44      R_SPARC = 51
  2680		R_SPARC_L44      R_SPARC = 52
  2681		R_SPARC_REGISTER R_SPARC = 53
  2682		R_SPARC_UA64     R_SPARC = 54
  2683		R_SPARC_UA16     R_SPARC = 55
  2684	)
  2685	
  2686	var rsparcStrings = []intName{
  2687		{0, "R_SPARC_NONE"},
  2688		{1, "R_SPARC_8"},
  2689		{2, "R_SPARC_16"},
  2690		{3, "R_SPARC_32"},
  2691		{4, "R_SPARC_DISP8"},
  2692		{5, "R_SPARC_DISP16"},
  2693		{6, "R_SPARC_DISP32"},
  2694		{7, "R_SPARC_WDISP30"},
  2695		{8, "R_SPARC_WDISP22"},
  2696		{9, "R_SPARC_HI22"},
  2697		{10, "R_SPARC_22"},
  2698		{11, "R_SPARC_13"},
  2699		{12, "R_SPARC_LO10"},
  2700		{13, "R_SPARC_GOT10"},
  2701		{14, "R_SPARC_GOT13"},
  2702		{15, "R_SPARC_GOT22"},
  2703		{16, "R_SPARC_PC10"},
  2704		{17, "R_SPARC_PC22"},
  2705		{18, "R_SPARC_WPLT30"},
  2706		{19, "R_SPARC_COPY"},
  2707		{20, "R_SPARC_GLOB_DAT"},
  2708		{21, "R_SPARC_JMP_SLOT"},
  2709		{22, "R_SPARC_RELATIVE"},
  2710		{23, "R_SPARC_UA32"},
  2711		{24, "R_SPARC_PLT32"},
  2712		{25, "R_SPARC_HIPLT22"},
  2713		{26, "R_SPARC_LOPLT10"},
  2714		{27, "R_SPARC_PCPLT32"},
  2715		{28, "R_SPARC_PCPLT22"},
  2716		{29, "R_SPARC_PCPLT10"},
  2717		{30, "R_SPARC_10"},
  2718		{31, "R_SPARC_11"},
  2719		{32, "R_SPARC_64"},
  2720		{33, "R_SPARC_OLO10"},
  2721		{34, "R_SPARC_HH22"},
  2722		{35, "R_SPARC_HM10"},
  2723		{36, "R_SPARC_LM22"},
  2724		{37, "R_SPARC_PC_HH22"},
  2725		{38, "R_SPARC_PC_HM10"},
  2726		{39, "R_SPARC_PC_LM22"},
  2727		{40, "R_SPARC_WDISP16"},
  2728		{41, "R_SPARC_WDISP19"},
  2729		{42, "R_SPARC_GLOB_JMP"},
  2730		{43, "R_SPARC_7"},
  2731		{44, "R_SPARC_5"},
  2732		{45, "R_SPARC_6"},
  2733		{46, "R_SPARC_DISP64"},
  2734		{47, "R_SPARC_PLT64"},
  2735		{48, "R_SPARC_HIX22"},
  2736		{49, "R_SPARC_LOX10"},
  2737		{50, "R_SPARC_H44"},
  2738		{51, "R_SPARC_M44"},
  2739		{52, "R_SPARC_L44"},
  2740		{53, "R_SPARC_REGISTER"},
  2741		{54, "R_SPARC_UA64"},
  2742		{55, "R_SPARC_UA16"},
  2743	}
  2744	
  2745	func (i R_SPARC) String() string   { return stringName(uint32(i), rsparcStrings, false) }
  2746	func (i R_SPARC) GoString() string { return stringName(uint32(i), rsparcStrings, true) }
  2747	
  2748	// Magic number for the elf trampoline, chosen wisely to be an immediate value.
  2749	const ARM_MAGIC_TRAMP_NUMBER = 0x5c000003
  2750	
  2751	// ELF32 File header.
  2752	type Header32 struct {
  2753		Ident     [EI_NIDENT]byte /* File identification. */
  2754		Type      uint16          /* File type. */
  2755		Machine   uint16          /* Machine architecture. */
  2756		Version   uint32          /* ELF format version. */
  2757		Entry     uint32          /* Entry point. */
  2758		Phoff     uint32          /* Program header file offset. */
  2759		Shoff     uint32          /* Section header file offset. */
  2760		Flags     uint32          /* Architecture-specific flags. */
  2761		Ehsize    uint16          /* Size of ELF header in bytes. */
  2762		Phentsize uint16          /* Size of program header entry. */
  2763		Phnum     uint16          /* Number of program header entries. */
  2764		Shentsize uint16          /* Size of section header entry. */
  2765		Shnum     uint16          /* Number of section header entries. */
  2766		Shstrndx  uint16          /* Section name strings section. */
  2767	}
  2768	
  2769	// ELF32 Section header.
  2770	type Section32 struct {
  2771		Name      uint32 /* Section name (index into the section header string table). */
  2772		Type      uint32 /* Section type. */
  2773		Flags     uint32 /* Section flags. */
  2774		Addr      uint32 /* Address in memory image. */
  2775		Off       uint32 /* Offset in file. */
  2776		Size      uint32 /* Size in bytes. */
  2777		Link      uint32 /* Index of a related section. */
  2778		Info      uint32 /* Depends on section type. */
  2779		Addralign uint32 /* Alignment in bytes. */
  2780		Entsize   uint32 /* Size of each entry in section. */
  2781	}
  2782	
  2783	// ELF32 Program header.
  2784	type Prog32 struct {
  2785		Type   uint32 /* Entry type. */
  2786		Off    uint32 /* File offset of contents. */
  2787		Vaddr  uint32 /* Virtual address in memory image. */
  2788		Paddr  uint32 /* Physical address (not used). */
  2789		Filesz uint32 /* Size of contents in file. */
  2790		Memsz  uint32 /* Size of contents in memory. */
  2791		Flags  uint32 /* Access permission flags. */
  2792		Align  uint32 /* Alignment in memory and file. */
  2793	}
  2794	
  2795	// ELF32 Dynamic structure. The ".dynamic" section contains an array of them.
  2796	type Dyn32 struct {
  2797		Tag int32  /* Entry type. */
  2798		Val uint32 /* Integer/Address value. */
  2799	}
  2800	
  2801	// ELF32 Compression header.
  2802	type Chdr32 struct {
  2803		Type      uint32
  2804		Size      uint32
  2805		Addralign uint32
  2806	}
  2807	
  2808	/*
  2809	 * Relocation entries.
  2810	 */
  2811	
  2812	// ELF32 Relocations that don't need an addend field.
  2813	type Rel32 struct {
  2814		Off  uint32 /* Location to be relocated. */
  2815		Info uint32 /* Relocation type and symbol index. */
  2816	}
  2817	
  2818	// ELF32 Relocations that need an addend field.
  2819	type Rela32 struct {
  2820		Off    uint32 /* Location to be relocated. */
  2821		Info   uint32 /* Relocation type and symbol index. */
  2822		Addend int32  /* Addend. */
  2823	}
  2824	
  2825	func R_SYM32(info uint32) uint32      { return info >> 8 }
  2826	func R_TYPE32(info uint32) uint32     { return info & 0xff }
  2827	func R_INFO32(sym, typ uint32) uint32 { return sym<<8 | typ }
  2828	
  2829	// ELF32 Symbol.
  2830	type Sym32 struct {
  2831		Name  uint32
  2832		Value uint32
  2833		Size  uint32
  2834		Info  uint8
  2835		Other uint8
  2836		Shndx uint16
  2837	}
  2838	
  2839	const Sym32Size = 16
  2840	
  2841	func ST_BIND(info uint8) SymBind { return SymBind(info >> 4) }
  2842	func ST_TYPE(info uint8) SymType { return SymType(info & 0xF) }
  2843	func ST_INFO(bind SymBind, typ SymType) uint8 {
  2844		return uint8(bind)<<4 | uint8(typ)&0xf
  2845	}
  2846	func ST_VISIBILITY(other uint8) SymVis { return SymVis(other & 3) }
  2847	
  2848	/*
  2849	 * ELF64
  2850	 */
  2851	
  2852	// ELF64 file header.
  2853	type Header64 struct {
  2854		Ident     [EI_NIDENT]byte /* File identification. */
  2855		Type      uint16          /* File type. */
  2856		Machine   uint16          /* Machine architecture. */
  2857		Version   uint32          /* ELF format version. */
  2858		Entry     uint64          /* Entry point. */
  2859		Phoff     uint64          /* Program header file offset. */
  2860		Shoff     uint64          /* Section header file offset. */
  2861		Flags     uint32          /* Architecture-specific flags. */
  2862		Ehsize    uint16          /* Size of ELF header in bytes. */
  2863		Phentsize uint16          /* Size of program header entry. */
  2864		Phnum     uint16          /* Number of program header entries. */
  2865		Shentsize uint16          /* Size of section header entry. */
  2866		Shnum     uint16          /* Number of section header entries. */
  2867		Shstrndx  uint16          /* Section name strings section. */
  2868	}
  2869	
  2870	// ELF64 Section header.
  2871	type Section64 struct {
  2872		Name      uint32 /* Section name (index into the section header string table). */
  2873		Type      uint32 /* Section type. */
  2874		Flags     uint64 /* Section flags. */
  2875		Addr      uint64 /* Address in memory image. */
  2876		Off       uint64 /* Offset in file. */
  2877		Size      uint64 /* Size in bytes. */
  2878		Link      uint32 /* Index of a related section. */
  2879		Info      uint32 /* Depends on section type. */
  2880		Addralign uint64 /* Alignment in bytes. */
  2881		Entsize   uint64 /* Size of each entry in section. */
  2882	}
  2883	
  2884	// ELF64 Program header.
  2885	type Prog64 struct {
  2886		Type   uint32 /* Entry type. */
  2887		Flags  uint32 /* Access permission flags. */
  2888		Off    uint64 /* File offset of contents. */
  2889		Vaddr  uint64 /* Virtual address in memory image. */
  2890		Paddr  uint64 /* Physical address (not used). */
  2891		Filesz uint64 /* Size of contents in file. */
  2892		Memsz  uint64 /* Size of contents in memory. */
  2893		Align  uint64 /* Alignment in memory and file. */
  2894	}
  2895	
  2896	// ELF64 Dynamic structure. The ".dynamic" section contains an array of them.
  2897	type Dyn64 struct {
  2898		Tag int64  /* Entry type. */
  2899		Val uint64 /* Integer/address value */
  2900	}
  2901	
  2902	// ELF64 Compression header.
  2903	type Chdr64 struct {
  2904		Type      uint32
  2905		_         uint32 /* Reserved. */
  2906		Size      uint64
  2907		Addralign uint64
  2908	}
  2909	
  2910	/*
  2911	 * Relocation entries.
  2912	 */
  2913	
  2914	/* ELF64 relocations that don't need an addend field. */
  2915	type Rel64 struct {
  2916		Off  uint64 /* Location to be relocated. */
  2917		Info uint64 /* Relocation type and symbol index. */
  2918	}
  2919	
  2920	/* ELF64 relocations that need an addend field. */
  2921	type Rela64 struct {
  2922		Off    uint64 /* Location to be relocated. */
  2923		Info   uint64 /* Relocation type and symbol index. */
  2924		Addend int64  /* Addend. */
  2925	}
  2926	
  2927	func R_SYM64(info uint64) uint32    { return uint32(info >> 32) }
  2928	func R_TYPE64(info uint64) uint32   { return uint32(info) }
  2929	func R_INFO(sym, typ uint32) uint64 { return uint64(sym)<<32 | uint64(typ) }
  2930	
  2931	// ELF64 symbol table entries.
  2932	type Sym64 struct {
  2933		Name  uint32 /* String table index of name. */
  2934		Info  uint8  /* Type and binding information. */
  2935		Other uint8  /* Reserved (not used). */
  2936		Shndx uint16 /* Section index of symbol. */
  2937		Value uint64 /* Symbol value. */
  2938		Size  uint64 /* Size of associated object. */
  2939	}
  2940	
  2941	const Sym64Size = 24
  2942	
  2943	type intName struct {
  2944		i uint32
  2945		s string
  2946	}
  2947	
  2948	func stringName(i uint32, names []intName, goSyntax bool) string {
  2949		for _, n := range names {
  2950			if n.i == i {
  2951				if goSyntax {
  2952					return "elf." + n.s
  2953				}
  2954				return n.s
  2955			}
  2956		}
  2957	
  2958		// second pass - look for smaller to add with.
  2959		// assume sorted already
  2960		for j := len(names) - 1; j >= 0; j-- {
  2961			n := names[j]
  2962			if n.i < i {
  2963				s := n.s
  2964				if goSyntax {
  2965					s = "elf." + s
  2966				}
  2967				return s + "+" + strconv.FormatUint(uint64(i-n.i), 10)
  2968			}
  2969		}
  2970	
  2971		return strconv.FormatUint(uint64(i), 10)
  2972	}
  2973	
  2974	func flagName(i uint32, names []intName, goSyntax bool) string {
  2975		s := ""
  2976		for _, n := range names {
  2977			if n.i&i == n.i {
  2978				if len(s) > 0 {
  2979					s += "+"
  2980				}
  2981				if goSyntax {
  2982					s += "elf."
  2983				}
  2984				s += n.s
  2985				i -= n.i
  2986			}
  2987		}
  2988		if len(s) == 0 {
  2989			return "0x" + strconv.FormatUint(uint64(i), 16)
  2990		}
  2991		if i != 0 {
  2992			s += "+0x" + strconv.FormatUint(uint64(i), 16)
  2993		}
  2994		return s
  2995	}
  2996	

View as plain text