* Makefile.am (ALL_MACHINES): Add cpu-tilegx.lo and cpu-tilepro.lo.
(ALL_MACHINE_CFILES): Add cpu-tilegx.c and cpu-tilepro.c.
    (BFD32_BACKENDS): Add elf32-tilegx.lo, elf32-tilepro.lo,
    and elfxx-tilegx.lo.
    (BFD32_BACKENDS_CFILES): Add elf32-tilegx.c elf32-tilepro.c, and
    elfxx-tilegx.c.
    (BFD64_BACKENDS): Add elf64-tilegx.lo.
    (BFD64_BACKENDS_CFILES): Add elf64-tilegx.c.
    * Makefile.in: Regenerate.
    * arctures.c (bfd_architecture): Define bfd_arch_tilepro,
    bfd_arch_tilegx, bfd_mach_tilepro, bfd_mach_tilegx.
    (bfd_arch_info): Add bfd_tilegx_arch, bfd_tilepro_arch.
    (bfd_archures_list): Add bfd_tilegx_arch, bfd_tilepro_arch.
    bfd-in2.h: Regenerate.
    * config.bfd: Handle tilegx-*-* and tilepro-*-*.
    * configure.in: Handle bfd_elf32_tilegx_vec, bfd_elf32_tilepro_vec,
    and bfd_elf64_tilegx_vec.
    * configure: Regenerate.
    * elf-bfd.h (enum elf_target_id): Define TILEGX_ELF_DATA and
    TILEPRO_ELF_DATA.
    * libbfd.h: Regenerate.
    * reloc.c: Add BFD_RELOC_TILEPRO_{COPY, GLOB_DAT, JMP_SLOT,
    RELATIVE, BROFF_X1, JOFFLONG_X1, JOFFLONG_X1_PLT, IMM8_X0,
    IMM8_Y0, IMM8_X1, IMM8_Y1, DEST_IMM8_X1, MT_IMM15_X1, MF_IMM15_X1,
    IMM16_X0, IMM16_X1, IMM16_X0_LO, IMM16_X1_LO, IMM16_X0_HI,
    IMM16_X1_HI, IMM16_X0_HA, IMM16_X1_HA, IMM16_X0_PCREL,
    IMM16_X1_PCREL, IMM16_X0_LO_PCREL, IMM16_X1_LO_PCREL,
    IMM16_X0_HI_PCREL, IMM16_X1_HI_PCREL, IMM16_X0_HA_PCREL,
    IMM16_X1_HA_PCREL, IMM16_X0_GOT, IMM16_X1_GOT, IMM16_X0_GOT_LO,
    IMM16_X1_GOT_LO, IMM16_X0_GOT_HI, IMM16_X1_GOT_HI,
    IMM16_X0_GOT_HA, IMM16_X1_GOT_HA, MMSTART_X0, MMEND_X0,
    MMSTART_X1, MMEND_X1, SHAMT_X0, SHAMT_X1, SHAMT_Y0, SHAMT_Y1,
    IMM16_X0_TLS_GD, IMM16_X1_TLS_GD, IMM16_X0_TLS_GD_LO,
    IMM16_X1_TLS_GD_LO, IMM16_X0_TLS_GD_HI, IMM16_X1_TLS_GD_HI,
    IMM16_X0_TLS_GD_HA, IMM16_X1_TLS_GD_HA, IMM16_X0_TLS_IE,
    IMM16_X1_TLS_IE, IMM16_X0_TLS_IE_LO, IMM16_X1_TLS_IE_LO,
    IMM16_X0_TLS_IE_HI, IMM16_X1_TLS_IE_HI, IMM16_X0_TLS_IE_HA,
    IMM16_X1_TLS_IE_HA, TLS_DTPMOD32, TLS_DTPOFF32, TLS_TPOFF32}
    Add BFD_RELOC_TILEGX_{HW0, HW1, HW2, HW3, HW0_LAST, HW1_LAST,
    HW2_LAST, COPY, GLOB_DAT, JMP_SLOT, RELATIVE, BROFF_X1,
    JUMPOFF_X1, JUMPOFF_X1_PLT, IMM8_X0, IMM8_Y0, IMM8_X1, IMM8_Y1,
    DEST_IMM8_X1, MT_IMM14_X1, MF_IMM14_X1, MMSTART_X0, MMEND_X0,
    SHAMT_X0, SHAMT_X1, SHAMT_Y0, SHAMT_Y1, IMM16_X0_HW0,
    IMM16_X1_HW0, IMM16_X0_HW1, IMM16_X1_HW1, IMM16_X0_HW2,
    IMM16_X1_HW2, IMM16_X0_HW3, IMM16_X1_HW3, IMM16_X0_HW0_LAST,
    IMM16_X1_HW0_LAST, IMM16_X0_HW1_LAST, IMM16_X1_HW1_LAST,
    IMM16_X0_HW2_LAST, IMM16_X1_HW2_LAST, IMM16_X0_HW0_PCREL,
    IMM16_X1_HW0_PCREL, IMM16_X0_HW1_PCREL, IMM16_X1_HW1_PCREL,
    IMM16_X0_HW2_PCREL, IMM16_X1_HW2_PCREL, IMM16_X0_HW3_PCREL,
    IMM16_X1_HW3_PCREL, IMM16_X0_HW0_LAST_PCREL,
    IMM16_X1_HW0_LAST_PCREL, IMM16_X0_HW1_LAST_PCREL,
    IMM16_X1_HW1_LAST_PCREL, IMM16_X0_HW2_LAST_PCREL,
    IMM16_X1_HW2_LAST_PCREL, IMM16_X0_HW0_GOT, IMM16_X1_HW0_GOT,
    IMM16_X0_HW1_GOT, IMM16_X1_HW1_GOT, IMM16_X0_HW2_GOT,
    IMM16_X1_HW2_GOT, IMM16_X0_HW3_GOT, IMM16_X1_HW3_GOT,
    IMM16_X0_HW0_LAST_GOT, IMM16_X1_HW0_LAST_GOT,
    IMM16_X0_HW1_LAST_GOT, IMM16_X1_HW1_LAST_GOT,
    IMM16_X0_HW2_LAST_GOT, IMM16_X1_HW2_LAST_GOT, IMM16_X0_HW0_TLS_GD,
    IMM16_X1_HW0_TLS_GD, IMM16_X0_HW1_TLS_GD, IMM16_X1_HW1_TLS_GD,
    IMM16_X0_HW2_TLS_GD, IMM16_X1_HW2_TLS_GD, IMM16_X0_HW3_TLS_GD,
    IMM16_X1_HW3_TLS_GD, IMM16_X0_HW0_LAST_TLS_GD,
    IMM16_X1_HW0_LAST_TLS_GD, IMM16_X0_HW1_LAST_TLS_GD,
    IMM16_X1_HW1_LAST_TLS_GD, IMM16_X0_HW2_LAST_TLS_GD,
    IMM16_X1_HW2_LAST_TLS_GD, IMM16_X0_HW0_TLS_IE,
    IMM16_X1_HW0_TLS_IE, IMM16_X0_HW1_TLS_IE, IMM16_X1_HW1_TLS_IE,
    IMM16_X0_HW2_TLS_IE, IMM16_X1_HW2_TLS_IE, IMM16_X0_HW3_TLS_IE,
    IMM16_X1_HW3_TLS_IE, IMM16_X0_HW0_LAST_TLS_IE,
    IMM16_X1_HW0_LAST_TLS_IE, IMM16_X0_HW1_LAST_TLS_IE,
    IMM16_X1_HW1_LAST_TLS_IE, IMM16_X0_HW2_LAST_TLS_IE,
    IMM16_X1_HW2_LAST_TLS_IE, TLS_DTPMOD64, TLS_DTPOFF64, TLS_TPOFF64,
    TLS_DTPMOD32, TLS_DTPOFF32, TLS_TPOFF32}
    * targets.c (bfd_elf32_tilegx_vec): Declare.
    (bfd_elf32_tilepro_vec): Declare.
    (bfd_elf64_tilegx_vec): Declare.
    (bfd_target_vector): Add bfd_elf32_tilegx_vec, bfd_elf32_tilepro_vec,
    and bfd_elf64_tilegx_vec.
    * cpu-tilegx.c: New file.
    * cpu-tilepro.c: New file.
    * elf32-tilepro.h: New file.
    * elf32-tilepro.c: New file.
    * elf32-tilegx.c: New file.
    * elf32-tilegx.h: New file.
    * elf64-tilegx.c: New file.
    * elf64-tilegx.h: New file.
    * elfxx-tilegx.c: New file.
    * elfxx-tilegx.h: New file.
	* Makefile.am (TARGET_CPU_CFILES): Add config/tc-tilegx.c and
	config/tc-tilepro.c.
	(TARGET_CPU_HFILES): Add config/tc-tilegx.h and
	config/tc-tilepro.h.
	* Makefile.in: Regenerate.
	* configure.tgt (tilepro-*-*): New.
	(tilegx-*-*): Likewise.
	* config/tc-tilegx.c: New file.
	* config/tc-tilegx.h: Likewise.
	* config/tc-tilepro.h: Likewise.
	* config/tc-tilepro.c: Likewise.
	* doc/Makefile.am (CPU_DOCS): Add c-tilegx.texi and
	c-tilepro.texi.
	* doc/Makefile.in: Regenerate.
	* doc/all.texi (TILEGX): Define.
	(TILEPRO): Define.
	* doc/as.texinfo: Add Tile-Gx and TILEPro documentation.  Include
	c-tilegx.texi and c-tilepro.texi.
	* doc/c-tilegx.texi: New.
	* doc/c-tilepro.texi: New.
        * gas/tilepro/t_constants.s: New file.
	* gas/tilepro/t_constants.d: Likewise.
	* gas/tilepro/t_insns.s: Likewise.
	* gas/tilepro/tilepro.exp: Likewise.
	* gas/tilepro/t_insns.d: Likewise.
	* gas/tilegx/tilegx.exp: Likewise.
	* gas/tilegx/t_insns.d: Likewise.
	* gas/tilegx/t_insns.s: Likewise.
	* dis-asm.h (print_insn_tilegx): Declare.
	(print_insn_tilepro): Likewise.
	* tilegx.h: New file.
	* tilepro.h: New file.
	* common.h: Add EM_TILEGX.
	* tilegx.h: New file.
	* tilepro.h: New file.
	* Makefile.am (ALL_EMULATION_SOURCES): Add eelf32tilegx.c and
	eelf32tilepro.c.
	(ALL_64_EMULATION_SOURCES): Add eelf64tilegx.c.
	(eelf32tilegx.c): New target.
	(eelf32tilepro.c): Likewise.
	(eelf64tilegx.c): Likewise.
	* Makefile.in: Regenerate.
	* configure.tgt: Handle tilegx-*-* and tilepro-*-*.
	* emulparams/elf32tilegx.sh: New file.
	* emulparams/elf64tilegx.sh: New file.
	* emulparams/elf32tilepro.sh: New file.
	* ld-elf/eh5.d: Don't run on tile*.
	* ld-srec/srec.exp: xfail on tile*.
	* ld-tilegx/external.s: New file.
	* ld-tilegx/reloc.d: New file.
	* ld-tilegx/reloc.s: New file.
	* ld-tilegx/tilegx.exp: New file.
	* ld-tilepro/external.s: New file.
	* ld-tilepro/reloc.d: New file.
	* ld-tilepro/reloc.s: New file.
	* ld-tilepro/tilepro.exp: New file.
	* Makefile.am (TARGET_LIBOPCODES_CFILES): Add tilegx-dis.c,
	tilegx-opc.c, tilepro-dis.c, and tilepro-opc.c.
	* Makefile.in: Regenerate.
	* configure.in: Handle bfd_tilegx_arch and bfd_tilepro_arch.
	* configure: Regenerate.
	* disassemble.c (disassembler): Add ARCH_tilegx and ARCH_tilepro.
	* po/POTFILES.in: Regenerate.
	* tilegx-dis.c: New file.
	* tilegx-opc.c: New file.
	* tilepro-dis.c: New file.
	* tilepro-opc.c: New file.
			
			
This commit is contained in:
		| @@ -1,3 +1,9 @@ | ||||
| 2011-06-13  Walter Lee  <walt@tilera.com> | ||||
|  | ||||
| 	* common.h: Add EM_TILEGX. | ||||
| 	* tilegx.h: New file. | ||||
| 	* tilepro.h: New file. | ||||
|  | ||||
| 2011-06-09  Tristan Gingold  <gingold@adacore.com> | ||||
|  | ||||
| 	* ia64.h (Elf64_External_VMS_ORIG_DYN_Note): New struct. | ||||
| @@ -56,6 +62,11 @@ | ||||
| 	R_ARM_TLS_DESCSEQ, T_ARM_THM_TLS_CALL, R_ARM_THM_TLS_DESCSEQ): New | ||||
| 	relocations. | ||||
|  | ||||
| 2010-11-16  Jie Zhang  <jie.zhang@analog.com> | ||||
|  | ||||
| 	* bfin.h (EF_BFIN_CODE_IN_L1): Define. | ||||
| 	(EF_BFIN_DATA_IN_L1): Define. | ||||
|  | ||||
| 2010-11-11  Mingming Sun  <mingm.sun@gmail.com> | ||||
|  | ||||
| 	* mips.h (E_MIPS_MACH_LS3A): Defined. | ||||
|   | ||||
| @@ -295,6 +295,7 @@ | ||||
| #define EM_TILEPRO	188	/* Tilera TILEPro multicore architecture family */ | ||||
| #define EM_MICROBLAZE	189	/* Xilinx MicroBlaze 32-bit RISC soft processor core */ | ||||
| #define EM_CUDA		190	/* NVIDIA CUDA architecture */ | ||||
| #define EM_TILEGX	191	/* Tilera TILE-Gx multicore architecture family */ | ||||
|  | ||||
| /* If it is necessary to assign new unofficial EM_* values, please pick large | ||||
|    random numbers (0x8523, 0xa7f2, etc.) to minimize the chances of collision | ||||
|   | ||||
							
								
								
									
										162
									
								
								include/elf/tilegx.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										162
									
								
								include/elf/tilegx.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,162 @@ | ||||
| /* TILE-Gx ELF support for BFD. | ||||
|    Copyright 2011 Free Software Foundation, Inc. | ||||
|  | ||||
|    This file is part of BFD, the Binary File Descriptor library. | ||||
|  | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
|  | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
|  | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, write to the Free Software | ||||
|    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, | ||||
|    MA 02110-1301, USA.  */ | ||||
|  | ||||
| #ifndef _ELF_TILEGX_H | ||||
| #define _ELF_TILEGX_H | ||||
|  | ||||
| #include "elf/reloc-macros.h" | ||||
|  | ||||
| /* Relocations.  */ | ||||
| START_RELOC_NUMBERS (elf_tilegx_reloc_type) | ||||
|   RELOC_NUMBER (R_TILEGX_NONE,              0) | ||||
|  | ||||
|   /* Standard relocations */ | ||||
|   RELOC_NUMBER (R_TILEGX_64,                1) | ||||
|   RELOC_NUMBER (R_TILEGX_32,                2) | ||||
|   RELOC_NUMBER (R_TILEGX_16,                3) | ||||
|   RELOC_NUMBER (R_TILEGX_8,                 4) | ||||
|   RELOC_NUMBER (R_TILEGX_64_PCREL,          5) | ||||
|   RELOC_NUMBER (R_TILEGX_32_PCREL,          6) | ||||
|   RELOC_NUMBER (R_TILEGX_16_PCREL,          7) | ||||
|   RELOC_NUMBER (R_TILEGX_8_PCREL,           8) | ||||
|  | ||||
|   /* Custom relocations */ | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_HW0,               9) | ||||
|   RELOC_NUMBER (R_TILEGX_HW1,               10) | ||||
|   RELOC_NUMBER (R_TILEGX_HW2,               11) | ||||
|   RELOC_NUMBER (R_TILEGX_HW3,               12) | ||||
|   RELOC_NUMBER (R_TILEGX_HW0_LAST,          13) | ||||
|   RELOC_NUMBER (R_TILEGX_HW1_LAST,          14) | ||||
|   RELOC_NUMBER (R_TILEGX_HW2_LAST,          15) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_COPY,              16) | ||||
|   RELOC_NUMBER (R_TILEGX_GLOB_DAT,          17) | ||||
|   RELOC_NUMBER (R_TILEGX_JMP_SLOT,          18) | ||||
|   RELOC_NUMBER (R_TILEGX_RELATIVE,          19) | ||||
|  | ||||
|   /* Branch/jump offsets */ | ||||
|   RELOC_NUMBER (R_TILEGX_BROFF_X1,          20) | ||||
|   RELOC_NUMBER (R_TILEGX_JUMPOFF_X1,        21) | ||||
|   RELOC_NUMBER (R_TILEGX_JUMPOFF_X1_PLT,    22) | ||||
|  | ||||
|   /* Immediate operands. */ | ||||
|   RELOC_NUMBER (R_TILEGX_IMM8_X0,           23) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM8_Y0,           24) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM8_X1,           25) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM8_Y1,           26) | ||||
|   RELOC_NUMBER (R_TILEGX_DEST_IMM8_X1,      27) | ||||
|   RELOC_NUMBER (R_TILEGX_MT_IMM14_X1,       28) | ||||
|   RELOC_NUMBER (R_TILEGX_MF_IMM14_X1,       29) | ||||
|   RELOC_NUMBER (R_TILEGX_MMSTART_X0,        30) | ||||
|   RELOC_NUMBER (R_TILEGX_MMEND_X0,          31) | ||||
|   RELOC_NUMBER (R_TILEGX_SHAMT_X0,          32) | ||||
|   RELOC_NUMBER (R_TILEGX_SHAMT_X1,          33) | ||||
|   RELOC_NUMBER (R_TILEGX_SHAMT_Y0,          34) | ||||
|   RELOC_NUMBER (R_TILEGX_SHAMT_Y1,          35) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0,       36) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0,       37) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1,       38) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1,       39) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2,       40) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2,       41) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3,       42) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3,       43) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST,  44) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST,  45) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST,  46) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST,  47) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST,  48) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST,  49) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_PCREL,        50) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_PCREL,        51) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_PCREL,        52) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_PCREL,        53) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_PCREL,        54) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_PCREL,        55) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3_PCREL,        56) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3_PCREL,        57) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_PCREL,   58) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_PCREL,   59) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_PCREL,   60) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_PCREL,   61) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST_PCREL,   62) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST_PCREL,   63) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_GOT,          64) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_GOT,          65) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_GOT,          66) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_GOT,          67) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_GOT,          68) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_GOT,          69) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3_GOT,          70) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3_GOT,          71) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_GOT,     72) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_GOT,     73) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_GOT,     74) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_GOT,     75) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST_GOT,     76) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST_GOT,     77) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_TLS_GD,       78) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_TLS_GD,       79) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_TLS_GD,       80) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_TLS_GD,       81) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_TLS_GD,       82) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_TLS_GD,       83) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3_TLS_GD,       84) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3_TLS_GD,       85) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_TLS_GD,  86) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_TLS_GD,  87) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_TLS_GD,  88) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_TLS_GD,  89) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST_TLS_GD,  90) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST_TLS_GD,  91) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_TLS_IE,       92) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_TLS_IE,       93) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_TLS_IE,       94) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_TLS_IE,       95) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_TLS_IE,       96) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_TLS_IE,       97) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3_TLS_IE,       98) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3_TLS_IE,       99) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_TLS_IE, 100) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_TLS_IE, 101) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_TLS_IE, 102) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_TLS_IE, 103) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST_TLS_IE, 104) | ||||
|   RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST_TLS_IE, 105) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEGX_TLS_DTPMOD64,             106) | ||||
|   RELOC_NUMBER (R_TILEGX_TLS_DTPOFF64,             107) | ||||
|   RELOC_NUMBER (R_TILEGX_TLS_TPOFF64,              108) | ||||
|   RELOC_NUMBER (R_TILEGX_TLS_DTPMOD32,             109) | ||||
|   RELOC_NUMBER (R_TILEGX_TLS_DTPOFF32,             110) | ||||
|   RELOC_NUMBER (R_TILEGX_TLS_TPOFF32,              111) | ||||
|  | ||||
| /* These are GNU extensions to enable C++ vtable garbage collection.  */ | ||||
|   RELOC_NUMBER (R_TILEGX_GNU_VTINHERIT, 128) | ||||
|   RELOC_NUMBER (R_TILEGX_GNU_VTENTRY, 129) | ||||
| END_RELOC_NUMBERS (R_TILEGX_max) | ||||
|  | ||||
| #endif /* _ELF_TILEGX_H */ | ||||
							
								
								
									
										128
									
								
								include/elf/tilepro.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								include/elf/tilepro.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,128 @@ | ||||
| /* TILEPro ELF support for BFD. | ||||
|    Copyright 2011 Free Software Foundation, Inc. | ||||
|  | ||||
|    This file is part of BFD, the Binary File Descriptor library. | ||||
|  | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
|  | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
|  | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, write to the Free Software | ||||
|    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, | ||||
|    MA 02110-1301, USA.  */ | ||||
|  | ||||
| #ifndef _ELF_TILEPRO_H | ||||
| #define _ELF_TILEPRO_H | ||||
|  | ||||
| #include "elf/reloc-macros.h" | ||||
|  | ||||
| /* Relocations.  */ | ||||
| START_RELOC_NUMBERS (elf_tilepro_reloc_type) | ||||
|   RELOC_NUMBER (R_TILEPRO_NONE,        0) | ||||
|  | ||||
|   /* Standard relocations */ | ||||
|   RELOC_NUMBER (R_TILEPRO_32,                  1) | ||||
|   RELOC_NUMBER (R_TILEPRO_16,                  2) | ||||
|   RELOC_NUMBER (R_TILEPRO_8,                   3) | ||||
|   RELOC_NUMBER (R_TILEPRO_32_PCREL,            4) | ||||
|   RELOC_NUMBER (R_TILEPRO_16_PCREL,            5) | ||||
|   RELOC_NUMBER (R_TILEPRO_8_PCREL,             6) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_LO16,                7) | ||||
|   RELOC_NUMBER (R_TILEPRO_HI16,                8) | ||||
|   RELOC_NUMBER (R_TILEPRO_HA16,                9) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_COPY,               10) | ||||
|   RELOC_NUMBER (R_TILEPRO_GLOB_DAT,           11) | ||||
|   RELOC_NUMBER (R_TILEPRO_JMP_SLOT,           12) | ||||
|   RELOC_NUMBER (R_TILEPRO_RELATIVE,           13) | ||||
|  | ||||
|   /* Branch/jump offsets */ | ||||
|   RELOC_NUMBER (R_TILEPRO_BROFF_X1,           14) | ||||
|   RELOC_NUMBER (R_TILEPRO_JOFFLONG_X1,        15) | ||||
|   RELOC_NUMBER (R_TILEPRO_JOFFLONG_X1_PLT,    16) | ||||
|  | ||||
|   /* Immediate operands. */ | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM8_X0,            17) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM8_Y0,            18) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM8_X1,            19) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM8_Y1,            20) | ||||
|   RELOC_NUMBER (R_TILEPRO_MT_IMM15_X1,        21) | ||||
|   RELOC_NUMBER (R_TILEPRO_MF_IMM15_X1,        22) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0,           23) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1,           24) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_LO,        25) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_LO,        26) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HI,        27) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HI,        28) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HA,        29) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HA,        30) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_PCREL,     31) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_PCREL,     32) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_LO_PCREL,  33) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_LO_PCREL,  34) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HI_PCREL,  35) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HI_PCREL,  36) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HA_PCREL,  37) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HA_PCREL,  38) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT,       39) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT,       40) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_LO,    41) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_LO,    42) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_HI,    43) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_HI,    44) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_HA,    45) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_HA,    46) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_MMSTART_X0,         47) | ||||
|   RELOC_NUMBER (R_TILEPRO_MMEND_X0,           48) | ||||
|   RELOC_NUMBER (R_TILEPRO_MMSTART_X1,         49) | ||||
|   RELOC_NUMBER (R_TILEPRO_MMEND_X1,           50) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_SHAMT_X0,           51) | ||||
|   RELOC_NUMBER (R_TILEPRO_SHAMT_X1,           52) | ||||
|   RELOC_NUMBER (R_TILEPRO_SHAMT_Y0,           53) | ||||
|   RELOC_NUMBER (R_TILEPRO_SHAMT_Y1,           54) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_DEST_IMM8_X1,       55) | ||||
|  | ||||
|   /* Relocs 56-65 are currently not defined.  */ | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD,    66) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD,    67) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_LO, 68) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_LO, 69) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_HI, 70) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_HI, 71) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_HA, 72) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_HA, 73) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE,    74) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE,    75) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_LO, 76) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_LO, 77) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_HI, 78) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_HI, 79) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_HA, 80) | ||||
|   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_HA, 81) | ||||
|  | ||||
|   RELOC_NUMBER (R_TILEPRO_TLS_DTPMOD32,       82) | ||||
|   RELOC_NUMBER (R_TILEPRO_TLS_DTPOFF32,       83) | ||||
|   RELOC_NUMBER (R_TILEPRO_TLS_TPOFF32,        84) | ||||
|  | ||||
| /* These are GNU extensions to enable C++ vtable garbage collection.  */ | ||||
|   RELOC_NUMBER (R_TILEPRO_GNU_VTINHERIT, 128) | ||||
|   RELOC_NUMBER (R_TILEPRO_GNU_VTENTRY, 129) | ||||
| END_RELOC_NUMBERS (R_TILEPRO_max) | ||||
|  | ||||
| #endif /* _ELF_TILEPRO_H */ | ||||
		Reference in New Issue
	
	Block a user