X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gas%2Ftc.h;h=4e4046ccc149531b762d2db6675b6369bd9a2ebb;hb=bc4466dcf10e23054dc420c9eee11210dce0e9d8;hp=8a7bf517a9f072b7aeda47dd8dee5e1f79727cf3;hpb=27cf8bfb1bc140fd9f8014ec23ad846312a9f3c8;p=deliverable%2Fbinutils-gdb.git diff --git a/gas/tc.h b/gas/tc.h index 8a7bf517a9..4e4046ccc1 100644 --- a/gas/tc.h +++ b/gas/tc.h @@ -16,7 +16,7 @@ You should have received a copy of the GNU General Public License along with GAS; see the file COPYING. If not, write to - the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ + the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* In theory (mine, at least!) the machine dependent part of the assembler should only have to include one file. This one. -- JF */ @@ -42,42 +42,54 @@ struct relax_type typedef struct relax_type relax_typeS; -extern const relax_typeS md_relax_table[]; /* Define it in MACHINE.c */ - -extern int md_reloc_size; /* Size of a relocation record */ - -extern void (*md_emit_relocations) (); +extern const int md_reloc_size; /* Size of a relocation record */ char *md_atof PARAMS ((int what_statement_type, char *literalP, int *sizeP)); +#ifndef md_estimate_size_before_relax int md_estimate_size_before_relax PARAMS ((fragS * fragP, segT segment)); -int md_parse_option PARAMS ((char **argP, int *cntP, char ***vecP)); +#endif +int md_parse_option PARAMS ((int c, char *arg)); +void md_show_usage PARAMS ((FILE *)); long md_pcrel_from PARAMS ((fixS * fixP)); short tc_coff_fix2rtype PARAMS ((fixS * fixP)); void md_assemble PARAMS ((char *str)); void md_begin PARAMS ((void)); -void md_create_long_jump PARAMS ((char *ptr, long from_addr, long to_addr, - fragS * frag, symbolS * to_symbol)); -void md_create_short_jump PARAMS ((char *ptr, long from_addr, long to_addr, - fragS * frag, symbolS * to_symbol)); -void md_end PARAMS ((void)); -void md_number_to_chars PARAMS ((char *buf, long val, int n)); +#ifndef md_create_long_jump +void md_create_long_jump PARAMS ((char *ptr, addressT from_addr, + addressT to_addr, fragS * frag, + symbolS * to_symbol)); +#endif +#ifndef md_create_short_jump +void md_create_short_jump PARAMS ((char *ptr, addressT from_addr, + addressT to_addr, fragS * frag, + symbolS * to_symbol)); +#endif +void md_number_to_chars PARAMS ((char *buf, valueT val, int n)); #ifndef md_operand void md_operand PARAMS ((expressionS * expressionP)); #endif +#ifdef MD_APPLY_FIX3 +int md_apply_fix3 PARAMS ((fixS * fixP, valueT *val, segT seg)); +#endif #ifdef BFD_ASSEMBLER -int md_apply_fix PARAMS ((fixS * fixP, long *val)); +int md_apply_fix PARAMS ((fixS * fixP, valueT *val)); #ifndef md_convert_frag void md_convert_frag PARAMS ((bfd * headers, segT sec, fragS * fragP)); #endif #ifndef tc_headers_hook void tc_headers_hook PARAMS ((segT *, fixS *)); #endif +#ifndef RELOC_EXPANSION_POSSIBLE +extern arelent *tc_gen_reloc PARAMS ((asection *, fixS *)); #else +extern arelent **tc_gen_reloc PARAMS ((asection *, fixS *)); +#endif +#else /* not BFD_ASSEMBLER */ void md_apply_fix PARAMS ((fixS * fixP, long val)); #ifndef md_convert_frag -void md_convert_frag PARAMS ((object_headers * headers, fragS * fragP)); +void md_convert_frag PARAMS ((object_headers * headers, segT, fragS * fragP)); #endif #ifndef tc_crawl_symbol_chain @@ -90,14 +102,11 @@ void tc_headers_hook PARAMS ((object_headers * headers)); #endif /* BFD_ASSEMBLER */ #ifndef md_section_align -long md_section_align PARAMS ((segT seg, long align)); +valueT md_section_align PARAMS ((segT seg, valueT size)); #endif #ifndef md_undefined_symbol symbolS *md_undefined_symbol PARAMS ((char *name)); #endif -#define TC_COFF_SIZEMACHDEP(frag) tc_coff_sizemachdep(frag) /* end of tc.h */ - -