1 /* tc-d10v.h -- Header file for tc-d10v.c.
2    Copyright 1996, 1997, 1998, 2000, 2001, 2002, 2003
3    Free Software Foundation, Inc.
4    Written by Martin Hunt, Cygnus Support.
5 
6    This file is part of GAS, the GNU Assembler.
7 
8    GAS is free software; you can redistribute it and/or modify
9    it under the terms of the GNU General Public License as published by
10    the Free Software Foundation; either version 2, or (at your option)
11    any later version.
12 
13    GAS is distributed in the hope that it will be useful,
14    but WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16    GNU General Public License for more details.
17 
18    You should have received a copy of the GNU General Public License
19    along with GAS; see the file COPYING.  If not, write to the Free
20    Software Foundation, 59 Temple Place - Suite 330, Boston, MA
21    02111-1307, USA.  */
22 
23 #define TC_D10V
24 
25 #define TARGET_BYTES_BIG_ENDIAN 0
26 
27 #ifndef BFD_ASSEMBLER
28  #error D10V support requires BFD_ASSEMBLER
29 #endif
30 
31 /* The target BFD architecture.  */
32 #define TARGET_ARCH bfd_arch_d10v
33 
34 #define TARGET_FORMAT "elf32-d10v"
35 
36 /* Call md_pcrel_from_section, not md_pcrel_from.  */
37 #define MD_PCREL_FROM_SECTION(FIX, SEC) md_pcrel_from_section(FIX, SEC)
38 struct fix;
39 long md_pcrel_from_section PARAMS ((struct fix *, segT));
40 
41 /* Permit temporary numeric labels.  */
42 #define LOCAL_LABELS_FB 1
43 
44 #define DIFF_EXPR_OK		/* .-foo gets turned into PC relative relocs */
45 
46 /* We don't need to handle .word strangely.  */
47 #define WORKING_DOT_WORD
48 
49 #define md_number_to_chars	     number_to_chars_bigendian
50 
51 int d10v_cleanup PARAMS ((void));
52 #define md_after_pass_hook()	     d10v_cleanup ()
53 #define md_cleanup()		     d10v_cleanup ()
54 #define md_do_align(a,b,c,d,e)	     d10v_cleanup ()
55 #define tc_frob_label(sym) do {\
56   d10v_cleanup (); \
57   symbol_set_frag (sym, frag_now);					\
58   S_SET_VALUE (sym, (valueT) frag_now_fix ());				\
59 } while (0)
60 
61 #define tc_fix_adjustable(FIX) d10v_fix_adjustable(FIX)
62 bfd_boolean d10v_fix_adjustable PARAMS ((struct fix *));
63 
64 /* Values passed to md_apply_fix3 don't include the symbol value.  */
65 #define MD_APPLY_SYM_VALUE(FIX) 0
66 
67 /* No shared lib support, so we don't need to ensure externally
68    visible symbols can be overridden.  */
69 #define EXTERN_FORCE_RELOC 0
70 
71 #define md_flush_pending_output  d10v_cleanup
72