1*a9fa9459Szrj /* TILEPro ELF support for BFD. 2*a9fa9459Szrj Copyright (C) 2011-2016 Free Software Foundation, Inc. 3*a9fa9459Szrj 4*a9fa9459Szrj This file is part of BFD, the Binary File Descriptor library. 5*a9fa9459Szrj 6*a9fa9459Szrj This program is free software; you can redistribute it and/or modify 7*a9fa9459Szrj it under the terms of the GNU General Public License as published by 8*a9fa9459Szrj the Free Software Foundation; either version 3 of the License, or 9*a9fa9459Szrj (at your option) any later version. 10*a9fa9459Szrj 11*a9fa9459Szrj This program is distributed in the hope that it will be useful, 12*a9fa9459Szrj but WITHOUT ANY WARRANTY; without even the implied warranty of 13*a9fa9459Szrj MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14*a9fa9459Szrj GNU General Public License for more details. 15*a9fa9459Szrj 16*a9fa9459Szrj You should have received a copy of the GNU General Public License 17*a9fa9459Szrj along with this program; if not, write to the Free Software 18*a9fa9459Szrj Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, 19*a9fa9459Szrj MA 02110-1301, USA. */ 20*a9fa9459Szrj 21*a9fa9459Szrj #ifndef _ELF_TILEPRO_H 22*a9fa9459Szrj #define _ELF_TILEPRO_H 23*a9fa9459Szrj 24*a9fa9459Szrj #include "elf/reloc-macros.h" 25*a9fa9459Szrj 26*a9fa9459Szrj /* Relocations. */ 27*a9fa9459Szrj START_RELOC_NUMBERS (elf_tilepro_reloc_type) 28*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_NONE, 0) 29*a9fa9459Szrj 30*a9fa9459Szrj /* Standard relocations */ 31*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_32, 1) 32*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_16, 2) 33*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_8, 3) 34*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_32_PCREL, 4) 35*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_16_PCREL, 5) 36*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_8_PCREL, 6) 37*a9fa9459Szrj 38*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_LO16, 7) 39*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_HI16, 8) 40*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_HA16, 9) 41*a9fa9459Szrj 42*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_COPY, 10) 43*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_GLOB_DAT, 11) 44*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_JMP_SLOT, 12) 45*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_RELATIVE, 13) 46*a9fa9459Szrj 47*a9fa9459Szrj /* Branch/jump offsets */ 48*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_BROFF_X1, 14) 49*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_JOFFLONG_X1, 15) 50*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_JOFFLONG_X1_PLT, 16) 51*a9fa9459Szrj 52*a9fa9459Szrj /* Immediate operands. */ 53*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_X0, 17) 54*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_Y0, 18) 55*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_X1, 19) 56*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_Y1, 20) 57*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_MT_IMM15_X1, 21) 58*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_MF_IMM15_X1, 22) 59*a9fa9459Szrj 60*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0, 23) 61*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1, 24) 62*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_LO, 25) 63*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_LO, 26) 64*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_HI, 27) 65*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_HI, 28) 66*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_HA, 29) 67*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_HA, 30) 68*a9fa9459Szrj 69*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_PCREL, 31) 70*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_PCREL, 32) 71*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_LO_PCREL, 33) 72*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_LO_PCREL, 34) 73*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_HI_PCREL, 35) 74*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_HI_PCREL, 36) 75*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_HA_PCREL, 37) 76*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_HA_PCREL, 38) 77*a9fa9459Szrj 78*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT, 39) 79*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT, 40) 80*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_LO, 41) 81*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_LO, 42) 82*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_HI, 43) 83*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_HI, 44) 84*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_HA, 45) 85*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_HA, 46) 86*a9fa9459Szrj 87*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_MMSTART_X0, 47) 88*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_MMEND_X0, 48) 89*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_MMSTART_X1, 49) 90*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_MMEND_X1, 50) 91*a9fa9459Szrj 92*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_SHAMT_X0, 51) 93*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_SHAMT_X1, 52) 94*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_SHAMT_Y0, 53) 95*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_SHAMT_Y1, 54) 96*a9fa9459Szrj 97*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_DEST_IMM8_X1, 55) 98*a9fa9459Szrj 99*a9fa9459Szrj /* Relocs 56-59 are currently not defined. */ 100*a9fa9459Szrj 101*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_TLS_GD_CALL, 60) 102*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_X0_TLS_GD_ADD, 61) 103*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_X1_TLS_GD_ADD, 62) 104*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_Y0_TLS_GD_ADD, 63) 105*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM8_Y1_TLS_GD_ADD, 64) 106*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_TLS_IE_LOAD, 65) 107*a9fa9459Szrj 108*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD, 66) 109*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD, 67) 110*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_LO, 68) 111*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_LO, 69) 112*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_HI, 70) 113*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_HI, 71) 114*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_HA, 72) 115*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_HA, 73) 116*a9fa9459Szrj 117*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE, 74) 118*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE, 75) 119*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_LO, 76) 120*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_LO, 77) 121*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_HI, 78) 122*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_HI, 79) 123*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_HA, 80) 124*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_HA, 81) 125*a9fa9459Szrj 126*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_TLS_DTPMOD32, 82) 127*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_TLS_DTPOFF32, 83) 128*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_TLS_TPOFF32, 84) 129*a9fa9459Szrj 130*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE, 85) 131*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE, 86) 132*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE_LO, 87) 133*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE_LO, 88) 134*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE_HI, 89) 135*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE_HI, 90) 136*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE_HA, 91) 137*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE_HA, 92) 138*a9fa9459Szrj 139*a9fa9459Szrj /* These are GNU extensions to enable C++ vtable garbage collection. */ 140*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_GNU_VTINHERIT, 128) 141*a9fa9459Szrj RELOC_NUMBER (R_TILEPRO_GNU_VTENTRY, 129) 142*a9fa9459Szrj END_RELOC_NUMBERS (R_TILEPRO_max) 143*a9fa9459Szrj 144*a9fa9459Szrj #endif /* _ELF_TILEPRO_H */ 145