Switch to GPLv3
[deliverable/binutils-gdb.git] / gas / config / tc-m32r.h
CommitLineData
252b5132 1/* tc-m32r.h -- Header file for tc-m32r.c.
66a4ad42
AM
2 Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
3 2007 Free Software Foundation, Inc.
252b5132
RH
4
5 This file is part of GAS, the GNU Assembler.
6
7 GAS is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
ec2655a6 9 the Free Software Foundation; either version 3, or (at your option)
252b5132
RH
10 any later version.
11
12 GAS 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 GAS; see the file COPYING. If not, write to
4b4da160
NC
19 the Free Software Foundation, 51 Franklin Street - Fifth Floor,
20 Boston, MA 02110-1301, USA. */
252b5132
RH
21
22#define TC_M32R
23
88845958
NC
24#define LISTING_HEADER \
25 (target_big_endian ? "M32R GAS" : "M32R GAS Little Endian")
252b5132
RH
26
27/* The target BFD architecture. */
28#define TARGET_ARCH bfd_arch_m32r
29
88845958
NC
30/* The endianness of the target format may change based on command
31 line arguments. */
32#define TARGET_FORMAT m32r_target_format()
ea1562b3 33extern const char *m32r_target_format (void);
252b5132 34
88845958
NC
35/* Default to big endian. */
36#ifndef TARGET_BYTES_BIG_ENDIAN
252b5132 37#define TARGET_BYTES_BIG_ENDIAN 1
88845958 38#endif
252b5132 39
88845958 40/* Call md_pcrel_from_section, not md_pcrel_from. */
ea1562b3 41long md_pcrel_from_section (struct fix *, segT);
a161fe53 42#define MD_PCREL_FROM_SECTION(FIX, SEC) md_pcrel_from_section(FIX, SEC)
252b5132
RH
43
44/* Permit temporary numeric labels. */
45#define LOCAL_LABELS_FB 1
46
ea1562b3 47#define DIFF_EXPR_OK /* .-foo gets turned into PC relative relocs. */
252b5132
RH
48
49/* We don't need to handle .word strangely. */
50#define WORKING_DOT_WORD
51
52/* For 8 vs 16 vs 32 bit branch selection. */
53extern const struct relax_type md_relax_table[];
54#define TC_GENERIC_RELAX_TABLE md_relax_table
ea1562b3
NC
55
56extern long m32r_relax_frag (segT, fragS *, long);
c842b53a 57#define md_relax_frag(segment, fragP, stretch) \
ea1562b3
NC
58 m32r_relax_frag (segment, fragP, stretch)
59
252b5132 60/* Account for nop if 32 bit insn falls on odd halfword boundary. */
ea1562b3 61#define TC_CGEN_MAX_RELAX(insn, len) 6
252b5132 62
0a9ef439 63/* Fill in rs_align_code fragments. */
ea1562b3 64extern void m32r_handle_align (fragS *);
0a9ef439
RH
65#define HANDLE_ALIGN(f) m32r_handle_align (f)
66
67#define MAX_MEM_FOR_RS_ALIGN_CODE (1 + 2 + 4)
252b5132 68
55cf6793 69/* Values passed to md_apply_fix don't include the symbol value. */
a161fe53
AM
70#define MD_APPLY_SYM_VALUE(FIX) 0
71
55cf6793 72#define md_apply_fix gas_cgen_md_apply_fix
252b5132 73
a161fe53 74#define tc_fix_adjustable(FIX) m32r_fix_adjustable (FIX)
ea1562b3 75bfd_boolean m32r_fix_adjustable (struct fix *);
252b5132
RH
76
77/* After creating a fixup for an instruction operand, we need to check for
78 HI16 relocs and queue them up for later sorting. */
79#define md_cgen_record_fixup_exp m32r_cgen_record_fixup_exp
80
6edf0760
NC
81#define TC_HANDLES_FX_DONE
82
83extern int pic_code;
84
ea1562b3 85extern bfd_boolean m32r_fix_adjustable (struct fix *);
6edf0760
NC
86
87/* This arranges for gas/write.c to not apply a relocation if
88 obj_fix_adjustable() says it is not adjustable. */
89#define TC_FIX_ADJUSTABLE(fixP) obj_fix_adjustable (fixP)
90
a161fe53 91#define tc_frob_file_before_fix() m32r_frob_file ()
ea1562b3 92extern void m32r_frob_file (void);
252b5132 93
a161fe53 94/* No shared lib support, so we don't need to ensure externally
6edf0760
NC
95 visible symbols can be overridden.
96#define EXTERN_FORCE_RELOC 0 */
a161fe53 97
252b5132
RH
98/* When relaxing, we need to emit various relocs we otherwise wouldn't. */
99#define TC_FORCE_RELOCATION(fix) m32r_force_relocation (fix)
ea1562b3 100extern int m32r_force_relocation (struct fix *);
252b5132
RH
101
102/* Ensure insns at labels are aligned to 32 bit boundaries. */
ea1562b3 103int m32r_fill_insn (int);
252b5132
RH
104#define md_after_pass_hook() m32r_fill_insn (1)
105#define TC_START_LABEL(ch, ptr) (ch == ':' && m32r_fill_insn (0))
106
252b5132
RH
107#define md_cleanup m32r_elf_section_change_hook
108#define md_elf_section_change_hook m32r_elf_section_change_hook
ea1562b3 109extern void m32r_elf_section_change_hook (void);
88845958
NC
110
111#define md_flush_pending_output() m32r_flush_pending_output ()
ea1562b3 112extern void m32r_flush_pending_output (void);
88845958
NC
113
114#define elf_tc_final_processing m32r_elf_final_processing
ea1562b3 115extern void m32r_elf_final_processing (void);
097f809a 116
9497f5ac
NC
117#define md_parse_name(name, exprP, mode, nextcharP) \
118 m32r_parse_name ((name), (exprP), (mode), (nextcharP))
119extern int m32r_parse_name (char const *, expressionS *, enum expr_mode, char *);
097f809a
NC
120
121/* This is used to construct expressions out of @GOTOFF, @PLT and @GOT
122 symbols. The relocation type is stored in X_md. */
123#define O_PIC_reloc O_md1
124
125#define TC_CGEN_PARSE_FIX_EXP(opinfo, exp) \
126 m32r_cgen_parse_fix_exp(opinfo, exp)
ea1562b3 127extern int m32r_cgen_parse_fix_exp (int, expressionS *);
This page took 0.330201 seconds and 4 git commands to generate.