1*a9fa9459Szrj /* Adapteva EPIPHANY ELF support for BFD.
2*a9fa9459Szrj    Copyright (C) 2009-2016 Free Software Foundation, Inc.
3*a9fa9459Szrj    Contributed by Embecosm on behalf of Adapteva, Inc.
4*a9fa9459Szrj 
5*a9fa9459Szrj    This file is part of BFD, the Binary File Descriptor library.
6*a9fa9459Szrj 
7*a9fa9459Szrj    This program is free software; you can redistribute it and/or modify
8*a9fa9459Szrj    it under the terms of the GNU General Public License as published by
9*a9fa9459Szrj    the Free Software Foundation; either version 3 of the License, or
10*a9fa9459Szrj    (at your option) any later version.
11*a9fa9459Szrj 
12*a9fa9459Szrj    This program is distributed in the hope that it will be useful,
13*a9fa9459Szrj    but WITHOUT ANY WARRANTY; without even the implied warranty of
14*a9fa9459Szrj    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15*a9fa9459Szrj    GNU General Public License for more details.
16*a9fa9459Szrj 
17*a9fa9459Szrj    You should have received a copy of the GNU General Public License
18*a9fa9459Szrj    along with this program; if not, write to the Free Software Foundation,
19*a9fa9459Szrj    Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
20*a9fa9459Szrj 
21*a9fa9459Szrj #ifndef _ELF_EPIPHANY_H
22*a9fa9459Szrj #define _ELF_EPIPHANY_H
23*a9fa9459Szrj 
24*a9fa9459Szrj #include "elf/reloc-macros.h"
25*a9fa9459Szrj 
26*a9fa9459Szrj /* Relocations.  */
27*a9fa9459Szrj START_RELOC_NUMBERS (elf_epiphany_reloc_type)
28*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_NONE,    0)
29*a9fa9459Szrj 
30*a9fa9459Szrj   /* Absolute address relocations.  */
31*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_8,       1)
32*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_16,      2)
33*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_32,      3)
34*a9fa9459Szrj 
35*a9fa9459Szrj   /* PC-relative relocations.  */
36*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_8_PCREL, 4)
37*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_16_PCREL,5)
38*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_32_PCREL,6)
39*a9fa9459Szrj 
40*a9fa9459Szrj   /* special forms for 8/24 bit branch displacements.  */
41*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_SIMM8,   7)
42*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_SIMM24,  8)
43*a9fa9459Szrj 
44*a9fa9459Szrj   /* HIGH and LOW relocations taking part of a 32 bit address and
45*a9fa9459Szrj      depositing it into the IMM16 field of a destination.  */
46*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_HIGH, 9)
47*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_LOW,10)
48*a9fa9459Szrj 
49*a9fa9459Szrj   /* 11 bit signed immediate value.  */
50*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_SIMM11, 11)
51*a9fa9459Szrj   /* 11 bit magnitude addressing displacement.  */
52*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_IMM11, 12)
53*a9fa9459Szrj 
54*a9fa9459Szrj   /* 8 bit immediate for MOV.S R,IMM8.  */
55*a9fa9459Szrj   RELOC_NUMBER (R_EPIPHANY_IMM8, 13)
56*a9fa9459Szrj 
57*a9fa9459Szrj END_RELOC_NUMBERS(R_EPIPHANY_max)
58*a9fa9459Szrj 
59*a9fa9459Szrj #endif /* _ELF_EPIPHANY_H */
60