1 /* tc-dlx.h -- Assemble for the DLX
2    Copyright 2002, 2003, 2005 Free Software Foundation, Inc.
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
8    the Free Software Foundation; either version 2, or (at your option)
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
18    Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
19    02110-1301, USA.  */
20 
21 /* Initially created by Kuang Hwa Lin, 3/20/2002.  */
22 
23 #define TC_DLX
24 
25 #ifndef BFD_ASSEMBLER
26  #error DLX support requires BFD_ASSEMBLER
27 #endif
28 
29 #ifndef  __BFD_H_SEEN__
30 #include "bfd.h"
31 #endif
32 
33 /* The target BFD architecture.  */
34 #define TARGET_ARCH              bfd_arch_dlx
35 #define TARGET_FORMAT            "elf32-dlx"
36 #define TARGET_BYTES_BIG_ENDIAN	 1
37 
38 #define WORKING_DOT_WORD
39 
40 #define LEX_DOLLAR 1
41 
42 extern void dlx_pop_insert         (void);
43 extern int set_dlx_skip_hi16_flag  (int);
44 extern int dlx_unrecognized_line   (int);
45 extern bfd_boolean md_dlx_fix_adjustable  (struct fix *);
46 
47 #define md_pop_insert()		        dlx_pop_insert ()
48 
49 #define md_convert_frag(b,s,f)		as_fatal ("convert_frag called\n")
50 #define md_estimate_size_before_relax(f,s) \
51 			(as_fatal ("estimate_size_before_relax called"),1)
52 
53 #define tc_unrecognized_line(c) dlx_unrecognized_line (c)
54 
55 #define tc_headers_hook(a)		;	/* Not used.  */
56 #define tc_headers_hook(a)		;	/* Not used.  */
57 #define tc_crawl_symbol_chain(a)	;	/* Not used.  */
58 #define tc_coff_symbol_emit_hook(a)	;	/* Not used.  */
59 
60 #define AOUT_MACHTYPE 101
61 #define TC_COFF_FIX2RTYPE(fix_ptr) tc_coff_fix2rtype (fix_ptr)
62 #define BFD_ARCH bfd_arch_dlx
63 #define COFF_MAGIC DLXMAGIC
64 /* Should the reloc be output ?
65 	on the 29k, this is true only if there is a symbol attached.
66 	on the h8, this is always true, since no fixup is done
67         on dlx, I have no idea!! but lets keep it here just for fun.  */
68 #define TC_COUNT_RELOC(x) (x->fx_addsy)
69 #define TC_CONS_RELOC BFD_RELOC_32_PCREL
70 
71 /* No shared lib support, so we don't need to ensure externally
72    visible symbols can be overridden.  */
73 #define EXTERN_FORCE_RELOC 0
74 
75 #define tc_fix_adjustable(FIX) md_dlx_fix_adjustable (FIX)
76 
77 /* Values passed to md_apply_fix don't include the symbol value.  */
78 #define MD_APPLY_SYM_VALUE(FIX) 0
79 
80 #define NEED_FX_R_TYPE
81 
82 /* Zero Based Segment?? sound very dangerous to me!     */
83 #define ZERO_BASED_SEGMENTS
84 
85 /* Permit temporary numeric labels.  */
86 #define LOCAL_LABELS_FB 1
87 
88 #undef  LOCAL_LABELS_DOLLAR
89 #define LOCAL_LABELS_DOLLAR 0
90 
91 /* .-foo gets turned into PC relative relocs.  */
92 #define DIFF_EXPR_OK
93