OpenCores
URL https://opencores.org/ocsvn/open8_urisc/open8_urisc/trunk

Subversion Repositories open8_urisc

[/] [open8_urisc/] [trunk/] [gnu/] [binutils/] [include/] [elf/] [s390.h] - Blame information for rev 268

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 17 khays
/* 390 ELF support for BFD.
2
   Copyright 2000, 2001, 2003, 2010 Free Software Foundation, Inc.
3
   Contributed by Carl B. Pedersen and Martin Schwidefsky.
4
 
5
   This file is part of BFD, the Binary File Descriptor library.
6
 
7
   This program is free software; you can redistribute it and/or modify
8
   it under the terms of the GNU General Public License as published by
9
   the Free Software Foundation; either version 3 of the License, or
10
   (at your option) any later version.
11
 
12
   This program is distributed in the hope that it will be useful,
13
   but WITHOUT ANY WARRANTY; without even the implied warranty of
14
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
   GNU General Public License for more details.
16
 
17
   You should have received a copy of the GNU General Public License
18
   along with this program; if not, write to the Free Software
19
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
20
   02110-1301, USA.  */
21
 
22
#ifndef _ELF_390_H
23
#define _ELF_390_H
24
 
25
/* Processor specific flags for the ELF header e_flags field.  */
26
 
27
/* Symbol types.  */
28
 
29
#define STACK_REG               15              /* Global Stack reg */
30
#define BACKL_REG               14              /* Global Backlink reg */
31
#define BASE_REG                13              /* Global Base reg */
32
#define GOT_REG                 12              /* Holds addr of GOT */
33
 
34
#include "elf/reloc-macros.h"
35
 
36
/* Processor specific flags for the ELF header e_flags field.  */
37
 
38
#define EF_S390_HIGH_GPRS        0x00000001
39
 
40
/* Relocation types.  */
41
 
42
START_RELOC_NUMBERS (elf_s390_reloc_type)
43
    RELOC_NUMBER (R_390_NONE, 0) /* No reloc.  */
44
    RELOC_NUMBER (R_390_8, 1)           /* Direct 8 bit.  */
45
    RELOC_NUMBER (R_390_12, 2)          /* Direct 12 bit.  */
46
    RELOC_NUMBER (R_390_16, 3)          /* Direct 16 bit.  */
47
    RELOC_NUMBER (R_390_32, 4)          /* Direct 32 bit.  */
48
    RELOC_NUMBER (R_390_PC32, 5)        /* PC relative 32 bit.  */
49
    RELOC_NUMBER (R_390_GOT12, 6)       /* 12 bit GOT offset.  */
50
    RELOC_NUMBER (R_390_GOT32, 7)       /* 32 bit GOT offset.  */
51
    RELOC_NUMBER (R_390_PLT32, 8)       /* 32 bit PC relative PLT address.  */
52
    RELOC_NUMBER (R_390_COPY, 9)        /* Copy symbol at runtime.  */
53
    RELOC_NUMBER (R_390_GLOB_DAT, 10)   /* Create GOT entry.  */
54
    RELOC_NUMBER (R_390_JMP_SLOT, 11)   /* Create PLT entry.  */
55
    RELOC_NUMBER (R_390_RELATIVE, 12)   /* Adjust by program base.  */
56
    RELOC_NUMBER (R_390_GOTOFF32, 13)   /* 32 bit offset to GOT.  */
57
    RELOC_NUMBER (R_390_GOTPC, 14)      /* 32 bit PC relative offset to GOT.  */
58
    RELOC_NUMBER (R_390_GOT16, 15)      /* 16 bit GOT offset.  */
59
    RELOC_NUMBER (R_390_PC16, 16)       /* PC relative 16 bit.  */
60
    RELOC_NUMBER (R_390_PC16DBL, 17)    /* PC relative 16 bit shifted by 1.  */
61
    RELOC_NUMBER (R_390_PLT16DBL, 18)   /* 16 bit PC rel. PLT shifted by 1.  */
62
    RELOC_NUMBER (R_390_PC32DBL, 19)    /* PC relative 32 bit shifted by 1.  */
63
    RELOC_NUMBER (R_390_PLT32DBL, 20)   /* 32 bit PC rel. PLT shifted by 1.  */
64
    RELOC_NUMBER (R_390_GOTPCDBL, 21)   /* 32 bit PC rel. GOT shifted by 1.  */
65
    RELOC_NUMBER (R_390_64, 22)         /* Direct 64 bit.  */
66
    RELOC_NUMBER (R_390_PC64, 23)       /* PC relative 64 bit.  */
67
    RELOC_NUMBER (R_390_GOT64, 24)      /* 64 bit GOT offset.  */
68
    RELOC_NUMBER (R_390_PLT64, 25)      /* 64 bit PC relative PLT address.  */
69
    RELOC_NUMBER (R_390_GOTENT, 26)     /* 32 bit PC rel. to GOT entry >> 1. */
70
    RELOC_NUMBER (R_390_GOTOFF16, 27)   /* 16 bit offset to GOT. */
71
    RELOC_NUMBER (R_390_GOTOFF64, 28)   /* 64 bit offset to GOT. */
72
    RELOC_NUMBER (R_390_GOTPLT12, 29)   /* 12 bit offset to jump slot.  */
73
    RELOC_NUMBER (R_390_GOTPLT16, 30)   /* 16 bit offset to jump slot.  */
74
    RELOC_NUMBER (R_390_GOTPLT32, 31)   /* 32 bit offset to jump slot.  */
75
    RELOC_NUMBER (R_390_GOTPLT64, 32)   /* 64 bit offset to jump slot.  */
76
    RELOC_NUMBER (R_390_GOTPLTENT, 33)  /* 32 bit rel. offset to jump slot.  */
77
    RELOC_NUMBER (R_390_PLTOFF16, 34)   /* 16 bit offset from GOT to PLT. */
78
    RELOC_NUMBER (R_390_PLTOFF32, 35)   /* 32 bit offset from GOT to PLT. */
79
    RELOC_NUMBER (R_390_PLTOFF64, 36)   /* 16 bit offset from GOT to PLT. */
80
    RELOC_NUMBER (R_390_TLS_LOAD, 37)   /* Tag for load insn in TLS code. */
81
    RELOC_NUMBER (R_390_TLS_GDCALL, 38) /* Tag for function call in general
82
                                           dynamic TLS code.  */
83
    RELOC_NUMBER (R_390_TLS_LDCALL, 39) /* Tag for function call in local
84
                                           dynamic TLS code.  */
85
    RELOC_NUMBER (R_390_TLS_GD32, 40)   /* Direct 32 bit for general dynamic
86
                                           thread local data.  */
87
    RELOC_NUMBER (R_390_TLS_GD64, 41)   /* Direct 64 bit for general dynamic
88
                                           thread local data.  */
89
    RELOC_NUMBER (R_390_TLS_GOTIE12, 42)/* 12 bit GOT offset for static TLS
90
                                           block offset.  */
91
    RELOC_NUMBER (R_390_TLS_GOTIE32, 43)/* 32 bit GOT offset for static TLS
92
                                           block offset.  */
93
    RELOC_NUMBER (R_390_TLS_GOTIE64, 44)/* 64 bit GOT offset for static TLS
94
                                           block offset.  */
95
    RELOC_NUMBER (R_390_TLS_LDM32, 45)  /* Direct 32 bit for local dynamic
96
                                           thread local data in LD code.  */
97
    RELOC_NUMBER (R_390_TLS_LDM64, 46)  /* Direct 64 bit for local dynamic
98
                                           thread local data in LD code.  */
99
    RELOC_NUMBER (R_390_TLS_IE32, 47)   /* 32 bit address of GOT entry for
100
                                           negated static TLS block offset.  */
101
    RELOC_NUMBER (R_390_TLS_IE64, 48)   /* 64 bit address of GOT entry for
102
                                           negated static TLS block offset.  */
103
    RELOC_NUMBER (R_390_TLS_IEENT, 49)  /* 32 bit rel. offset to GOT entry for
104
                                           negated static TLS block offset.  */
105
    RELOC_NUMBER (R_390_TLS_LE32, 50)   /* 32 bit negated offset relative to
106
                                           static TLS block.  */
107
    RELOC_NUMBER (R_390_TLS_LE64, 51)   /* 64 bit negated offset relative to
108
                                           static TLS block.  */
109
    RELOC_NUMBER (R_390_TLS_LDO32, 52)  /* 32 bit offset relative to TLS
110
                                           block.  */
111
    RELOC_NUMBER (R_390_TLS_LDO64, 53)  /* 64 bit offset relative to TLS
112
                                           block.  */
113
    RELOC_NUMBER (R_390_TLS_DTPMOD, 54) /* ID of module containing symbol.  */
114
    RELOC_NUMBER (R_390_TLS_DTPOFF, 55) /* Offset in TLS block.  */
115
    RELOC_NUMBER (R_390_TLS_TPOFF, 56)  /* Negate offset in static TLS
116
                                           block.  */
117
    RELOC_NUMBER (R_390_20, 57)         /* Direct 20 bit.  */
118
    RELOC_NUMBER (R_390_GOT20, 58)      /* 20 bit GOT offset.  */
119
    RELOC_NUMBER (R_390_GOTPLT20, 59)   /* 20 bit offset to jump slot.  */
120
    RELOC_NUMBER (R_390_TLS_GOTIE20, 60)/* 20 bit GOT offset for statis TLS
121
                                           block offset.  */
122
    /* These are GNU extensions to enable C++ vtable garbage collection.  */
123
    RELOC_NUMBER (R_390_GNU_VTINHERIT, 250)
124
    RELOC_NUMBER (R_390_GNU_VTENTRY, 251)
125
END_RELOC_NUMBERS (R_390_max)
126
 
127
#endif /* _ELF_390_H */
128
 
129
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.