Commit | Line | Data |
---|---|---|
252b5132 | 1 | /* This file is tc-h8300.h |
6f2750fe | 2 | Copyright (C) 1987-2016 Free Software Foundation, Inc. |
252b5132 RH |
3 | |
4 | This file is part of GAS, the GNU Assembler. | |
5 | ||
6 | GAS is free software; you can redistribute it and/or modify | |
7 | it under the terms of the GNU General Public License as published by | |
ec2655a6 | 8 | the Free Software Foundation; either version 3, or (at your option) |
252b5132 RH |
9 | any later version. |
10 | ||
11 | GAS is distributed in the hope that it will be useful, | |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | GNU General Public License for more details. | |
15 | ||
16 | You should have received a copy of the GNU General Public License | |
17 | along with GAS; see the file COPYING. If not, write to the Free | |
4b4da160 NC |
18 | Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA |
19 | 02110-1301, USA. */ | |
252b5132 | 20 | |
252b5132 RH |
21 | #define TC_H8300 |
22 | ||
23 | #define TARGET_BYTES_BIG_ENDIAN 1 | |
24 | ||
7e0de7bf JL |
25 | #define TARGET_ARCH bfd_arch_h8300 |
26 | ||
dfe0d3fe JL |
27 | /* Fixup debug sections since we will never relax them. */ |
28 | #define TC_LINKRELAX_FIXUP(seg) (seg->flags & SEC_ALLOC) | |
7e0de7bf | 29 | #ifdef OBJ_ELF |
5518c738 | 30 | #ifndef TE_LINUX |
7e0de7bf | 31 | #define TARGET_FORMAT "elf32-h8300" |
5518c738 YS |
32 | #else |
33 | #define TARGET_FORMAT "elf32-h8300-linux" | |
34 | #endif | |
7ee7b84d MS |
35 | #define LOCAL_LABEL_PREFIX '.' |
36 | #define LOCAL_LABEL(NAME) (NAME[0] == '.' && NAME[1] == 'L') | |
37 | #define FAKE_LABEL_NAME ".L0\001" | |
7e0de7bf JL |
38 | #endif |
39 | ||
a161fe53 | 40 | struct fix; |
252b5132 | 41 | struct internal_reloc; |
252b5132 RH |
42 | |
43 | #define WORKING_DOT_WORD | |
44 | ||
8d9cd6b1 | 45 | #define COFF_MAGIC ( Smode && Nmode ? 0x8304 : Hmode && Nmode ? 0x8303 : Smode ? 0x8302 : Hmode ? 0x8301 : 0x8300) |
252b5132 RH |
46 | #define IGNORE_NONSTANDARD_ESCAPES |
47 | ||
48 | #define tc_coff_symbol_emit_hook(a) ; /* not used */ | |
252b5132 | 49 | |
a161fe53 AM |
50 | /* No shared lib support, so we don't need to ensure externally |
51 | visible symbols can be overridden. */ | |
52 | #define EXTERN_FORCE_RELOC 0 | |
53 | ||
2c8714f2 NC |
54 | /* Minimum instruction is of 16 bits. */ |
55 | #define DWARF2_LINE_MIN_INSN_LENGTH 2 | |
453dc3f0 | 56 | #define DWARF2_USE_FIXED_ADVANCE_PC 0 |
2c8714f2 | 57 | |
36ed2fff JL |
58 | #ifdef OBJ_ELF |
59 | /* Provide mappings from the original H8 COFF relocation names to | |
60 | their corresponding BFD relocation names. This allows us to use | |
61 | most of tc-h8300.c without modifications for both ELF and COFF | |
62 | ports. */ | |
63 | #define R_MOV24B1 BFD_RELOC_H8_DIR24A8 | |
64 | #define R_MOVL1 BFD_RELOC_H8_DIR32A16 | |
36ed2fff JL |
65 | #define R_RELLONG BFD_RELOC_32 |
66 | #define R_MOV16B1 BFD_RELOC_H8_DIR16A8 | |
67 | #define R_RELWORD BFD_RELOC_16 | |
68 | #define R_RELBYTE BFD_RELOC_8 | |
69 | #define R_PCRWORD BFD_RELOC_16_PCREL | |
70 | #define R_PCRBYTE BFD_RELOC_8_PCREL | |
71 | #define R_JMPL1 BFD_RELOC_H8_DIR24R8 | |
72 | #define R_MEM_INDIRECT BFD_RELOC_8 | |
73 | ||
74 | /* We do not want to adjust any relocations to make implementation of | |
75 | linker relaxations easier. */ | |
76 | #define tc_fix_adjustable(FIX) 0 | |
77 | #endif | |
78 | ||
c2dcd04e | 79 | #define LISTING_HEADER "Renesas H8/300 GAS " |
36ed2fff | 80 | #ifndef OBJ_ELF |
252b5132 | 81 | #define RELOC_32 1234 |
36ed2fff | 82 | #endif |
252b5132 RH |
83 | |
84 | extern int Hmode; | |
85 | extern int Smode; | |
8d9cd6b1 | 86 | extern int Nmode; |
7ee7b84d | 87 | extern int SXmode; |
252b5132 RH |
88 | |
89 | #define md_operand(x) | |
d31f0f6d AM |
90 | |
91 | /* This target is buggy, and sets fix size too large. */ | |
92 | #define TC_FX_SIZE_SLACK(FIX) 1 | |
6fd4f6cc DD |
93 | |
94 | #define H_TICK_HEX 1 |