1999-05-03 15:29:11 +08:00
|
|
|
|
/* tc-alpha.c - Processor-specific code for the DEC Alpha AXP CPU.
|
2002-05-09 21:12:57 +08:00
|
|
|
|
Copyright 1989, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
|
2003-01-23 20:51:05 +08:00
|
|
|
|
2001, 2002, 2003 Free Software Foundation, Inc.
|
1999-05-03 15:29:11 +08:00
|
|
|
|
Contributed by Carnegie Mellon University, 1993.
|
|
|
|
|
Written by Alessandro Forin, based on earlier gas-1.38 target CPU files.
|
|
|
|
|
Modified by Ken Raeburn for gas-2.x and ECOFF support.
|
|
|
|
|
Modified by Richard Henderson for ELF support.
|
1999-06-06 07:15:34 +08:00
|
|
|
|
Modified by Klaus K"ampf for EVAX (OpenVMS/Alpha) support.
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
This file is part of GAS, the GNU Assembler.
|
|
|
|
|
|
|
|
|
|
GAS is free software; you can redistribute it and/or modify
|
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
|
the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
|
any later version.
|
|
|
|
|
|
|
|
|
|
GAS is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
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, 59 Temple Place - Suite 330, Boston, MA
|
|
|
|
|
02111-1307, USA. */
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Mach Operating System
|
|
|
|
|
* Copyright (c) 1993 Carnegie Mellon University
|
|
|
|
|
* All Rights Reserved.
|
|
|
|
|
*
|
|
|
|
|
* Permission to use, copy, modify and distribute this software and its
|
|
|
|
|
* documentation is hereby granted, provided that both the copyright
|
|
|
|
|
* notice and this permission notice appear in all copies of the
|
|
|
|
|
* software, derivative works or modified versions, and any portions
|
|
|
|
|
* thereof, and that both notices appear in supporting documentation.
|
|
|
|
|
*
|
|
|
|
|
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS
|
|
|
|
|
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
|
|
|
|
|
* ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
|
|
|
|
|
*
|
|
|
|
|
* Carnegie Mellon requests users of this software to return to
|
|
|
|
|
*
|
|
|
|
|
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
|
|
|
|
|
* School of Computer Science
|
|
|
|
|
* Carnegie Mellon University
|
|
|
|
|
* Pittsburgh PA 15213-3890
|
|
|
|
|
*
|
|
|
|
|
* any improvements or extensions that they make and grant Carnegie the
|
|
|
|
|
* rights to redistribute these changes.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "as.h"
|
|
|
|
|
#include "subsegs.h"
|
1999-11-29 08:46:16 +08:00
|
|
|
|
#include "struc-symbol.h"
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#include "ecoff.h"
|
|
|
|
|
|
|
|
|
|
#include "opcode/alpha.h"
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
#include "elf/alpha.h"
|
2000-11-17 16:47:52 +08:00
|
|
|
|
#include "dwarf2dbg.h"
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif
|
|
|
|
|
|
2001-09-19 13:33:36 +08:00
|
|
|
|
#include "safe-ctype.h"
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Local types. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
#define TOKENIZE_ERROR -1
|
|
|
|
|
#define TOKENIZE_ERROR_REPORT -2
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#define MAX_INSN_FIXUPS 2
|
|
|
|
|
#define MAX_INSN_ARGS 5
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
struct alpha_fixup
|
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expressionS exp;
|
|
|
|
|
bfd_reloc_code_real_type reloc;
|
|
|
|
|
};
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
struct alpha_insn
|
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
unsigned insn;
|
|
|
|
|
int nfixups;
|
|
|
|
|
struct alpha_fixup fixups[MAX_INSN_FIXUPS];
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
long sequence;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
};
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
enum alpha_macro_arg
|
|
|
|
|
{
|
|
|
|
|
MACRO_EOA = 1,
|
|
|
|
|
MACRO_IR,
|
|
|
|
|
MACRO_PIR,
|
|
|
|
|
MACRO_OPIR,
|
|
|
|
|
MACRO_CPIR,
|
|
|
|
|
MACRO_FPR,
|
|
|
|
|
MACRO_EXP,
|
|
|
|
|
};
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
struct alpha_macro
|
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const char *name;
|
|
|
|
|
void (*emit) PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
const PTR arg;
|
|
|
|
|
enum alpha_macro_arg argsets[16];
|
|
|
|
|
};
|
|
|
|
|
|
2000-09-15 09:06:52 +08:00
|
|
|
|
/* Extra expression types. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
1999-10-19 06:29:15 +08:00
|
|
|
|
#define O_pregister O_md1 /* O_register, in parentheses */
|
|
|
|
|
#define O_cpregister O_md2 /* + a leading comma */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
/* The alpha_reloc_op table below depends on the ordering of these. */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
#define O_literal O_md3 /* !literal relocation */
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#define O_lituse_addr O_md4 /* !lituse_addr relocation */
|
|
|
|
|
#define O_lituse_base O_md5 /* !lituse_base relocation */
|
|
|
|
|
#define O_lituse_bytoff O_md6 /* !lituse_bytoff relocation */
|
|
|
|
|
#define O_lituse_jsr O_md7 /* !lituse_jsr relocation */
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
#define O_lituse_tlsgd O_md8 /* !lituse_tlsgd relocation */
|
|
|
|
|
#define O_lituse_tlsldm O_md9 /* !lituse_tlsldm relocation */
|
|
|
|
|
#define O_gpdisp O_md10 /* !gpdisp relocation */
|
|
|
|
|
#define O_gprelhigh O_md11 /* !gprelhigh relocation */
|
|
|
|
|
#define O_gprellow O_md12 /* !gprellow relocation */
|
|
|
|
|
#define O_gprel O_md13 /* !gprel relocation */
|
|
|
|
|
#define O_samegp O_md14 /* !samegp relocation */
|
|
|
|
|
#define O_tlsgd O_md15 /* !tlsgd relocation */
|
|
|
|
|
#define O_tlsldm O_md16 /* !tlsldm relocation */
|
|
|
|
|
#define O_gotdtprel O_md17 /* !gotdtprel relocation */
|
|
|
|
|
#define O_dtprelhi O_md18 /* !dtprelhi relocation */
|
|
|
|
|
#define O_dtprello O_md19 /* !dtprello relocation */
|
|
|
|
|
#define O_dtprel O_md20 /* !dtprel relocation */
|
|
|
|
|
#define O_gottprel O_md21 /* !gottprel relocation */
|
|
|
|
|
#define O_tprelhi O_md22 /* !tprelhi relocation */
|
|
|
|
|
#define O_tprello O_md23 /* !tprello relocation */
|
|
|
|
|
#define O_tprel O_md24 /* !tprel relocation */
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
|
|
|
|
|
#define DUMMY_RELOC_LITUSE_ADDR (BFD_RELOC_UNUSED + 1)
|
|
|
|
|
#define DUMMY_RELOC_LITUSE_BASE (BFD_RELOC_UNUSED + 2)
|
|
|
|
|
#define DUMMY_RELOC_LITUSE_BYTOFF (BFD_RELOC_UNUSED + 3)
|
|
|
|
|
#define DUMMY_RELOC_LITUSE_JSR (BFD_RELOC_UNUSED + 4)
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
#define DUMMY_RELOC_LITUSE_TLSGD (BFD_RELOC_UNUSED + 5)
|
|
|
|
|
#define DUMMY_RELOC_LITUSE_TLSLDM (BFD_RELOC_UNUSED + 6)
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
#define USER_RELOC_P(R) ((R) >= O_literal && (R) <= O_tprel)
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Macros for extracting the type and number of encoded register tokens. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
#define is_ir_num(x) (((x) & 32) == 0)
|
|
|
|
|
#define is_fpr_num(x) (((x) & 32) != 0)
|
|
|
|
|
#define regno(x) ((x) & 31)
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Something odd inherited from the old assembler. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
#define note_gpreg(R) (alpha_gprmask |= (1 << (R)))
|
|
|
|
|
#define note_fpreg(R) (alpha_fprmask |= (1 << (R)))
|
|
|
|
|
|
|
|
|
|
/* Predicates for 16- and 32-bit ranges */
|
|
|
|
|
/* XXX: The non-shift version appears to trigger a compiler bug when
|
|
|
|
|
cross-assembling from x86 w/ gcc 2.7.2. */
|
|
|
|
|
|
|
|
|
|
#if 1
|
|
|
|
|
#define range_signed_16(x) \
|
2000-12-03 14:49:23 +08:00
|
|
|
|
(((offsetT) (x) >> 15) == 0 || ((offsetT) (x) >> 15) == -1)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#define range_signed_32(x) \
|
2000-12-03 14:49:23 +08:00
|
|
|
|
(((offsetT) (x) >> 31) == 0 || ((offsetT) (x) >> 31) == -1)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#else
|
2001-01-19 20:03:34 +08:00
|
|
|
|
#define range_signed_16(x) ((offsetT) (x) >= -(offsetT) 0x8000 && \
|
|
|
|
|
(offsetT) (x) <= (offsetT) 0x7FFF)
|
|
|
|
|
#define range_signed_32(x) ((offsetT) (x) >= -(offsetT) 0x80000000 && \
|
|
|
|
|
(offsetT) (x) <= (offsetT) 0x7FFFFFFF)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* Macros for sign extending from 16- and 32-bits. */
|
|
|
|
|
/* XXX: The cast macros will work on all the systems that I care about,
|
|
|
|
|
but really a predicate should be found to use the non-cast forms. */
|
|
|
|
|
|
|
|
|
|
#if 1
|
2000-12-03 14:49:23 +08:00
|
|
|
|
#define sign_extend_16(x) ((short) (x))
|
|
|
|
|
#define sign_extend_32(x) ((int) (x))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#else
|
2000-12-03 14:49:23 +08:00
|
|
|
|
#define sign_extend_16(x) ((offsetT) (((x) & 0xFFFF) ^ 0x8000) - 0x8000)
|
|
|
|
|
#define sign_extend_32(x) ((offsetT) (((x) & 0xFFFFFFFF) \
|
1999-05-03 15:29:11 +08:00
|
|
|
|
^ 0x80000000) - 0x80000000)
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Macros to build tokens. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
#define set_tok_reg(t, r) (memset (&(t), 0, sizeof (t)), \
|
1999-05-03 15:29:11 +08:00
|
|
|
|
(t).X_op = O_register, \
|
|
|
|
|
(t).X_add_number = (r))
|
2001-01-19 20:03:34 +08:00
|
|
|
|
#define set_tok_preg(t, r) (memset (&(t), 0, sizeof (t)), \
|
1999-05-03 15:29:11 +08:00
|
|
|
|
(t).X_op = O_pregister, \
|
|
|
|
|
(t).X_add_number = (r))
|
2001-01-19 20:03:34 +08:00
|
|
|
|
#define set_tok_cpreg(t, r) (memset (&(t), 0, sizeof (t)), \
|
1999-05-03 15:29:11 +08:00
|
|
|
|
(t).X_op = O_cpregister, \
|
|
|
|
|
(t).X_add_number = (r))
|
2001-01-19 20:03:34 +08:00
|
|
|
|
#define set_tok_freg(t, r) (memset (&(t), 0, sizeof (t)), \
|
1999-05-03 15:29:11 +08:00
|
|
|
|
(t).X_op = O_register, \
|
2001-01-23 04:24:11 +08:00
|
|
|
|
(t).X_add_number = (r) + 32)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
#define set_tok_sym(t, s, a) (memset (&(t), 0, sizeof (t)), \
|
1999-05-03 15:29:11 +08:00
|
|
|
|
(t).X_op = O_symbol, \
|
|
|
|
|
(t).X_add_symbol = (s), \
|
|
|
|
|
(t).X_add_number = (a))
|
2001-01-19 20:03:34 +08:00
|
|
|
|
#define set_tok_const(t, n) (memset (&(t), 0, sizeof (t)), \
|
1999-05-03 15:29:11 +08:00
|
|
|
|
(t).X_op = O_constant, \
|
|
|
|
|
(t).X_add_number = (n))
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Prototypes for all local functions. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
static struct alpha_reloc_tag *get_alpha_reloc_tag PARAMS ((long));
|
2002-09-05 08:01:18 +08:00
|
|
|
|
static void alpha_adjust_relocs PARAMS ((bfd *, asection *, PTR));
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static int tokenize_arguments PARAMS ((char *, expressionS *, int));
|
|
|
|
|
static const struct alpha_opcode *find_opcode_match
|
|
|
|
|
PARAMS ((const struct alpha_opcode *, const expressionS *, int *, int *));
|
|
|
|
|
static const struct alpha_macro *find_macro_match
|
|
|
|
|
PARAMS ((const struct alpha_macro *, const expressionS *, int *));
|
|
|
|
|
static unsigned insert_operand
|
|
|
|
|
PARAMS ((unsigned, const struct alpha_operand *, offsetT, char *, unsigned));
|
|
|
|
|
static void assemble_insn
|
|
|
|
|
PARAMS ((const struct alpha_opcode *, const expressionS *, int,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
struct alpha_insn *, bfd_reloc_code_real_type));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static void emit_insn PARAMS ((struct alpha_insn *));
|
|
|
|
|
static void assemble_tokens_to_insn
|
|
|
|
|
PARAMS ((const char *, const expressionS *, int, struct alpha_insn *));
|
|
|
|
|
static void assemble_tokens
|
|
|
|
|
PARAMS ((const char *, const expressionS *, int, int));
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
static long load_expression
|
|
|
|
|
PARAMS ((int, const expressionS *, int *, expressionS *));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
static void emit_ldgp PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_division PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_lda PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_ldah PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_ir_load PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_loadstore PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_jsrjmp PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_ldX PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_ldXu PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_uldX PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_uldXu PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_ldil PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_stX PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_ustX PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_sextX PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
static void emit_retjcr PARAMS ((const expressionS *, int, const PTR));
|
|
|
|
|
|
|
|
|
|
static void s_alpha_text PARAMS ((int));
|
|
|
|
|
static void s_alpha_data PARAMS ((int));
|
|
|
|
|
#ifndef OBJ_ELF
|
|
|
|
|
static void s_alpha_comm PARAMS ((int));
|
|
|
|
|
static void s_alpha_rdata PARAMS ((int));
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
static void s_alpha_sdata PARAMS ((int));
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
static void s_alpha_section PARAMS ((int));
|
|
|
|
|
static void s_alpha_ent PARAMS ((int));
|
|
|
|
|
static void s_alpha_end PARAMS ((int));
|
|
|
|
|
static void s_alpha_mask PARAMS ((int));
|
|
|
|
|
static void s_alpha_frame PARAMS ((int));
|
|
|
|
|
static void s_alpha_prologue PARAMS ((int));
|
2000-11-17 16:47:52 +08:00
|
|
|
|
static void s_alpha_file PARAMS ((int));
|
|
|
|
|
static void s_alpha_loc PARAMS ((int));
|
2000-11-18 02:07:33 +08:00
|
|
|
|
static void s_alpha_stab PARAMS ((int));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static void s_alpha_coff_wrapper PARAMS ((int));
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
static void s_alpha_section PARAMS ((int));
|
|
|
|
|
#endif
|
|
|
|
|
static void s_alpha_gprel32 PARAMS ((int));
|
|
|
|
|
static void s_alpha_float_cons PARAMS ((int));
|
|
|
|
|
static void s_alpha_proc PARAMS ((int));
|
|
|
|
|
static void s_alpha_set PARAMS ((int));
|
|
|
|
|
static void s_alpha_base PARAMS ((int));
|
|
|
|
|
static void s_alpha_align PARAMS ((int));
|
|
|
|
|
static void s_alpha_stringer PARAMS ((int));
|
|
|
|
|
static void s_alpha_space PARAMS ((int));
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
static void s_alpha_ucons PARAMS ((int));
|
|
|
|
|
static void s_alpha_arch PARAMS ((int));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
static void create_literal_section PARAMS ((const char *, segT *, symbolS **));
|
|
|
|
|
#ifndef OBJ_ELF
|
|
|
|
|
static void select_gp_value PARAMS ((void));
|
|
|
|
|
#endif
|
|
|
|
|
static void alpha_align PARAMS ((int, char *, symbolS *, int));
|
|
|
|
|
|
|
|
|
|
/* Generic assembler global variables which must be defined by all
|
|
|
|
|
targets. */
|
|
|
|
|
|
|
|
|
|
/* Characters which always start a comment. */
|
|
|
|
|
const char comment_chars[] = "#";
|
|
|
|
|
|
|
|
|
|
/* Characters which start a comment at the beginning of a line. */
|
|
|
|
|
const char line_comment_chars[] = "#";
|
|
|
|
|
|
|
|
|
|
/* Characters which may be used to separate multiple commands on a
|
|
|
|
|
single line. */
|
|
|
|
|
const char line_separator_chars[] = ";";
|
|
|
|
|
|
|
|
|
|
/* Characters which are used to indicate an exponent in a floating
|
|
|
|
|
point number. */
|
|
|
|
|
const char EXP_CHARS[] = "eE";
|
|
|
|
|
|
|
|
|
|
/* Characters which mean that a number is a floating point constant,
|
|
|
|
|
as in 0d1.0. */
|
|
|
|
|
#if 0
|
|
|
|
|
const char FLT_CHARS[] = "dD";
|
|
|
|
|
#else
|
|
|
|
|
/* XXX: Do all of these really get used on the alpha?? */
|
|
|
|
|
char FLT_CHARS[] = "rRsSfFdDxXpP";
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
const char *md_shortopts = "Fm:g+1h:HG:";
|
|
|
|
|
#else
|
|
|
|
|
const char *md_shortopts = "Fm:gG:";
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
struct option md_longopts[] =
|
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#define OPTION_32ADDR (OPTION_MD_BASE)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
{ "32addr", no_argument, NULL, OPTION_32ADDR },
|
2001-01-23 04:24:11 +08:00
|
|
|
|
#define OPTION_RELAX (OPTION_32ADDR + 1)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
{ "relax", no_argument, NULL, OPTION_RELAX },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#ifdef OBJ_ELF
|
2001-01-23 04:24:11 +08:00
|
|
|
|
#define OPTION_MDEBUG (OPTION_RELAX + 1)
|
|
|
|
|
#define OPTION_NO_MDEBUG (OPTION_MDEBUG + 1)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
{ "mdebug", no_argument, NULL, OPTION_MDEBUG },
|
|
|
|
|
{ "no-mdebug", no_argument, NULL, OPTION_NO_MDEBUG },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif
|
2002-08-14 21:27:06 +08:00
|
|
|
|
{ NULL, no_argument, NULL, 0 }
|
|
|
|
|
};
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2000-12-03 14:49:23 +08:00
|
|
|
|
size_t md_longopts_size = sizeof (md_longopts);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
#define AXP_REG_R0 0
|
|
|
|
|
#define AXP_REG_R16 16
|
|
|
|
|
#define AXP_REG_R17 17
|
|
|
|
|
#undef AXP_REG_T9
|
|
|
|
|
#define AXP_REG_T9 22
|
|
|
|
|
#undef AXP_REG_T10
|
|
|
|
|
#define AXP_REG_T10 23
|
|
|
|
|
#undef AXP_REG_T11
|
|
|
|
|
#define AXP_REG_T11 24
|
|
|
|
|
#undef AXP_REG_T12
|
|
|
|
|
#define AXP_REG_T12 25
|
|
|
|
|
#define AXP_REG_AI 25
|
|
|
|
|
#undef AXP_REG_FP
|
|
|
|
|
#define AXP_REG_FP 29
|
|
|
|
|
|
|
|
|
|
#undef AXP_REG_GP
|
|
|
|
|
#define AXP_REG_GP AXP_REG_PV
|
|
|
|
|
#endif /* OBJ_EVAX */
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* The cpu for which we are generating code. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static unsigned alpha_target = AXP_OPCODE_BASE;
|
|
|
|
|
static const char *alpha_target_name = "<all>";
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* The hash table of instruction opcodes. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static struct hash_control *alpha_opcode_hash;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* The hash table of macro opcodes. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static struct hash_control *alpha_macro_hash;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* The $gp relocation symbol. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static symbolS *alpha_gp_symbol;
|
|
|
|
|
|
|
|
|
|
/* XXX: what is this, and why is it exported? */
|
|
|
|
|
valueT alpha_gp_value;
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* The current $gp register. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static int alpha_gp_register = AXP_REG_GP;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* A table of the register symbols. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static symbolS *alpha_register_table[64];
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Constant sections, or sections of constants. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
static segT alpha_lita_section;
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
static segT alpha_link_section;
|
|
|
|
|
static segT alpha_ctors_section;
|
|
|
|
|
static segT alpha_dtors_section;
|
|
|
|
|
#endif
|
|
|
|
|
static segT alpha_lit8_section;
|
|
|
|
|
|
2000-09-15 09:06:52 +08:00
|
|
|
|
/* Symbols referring to said sections. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
static symbolS *alpha_lita_symbol;
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
static symbolS *alpha_link_symbol;
|
|
|
|
|
static symbolS *alpha_ctors_symbol;
|
|
|
|
|
static symbolS *alpha_dtors_symbol;
|
|
|
|
|
#endif
|
|
|
|
|
static symbolS *alpha_lit8_symbol;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Literal for .litX+0x8000 within .lita. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
static offsetT alpha_lit8_literal;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
2000-11-17 16:47:52 +08:00
|
|
|
|
/* The active .ent symbol. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static symbolS *alpha_cur_ent_sym;
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Is the assembler not allowed to use $at? */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static int alpha_noat_on = 0;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Are macros enabled? */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static int alpha_macros_on = 1;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Are floats disabled? */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static int alpha_nofloats_on = 0;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Are addresses 32 bit? */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static int alpha_addr32_on = 0;
|
|
|
|
|
|
|
|
|
|
/* Symbol labelling the current insn. When the Alpha gas sees
|
|
|
|
|
foo:
|
|
|
|
|
.quad 0
|
|
|
|
|
and the section happens to not be on an eight byte boundary, it
|
|
|
|
|
will align both the symbol and the .quad to an eight byte boundary. */
|
|
|
|
|
static symbolS *alpha_insn_label;
|
|
|
|
|
|
|
|
|
|
/* Whether we should automatically align data generation pseudo-ops.
|
|
|
|
|
.align 0 will turn this off. */
|
|
|
|
|
static int alpha_auto_align_on = 1;
|
|
|
|
|
|
|
|
|
|
/* The known current alignment of the current section. */
|
|
|
|
|
static int alpha_current_align;
|
|
|
|
|
|
|
|
|
|
/* These are exported to ECOFF code. */
|
|
|
|
|
unsigned long alpha_gprmask, alpha_fprmask;
|
|
|
|
|
|
|
|
|
|
/* Whether the debugging option was seen. */
|
|
|
|
|
static int alpha_debug;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
/* Whether we are emitting an mdebug section. */
|
2000-11-18 02:07:33 +08:00
|
|
|
|
int alpha_flag_mdebug = -1;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* Don't fully resolve relocations, allowing code movement in the linker. */
|
|
|
|
|
static int alpha_flag_relax;
|
|
|
|
|
|
|
|
|
|
/* What value to give to bfd_set_gp_size. */
|
|
|
|
|
static int g_switch_value = 8;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
/* Collect information about current procedure here. */
|
|
|
|
|
static struct {
|
|
|
|
|
symbolS *symbol; /* proc pdesc symbol */
|
|
|
|
|
int pdsckind;
|
|
|
|
|
int framereg; /* register for frame pointer */
|
|
|
|
|
int framesize; /* size of frame */
|
|
|
|
|
int rsa_offset;
|
|
|
|
|
int ra_save;
|
|
|
|
|
int fp_save;
|
|
|
|
|
long imask;
|
|
|
|
|
long fmask;
|
|
|
|
|
int type;
|
|
|
|
|
int prologue;
|
|
|
|
|
} alpha_evax_proc;
|
|
|
|
|
|
|
|
|
|
static int alpha_flag_hash_long_names = 0; /* -+ */
|
|
|
|
|
static int alpha_flag_show_after_trunc = 0; /* -H */
|
|
|
|
|
|
|
|
|
|
/* If the -+ switch is given, then a hash is appended to any name that is
|
2002-08-14 21:27:06 +08:00
|
|
|
|
longer than 64 characters, else longer symbol names are truncated. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef RELOC_OP_P
|
|
|
|
|
/* A table to map the spelling of a relocation operand into an appropriate
|
|
|
|
|
bfd_reloc_code_real_type type. The table is assumed to be ordered such
|
|
|
|
|
that op-O_literal indexes into it. */
|
|
|
|
|
|
|
|
|
|
#define ALPHA_RELOC_TABLE(op) \
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
(&alpha_reloc_op[ ((!USER_RELOC_P (op)) \
|
1999-11-29 08:46:16 +08:00
|
|
|
|
? (abort (), 0) \
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
: (int) (op) - (int) O_literal) ])
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2001-09-08 09:12:00 +08:00
|
|
|
|
#define DEF(NAME, RELOC, REQ, ALLOW) \
|
|
|
|
|
{ #NAME, sizeof(#NAME)-1, O_##NAME, RELOC, REQ, ALLOW}
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
static const struct alpha_reloc_op_tag
|
|
|
|
|
{
|
1999-11-29 08:46:16 +08:00
|
|
|
|
const char *name; /* string to lookup */
|
|
|
|
|
size_t length; /* size of the string */
|
|
|
|
|
operatorT op; /* which operator to use */
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
bfd_reloc_code_real_type reloc; /* relocation before frob */
|
2001-09-08 09:12:00 +08:00
|
|
|
|
unsigned int require_seq : 1; /* require a sequence number */
|
|
|
|
|
unsigned int allow_seq : 1; /* allow a sequence number */
|
2002-08-14 21:27:06 +08:00
|
|
|
|
}
|
|
|
|
|
alpha_reloc_op[] =
|
|
|
|
|
{
|
2001-09-08 09:12:00 +08:00
|
|
|
|
DEF(literal, BFD_RELOC_ALPHA_ELF_LITERAL, 0, 1),
|
|
|
|
|
DEF(lituse_addr, DUMMY_RELOC_LITUSE_ADDR, 1, 1),
|
|
|
|
|
DEF(lituse_base, DUMMY_RELOC_LITUSE_BASE, 1, 1),
|
|
|
|
|
DEF(lituse_bytoff, DUMMY_RELOC_LITUSE_BYTOFF, 1, 1),
|
|
|
|
|
DEF(lituse_jsr, DUMMY_RELOC_LITUSE_JSR, 1, 1),
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
DEF(lituse_tlsgd, DUMMY_RELOC_LITUSE_TLSGD, 1, 1),
|
|
|
|
|
DEF(lituse_tlsldm, DUMMY_RELOC_LITUSE_TLSLDM, 1, 1),
|
2001-09-08 09:12:00 +08:00
|
|
|
|
DEF(gpdisp, BFD_RELOC_ALPHA_GPDISP, 1, 1),
|
|
|
|
|
DEF(gprelhigh, BFD_RELOC_ALPHA_GPREL_HI16, 0, 0),
|
|
|
|
|
DEF(gprellow, BFD_RELOC_ALPHA_GPREL_LO16, 0, 0),
|
2002-02-10 06:55:06 +08:00
|
|
|
|
DEF(gprel, BFD_RELOC_GPREL16, 0, 0),
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
DEF(samegp, BFD_RELOC_ALPHA_BRSGP, 0, 0),
|
|
|
|
|
DEF(tlsgd, BFD_RELOC_ALPHA_TLSGD, 0, 1),
|
|
|
|
|
DEF(tlsldm, BFD_RELOC_ALPHA_TLSLDM, 0, 1),
|
|
|
|
|
DEF(gotdtprel, BFD_RELOC_ALPHA_GOTDTPREL16, 0, 0),
|
|
|
|
|
DEF(dtprelhi, BFD_RELOC_ALPHA_DTPREL_HI16, 0, 0),
|
|
|
|
|
DEF(dtprello, BFD_RELOC_ALPHA_DTPREL_LO16, 0, 0),
|
|
|
|
|
DEF(dtprel, BFD_RELOC_ALPHA_DTPREL16, 0, 0),
|
|
|
|
|
DEF(gottprel, BFD_RELOC_ALPHA_GOTTPREL16, 0, 0),
|
|
|
|
|
DEF(tprelhi, BFD_RELOC_ALPHA_TPREL_HI16, 0, 0),
|
|
|
|
|
DEF(tprello, BFD_RELOC_ALPHA_TPREL_LO16, 0, 0),
|
|
|
|
|
DEF(tprel, BFD_RELOC_ALPHA_TPREL16, 0, 0),
|
1999-11-29 08:46:16 +08:00
|
|
|
|
};
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#undef DEF
|
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
static const int alpha_num_reloc_op
|
2000-12-03 14:49:23 +08:00
|
|
|
|
= sizeof (alpha_reloc_op) / sizeof (*alpha_reloc_op);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#endif /* RELOC_OP_P */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
|
|
|
|
/* Maximum # digits needed to hold the largest sequence # */
|
|
|
|
|
#define ALPHA_RELOC_DIGITS 25
|
|
|
|
|
|
|
|
|
|
/* Structure to hold explict sequence information. */
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
struct alpha_reloc_tag
|
1999-11-29 08:46:16 +08:00
|
|
|
|
{
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
fixS *master; /* the literal reloc */
|
|
|
|
|
fixS *slaves; /* head of linked list of lituses */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
segT segment; /* segment relocs are in or undefined_section*/
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
long sequence; /* sequence # */
|
|
|
|
|
unsigned n_master; /* # of literals */
|
|
|
|
|
unsigned n_slaves; /* # of lituses */
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
unsigned saw_tlsgd : 1; /* true if ... */
|
|
|
|
|
unsigned saw_tlsldm : 1;
|
|
|
|
|
unsigned saw_lu_tlsgd : 1;
|
|
|
|
|
unsigned saw_lu_tlsldm : 1;
|
|
|
|
|
unsigned multi_section_p : 1; /* true if more than one section was used */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
char string[1]; /* printable form of sequence to hash with */
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Hash table to link up literals with the appropriate lituse */
|
|
|
|
|
static struct hash_control *alpha_literal_hash;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
|
|
|
|
|
/* Sequence numbers for internal use by macros. */
|
|
|
|
|
static long next_sequence_num = -1;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* A table of CPU names and opcode sets. */
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
static const struct cpu_type
|
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const char *name;
|
|
|
|
|
unsigned flags;
|
2002-08-14 21:27:06 +08:00
|
|
|
|
}
|
|
|
|
|
cpu_types[] =
|
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* Ad hoc convention: cpu number gets palcode, process code doesn't.
|
2000-09-15 09:06:52 +08:00
|
|
|
|
This supports usage under DU 4.0b that does ".arch ev4", and
|
1999-05-03 15:29:11 +08:00
|
|
|
|
usage in MILO that does -m21064. Probably something more
|
|
|
|
|
specific like -m21064-pal should be used, but oh well. */
|
|
|
|
|
|
|
|
|
|
{ "21064", AXP_OPCODE_BASE|AXP_OPCODE_EV4 },
|
|
|
|
|
{ "21064a", AXP_OPCODE_BASE|AXP_OPCODE_EV4 },
|
|
|
|
|
{ "21066", AXP_OPCODE_BASE|AXP_OPCODE_EV4 },
|
|
|
|
|
{ "21068", AXP_OPCODE_BASE|AXP_OPCODE_EV4 },
|
|
|
|
|
{ "21164", AXP_OPCODE_BASE|AXP_OPCODE_EV5 },
|
|
|
|
|
{ "21164a", AXP_OPCODE_BASE|AXP_OPCODE_EV5|AXP_OPCODE_BWX },
|
|
|
|
|
{ "21164pc", (AXP_OPCODE_BASE|AXP_OPCODE_EV5|AXP_OPCODE_BWX
|
|
|
|
|
|AXP_OPCODE_MAX) },
|
|
|
|
|
{ "21264", (AXP_OPCODE_BASE|AXP_OPCODE_EV6|AXP_OPCODE_BWX
|
|
|
|
|
|AXP_OPCODE_MAX|AXP_OPCODE_CIX) },
|
2002-08-07 06:06:08 +08:00
|
|
|
|
{ "21264a", (AXP_OPCODE_BASE|AXP_OPCODE_EV6|AXP_OPCODE_BWX
|
|
|
|
|
|AXP_OPCODE_MAX|AXP_OPCODE_CIX) },
|
|
|
|
|
{ "21264b", (AXP_OPCODE_BASE|AXP_OPCODE_EV6|AXP_OPCODE_BWX
|
|
|
|
|
|AXP_OPCODE_MAX|AXP_OPCODE_CIX) },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
{ "ev4", AXP_OPCODE_BASE },
|
|
|
|
|
{ "ev45", AXP_OPCODE_BASE },
|
|
|
|
|
{ "lca45", AXP_OPCODE_BASE },
|
|
|
|
|
{ "ev5", AXP_OPCODE_BASE },
|
|
|
|
|
{ "ev56", AXP_OPCODE_BASE|AXP_OPCODE_BWX },
|
|
|
|
|
{ "pca56", AXP_OPCODE_BASE|AXP_OPCODE_BWX|AXP_OPCODE_MAX },
|
|
|
|
|
{ "ev6", AXP_OPCODE_BASE|AXP_OPCODE_BWX|AXP_OPCODE_MAX|AXP_OPCODE_CIX },
|
2002-08-07 06:06:08 +08:00
|
|
|
|
{ "ev67", AXP_OPCODE_BASE|AXP_OPCODE_BWX|AXP_OPCODE_MAX|AXP_OPCODE_CIX },
|
|
|
|
|
{ "ev68", AXP_OPCODE_BASE|AXP_OPCODE_BWX|AXP_OPCODE_MAX|AXP_OPCODE_CIX },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
{ "all", AXP_OPCODE_BASE },
|
1999-10-19 06:29:15 +08:00
|
|
|
|
{ 0, 0 }
|
1999-05-03 15:29:11 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* The macro table */
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
static const struct alpha_macro alpha_macros[] =
|
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* Load/Store macros */
|
|
|
|
|
{ "lda", emit_lda, NULL,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldah", emit_ldah, NULL,
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
|
|
|
|
|
{ "ldl", emit_ir_load, "ldl",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldl_l", emit_ir_load, "ldl_l",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldq", emit_ir_load, "ldq",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldq_l", emit_ir_load, "ldq_l",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldq_u", emit_ir_load, "ldq_u",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldf", emit_loadstore, "ldf",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldg", emit_loadstore, "ldg",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "lds", emit_loadstore, "lds",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ldt", emit_loadstore, "ldt",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "ldb", emit_ldX, (PTR) 0,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "ldbu", emit_ldXu, (PTR) 0,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "ldw", emit_ldX, (PTR) 1,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "ldwu", emit_ldXu, (PTR) 1,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "uldw", emit_uldX, (PTR) 1,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "uldwu", emit_uldXu, (PTR) 1,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "uldl", emit_uldX, (PTR) 2,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "uldlu", emit_uldXu, (PTR) 2,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "uldq", emit_uldXu, (PTR) 3,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
{ "ldgp", emit_ldgp, NULL,
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_PIR, MACRO_EOA } },
|
|
|
|
|
|
|
|
|
|
{ "ldi", emit_lda, NULL,
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
{ "ldil", emit_ldil, NULL,
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
{ "ldiq", emit_lda, NULL,
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
#if 0
|
|
|
|
|
{ "ldif" emit_ldiq, NULL,
|
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
{ "ldid" emit_ldiq, NULL,
|
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
{ "ldig" emit_ldiq, NULL,
|
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
{ "ldis" emit_ldiq, NULL,
|
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
{ "ldit" emit_ldiq, NULL,
|
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_EOA } },
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
{ "stl", emit_loadstore, "stl",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "stl_c", emit_loadstore, "stl_c",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "stq", emit_loadstore, "stq",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "stq_c", emit_loadstore, "stq_c",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "stq_u", emit_loadstore, "stq_u",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "stf", emit_loadstore, "stf",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "stg", emit_loadstore, "stg",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "sts", emit_loadstore, "sts",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "stt", emit_loadstore, "stt",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_FPR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "stb", emit_stX, (PTR) 0,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "stw", emit_stX, (PTR) 1,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "ustw", emit_ustX, (PTR) 1,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "ustl", emit_ustX, (PTR) 2,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "ustq", emit_ustX, (PTR) 3,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_OPIR, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* Arithmetic macros */
|
|
|
|
|
#if 0
|
|
|
|
|
{ "absl" emit_absl, 1, { IR } },
|
|
|
|
|
{ "absl" emit_absl, 2, { IR, IR } },
|
|
|
|
|
{ "absl" emit_absl, 2, { EXP, IR } },
|
|
|
|
|
{ "absq" emit_absq, 1, { IR } },
|
|
|
|
|
{ "absq" emit_absq, 2, { IR, IR } },
|
|
|
|
|
{ "absq" emit_absq, 2, { EXP, IR } },
|
|
|
|
|
#endif
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "sextb", emit_sextX, (PTR) 0,
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_EXP, MACRO_IR, MACRO_EOA */ } },
|
2001-01-19 20:03:34 +08:00
|
|
|
|
{ "sextw", emit_sextX, (PTR) 1,
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_EXP, MACRO_IR, MACRO_EOA */ } },
|
|
|
|
|
|
|
|
|
|
{ "divl", emit_division, "__divl",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
{ "divlu", emit_division, "__divlu",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
{ "divq", emit_division, "__divq",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
{ "divqu", emit_division, "__divqu",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
{ "reml", emit_division, "__reml",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
{ "remlu", emit_division, "__remlu",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
{ "remq", emit_division, "__remq",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
{ "remqu", emit_division, "__remqu",
|
|
|
|
|
{ MACRO_IR, MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_IR, MACRO_EOA,
|
|
|
|
|
/* MACRO_IR, MACRO_EXP, MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA */ } },
|
|
|
|
|
|
|
|
|
|
{ "jsr", emit_jsrjmp, "jsr",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_PIR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_EXP, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "jmp", emit_jsrjmp, "jmp",
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{ MACRO_PIR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_EXP, MACRO_EOA } },
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "ret", emit_retjcr, "ret",
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EOA,
|
|
|
|
|
MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_EOA } },
|
|
|
|
|
{ "jcr", emit_retjcr, "jcr",
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EOA,
|
|
|
|
|
MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_EOA } },
|
|
|
|
|
{ "jsr_coroutine", emit_retjcr, "jcr",
|
|
|
|
|
{ MACRO_IR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_IR, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_PIR, MACRO_EOA,
|
|
|
|
|
MACRO_EXP, MACRO_EOA,
|
|
|
|
|
MACRO_EOA } },
|
|
|
|
|
};
|
|
|
|
|
|
1999-10-19 06:29:15 +08:00
|
|
|
|
static const unsigned int alpha_num_macros
|
2000-12-03 14:49:23 +08:00
|
|
|
|
= sizeof (alpha_macros) / sizeof (*alpha_macros);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* Public interface functions */
|
|
|
|
|
|
|
|
|
|
/* This function is called once, at assembler startup time. It sets
|
|
|
|
|
up all the tables, etc. that the MD part of the assembler will
|
|
|
|
|
need, that can be determined before arguments are parsed. */
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
md_begin ()
|
|
|
|
|
{
|
|
|
|
|
unsigned int i;
|
|
|
|
|
|
1999-06-07 18:23:47 +08:00
|
|
|
|
/* Verify that X_op field is wide enough. */
|
|
|
|
|
{
|
|
|
|
|
expressionS e;
|
1999-10-19 06:29:15 +08:00
|
|
|
|
e.X_op = O_max;
|
|
|
|
|
assert (e.X_op == O_max);
|
1999-06-07 18:23:47 +08:00
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Create the opcode hash table. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
alpha_opcode_hash = hash_new ();
|
2001-01-23 04:24:11 +08:00
|
|
|
|
for (i = 0; i < alpha_num_opcodes;)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
const char *name, *retval, *slash;
|
|
|
|
|
|
|
|
|
|
name = alpha_opcodes[i].name;
|
2001-01-23 04:24:11 +08:00
|
|
|
|
retval = hash_insert (alpha_opcode_hash, name, (PTR) &alpha_opcodes[i]);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (retval)
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
as_fatal (_("internal error: can't hash opcode `%s': %s"),
|
|
|
|
|
name, retval);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* Some opcodes include modifiers of various sorts with a "/mod"
|
|
|
|
|
syntax, like the architecture manual suggests. However, for
|
|
|
|
|
use with gcc at least, we also need access to those same opcodes
|
|
|
|
|
without the "/". */
|
|
|
|
|
|
|
|
|
|
if ((slash = strchr (name, '/')) != NULL)
|
|
|
|
|
{
|
|
|
|
|
char *p = xmalloc (strlen (name));
|
|
|
|
|
memcpy (p, name, slash - name);
|
|
|
|
|
strcpy (p + (slash - name), slash + 1);
|
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
(void) hash_insert (alpha_opcode_hash, p, (PTR) &alpha_opcodes[i]);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* Ignore failures -- the opcode table does duplicate some
|
|
|
|
|
variants in different forms, like "hw_stq" and "hw_st/q". */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
while (++i < alpha_num_opcodes
|
|
|
|
|
&& (alpha_opcodes[i].name == name
|
|
|
|
|
|| !strcmp (alpha_opcodes[i].name, name)))
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Create the macro hash table. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
alpha_macro_hash = hash_new ();
|
2001-01-23 04:24:11 +08:00
|
|
|
|
for (i = 0; i < alpha_num_macros;)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
const char *name, *retval;
|
|
|
|
|
|
|
|
|
|
name = alpha_macros[i].name;
|
2001-01-23 04:24:11 +08:00
|
|
|
|
retval = hash_insert (alpha_macro_hash, name, (PTR) &alpha_macros[i]);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (retval)
|
2001-01-23 04:24:11 +08:00
|
|
|
|
as_fatal (_("internal error: can't hash macro `%s': %s"),
|
|
|
|
|
name, retval);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
while (++i < alpha_num_macros
|
|
|
|
|
&& (alpha_macros[i].name == name
|
|
|
|
|
|| !strcmp (alpha_macros[i].name, name)))
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Construct symbols for each of the registers. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
for (i = 0; i < 32; ++i)
|
|
|
|
|
{
|
|
|
|
|
char name[4];
|
2002-08-14 21:27:06 +08:00
|
|
|
|
|
2000-12-03 14:49:23 +08:00
|
|
|
|
sprintf (name, "$%d", i);
|
2001-01-19 20:03:34 +08:00
|
|
|
|
alpha_register_table[i] = symbol_create (name, reg_section, i,
|
|
|
|
|
&zero_address_frag);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
for (; i < 64; ++i)
|
|
|
|
|
{
|
|
|
|
|
char name[5];
|
2002-08-14 21:27:06 +08:00
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
sprintf (name, "$f%d", i - 32);
|
2001-01-19 20:03:34 +08:00
|
|
|
|
alpha_register_table[i] = symbol_create (name, reg_section, i,
|
|
|
|
|
&zero_address_frag);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Create the special symbols and sections we'll be using. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* So .sbss will get used for tiny objects. */
|
|
|
|
|
bfd_set_gp_size (stdoutput, g_switch_value);
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
create_literal_section (".lita", &alpha_lita_section, &alpha_lita_symbol);
|
|
|
|
|
|
|
|
|
|
/* For handling the GP, create a symbol that won't be output in the
|
|
|
|
|
symbol table. We'll edit it out of relocs later. */
|
|
|
|
|
alpha_gp_symbol = symbol_create ("<GP value>", alpha_lita_section, 0x8000,
|
|
|
|
|
&zero_address_frag);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
create_literal_section (".link", &alpha_link_section, &alpha_link_symbol);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
segT sec = subseg_new (".mdebug", (subsegT) 0);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
bfd_set_section_flags (stdoutput, sec, SEC_HAS_CONTENTS | SEC_READONLY);
|
2001-01-19 20:03:34 +08:00
|
|
|
|
bfd_set_section_alignment (stdoutput, sec, 3);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
#endif /* OBJ_ELF */
|
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
/* Create literal lookup hash table. */
|
2001-01-19 20:03:34 +08:00
|
|
|
|
alpha_literal_hash = hash_new ();
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
|
|
|
|
|
subseg_set (text_section, 0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The public interface to the instruction assembler. */
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
md_assemble (str)
|
|
|
|
|
char *str;
|
|
|
|
|
{
|
2002-08-14 21:27:06 +08:00
|
|
|
|
char opname[32]; /* Current maximum is 13. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expressionS tok[MAX_INSN_ARGS];
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ntok, trunclen;
|
|
|
|
|
size_t opnamelen;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Split off the opcode. */
|
2000-02-28 11:25:35 +08:00
|
|
|
|
opnamelen = strspn (str, "abcdefghijklmnopqrstuvwxyz_/46819");
|
1999-05-03 15:29:11 +08:00
|
|
|
|
trunclen = (opnamelen < sizeof (opname) - 1
|
|
|
|
|
? opnamelen
|
|
|
|
|
: sizeof (opname) - 1);
|
|
|
|
|
memcpy (opname, str, trunclen);
|
|
|
|
|
opname[trunclen] = '\0';
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Tokenize the rest of the line. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if ((ntok = tokenize_arguments (str + opnamelen, tok, MAX_INSN_ARGS)) < 0)
|
|
|
|
|
{
|
1999-11-29 08:46:16 +08:00
|
|
|
|
if (ntok != TOKENIZE_ERROR_REPORT)
|
|
|
|
|
as_bad (_("syntax error"));
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Finish it off. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
assemble_tokens (opname, tok, ntok, alpha_macros_on);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Round up a section's size to the appropriate boundary. */
|
|
|
|
|
|
|
|
|
|
valueT
|
|
|
|
|
md_section_align (seg, size)
|
|
|
|
|
segT seg;
|
|
|
|
|
valueT size;
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
int align = bfd_get_section_alignment (stdoutput, seg);
|
|
|
|
|
valueT mask = ((valueT) 1 << align) - 1;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
return (size + mask) & ~mask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Turn a string in input_line_pointer into a floating point constant
|
2000-07-08 00:58:25 +08:00
|
|
|
|
of type TYPE, and store the appropriate bytes in *LITP. The number
|
|
|
|
|
of LITTLENUMS emitted is stored in *SIZEP. An error message is
|
1999-05-03 15:29:11 +08:00
|
|
|
|
returned, or NULL on OK. */
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Equal to MAX_PRECISION in atof-ieee.c. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#define MAX_LITTLENUMS 6
|
|
|
|
|
|
|
|
|
|
extern char *vax_md_atof PARAMS ((int, char *, int *));
|
|
|
|
|
|
|
|
|
|
char *
|
|
|
|
|
md_atof (type, litP, sizeP)
|
|
|
|
|
char type;
|
|
|
|
|
char *litP;
|
|
|
|
|
int *sizeP;
|
|
|
|
|
{
|
|
|
|
|
int prec;
|
|
|
|
|
LITTLENUM_TYPE words[MAX_LITTLENUMS];
|
|
|
|
|
LITTLENUM_TYPE *wordP;
|
|
|
|
|
char *t;
|
|
|
|
|
|
|
|
|
|
switch (type)
|
|
|
|
|
{
|
|
|
|
|
/* VAX floats */
|
|
|
|
|
case 'G':
|
|
|
|
|
/* VAX md_atof doesn't like "G" for some reason. */
|
|
|
|
|
type = 'g';
|
|
|
|
|
case 'F':
|
|
|
|
|
case 'D':
|
|
|
|
|
return vax_md_atof (type, litP, sizeP);
|
|
|
|
|
|
|
|
|
|
/* IEEE floats */
|
|
|
|
|
case 'f':
|
|
|
|
|
prec = 2;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'd':
|
|
|
|
|
prec = 4;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'x':
|
|
|
|
|
case 'X':
|
|
|
|
|
prec = 6;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'p':
|
|
|
|
|
case 'P':
|
|
|
|
|
prec = 6;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
*sizeP = 0;
|
|
|
|
|
return _("Bad call to MD_ATOF()");
|
|
|
|
|
}
|
|
|
|
|
t = atof_ieee (input_line_pointer, type, words);
|
|
|
|
|
if (t)
|
|
|
|
|
input_line_pointer = t;
|
|
|
|
|
*sizeP = prec * sizeof (LITTLENUM_TYPE);
|
|
|
|
|
|
|
|
|
|
for (wordP = words + prec - 1; prec--;)
|
|
|
|
|
{
|
|
|
|
|
md_number_to_chars (litP, (long) (*wordP--), sizeof (LITTLENUM_TYPE));
|
|
|
|
|
litP += sizeof (LITTLENUM_TYPE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Take care of the target-specific command-line options. */
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
md_parse_option (c, arg)
|
|
|
|
|
int c;
|
|
|
|
|
char *arg;
|
|
|
|
|
{
|
|
|
|
|
switch (c)
|
|
|
|
|
{
|
|
|
|
|
case 'F':
|
|
|
|
|
alpha_nofloats_on = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case OPTION_32ADDR:
|
|
|
|
|
alpha_addr32_on = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'g':
|
|
|
|
|
alpha_debug = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'G':
|
2001-01-19 20:03:34 +08:00
|
|
|
|
g_switch_value = atoi (arg);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'm':
|
|
|
|
|
{
|
|
|
|
|
const struct cpu_type *p;
|
|
|
|
|
for (p = cpu_types; p->name; ++p)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
if (strcmp (arg, p->name) == 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
alpha_target_name = p->name, alpha_target = p->flags;
|
|
|
|
|
goto found;
|
|
|
|
|
}
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_warn (_("Unknown CPU identifier `%s'"), arg);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
found:;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
2000-09-15 09:06:52 +08:00
|
|
|
|
case '+': /* For g++. Hash any name > 63 chars long. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
alpha_flag_hash_long_names = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'H': /* Show new symbol after hash truncation */
|
|
|
|
|
alpha_flag_show_after_trunc = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'h': /* for gnu-c/vax compatibility. */
|
|
|
|
|
break;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
case OPTION_RELAX:
|
|
|
|
|
alpha_flag_relax = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
case OPTION_MDEBUG:
|
|
|
|
|
alpha_flag_mdebug = 1;
|
|
|
|
|
break;
|
|
|
|
|
case OPTION_NO_MDEBUG:
|
|
|
|
|
alpha_flag_mdebug = 0;
|
|
|
|
|
break;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Print a description of the command-line options that we accept. */
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
md_show_usage (stream)
|
|
|
|
|
FILE *stream;
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
fputs (_("\
|
1999-05-03 15:29:11 +08:00
|
|
|
|
Alpha options:\n\
|
|
|
|
|
-32addr treat addresses as 32-bit values\n\
|
|
|
|
|
-F lack floating point instructions support\n\
|
2002-08-07 06:06:08 +08:00
|
|
|
|
-mev4 | -mev45 | -mev5 | -mev56 | -mpca56 | -mev6 | -mev67 | -mev68 | -mall\n\
|
1999-05-03 15:29:11 +08:00
|
|
|
|
specify variant of Alpha architecture\n\
|
2002-08-07 06:06:08 +08:00
|
|
|
|
-m21064 | -m21066 | -m21164 | -m21164a | -m21164pc | -m21264 | -m21264a | -m21264b\n\
|
1999-05-03 15:29:11 +08:00
|
|
|
|
these variants include PALcode opcodes\n"),
|
|
|
|
|
stream);
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
fputs (_("\
|
|
|
|
|
VMS options:\n\
|
|
|
|
|
-+ hash encode (don't truncate) names longer than 64 characters\n\
|
|
|
|
|
-H show new symbol after hash truncation\n"),
|
|
|
|
|
stream);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Decide from what point a pc-relative relocation is relative to,
|
|
|
|
|
relative to the pc-relative fixup. Er, relatively speaking. */
|
|
|
|
|
|
|
|
|
|
long
|
|
|
|
|
md_pcrel_from (fixP)
|
|
|
|
|
fixS *fixP;
|
|
|
|
|
{
|
|
|
|
|
valueT addr = fixP->fx_where + fixP->fx_frag->fr_address;
|
|
|
|
|
switch (fixP->fx_r_type)
|
|
|
|
|
{
|
2002-09-20 00:13:38 +08:00
|
|
|
|
case BFD_RELOC_23_PCREL_S2:
|
|
|
|
|
case BFD_RELOC_ALPHA_HINT:
|
|
|
|
|
case BFD_RELOC_ALPHA_BRSGP:
|
|
|
|
|
return addr + 4;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
default:
|
2002-09-20 00:13:38 +08:00
|
|
|
|
return addr;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Attempt to simplify or even eliminate a fixup. The return value is
|
|
|
|
|
ignored; perhaps it was once meaningful, but now it is historical.
|
|
|
|
|
To indicate that a fixup has been eliminated, set fixP->fx_done.
|
|
|
|
|
|
|
|
|
|
For ELF, here it is that we transform the GPDISP_HI16 reloc we used
|
|
|
|
|
internally into the GPDISP reloc used externally. We had to do
|
|
|
|
|
this so that we'd have the GPDISP_LO16 reloc as a tag to compute
|
|
|
|
|
the distance to the "lda" instruction for setting the addend to
|
|
|
|
|
GPDISP. */
|
|
|
|
|
|
2001-11-16 05:29:00 +08:00
|
|
|
|
void
|
2001-11-16 15:17:12 +08:00
|
|
|
|
md_apply_fix3 (fixP, valP, seg)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
fixS *fixP;
|
2001-11-16 05:29:00 +08:00
|
|
|
|
valueT * valP;
|
2001-08-21 08:22:23 +08:00
|
|
|
|
segT seg;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
char * const fixpos = fixP->fx_frag->fr_literal + fixP->fx_where;
|
2001-11-16 05:29:00 +08:00
|
|
|
|
valueT value = * valP;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
unsigned image, size;
|
|
|
|
|
|
|
|
|
|
switch (fixP->fx_r_type)
|
|
|
|
|
{
|
|
|
|
|
/* The GPDISP relocations are processed internally with a symbol
|
2002-09-05 08:01:18 +08:00
|
|
|
|
referring to the current function's section; we need to drop
|
|
|
|
|
in a value which, when added to the address of the start of
|
|
|
|
|
the function, gives the desired GP. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_HI16:
|
|
|
|
|
{
|
|
|
|
|
fixS *next = fixP->fx_next;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
/* With user-specified !gpdisp relocations, we can be missing
|
|
|
|
|
the matching LO16 reloc. We will have already issued an
|
|
|
|
|
error message. */
|
|
|
|
|
if (next)
|
|
|
|
|
fixP->fx_offset = (next->fx_frag->fr_address + next->fx_where
|
|
|
|
|
- fixP->fx_frag->fr_address - fixP->fx_where);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
value = (value - sign_extend_16 (value)) >> 16;
|
|
|
|
|
}
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
fixP->fx_r_type = BFD_RELOC_ALPHA_GPDISP;
|
|
|
|
|
#endif
|
|
|
|
|
goto do_reloc_gp;
|
|
|
|
|
|
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_LO16:
|
|
|
|
|
value = sign_extend_16 (value);
|
|
|
|
|
fixP->fx_offset = 0;
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
fixP->fx_done = 1;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
do_reloc_gp:
|
2001-08-21 08:22:23 +08:00
|
|
|
|
fixP->fx_addsy = section_symbol (seg);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
md_number_to_chars (fixpos, value, 2);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case BFD_RELOC_16:
|
|
|
|
|
if (fixP->fx_pcrel)
|
|
|
|
|
fixP->fx_r_type = BFD_RELOC_16_PCREL;
|
|
|
|
|
size = 2;
|
|
|
|
|
goto do_reloc_xx;
|
|
|
|
|
case BFD_RELOC_32:
|
|
|
|
|
if (fixP->fx_pcrel)
|
|
|
|
|
fixP->fx_r_type = BFD_RELOC_32_PCREL;
|
|
|
|
|
size = 4;
|
|
|
|
|
goto do_reloc_xx;
|
|
|
|
|
case BFD_RELOC_64:
|
|
|
|
|
if (fixP->fx_pcrel)
|
|
|
|
|
fixP->fx_r_type = BFD_RELOC_64_PCREL;
|
|
|
|
|
size = 8;
|
|
|
|
|
do_reloc_xx:
|
|
|
|
|
if (fixP->fx_pcrel == 0 && fixP->fx_addsy == 0)
|
|
|
|
|
{
|
|
|
|
|
md_number_to_chars (fixpos, value, size);
|
|
|
|
|
goto done;
|
|
|
|
|
}
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
case BFD_RELOC_GPREL32:
|
|
|
|
|
assert (fixP->fx_subsy == alpha_gp_symbol);
|
|
|
|
|
fixP->fx_subsy = 0;
|
|
|
|
|
/* FIXME: inherited this obliviousness of `value' -- why? */
|
|
|
|
|
md_number_to_chars (fixpos, -alpha_gp_value, 4);
|
|
|
|
|
break;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#else
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_GPREL32:
|
|
|
|
|
#endif
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_GPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_LO16:
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
case BFD_RELOC_23_PCREL_S2:
|
|
|
|
|
if (fixP->fx_pcrel == 0 && fixP->fx_addsy == 0)
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
image = bfd_getl32 (fixpos);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
image = (image & ~0x1FFFFF) | ((value >> 2) & 0x1FFFFF);
|
|
|
|
|
goto write_done;
|
|
|
|
|
}
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
case BFD_RELOC_ALPHA_HINT:
|
|
|
|
|
if (fixP->fx_pcrel == 0 && fixP->fx_addsy == 0)
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
image = bfd_getl32 (fixpos);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
image = (image & ~0x3FFF) | ((value >> 2) & 0x3FFF);
|
|
|
|
|
goto write_done;
|
|
|
|
|
}
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2002-02-10 06:55:06 +08:00
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
case BFD_RELOC_ALPHA_BRSGP:
|
2002-11-28 22:15:55 +08:00
|
|
|
|
return;
|
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_TLSGD:
|
|
|
|
|
case BFD_RELOC_ALPHA_TLSLDM:
|
|
|
|
|
case BFD_RELOC_ALPHA_GOTDTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GOTTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL16:
|
2002-11-28 22:15:55 +08:00
|
|
|
|
if (fixP->fx_addsy)
|
|
|
|
|
S_SET_THREAD_LOCAL (fixP->fx_addsy);
|
2002-02-10 06:55:06 +08:00
|
|
|
|
return;
|
|
|
|
|
#endif
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
case BFD_RELOC_ALPHA_LITERAL:
|
|
|
|
|
md_number_to_chars (fixpos, value, 2);
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif
|
|
|
|
|
case BFD_RELOC_ALPHA_ELF_LITERAL:
|
|
|
|
|
case BFD_RELOC_ALPHA_LITUSE:
|
|
|
|
|
case BFD_RELOC_ALPHA_LINKAGE:
|
|
|
|
|
case BFD_RELOC_ALPHA_CODEADDR:
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2001-01-03 18:03:46 +08:00
|
|
|
|
case BFD_RELOC_VTABLE_INHERIT:
|
|
|
|
|
case BFD_RELOC_VTABLE_ENTRY:
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
2001-01-03 18:03:46 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
default:
|
|
|
|
|
{
|
|
|
|
|
const struct alpha_operand *operand;
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
if ((int) fixP->fx_r_type >= 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
as_fatal (_("unhandled relocation type %s"),
|
|
|
|
|
bfd_get_reloc_code_name (fixP->fx_r_type));
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
assert (-(int) fixP->fx_r_type < (int) alpha_num_operands);
|
|
|
|
|
operand = &alpha_operands[-(int) fixP->fx_r_type];
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* The rest of these fixups only exist internally during symbol
|
|
|
|
|
resolution and have no representation in the object file.
|
|
|
|
|
Therefore they must be completely resolved as constants. */
|
|
|
|
|
|
|
|
|
|
if (fixP->fx_addsy != 0
|
Add support for storing local symbols in a small structure to save
memory when assembling large files.
* as.h: Don't include struc-symbol.h.
(symbolS): Add typedef.
* symbols.c: Include struc-symbol.h.
(local_hash): New static variable.
(save_symbol_name): New static function, from symbol_create.
(symbol_create): Call save_symbol_name.
(local_symbol_count): New static variable.
(local_symbol_conversion_count): Likewise.
(LOCAL_SYMBOL_CHECK): Define.
(local_symbol_make): New static function.
(local_symbol_convert): New static function.
(colon): Handle local symbols. Create local symbol for local
label name.
(symbol_table_insert): Handle local symbols.
(symbol_find_or_make): Create local symbol for local label name.
(symbol_find_base): Check for local symbol.
(symbol_append, symbol_insert): Check for local symbols.
(symbol_clear_list_pointers, symbol_remove): Likewise.
(verify_symbol_chain): Likewise.
(copy_symbol_attributes): Likewise.
(resolve_symbol_value): Handle local symbols.
(resolve_local_symbol): New static function.
(resolve_local_symbol_values): New function.
(S_GET_VALUE, S_SET_VALUE): Handle local symbols.
(S_IS_FUNCTION, S_IS_EXTERNAL, S_IS_WEAK, S_IS_COMMON): Likewise.
(S_IS_DEFINED, S_IS_DEBUG, S_IS_LOCAL, S_GET_NAME): Likewise.
(S_GET_SEGMENT, S_SET_SEGMENT, S_SET_EXTERNAL): Likewise.
(S_CLEAR_EXTERNAL, S_SET_WEAK, S_SET_NAME): Likewise.
(symbol_previous, symbol_next): New functions.
(symbol_get_value_expression): Likewise.
(symbol_set_value_expression): Likewise.
(symbol_set_frag, symbol_get_frag): Likewise.
(symbol_mark_used, symbol_clear_used, symbol_used_p): Likewise.
(symbol_mark_used_in_reloc): Likewise.
(symbol_clear_used_in_reloc, symbol_used_in_reloc_p): Likewise.
(symbol_mark_mri_common, symbol_clear_mri_common): Likewise.
(symbol_mri_common_p): Likewise.
(symbol_mark_written, symbol_clear_written): Likewise.
(symbol_written_p): Likewise.
(symbol_mark_resolved, symbol_resolved_p): Likewise.
(symbol_section_p, symbol_equated_p): Likewise.
(symbol_constant_p): Likewise.
(symbol_get_bfdsym, symbol_set_bfdsym): Likewise.
(symbol_get_obj, symbol_set_obj): Likewise.
(symbol_get_tc, symbol_set_tc): Likewise.
(symbol_begin): Initialize local_hash.
(print_symbol_value_1): Handle local symbols.
(symbol_print_statistics): Print local symbol statistics.
* symbols.h: Include "struc-symbol.h" if not BFD_ASSEMBLER.
Declare new symbols.c functions. Move many declarations here from
struc-symbol.h.
(SYMBOLS_NEED_BACKPOINTERS): Define if needed.
* struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Don't set.
(struct symbol): Move bsym to make it clearly the first field.
Remove TARGET_SYMBOL_FIELDS.
(symbolS): Don't typedef.
(struct broken_word): Remove.
(N_TYPE_seg, seg_N_TYPE): Move to symbol.h.
(SEGMENT_TO_SYMBOL_TYPE, N_REGISTER): Likewise.
(symbol_clear_list_pointers): Likewise.
(symbol_insert, symbol_remove): Likewise.
(symbol_previous, symbol_append): Likewise.
(verify_symbol_chain, verify_symbol_chain_2): Likewise.
(struct local_symbol): Define.
(local_symbol_converted_p, local_symbol_mark_converted): Define.
(local_symbol_resolved_p, local_symbol_mark_resolved): Define.
(local_symbol_get_frag, local_symbol_set_frag): Define.
(local_symbol_get_real_symbol): Define.
(local_symbol_set_real_symbol): Define.
Define.
* write.c (write_object_file): Call resolve_local_symbol_values.
* config/obj-ecoff.h (OBJ_SYMFIELD_TYPE): Define.
(TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-elf.h (OBJ_SYMFIELD_TYPE): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-multi.h (struct elf_obj_sy): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
(ECOFF_DEBUG_TARGET_SYMBOL_FIELDS): Don't define.
* config/tc-mcore.h: Don't include struc-symbol.h.
(TARGET_SYMBOL_FIELDS): Don't define.
(struct mcore_tc_sy): Define.
(TC_SYMFIELD_TYPE): Define.
* Many files: Use symbolS instead of struct symbol. Use new
accessor functions rather than referring to symbolS fields
directly.
* read.c (s_mri_common): Don't add in value of line_label.
* config/tc-mips.c (md_apply_fix): Correct parenthesization when
checking for SEC_LINK_ONCE.
* config/tc-sh.h (sh_fix_adjustable): Declare.
1999-06-03 08:29:48 +08:00
|
|
|
|
&& S_GET_SEGMENT (fixP->fx_addsy) != absolute_section)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
as_bad_where (fixP->fx_file, fixP->fx_line,
|
|
|
|
|
_("non-absolute expression in constant field"));
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
image = bfd_getl32 (fixpos);
|
|
|
|
|
image = insert_operand (image, operand, (offsetT) value,
|
|
|
|
|
fixP->fx_file, fixP->fx_line);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
goto write_done;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (fixP->fx_addsy != 0 || fixP->fx_pcrel != 0)
|
2001-11-16 05:29:00 +08:00
|
|
|
|
return;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
else
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_warn_where (fixP->fx_file, fixP->fx_line,
|
2001-01-23 04:24:11 +08:00
|
|
|
|
_("type %d reloc done?\n"), (int) fixP->fx_r_type);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto done;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
write_done:
|
2001-01-19 20:03:34 +08:00
|
|
|
|
md_number_to_chars (fixpos, image, 4);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
done:
|
|
|
|
|
fixP->fx_done = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2001-11-16 05:29:00 +08:00
|
|
|
|
/* Look for a register name in the given symbol. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
symbolS *
|
2001-01-19 20:03:34 +08:00
|
|
|
|
md_undefined_symbol (name)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
char *name;
|
|
|
|
|
{
|
|
|
|
|
if (*name == '$')
|
|
|
|
|
{
|
|
|
|
|
int is_float = 0, num;
|
|
|
|
|
|
|
|
|
|
switch (*++name)
|
|
|
|
|
{
|
|
|
|
|
case 'f':
|
|
|
|
|
if (name[1] == 'p' && name[2] == '\0')
|
|
|
|
|
return alpha_register_table[AXP_REG_FP];
|
|
|
|
|
is_float = 32;
|
|
|
|
|
/* FALLTHRU */
|
|
|
|
|
|
|
|
|
|
case 'r':
|
2001-09-19 13:33:36 +08:00
|
|
|
|
if (!ISDIGIT (*++name))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
break;
|
|
|
|
|
/* FALLTHRU */
|
|
|
|
|
|
|
|
|
|
case '0': case '1': case '2': case '3': case '4':
|
|
|
|
|
case '5': case '6': case '7': case '8': case '9':
|
|
|
|
|
if (name[1] == '\0')
|
|
|
|
|
num = name[0] - '0';
|
2001-09-19 13:33:36 +08:00
|
|
|
|
else if (name[0] != '0' && ISDIGIT (name[1]) && name[2] == '\0')
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
num = (name[0] - '0') * 10 + name[1] - '0';
|
|
|
|
|
if (num >= 32)
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
break;
|
|
|
|
|
|
2000-06-09 02:34:06 +08:00
|
|
|
|
if (!alpha_noat_on && (num + is_float) == AXP_REG_AT)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_warn (_("Used $at without \".set noat\""));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
return alpha_register_table[num + is_float];
|
|
|
|
|
|
|
|
|
|
case 'a':
|
|
|
|
|
if (name[1] == 't' && name[2] == '\0')
|
|
|
|
|
{
|
|
|
|
|
if (!alpha_noat_on)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_warn (_("Used $at without \".set noat\""));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
return alpha_register_table[AXP_REG_AT];
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'g':
|
|
|
|
|
if (name[1] == 'p' && name[2] == '\0')
|
|
|
|
|
return alpha_register_table[alpha_gp_register];
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 's':
|
|
|
|
|
if (name[1] == 'p' && name[2] == '\0')
|
|
|
|
|
return alpha_register_table[AXP_REG_SP];
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
/* @@@ Magic ECOFF bits. */
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
alpha_frob_ecoff_data ()
|
|
|
|
|
{
|
|
|
|
|
select_gp_value ();
|
|
|
|
|
/* $zero and $f31 are read-only */
|
|
|
|
|
alpha_gprmask &= ~1;
|
|
|
|
|
alpha_fprmask &= ~1;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* Hook to remember a recently defined label so that the auto-align
|
|
|
|
|
code can adjust the symbol after we know what alignment will be
|
|
|
|
|
required. */
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
alpha_define_label (sym)
|
|
|
|
|
symbolS *sym;
|
|
|
|
|
{
|
|
|
|
|
alpha_insn_label = sym;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Return true if we must always emit a reloc for a type and false if
|
2001-10-12 07:56:33 +08:00
|
|
|
|
there is some hope of resolving it at assembly time. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
alpha_force_relocation (f)
|
|
|
|
|
fixS *f;
|
|
|
|
|
{
|
|
|
|
|
if (alpha_flag_relax)
|
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
|
|
switch (f->fx_r_type)
|
|
|
|
|
{
|
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP:
|
|
|
|
|
case BFD_RELOC_ALPHA_LITERAL:
|
|
|
|
|
case BFD_RELOC_ALPHA_ELF_LITERAL:
|
|
|
|
|
case BFD_RELOC_ALPHA_LITUSE:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_GPREL16:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_GPREL32:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_LO16:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_LINKAGE:
|
|
|
|
|
case BFD_RELOC_ALPHA_CODEADDR:
|
2002-02-10 06:55:06 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_BRSGP:
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_TLSGD:
|
|
|
|
|
case BFD_RELOC_ALPHA_TLSLDM:
|
|
|
|
|
case BFD_RELOC_ALPHA_GOTDTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GOTTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL16:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
|
|
default:
|
2002-09-05 08:01:18 +08:00
|
|
|
|
break;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
2002-09-05 08:01:18 +08:00
|
|
|
|
|
2003-01-23 20:51:05 +08:00
|
|
|
|
return generic_force_reloc (f);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Return true if we can partially resolve a relocation now. */
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
alpha_fix_adjustable (f)
|
|
|
|
|
fixS *f;
|
|
|
|
|
{
|
|
|
|
|
/* Are there any relocation types for which we must generate a reloc
|
|
|
|
|
but we can adjust the values contained within it? */
|
|
|
|
|
switch (f->fx_r_type)
|
|
|
|
|
{
|
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP:
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
case BFD_RELOC_ALPHA_LITERAL:
|
|
|
|
|
case BFD_RELOC_ALPHA_ELF_LITERAL:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_LITUSE:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_LINKAGE:
|
|
|
|
|
case BFD_RELOC_ALPHA_CODEADDR:
|
|
|
|
|
return 1;
|
|
|
|
|
|
2001-01-03 18:03:46 +08:00
|
|
|
|
case BFD_RELOC_VTABLE_ENTRY:
|
|
|
|
|
case BFD_RELOC_VTABLE_INHERIT:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
return 0;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_GPREL16:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_GPREL32:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_LO16:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_23_PCREL_S2:
|
|
|
|
|
case BFD_RELOC_32:
|
|
|
|
|
case BFD_RELOC_64:
|
|
|
|
|
case BFD_RELOC_ALPHA_HINT:
|
|
|
|
|
return 1;
|
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_TLSGD:
|
|
|
|
|
case BFD_RELOC_ALPHA_TLSLDM:
|
|
|
|
|
case BFD_RELOC_ALPHA_GOTDTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GOTTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL16:
|
|
|
|
|
/* ??? No idea why we can't return a reference to .tbss+10, but
|
|
|
|
|
we're preventing this in the other assemblers. Follow for now. */
|
|
|
|
|
return 0;
|
|
|
|
|
|
2002-12-31 03:25:13 +08:00
|
|
|
|
#ifdef OBJ_ELF
|
2002-11-07 08:42:19 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_BRSGP:
|
|
|
|
|
/* If we have a BRSGP reloc to a local symbol, adjust it to BRADDR and
|
|
|
|
|
let it get resolved at assembly time. */
|
|
|
|
|
{
|
|
|
|
|
symbolS *sym = f->fx_addsy;
|
|
|
|
|
const char *name;
|
|
|
|
|
int offset = 0;
|
|
|
|
|
|
2003-01-23 20:51:05 +08:00
|
|
|
|
if (generic_force_reloc (f))
|
2002-11-07 08:42:19 +08:00
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
switch (S_GET_OTHER (sym) & STO_ALPHA_STD_GPLOAD)
|
|
|
|
|
{
|
|
|
|
|
case STO_ALPHA_NOPV:
|
|
|
|
|
break;
|
|
|
|
|
case STO_ALPHA_STD_GPLOAD:
|
|
|
|
|
offset = 8;
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
if (S_IS_LOCAL (sym))
|
|
|
|
|
name = "<local>";
|
|
|
|
|
else
|
|
|
|
|
name = S_GET_NAME (sym);
|
|
|
|
|
as_bad_where (f->fx_file, f->fx_line,
|
|
|
|
|
_("!samegp reloc against symbol without .prologue: %s"),
|
|
|
|
|
name);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
f->fx_r_type = BFD_RELOC_23_PCREL_S2;
|
|
|
|
|
f->fx_offset += offset;
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
2002-12-31 03:25:13 +08:00
|
|
|
|
#endif
|
2002-11-07 08:42:19 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
default:
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
/*NOTREACHED*/
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Generate the BFD reloc to be stuck in the object file from the
|
|
|
|
|
fixup used internally in the assembler. */
|
|
|
|
|
|
|
|
|
|
arelent *
|
|
|
|
|
tc_gen_reloc (sec, fixp)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
asection *sec ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
fixS *fixp;
|
|
|
|
|
{
|
|
|
|
|
arelent *reloc;
|
|
|
|
|
|
|
|
|
|
reloc = (arelent *) xmalloc (sizeof (arelent));
|
Add support for storing local symbols in a small structure to save
memory when assembling large files.
* as.h: Don't include struc-symbol.h.
(symbolS): Add typedef.
* symbols.c: Include struc-symbol.h.
(local_hash): New static variable.
(save_symbol_name): New static function, from symbol_create.
(symbol_create): Call save_symbol_name.
(local_symbol_count): New static variable.
(local_symbol_conversion_count): Likewise.
(LOCAL_SYMBOL_CHECK): Define.
(local_symbol_make): New static function.
(local_symbol_convert): New static function.
(colon): Handle local symbols. Create local symbol for local
label name.
(symbol_table_insert): Handle local symbols.
(symbol_find_or_make): Create local symbol for local label name.
(symbol_find_base): Check for local symbol.
(symbol_append, symbol_insert): Check for local symbols.
(symbol_clear_list_pointers, symbol_remove): Likewise.
(verify_symbol_chain): Likewise.
(copy_symbol_attributes): Likewise.
(resolve_symbol_value): Handle local symbols.
(resolve_local_symbol): New static function.
(resolve_local_symbol_values): New function.
(S_GET_VALUE, S_SET_VALUE): Handle local symbols.
(S_IS_FUNCTION, S_IS_EXTERNAL, S_IS_WEAK, S_IS_COMMON): Likewise.
(S_IS_DEFINED, S_IS_DEBUG, S_IS_LOCAL, S_GET_NAME): Likewise.
(S_GET_SEGMENT, S_SET_SEGMENT, S_SET_EXTERNAL): Likewise.
(S_CLEAR_EXTERNAL, S_SET_WEAK, S_SET_NAME): Likewise.
(symbol_previous, symbol_next): New functions.
(symbol_get_value_expression): Likewise.
(symbol_set_value_expression): Likewise.
(symbol_set_frag, symbol_get_frag): Likewise.
(symbol_mark_used, symbol_clear_used, symbol_used_p): Likewise.
(symbol_mark_used_in_reloc): Likewise.
(symbol_clear_used_in_reloc, symbol_used_in_reloc_p): Likewise.
(symbol_mark_mri_common, symbol_clear_mri_common): Likewise.
(symbol_mri_common_p): Likewise.
(symbol_mark_written, symbol_clear_written): Likewise.
(symbol_written_p): Likewise.
(symbol_mark_resolved, symbol_resolved_p): Likewise.
(symbol_section_p, symbol_equated_p): Likewise.
(symbol_constant_p): Likewise.
(symbol_get_bfdsym, symbol_set_bfdsym): Likewise.
(symbol_get_obj, symbol_set_obj): Likewise.
(symbol_get_tc, symbol_set_tc): Likewise.
(symbol_begin): Initialize local_hash.
(print_symbol_value_1): Handle local symbols.
(symbol_print_statistics): Print local symbol statistics.
* symbols.h: Include "struc-symbol.h" if not BFD_ASSEMBLER.
Declare new symbols.c functions. Move many declarations here from
struc-symbol.h.
(SYMBOLS_NEED_BACKPOINTERS): Define if needed.
* struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Don't set.
(struct symbol): Move bsym to make it clearly the first field.
Remove TARGET_SYMBOL_FIELDS.
(symbolS): Don't typedef.
(struct broken_word): Remove.
(N_TYPE_seg, seg_N_TYPE): Move to symbol.h.
(SEGMENT_TO_SYMBOL_TYPE, N_REGISTER): Likewise.
(symbol_clear_list_pointers): Likewise.
(symbol_insert, symbol_remove): Likewise.
(symbol_previous, symbol_append): Likewise.
(verify_symbol_chain, verify_symbol_chain_2): Likewise.
(struct local_symbol): Define.
(local_symbol_converted_p, local_symbol_mark_converted): Define.
(local_symbol_resolved_p, local_symbol_mark_resolved): Define.
(local_symbol_get_frag, local_symbol_set_frag): Define.
(local_symbol_get_real_symbol): Define.
(local_symbol_set_real_symbol): Define.
Define.
* write.c (write_object_file): Call resolve_local_symbol_values.
* config/obj-ecoff.h (OBJ_SYMFIELD_TYPE): Define.
(TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-elf.h (OBJ_SYMFIELD_TYPE): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-multi.h (struct elf_obj_sy): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
(ECOFF_DEBUG_TARGET_SYMBOL_FIELDS): Don't define.
* config/tc-mcore.h: Don't include struc-symbol.h.
(TARGET_SYMBOL_FIELDS): Don't define.
(struct mcore_tc_sy): Define.
(TC_SYMFIELD_TYPE): Define.
* Many files: Use symbolS instead of struct symbol. Use new
accessor functions rather than referring to symbolS fields
directly.
* read.c (s_mri_common): Don't add in value of line_label.
* config/tc-mips.c (md_apply_fix): Correct parenthesization when
checking for SEC_LINK_ONCE.
* config/tc-sh.h (sh_fix_adjustable): Declare.
1999-06-03 08:29:48 +08:00
|
|
|
|
reloc->sym_ptr_ptr = (asymbol **) xmalloc (sizeof (asymbol *));
|
|
|
|
|
*reloc->sym_ptr_ptr = symbol_get_bfdsym (fixp->fx_addsy);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
reloc->address = fixp->fx_frag->fr_address + fixp->fx_where;
|
|
|
|
|
|
|
|
|
|
/* Make sure none of our internal relocations make it this far.
|
|
|
|
|
They'd better have been fully resolved by this point. */
|
2001-01-19 20:03:34 +08:00
|
|
|
|
assert ((int) fixp->fx_r_type > 0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
reloc->howto = bfd_reloc_type_lookup (stdoutput, fixp->fx_r_type);
|
|
|
|
|
if (reloc->howto == NULL)
|
|
|
|
|
{
|
|
|
|
|
as_bad_where (fixp->fx_file, fixp->fx_line,
|
|
|
|
|
_("cannot represent `%s' relocation in object file"),
|
|
|
|
|
bfd_get_reloc_code_name (fixp->fx_r_type));
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!fixp->fx_pcrel != !reloc->howto->pc_relative)
|
|
|
|
|
{
|
|
|
|
|
as_fatal (_("internal error? cannot generate `%s' relocation"),
|
|
|
|
|
bfd_get_reloc_code_name (fixp->fx_r_type));
|
|
|
|
|
}
|
|
|
|
|
assert (!fixp->fx_pcrel == !reloc->howto->pc_relative);
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
if (fixp->fx_r_type == BFD_RELOC_ALPHA_LITERAL)
|
|
|
|
|
{
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Fake out bfd_perform_relocation. sigh. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
reloc->addend = -alpha_gp_value;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
reloc->addend = fixp->fx_offset;
|
|
|
|
|
#ifdef OBJ_ELF
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Ohhh, this is ugly. The problem is that if this is a local global
|
|
|
|
|
symbol, the relocation will entirely be performed at link time, not
|
|
|
|
|
at assembly time. bfd_perform_reloc doesn't know about this sort
|
|
|
|
|
of thing, and as a result we need to fake it out here. */
|
2001-11-29 03:15:14 +08:00
|
|
|
|
if ((S_IS_EXTERN (fixp->fx_addsy) || S_IS_WEAK (fixp->fx_addsy)
|
* elf.c (_bfd_elf_make_section_from_shdr): Set SEC_THREAD_LOCAL
for symbols from SHF_TLS section.
(_bfd_elf_print_private_bfd_data): Add PT_TLS.
(elf_fake_sections): Set SHF_TLS for SEC_THREAD_LOCAL sections.
(map_sections_to_segments): Build PT_TLS segment if necessary.
(assign_file_positions_for_segments): Likewise.
(get_program_header_size): Account for PT_TLS segment.
(swap_out_syms): Set type of BSF_THREAD_LOCAL symbols and symbols from
SEC_THREAD_LOCAL sections to STT_TLS.
* reloc.c: Add 386 and IA-64 TLS relocs.
* section.c (SEC_THREAD_LOCAL): Define.
(SEC_CONSTRUCTOR_TEXT, SEC_CONSTRUCTOR_DATA, SEC_CONSTRUCTOR_BSS):
Remove.
* elflink.h (elf_link_add_object_symbols): Support .tcommon.
(size_dynamic_sections): If DF_STATIC_TLS, set DF_FLAGS
unconditionally.
(struct elf_final_link_info): Add first_tls_sec.
(elf_bfd_final_link): Set first_tls_sec.
Compute elf_hash_table (info)->tls_segment.
(elf_link_output_extsym): Handle STT_TLS symbols.
(elf_link_input_bfd): Likewise.
* syms.c (BSF_THREAD_LOCAL): Define.
* bfd-in2.h: Rebuilt.
* libbfd.h: Rebuilt.
* elf32-i386.c (elf_i386_tls_transition, dtpoff_base, tpoff,
elf_i386_mkobject, elf_i386_object_p): New functions.
(elf_howto_table): Add TLS relocs.
(elf_i386_reloc_type_lookup): Support TLS relocs.
(elf_i386_info_to_howto_rel): Likewise.
(struct elf_i386_link_hash_entry): Add tls_type.
(struct elf_i386_obj_tdata): New.
(elf_i386_hash_entry, elf_i386_tdata, elf_i386_local_got_tls_type):
New macros.
(struct elf_i386_link_hash_table): Add tls_ldm_got.
(link_hash_newfunc): Clear tls_type.
(elf_i386_check_relocs): Support TLS relocs.
(elf_i386_gc_sweep_hook): Likewise.
(allocate_dynrelocs): Likewise.
(elf_i386_size_dynamic_sections): Likewise.
(elf_i386_relocate_section): Likewise.
(elf_i386_finish_dynamic_symbol): Likewise.
(bfd_elf32_mkobject, elf_backend_object_p): Define.
* elfxx-ia64.c (struct elfNN_ia64_dyn_sym_info): Add tprel_offset,
dtpmod_offset, dtprel_offset, tprel_done, dtpmod_done, dtprel_done,
want_tprel, want_dtpmod, want_dtprel.
(elfNN_ia64_tprel_base, elfNN_ia64_dtprel_base): New functions.
(ia64_howto_table): Add TLS relocs, rename R_IA64_LTOFF_TP22 to
R_IA64_LTOFF_TPREL22.
(elf_code_to_howto_index): Add TLS relocs.
(elfNN_ia64_check_relocs): Support TLS relocs.
(allocate_global_data_got): Account for TLS .got data.
(allocate_dynrel_entries): Account for TLS dynamic relocations.
(elfNN_ia64_install_value): Supprt TLS relocs.
(set_got_entry): Support TLS relocs.
(elfNN_ia64_relocate_section): Likewise.
* config/obj-elf.c (elf_common): Renamed from obj_elf_common.
(obj_elf_common): Call elf_common.
(obj_elf_tls_common): New function.
(elf_pseudo_tab): Support .tls_common.
(special_sections): Add .tdata and .tbss.
(obj_elf_change_section): Set SEC_THREAD_LOCAL for SHF_TLS
sections.
(obj_elf_parse_section_letters): Support T in section flags (SHF_TLS).
(obj_elf_parse_section_letters): Include T in error message.
* config/tc-ppc.c (ppc_section_letter): Likewise.
* config/tc-alpha.c (alpha_elf_section_letter): Likewise.
(tc_gen_reloc): Handle SEC_THREAD_LOCAL the same way as
SEC_MERGE.
* config/tc-sparc.c (md_apply_fix3): Likewise.
* config/tc-i386.c (tc_i386_fix_adjustable): Add TLS relocs.
Define them if not BFD_ASSEMBLER.
(lex_got): Support @TLSGD, @TLSLDM, @GOTTPOFF, @TPOFF, @DTPOFF
and @NTPOFF.
(md_apply_fix3): Add TLS relocs.
* config/tc-ia64.c (enum reloc_func): Add FUNC_DTP_MODULE,
FUNC_DTP_RELATIVE, FUNC_TP_RELATIVE, FUNC_LT_DTP_MODULE,
FUNC_LT_DTP_RELATIVE, FUNC_LT_TP_RELATIVE.
(pseudo_func): Support @dtpmod(), @dtprel() and @tprel().
(ia64_elf_section_letter): Include T in error message.
(md_begin): Support TLS operators.
(md_operand): Likewise.
(ia64_gen_real_reloc_type): Support TLS relocs.
* testsuite/gas/i386/tlspic.s: New file.
* testsuite/gas/i386/tlsd.s: New file.
* testsuite/gas/i386/tlsnopic.s: New file.
* testsuite/gas/i386/tlsd.d: New file.
* testsuite/gas/i386/tlsnopic.d: New file.
* testsuite/gas/i386/tlspic.d: New file.
* testsuite/gas/i386/i386.exp: Add tlsd, tlsnopic and tlspic tests.
* testsuite/gas/ia64/tls.s: New file.
* testsuite/gas/ia64/tls.d: New file.
* testsuite/gas/ia64/ia64.exp: Add tls test.
* write.c (adjust_reloc_syms): Don't change symbols in
SEC_THREAD_LOCAL sections to STT_SECTION + addend.
* elf/common.h (PT_TLS, SHF_TLS, STT_TLS, DF_STATIC_TLS): Define.
* elf/ia64.h (R_IA64_LTOFF_TPREL22): Renamed from R_IA64_LTOFF_TP22.
* elf/i386.h: Add TLS relocs.
* scripttempl/elf.sc: Add .rel{,a}.t{bss,data}, .tdata and .tbss.
* ldlang.c (lang_add_section): Set SEC_THREAD_LOCAL for
output section if necessary. Handle .tbss.
(lang_size_sections): Clear _raw_size for .tbss section
(it allocates space in PT_TLS segment only).
* ldwrite.c (build_link_order): Build link order for .tbss too.
* readelf.c (get_segment_type): Add PT_TLS.
(get_elf_section_flags): Add SHF_TLS.
(get_dynamic_flags): Optimize. Add DF_STATIC_TLS.
(process_dynamic_segment): Use puts instead of printf.
(get_symbol_type): Support STT_TLS.
* objdump.c (dump_section_header): Remove SEC_CONSTRUCTOR_TEXT,
SEC_CONSTRUCTOR_DATA, SEC_CONSTRUCTOR_BSS.
Add SEC_THREAD_LOCAL.
2002-05-23 21:12:53 +08:00
|
|
|
|
|| (S_GET_SEGMENT (fixp->fx_addsy)->flags & SEC_MERGE)
|
|
|
|
|
|| (S_GET_SEGMENT (fixp->fx_addsy)->flags & SEC_THREAD_LOCAL))
|
2001-01-19 20:03:34 +08:00
|
|
|
|
&& !S_IS_COMMON (fixp->fx_addsy))
|
Add support for storing local symbols in a small structure to save
memory when assembling large files.
* as.h: Don't include struc-symbol.h.
(symbolS): Add typedef.
* symbols.c: Include struc-symbol.h.
(local_hash): New static variable.
(save_symbol_name): New static function, from symbol_create.
(symbol_create): Call save_symbol_name.
(local_symbol_count): New static variable.
(local_symbol_conversion_count): Likewise.
(LOCAL_SYMBOL_CHECK): Define.
(local_symbol_make): New static function.
(local_symbol_convert): New static function.
(colon): Handle local symbols. Create local symbol for local
label name.
(symbol_table_insert): Handle local symbols.
(symbol_find_or_make): Create local symbol for local label name.
(symbol_find_base): Check for local symbol.
(symbol_append, symbol_insert): Check for local symbols.
(symbol_clear_list_pointers, symbol_remove): Likewise.
(verify_symbol_chain): Likewise.
(copy_symbol_attributes): Likewise.
(resolve_symbol_value): Handle local symbols.
(resolve_local_symbol): New static function.
(resolve_local_symbol_values): New function.
(S_GET_VALUE, S_SET_VALUE): Handle local symbols.
(S_IS_FUNCTION, S_IS_EXTERNAL, S_IS_WEAK, S_IS_COMMON): Likewise.
(S_IS_DEFINED, S_IS_DEBUG, S_IS_LOCAL, S_GET_NAME): Likewise.
(S_GET_SEGMENT, S_SET_SEGMENT, S_SET_EXTERNAL): Likewise.
(S_CLEAR_EXTERNAL, S_SET_WEAK, S_SET_NAME): Likewise.
(symbol_previous, symbol_next): New functions.
(symbol_get_value_expression): Likewise.
(symbol_set_value_expression): Likewise.
(symbol_set_frag, symbol_get_frag): Likewise.
(symbol_mark_used, symbol_clear_used, symbol_used_p): Likewise.
(symbol_mark_used_in_reloc): Likewise.
(symbol_clear_used_in_reloc, symbol_used_in_reloc_p): Likewise.
(symbol_mark_mri_common, symbol_clear_mri_common): Likewise.
(symbol_mri_common_p): Likewise.
(symbol_mark_written, symbol_clear_written): Likewise.
(symbol_written_p): Likewise.
(symbol_mark_resolved, symbol_resolved_p): Likewise.
(symbol_section_p, symbol_equated_p): Likewise.
(symbol_constant_p): Likewise.
(symbol_get_bfdsym, symbol_set_bfdsym): Likewise.
(symbol_get_obj, symbol_set_obj): Likewise.
(symbol_get_tc, symbol_set_tc): Likewise.
(symbol_begin): Initialize local_hash.
(print_symbol_value_1): Handle local symbols.
(symbol_print_statistics): Print local symbol statistics.
* symbols.h: Include "struc-symbol.h" if not BFD_ASSEMBLER.
Declare new symbols.c functions. Move many declarations here from
struc-symbol.h.
(SYMBOLS_NEED_BACKPOINTERS): Define if needed.
* struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Don't set.
(struct symbol): Move bsym to make it clearly the first field.
Remove TARGET_SYMBOL_FIELDS.
(symbolS): Don't typedef.
(struct broken_word): Remove.
(N_TYPE_seg, seg_N_TYPE): Move to symbol.h.
(SEGMENT_TO_SYMBOL_TYPE, N_REGISTER): Likewise.
(symbol_clear_list_pointers): Likewise.
(symbol_insert, symbol_remove): Likewise.
(symbol_previous, symbol_append): Likewise.
(verify_symbol_chain, verify_symbol_chain_2): Likewise.
(struct local_symbol): Define.
(local_symbol_converted_p, local_symbol_mark_converted): Define.
(local_symbol_resolved_p, local_symbol_mark_resolved): Define.
(local_symbol_get_frag, local_symbol_set_frag): Define.
(local_symbol_get_real_symbol): Define.
(local_symbol_set_real_symbol): Define.
Define.
* write.c (write_object_file): Call resolve_local_symbol_values.
* config/obj-ecoff.h (OBJ_SYMFIELD_TYPE): Define.
(TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-elf.h (OBJ_SYMFIELD_TYPE): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-multi.h (struct elf_obj_sy): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
(ECOFF_DEBUG_TARGET_SYMBOL_FIELDS): Don't define.
* config/tc-mcore.h: Don't include struc-symbol.h.
(TARGET_SYMBOL_FIELDS): Don't define.
(struct mcore_tc_sy): Define.
(TC_SYMFIELD_TYPE): Define.
* Many files: Use symbolS instead of struct symbol. Use new
accessor functions rather than referring to symbolS fields
directly.
* read.c (s_mri_common): Don't add in value of line_label.
* config/tc-mips.c (md_apply_fix): Correct parenthesization when
checking for SEC_LINK_ONCE.
* config/tc-sh.h (sh_fix_adjustable): Declare.
1999-06-03 08:29:48 +08:00
|
|
|
|
reloc->addend -= symbol_get_bfdsym (fixp->fx_addsy)->value;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return reloc;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Parse a register name off of the input_line and return a register
|
|
|
|
|
number. Gets md_undefined_symbol above to do the register name
|
|
|
|
|
matching for us.
|
|
|
|
|
|
|
|
|
|
Only called as a part of processing the ECOFF .frame directive. */
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
tc_get_register (frame)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int frame ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
int framereg = AXP_REG_SP;
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
if (*input_line_pointer == '$')
|
|
|
|
|
{
|
|
|
|
|
char *s = input_line_pointer;
|
|
|
|
|
char c = get_symbol_end ();
|
|
|
|
|
symbolS *sym = md_undefined_symbol (s);
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
*strchr (s, '\0') = c;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (sym && (framereg = S_GET_VALUE (sym)) <= 31)
|
|
|
|
|
goto found;
|
|
|
|
|
}
|
|
|
|
|
as_warn (_("frame reg expected, using $%d."), framereg);
|
|
|
|
|
|
|
|
|
|
found:
|
|
|
|
|
note_gpreg (framereg);
|
|
|
|
|
return framereg;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* This is called before the symbol table is processed. In order to
|
|
|
|
|
work with gcc when using mips-tfile, we must keep all local labels.
|
|
|
|
|
However, in other cases, we want to discard them. If we were
|
|
|
|
|
called with -g, but we didn't see any debugging information, it may
|
|
|
|
|
mean that gcc is smuggling debugging information through to
|
|
|
|
|
mips-tfile, in which case we must generate all local labels. */
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
alpha_frob_file_before_adjust ()
|
|
|
|
|
{
|
|
|
|
|
if (alpha_debug != 0
|
|
|
|
|
&& ! ecoff_debugging_seen)
|
|
|
|
|
flag_keep_locals = 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif /* OBJ_ECOFF */
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
static struct alpha_reloc_tag *
|
|
|
|
|
get_alpha_reloc_tag (sequence)
|
|
|
|
|
long sequence;
|
|
|
|
|
{
|
|
|
|
|
char buffer[ALPHA_RELOC_DIGITS];
|
|
|
|
|
struct alpha_reloc_tag *info;
|
|
|
|
|
|
|
|
|
|
sprintf (buffer, "!%ld", sequence);
|
|
|
|
|
|
|
|
|
|
info = (struct alpha_reloc_tag *) hash_find (alpha_literal_hash, buffer);
|
|
|
|
|
if (! info)
|
|
|
|
|
{
|
|
|
|
|
size_t len = strlen (buffer);
|
|
|
|
|
const char *errmsg;
|
|
|
|
|
|
|
|
|
|
info = (struct alpha_reloc_tag *)
|
|
|
|
|
xcalloc (sizeof (struct alpha_reloc_tag) + len, 1);
|
|
|
|
|
|
|
|
|
|
info->segment = now_seg;
|
|
|
|
|
info->sequence = sequence;
|
|
|
|
|
strcpy (info->string, buffer);
|
|
|
|
|
errmsg = hash_insert (alpha_literal_hash, info->string, (PTR) info);
|
|
|
|
|
if (errmsg)
|
|
|
|
|
as_fatal (errmsg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return info;
|
|
|
|
|
}
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
/* Before the relocations are written, reorder them, so that user
|
|
|
|
|
supplied !lituse relocations follow the appropriate !literal
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
relocations, and similarly for !gpdisp relocations. */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
|
|
|
|
void
|
2002-09-05 08:01:18 +08:00
|
|
|
|
alpha_before_fix ()
|
1999-11-29 08:46:16 +08:00
|
|
|
|
{
|
|
|
|
|
if (alpha_literal_hash)
|
2002-09-05 08:01:18 +08:00
|
|
|
|
bfd_map_over_sections (stdoutput, alpha_adjust_relocs, NULL);
|
1999-11-29 08:46:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
2002-09-05 08:01:18 +08:00
|
|
|
|
alpha_adjust_relocs (abfd, sec, ptr)
|
2000-11-17 16:47:52 +08:00
|
|
|
|
bfd *abfd ATTRIBUTE_UNUSED;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
asection *sec;
|
2000-11-17 16:47:52 +08:00
|
|
|
|
PTR ptr ATTRIBUTE_UNUSED;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
{
|
|
|
|
|
segment_info_type *seginfo = seg_info (sec);
|
|
|
|
|
fixS **prevP;
|
|
|
|
|
fixS *fixp;
|
|
|
|
|
fixS *next;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
fixS *slave;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
/* If seginfo is NULL, we did not create this section; don't do
|
|
|
|
|
anything with it. By using a pointer to a pointer, we can update
|
|
|
|
|
the links in place. */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
if (seginfo == NULL)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/* If there are no relocations, skip the section. */
|
|
|
|
|
if (! seginfo->fix_root)
|
|
|
|
|
return;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
/* First rebuild the fixup chain without the expicit lituse and
|
|
|
|
|
gpdisp_lo16 relocs. */
|
|
|
|
|
prevP = &seginfo->fix_root;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
for (fixp = seginfo->fix_root; fixp; fixp = next)
|
|
|
|
|
{
|
|
|
|
|
next = fixp->fx_next;
|
2001-01-19 20:03:34 +08:00
|
|
|
|
fixp->fx_next = (fixS *) 0;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
|
|
|
|
switch (fixp->fx_r_type)
|
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_LITUSE:
|
|
|
|
|
if (fixp->tc_fix_data.info->n_master == 0)
|
|
|
|
|
as_bad_where (fixp->fx_file, fixp->fx_line,
|
|
|
|
|
_("No !literal!%ld was found"),
|
|
|
|
|
fixp->tc_fix_data.info->sequence);
|
2002-08-14 21:27:06 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
2002-06-02 10:28:45 +08:00
|
|
|
|
if (fixp->fx_offset == LITUSE_ALPHA_TLSGD)
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
{
|
|
|
|
|
if (! fixp->tc_fix_data.info->saw_tlsgd)
|
|
|
|
|
as_bad_where (fixp->fx_file, fixp->fx_line,
|
|
|
|
|
_("No !tlsgd!%ld was found"),
|
|
|
|
|
fixp->tc_fix_data.info->sequence);
|
|
|
|
|
}
|
2002-06-02 10:28:45 +08:00
|
|
|
|
else if (fixp->fx_offset == LITUSE_ALPHA_TLSLDM)
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
{
|
|
|
|
|
if (! fixp->tc_fix_data.info->saw_tlsldm)
|
|
|
|
|
as_bad_where (fixp->fx_file, fixp->fx_line,
|
|
|
|
|
_("No !tlsldm!%ld was found"),
|
|
|
|
|
fixp->tc_fix_data.info->sequence);
|
|
|
|
|
}
|
2002-08-14 21:27:06 +08:00
|
|
|
|
#endif
|
1999-11-29 08:46:16 +08:00
|
|
|
|
break;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_LO16:
|
|
|
|
|
if (fixp->tc_fix_data.info->n_master == 0)
|
1999-11-29 08:46:16 +08:00
|
|
|
|
as_bad_where (fixp->fx_file, fixp->fx_line,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
_("No ldah !gpdisp!%ld was found"),
|
1999-11-29 08:46:16 +08:00
|
|
|
|
fixp->tc_fix_data.info->sequence);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
break;
|
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_ELF_LITERAL:
|
2002-06-02 16:36:10 +08:00
|
|
|
|
if (fixp->tc_fix_data.info
|
|
|
|
|
&& (fixp->tc_fix_data.info->saw_tlsgd
|
|
|
|
|
|| fixp->tc_fix_data.info->saw_tlsldm))
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
break;
|
|
|
|
|
/* FALLTHRU */
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
default:
|
|
|
|
|
*prevP = fixp;
|
|
|
|
|
prevP = &fixp->fx_next;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
/* Go back and re-chain dependent relocations. They are currently
|
|
|
|
|
linked through the next_reloc field in reverse order, so as we
|
|
|
|
|
go through the next_reloc chain, we effectively reverse the chain
|
|
|
|
|
once again.
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
|
|
|
|
|
Except if there is more than one !literal for a given sequence
|
|
|
|
|
number. In that case, the programmer and/or compiler is not sure
|
|
|
|
|
how control flows from literal to lituse, and we can't be sure to
|
|
|
|
|
get the relaxation correct.
|
|
|
|
|
|
|
|
|
|
??? Well, actually we could, if there are enough lituses such that
|
|
|
|
|
we can make each literal have at least one of each lituse type
|
|
|
|
|
present. Not implemented.
|
|
|
|
|
|
|
|
|
|
Also suppress the optimization if the !literals/!lituses are spread
|
|
|
|
|
in different segments. This can happen with "intersting" uses of
|
|
|
|
|
inline assembly; examples are present in the Linux kernel semaphores. */
|
|
|
|
|
|
|
|
|
|
for (fixp = seginfo->fix_root; fixp; fixp = next)
|
1999-11-29 08:46:16 +08:00
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
next = fixp->fx_next;
|
|
|
|
|
switch (fixp->fx_r_type)
|
1999-11-29 08:46:16 +08:00
|
|
|
|
{
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_TLSGD:
|
|
|
|
|
case BFD_RELOC_ALPHA_TLSLDM:
|
|
|
|
|
if (!fixp->tc_fix_data.info)
|
|
|
|
|
break;
|
|
|
|
|
if (fixp->tc_fix_data.info->n_master == 0)
|
|
|
|
|
break;
|
|
|
|
|
else if (fixp->tc_fix_data.info->n_master > 1)
|
|
|
|
|
{
|
|
|
|
|
as_bad_where (fixp->fx_file, fixp->fx_line,
|
|
|
|
|
_("too many !literal!%ld for %s"),
|
|
|
|
|
fixp->tc_fix_data.info->sequence,
|
|
|
|
|
(fixp->fx_r_type == BFD_RELOC_ALPHA_TLSGD
|
|
|
|
|
? "!tlsgd" : "!tlsldm"));
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fixp->tc_fix_data.info->master->fx_next = fixp->fx_next;
|
|
|
|
|
fixp->fx_next = fixp->tc_fix_data.info->master;
|
|
|
|
|
fixp = fixp->fx_next;
|
|
|
|
|
/* FALLTHRU */
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_ELF_LITERAL:
|
2002-06-02 16:36:10 +08:00
|
|
|
|
if (fixp->tc_fix_data.info
|
|
|
|
|
&& fixp->tc_fix_data.info->n_master == 1
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
&& ! fixp->tc_fix_data.info->multi_section_p)
|
1999-11-29 08:46:16 +08:00
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
for (slave = fixp->tc_fix_data.info->slaves;
|
|
|
|
|
slave != (fixS *) 0;
|
|
|
|
|
slave = slave->tc_fix_data.next_reloc)
|
1999-11-29 08:46:16 +08:00
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
slave->fx_next = fixp->fx_next;
|
|
|
|
|
fixp->fx_next = slave;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
}
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_HI16:
|
|
|
|
|
if (fixp->tc_fix_data.info->n_slaves == 0)
|
|
|
|
|
as_bad_where (fixp->fx_file, fixp->fx_line,
|
|
|
|
|
_("No lda !gpdisp!%ld was found"),
|
|
|
|
|
fixp->tc_fix_data.info->sequence);
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
slave = fixp->tc_fix_data.info->slaves;
|
|
|
|
|
slave->fx_next = next;
|
|
|
|
|
fixp->fx_next = slave;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
}
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef DEBUG_ALPHA
|
|
|
|
|
static void
|
|
|
|
|
debug_exp (tok, ntok)
|
|
|
|
|
expressionS tok[];
|
|
|
|
|
int ntok;
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
fprintf (stderr, "debug_exp: %d tokens", ntok);
|
|
|
|
|
for (i = 0; i < ntok; i++)
|
|
|
|
|
{
|
|
|
|
|
expressionS *t = &tok[i];
|
|
|
|
|
const char *name;
|
2002-08-14 21:27:06 +08:00
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
switch (t->X_op)
|
|
|
|
|
{
|
|
|
|
|
default: name = "unknown"; break;
|
|
|
|
|
case O_illegal: name = "O_illegal"; break;
|
|
|
|
|
case O_absent: name = "O_absent"; break;
|
|
|
|
|
case O_constant: name = "O_constant"; break;
|
|
|
|
|
case O_symbol: name = "O_symbol"; break;
|
|
|
|
|
case O_symbol_rva: name = "O_symbol_rva"; break;
|
|
|
|
|
case O_register: name = "O_register"; break;
|
|
|
|
|
case O_big: name = "O_big"; break;
|
|
|
|
|
case O_uminus: name = "O_uminus"; break;
|
|
|
|
|
case O_bit_not: name = "O_bit_not"; break;
|
|
|
|
|
case O_logical_not: name = "O_logical_not"; break;
|
|
|
|
|
case O_multiply: name = "O_multiply"; break;
|
|
|
|
|
case O_divide: name = "O_divide"; break;
|
|
|
|
|
case O_modulus: name = "O_modulus"; break;
|
|
|
|
|
case O_left_shift: name = "O_left_shift"; break;
|
|
|
|
|
case O_right_shift: name = "O_right_shift"; break;
|
|
|
|
|
case O_bit_inclusive_or: name = "O_bit_inclusive_or"; break;
|
|
|
|
|
case O_bit_or_not: name = "O_bit_or_not"; break;
|
|
|
|
|
case O_bit_exclusive_or: name = "O_bit_exclusive_or"; break;
|
|
|
|
|
case O_bit_and: name = "O_bit_and"; break;
|
|
|
|
|
case O_add: name = "O_add"; break;
|
|
|
|
|
case O_subtract: name = "O_subtract"; break;
|
|
|
|
|
case O_eq: name = "O_eq"; break;
|
|
|
|
|
case O_ne: name = "O_ne"; break;
|
|
|
|
|
case O_lt: name = "O_lt"; break;
|
|
|
|
|
case O_le: name = "O_le"; break;
|
|
|
|
|
case O_ge: name = "O_ge"; break;
|
|
|
|
|
case O_gt: name = "O_gt"; break;
|
|
|
|
|
case O_logical_and: name = "O_logical_and"; break;
|
|
|
|
|
case O_logical_or: name = "O_logical_or"; break;
|
|
|
|
|
case O_index: name = "O_index"; break;
|
|
|
|
|
case O_pregister: name = "O_pregister"; break;
|
|
|
|
|
case O_cpregister: name = "O_cpregister"; break;
|
|
|
|
|
case O_literal: name = "O_literal"; break;
|
2002-02-10 06:55:06 +08:00
|
|
|
|
case O_lituse_addr: name = "O_lituse_addr"; break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
case O_lituse_base: name = "O_lituse_base"; break;
|
|
|
|
|
case O_lituse_bytoff: name = "O_lituse_bytoff"; break;
|
|
|
|
|
case O_lituse_jsr: name = "O_lituse_jsr"; break;
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case O_lituse_tlsgd: name = "O_lituse_tlsgd"; break;
|
|
|
|
|
case O_lituse_tlsldm: name = "O_lituse_tlsldm"; break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
case O_gpdisp: name = "O_gpdisp"; break;
|
|
|
|
|
case O_gprelhigh: name = "O_gprelhigh"; break;
|
|
|
|
|
case O_gprellow: name = "O_gprellow"; break;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case O_gprel: name = "O_gprel"; break;
|
2002-02-10 06:55:06 +08:00
|
|
|
|
case O_samegp: name = "O_samegp"; break;
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case O_tlsgd: name = "O_tlsgd"; break;
|
|
|
|
|
case O_tlsldm: name = "O_tlsldm"; break;
|
|
|
|
|
case O_gotdtprel: name = "O_gotdtprel"; break;
|
|
|
|
|
case O_dtprelhi: name = "O_dtprelhi"; break;
|
|
|
|
|
case O_dtprello: name = "O_dtprello"; break;
|
|
|
|
|
case O_dtprel: name = "O_dtprel"; break;
|
|
|
|
|
case O_gottprel: name = "O_gottprel"; break;
|
|
|
|
|
case O_tprelhi: name = "O_tprelhi"; break;
|
|
|
|
|
case O_tprello: name = "O_tprello"; break;
|
|
|
|
|
case O_tprel: name = "O_tprel"; break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fprintf (stderr, ", %s(%s, %s, %d)", name,
|
|
|
|
|
(t->X_add_symbol) ? S_GET_NAME (t->X_add_symbol) : "--",
|
|
|
|
|
(t->X_op_symbol) ? S_GET_NAME (t->X_op_symbol) : "--",
|
2001-01-19 20:03:34 +08:00
|
|
|
|
(int) t->X_add_number);
|
1999-11-29 08:46:16 +08:00
|
|
|
|
}
|
|
|
|
|
fprintf (stderr, "\n");
|
|
|
|
|
fflush (stderr);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* Parse the arguments to an opcode. */
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
tokenize_arguments (str, tok, ntok)
|
|
|
|
|
char *str;
|
|
|
|
|
expressionS tok[];
|
|
|
|
|
int ntok;
|
|
|
|
|
{
|
|
|
|
|
expressionS *end_tok = tok + ntok;
|
|
|
|
|
char *old_input_line_pointer;
|
|
|
|
|
int saw_comma = 0, saw_arg = 0;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
#ifdef DEBUG_ALPHA
|
|
|
|
|
expressionS *orig_tok = tok;
|
|
|
|
|
#endif
|
2002-08-14 21:27:06 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
1999-11-29 08:46:16 +08:00
|
|
|
|
char *p;
|
|
|
|
|
const struct alpha_reloc_op_tag *r;
|
|
|
|
|
int c, i;
|
|
|
|
|
size_t len;
|
|
|
|
|
int reloc_found_p = 0;
|
2002-08-14 21:27:06 +08:00
|
|
|
|
#endif
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
memset (tok, 0, sizeof (*tok) * ntok);
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Save and restore input_line_pointer around this function. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
old_input_line_pointer = input_line_pointer;
|
|
|
|
|
input_line_pointer = str;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
|
|
|
|
/* ??? Wrest control of ! away from the regular expression parser. */
|
|
|
|
|
is_end_of_line[(unsigned char) '!'] = 1;
|
|
|
|
|
#endif
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
while (tok < end_tok && *input_line_pointer)
|
|
|
|
|
{
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
switch (*input_line_pointer)
|
|
|
|
|
{
|
|
|
|
|
case '\0':
|
|
|
|
|
goto fini;
|
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
|
|
|
|
case '!':
|
|
|
|
|
/* A relocation operand can be placed after the normal operand on an
|
|
|
|
|
assembly language statement, and has the following form:
|
|
|
|
|
!relocation_type!sequence_number. */
|
|
|
|
|
if (reloc_found_p)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
{
|
|
|
|
|
/* Only support one relocation op per insn. */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
as_bad (_("More than one relocation op per insn"));
|
|
|
|
|
goto err_report;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!saw_arg)
|
|
|
|
|
goto err;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
++input_line_pointer;
|
2002-05-09 21:12:57 +08:00
|
|
|
|
SKIP_WHITESPACE ();
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
p = input_line_pointer;
|
|
|
|
|
c = get_symbol_end ();
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Parse !relocation_type. */
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
len = input_line_pointer - p;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
if (len == 0)
|
|
|
|
|
{
|
|
|
|
|
as_bad (_("No relocation operand"));
|
|
|
|
|
goto err_report;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
r = &alpha_reloc_op[0];
|
2001-01-23 04:24:11 +08:00
|
|
|
|
for (i = alpha_num_reloc_op - 1; i >= 0; i--, r++)
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
if (len == r->length && memcmp (p, r->name, len) == 0)
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
if (i < 0)
|
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
as_bad (_("Unknown relocation operand: !%s"), p);
|
1999-11-29 08:46:16 +08:00
|
|
|
|
goto err_report;
|
|
|
|
|
}
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
*input_line_pointer = c;
|
2002-05-09 21:12:57 +08:00
|
|
|
|
SKIP_WHITESPACE ();
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
if (*input_line_pointer != '!')
|
|
|
|
|
{
|
2001-09-08 09:12:00 +08:00
|
|
|
|
if (r->require_seq)
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{
|
2001-09-08 09:12:00 +08:00
|
|
|
|
as_bad (_("no sequence number after !%s"), p);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
goto err_report;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
tok->X_add_number = 0;
|
|
|
|
|
}
|
2001-09-08 09:12:00 +08:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (! r->allow_seq)
|
|
|
|
|
{
|
|
|
|
|
as_bad (_("!%s does not use a sequence number"), p);
|
|
|
|
|
goto err_report;
|
|
|
|
|
}
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
|
2001-09-08 09:12:00 +08:00
|
|
|
|
input_line_pointer++;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Parse !sequence_number. */
|
2001-09-08 09:12:00 +08:00
|
|
|
|
expression (tok);
|
|
|
|
|
if (tok->X_op != O_constant || tok->X_add_number <= 0)
|
|
|
|
|
{
|
|
|
|
|
as_bad (_("Bad sequence number: !%s!%s"),
|
|
|
|
|
r->name, input_line_pointer);
|
|
|
|
|
goto err_report;
|
|
|
|
|
}
|
1999-11-29 08:46:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
tok->X_op = r->op;
|
|
|
|
|
reloc_found_p = 1;
|
|
|
|
|
++tok;
|
|
|
|
|
break;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#endif /* RELOC_OP_P */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case ',':
|
|
|
|
|
++input_line_pointer;
|
|
|
|
|
if (saw_comma || !saw_arg)
|
|
|
|
|
goto err;
|
|
|
|
|
saw_comma = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case '(':
|
|
|
|
|
{
|
|
|
|
|
char *hold = input_line_pointer++;
|
|
|
|
|
|
2000-09-15 09:06:52 +08:00
|
|
|
|
/* First try for parenthesized register ... */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expression (tok);
|
|
|
|
|
if (*input_line_pointer == ')' && tok->X_op == O_register)
|
|
|
|
|
{
|
|
|
|
|
tok->X_op = (saw_comma ? O_cpregister : O_pregister);
|
|
|
|
|
saw_comma = 0;
|
|
|
|
|
saw_arg = 1;
|
|
|
|
|
++input_line_pointer;
|
|
|
|
|
++tok;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* ... then fall through to plain expression. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
input_line_pointer = hold;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
if (saw_arg && !saw_comma)
|
|
|
|
|
goto err;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expression (tok);
|
|
|
|
|
if (tok->X_op == O_illegal || tok->X_op == O_absent)
|
|
|
|
|
goto err;
|
|
|
|
|
|
|
|
|
|
saw_comma = 0;
|
|
|
|
|
saw_arg = 1;
|
|
|
|
|
++tok;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fini:
|
|
|
|
|
if (saw_comma)
|
|
|
|
|
goto err;
|
|
|
|
|
input_line_pointer = old_input_line_pointer;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
|
|
|
|
#ifdef DEBUG_ALPHA
|
|
|
|
|
debug_exp (orig_tok, ntok - (end_tok - tok));
|
|
|
|
|
#endif
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
|
|
|
|
is_end_of_line[(unsigned char) '!'] = 0;
|
|
|
|
|
#endif
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
return ntok - (end_tok - tok);
|
|
|
|
|
|
|
|
|
|
err:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
|
|
|
|
is_end_of_line[(unsigned char) '!'] = 0;
|
|
|
|
|
#endif
|
1999-05-03 15:29:11 +08:00
|
|
|
|
input_line_pointer = old_input_line_pointer;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
return TOKENIZE_ERROR;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
2002-08-14 21:27:06 +08:00
|
|
|
|
err_report:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
is_end_of_line[(unsigned char) '!'] = 0;
|
|
|
|
|
#endif
|
1999-11-29 08:46:16 +08:00
|
|
|
|
input_line_pointer = old_input_line_pointer;
|
|
|
|
|
return TOKENIZE_ERROR_REPORT;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Search forward through all variants of an opcode looking for a
|
|
|
|
|
syntax match. */
|
|
|
|
|
|
|
|
|
|
static const struct alpha_opcode *
|
2001-01-19 20:03:34 +08:00
|
|
|
|
find_opcode_match (first_opcode, tok, pntok, pcpumatch)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const struct alpha_opcode *first_opcode;
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int *pntok;
|
|
|
|
|
int *pcpumatch;
|
|
|
|
|
{
|
|
|
|
|
const struct alpha_opcode *opcode = first_opcode;
|
|
|
|
|
int ntok = *pntok;
|
|
|
|
|
int got_cpu_match = 0;
|
|
|
|
|
|
|
|
|
|
do
|
|
|
|
|
{
|
|
|
|
|
const unsigned char *opidx;
|
|
|
|
|
int tokidx = 0;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Don't match opcodes that don't exist on this architecture. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (!(opcode->flags & alpha_target))
|
|
|
|
|
goto match_failed;
|
|
|
|
|
|
|
|
|
|
got_cpu_match = 1;
|
|
|
|
|
|
|
|
|
|
for (opidx = opcode->operands; *opidx; ++opidx)
|
|
|
|
|
{
|
|
|
|
|
const struct alpha_operand *operand = &alpha_operands[*opidx];
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Only take input from real operands. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (operand->flags & AXP_OPERAND_FAKE)
|
|
|
|
|
continue;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* When we expect input, make sure we have it. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (tokidx >= ntok)
|
|
|
|
|
{
|
|
|
|
|
if ((operand->flags & AXP_OPERAND_OPTIONAL_MASK) == 0)
|
|
|
|
|
goto match_failed;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Match operand type with expression type. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
switch (operand->flags & AXP_OPERAND_TYPECHECK_MASK)
|
|
|
|
|
{
|
|
|
|
|
case AXP_OPERAND_IR:
|
|
|
|
|
if (tok[tokidx].X_op != O_register
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_ir_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
break;
|
|
|
|
|
case AXP_OPERAND_FPR:
|
|
|
|
|
if (tok[tokidx].X_op != O_register
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_fpr_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
break;
|
2001-01-23 04:24:11 +08:00
|
|
|
|
case AXP_OPERAND_IR | AXP_OPERAND_PARENS:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (tok[tokidx].X_op != O_pregister
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_ir_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
break;
|
2001-01-23 04:24:11 +08:00
|
|
|
|
case AXP_OPERAND_IR | AXP_OPERAND_PARENS | AXP_OPERAND_COMMA:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (tok[tokidx].X_op != O_cpregister
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_ir_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case AXP_OPERAND_RELATIVE:
|
|
|
|
|
case AXP_OPERAND_SIGNED:
|
|
|
|
|
case AXP_OPERAND_UNSIGNED:
|
|
|
|
|
switch (tok[tokidx].X_op)
|
|
|
|
|
{
|
|
|
|
|
case O_illegal:
|
|
|
|
|
case O_absent:
|
|
|
|
|
case O_register:
|
|
|
|
|
case O_pregister:
|
|
|
|
|
case O_cpregister:
|
|
|
|
|
goto match_failed;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Everything else should have been fake. */
|
2000-12-03 14:49:23 +08:00
|
|
|
|
abort ();
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
++tokidx;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Possible match -- did we use all of our input? */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (tokidx == ntok)
|
|
|
|
|
{
|
|
|
|
|
*pntok = ntok;
|
|
|
|
|
return opcode;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
match_failed:;
|
|
|
|
|
}
|
2002-08-14 21:27:06 +08:00
|
|
|
|
while (++opcode - alpha_opcodes < (int) alpha_num_opcodes
|
2001-01-19 20:03:34 +08:00
|
|
|
|
&& !strcmp (opcode->name, first_opcode->name));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (*pcpumatch)
|
2001-01-20 12:23:33 +08:00
|
|
|
|
*pcpumatch = got_cpu_match;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Search forward through all variants of a macro looking for a syntax
|
|
|
|
|
match. */
|
|
|
|
|
|
|
|
|
|
static const struct alpha_macro *
|
2001-01-19 20:03:34 +08:00
|
|
|
|
find_macro_match (first_macro, tok, pntok)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const struct alpha_macro *first_macro;
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int *pntok;
|
|
|
|
|
{
|
|
|
|
|
const struct alpha_macro *macro = first_macro;
|
|
|
|
|
int ntok = *pntok;
|
|
|
|
|
|
|
|
|
|
do
|
|
|
|
|
{
|
|
|
|
|
const enum alpha_macro_arg *arg = macro->argsets;
|
|
|
|
|
int tokidx = 0;
|
|
|
|
|
|
|
|
|
|
while (*arg)
|
|
|
|
|
{
|
|
|
|
|
switch (*arg)
|
|
|
|
|
{
|
|
|
|
|
case MACRO_EOA:
|
|
|
|
|
if (tokidx == ntok)
|
|
|
|
|
return macro;
|
|
|
|
|
else
|
|
|
|
|
tokidx = 0;
|
|
|
|
|
break;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Index register. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case MACRO_IR:
|
|
|
|
|
if (tokidx >= ntok || tok[tokidx].X_op != O_register
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_ir_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
++tokidx;
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Parenthesized index register. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case MACRO_PIR:
|
|
|
|
|
if (tokidx >= ntok || tok[tokidx].X_op != O_pregister
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_ir_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
++tokidx;
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Optional parenthesized index register. */
|
1999-11-29 08:46:16 +08:00
|
|
|
|
case MACRO_OPIR:
|
|
|
|
|
if (tokidx < ntok && tok[tokidx].X_op == O_pregister
|
2001-01-19 20:03:34 +08:00
|
|
|
|
&& is_ir_num (tok[tokidx].X_add_number))
|
1999-11-29 08:46:16 +08:00
|
|
|
|
++tokidx;
|
|
|
|
|
break;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Leading comma with a parenthesized index register. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case MACRO_CPIR:
|
|
|
|
|
if (tokidx >= ntok || tok[tokidx].X_op != O_cpregister
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_ir_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
++tokidx;
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Floating point register. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case MACRO_FPR:
|
|
|
|
|
if (tokidx >= ntok || tok[tokidx].X_op != O_register
|
2001-01-19 20:03:34 +08:00
|
|
|
|
|| !is_fpr_num (tok[tokidx].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
++tokidx;
|
|
|
|
|
break;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Normal expression. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case MACRO_EXP:
|
|
|
|
|
if (tokidx >= ntok)
|
|
|
|
|
goto match_failed;
|
|
|
|
|
switch (tok[tokidx].X_op)
|
|
|
|
|
{
|
|
|
|
|
case O_illegal:
|
|
|
|
|
case O_absent:
|
|
|
|
|
case O_register:
|
|
|
|
|
case O_pregister:
|
|
|
|
|
case O_cpregister:
|
1999-11-29 08:46:16 +08:00
|
|
|
|
case O_literal:
|
|
|
|
|
case O_lituse_base:
|
|
|
|
|
case O_lituse_bytoff:
|
|
|
|
|
case O_lituse_jsr:
|
|
|
|
|
case O_gpdisp:
|
|
|
|
|
case O_gprelhigh:
|
|
|
|
|
case O_gprellow:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case O_gprel:
|
2002-02-10 06:55:06 +08:00
|
|
|
|
case O_samegp:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto match_failed;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
++tokidx;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
match_failed:
|
|
|
|
|
while (*arg != MACRO_EOA)
|
|
|
|
|
++arg;
|
|
|
|
|
tokidx = 0;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
++arg;
|
|
|
|
|
}
|
|
|
|
|
}
|
2002-08-14 21:27:06 +08:00
|
|
|
|
while (++macro - alpha_macros < (int) alpha_num_macros
|
2001-01-19 20:03:34 +08:00
|
|
|
|
&& !strcmp (macro->name, first_macro->name));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Insert an operand value into an instruction. */
|
|
|
|
|
|
|
|
|
|
static unsigned
|
2001-01-19 20:03:34 +08:00
|
|
|
|
insert_operand (insn, operand, val, file, line)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
unsigned insn;
|
|
|
|
|
const struct alpha_operand *operand;
|
|
|
|
|
offsetT val;
|
|
|
|
|
char *file;
|
|
|
|
|
unsigned line;
|
|
|
|
|
{
|
|
|
|
|
if (operand->bits != 32 && !(operand->flags & AXP_OPERAND_NOOVERFLOW))
|
|
|
|
|
{
|
|
|
|
|
offsetT min, max;
|
|
|
|
|
|
|
|
|
|
if (operand->flags & AXP_OPERAND_SIGNED)
|
|
|
|
|
{
|
|
|
|
|
max = (1 << (operand->bits - 1)) - 1;
|
|
|
|
|
min = -(1 << (operand->bits - 1));
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
max = (1 << operand->bits) - 1;
|
|
|
|
|
min = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (val < min || val > max)
|
|
|
|
|
{
|
|
|
|
|
const char *err =
|
|
|
|
|
_("operand out of range (%s not between %d and %d)");
|
|
|
|
|
char buf[sizeof (val) * 3 + 2];
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
sprint_value (buf, val);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (file)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_warn_where (file, line, err, buf, min, max);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
else
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_warn (err, buf, min, max);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (operand->insert)
|
|
|
|
|
{
|
|
|
|
|
const char *errmsg = NULL;
|
|
|
|
|
|
|
|
|
|
insn = (*operand->insert) (insn, val, &errmsg);
|
|
|
|
|
if (errmsg)
|
|
|
|
|
as_warn (errmsg);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
insn |= ((val & ((1 << operand->bits) - 1)) << operand->shift);
|
|
|
|
|
|
|
|
|
|
return insn;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Turn an opcode description and a set of arguments into
|
|
|
|
|
an instruction and a fixup. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
static void
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assemble_insn (opcode, tok, ntok, insn, reloc)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const struct alpha_opcode *opcode;
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
struct alpha_insn *insn;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
bfd_reloc_code_real_type reloc;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
const struct alpha_operand *reloc_operand = NULL;
|
|
|
|
|
const expressionS *reloc_exp = NULL;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const unsigned char *argidx;
|
|
|
|
|
unsigned image;
|
|
|
|
|
int tokidx = 0;
|
|
|
|
|
|
|
|
|
|
memset (insn, 0, sizeof (*insn));
|
|
|
|
|
image = opcode->opcode;
|
|
|
|
|
|
|
|
|
|
for (argidx = opcode->operands; *argidx; ++argidx)
|
|
|
|
|
{
|
|
|
|
|
const struct alpha_operand *operand = &alpha_operands[*argidx];
|
2001-01-19 20:03:34 +08:00
|
|
|
|
const expressionS *t = (const expressionS *) 0;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (operand->flags & AXP_OPERAND_FAKE)
|
|
|
|
|
{
|
|
|
|
|
/* fake operands take no value and generate no fixup */
|
2001-01-19 20:03:34 +08:00
|
|
|
|
image = insert_operand (image, operand, 0, NULL, 0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (tokidx >= ntok)
|
|
|
|
|
{
|
|
|
|
|
switch (operand->flags & AXP_OPERAND_OPTIONAL_MASK)
|
|
|
|
|
{
|
|
|
|
|
case AXP_OPERAND_DEFAULT_FIRST:
|
|
|
|
|
t = &tok[0];
|
|
|
|
|
break;
|
|
|
|
|
case AXP_OPERAND_DEFAULT_SECOND:
|
|
|
|
|
t = &tok[1];
|
|
|
|
|
break;
|
|
|
|
|
case AXP_OPERAND_DEFAULT_ZERO:
|
|
|
|
|
{
|
1999-10-19 06:29:15 +08:00
|
|
|
|
static expressionS zero_exp;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
t = &zero_exp;
|
1999-10-19 06:29:15 +08:00
|
|
|
|
zero_exp.X_op = O_constant;
|
|
|
|
|
zero_exp.X_unsigned = 1;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
default:
|
2000-12-03 14:49:23 +08:00
|
|
|
|
abort ();
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
t = &tok[tokidx++];
|
|
|
|
|
|
|
|
|
|
switch (t->X_op)
|
|
|
|
|
{
|
|
|
|
|
case O_register:
|
|
|
|
|
case O_pregister:
|
|
|
|
|
case O_cpregister:
|
2001-01-19 20:03:34 +08:00
|
|
|
|
image = insert_operand (image, operand, regno (t->X_add_number),
|
|
|
|
|
NULL, 0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case O_constant:
|
2001-01-19 20:03:34 +08:00
|
|
|
|
image = insert_operand (image, operand, t->X_add_number, NULL, 0);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assert (reloc_operand == NULL);
|
|
|
|
|
reloc_operand = operand;
|
|
|
|
|
reloc_exp = t;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
/* This is only 0 for fields that should contain registers,
|
|
|
|
|
which means this pattern shouldn't have matched. */
|
|
|
|
|
if (operand->default_reloc == 0)
|
|
|
|
|
abort ();
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
/* There is one special case for which an insn receives two
|
2002-05-09 21:12:57 +08:00
|
|
|
|
relocations, and thus the user-supplied reloc does not
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
override the operand reloc. */
|
|
|
|
|
if (operand->default_reloc == BFD_RELOC_ALPHA_HINT)
|
|
|
|
|
{
|
|
|
|
|
struct alpha_fixup *fixup;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
if (insn->nfixups >= MAX_INSN_FIXUPS)
|
|
|
|
|
as_fatal (_("too many fixups"));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
fixup = &insn->fixups[insn->nfixups++];
|
|
|
|
|
fixup->exp = *t;
|
|
|
|
|
fixup->reloc = BFD_RELOC_ALPHA_HINT;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (reloc == BFD_RELOC_UNUSED)
|
|
|
|
|
reloc = operand->default_reloc;
|
|
|
|
|
|
|
|
|
|
assert (reloc_operand == NULL);
|
|
|
|
|
reloc_operand = operand;
|
|
|
|
|
reloc_exp = t;
|
|
|
|
|
}
|
1999-05-03 15:29:11 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
if (reloc != BFD_RELOC_UNUSED)
|
|
|
|
|
{
|
|
|
|
|
struct alpha_fixup *fixup;
|
|
|
|
|
|
|
|
|
|
if (insn->nfixups >= MAX_INSN_FIXUPS)
|
|
|
|
|
as_fatal (_("too many fixups"));
|
|
|
|
|
|
|
|
|
|
/* ??? My but this is hacky. But the OSF/1 assembler uses the same
|
|
|
|
|
relocation tag for both ldah and lda with gpdisp. Choose the
|
|
|
|
|
correct internal relocation based on the opcode. */
|
|
|
|
|
if (reloc == BFD_RELOC_ALPHA_GPDISP)
|
|
|
|
|
{
|
|
|
|
|
if (strcmp (opcode->name, "ldah") == 0)
|
|
|
|
|
reloc = BFD_RELOC_ALPHA_GPDISP_HI16;
|
|
|
|
|
else if (strcmp (opcode->name, "lda") == 0)
|
|
|
|
|
reloc = BFD_RELOC_ALPHA_GPDISP_LO16;
|
|
|
|
|
else
|
|
|
|
|
as_bad (_("invalid relocation for instruction"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* If this is a real relocation (as opposed to a lituse hint), then
|
|
|
|
|
the relocation width should match the operand width. */
|
|
|
|
|
else if (reloc < BFD_RELOC_UNUSED)
|
|
|
|
|
{
|
|
|
|
|
reloc_howto_type *reloc_howto
|
|
|
|
|
= bfd_reloc_type_lookup (stdoutput, reloc);
|
|
|
|
|
if (reloc_howto->bitsize != reloc_operand->bits)
|
|
|
|
|
{
|
|
|
|
|
as_bad (_("invalid relocation for field"));
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fixup = &insn->fixups[insn->nfixups++];
|
|
|
|
|
if (reloc_exp)
|
|
|
|
|
fixup->exp = *reloc_exp;
|
|
|
|
|
else
|
|
|
|
|
fixup->exp.X_op = O_absent;
|
|
|
|
|
fixup->reloc = reloc;
|
|
|
|
|
}
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
insn->insn = image;
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Actually output an instruction with its fixup. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_insn (insn)
|
2001-01-23 04:24:11 +08:00
|
|
|
|
struct alpha_insn *insn;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
char *f;
|
|
|
|
|
int i;
|
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
/* Take care of alignment duties. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (alpha_auto_align_on && alpha_current_align < 2)
|
|
|
|
|
alpha_align (2, (char *) NULL, alpha_insn_label, 0);
|
|
|
|
|
if (alpha_current_align > 2)
|
|
|
|
|
alpha_current_align = 2;
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
|
|
|
|
|
/* Write out the instruction. */
|
|
|
|
|
f = frag_more (4);
|
|
|
|
|
md_number_to_chars (f, insn->insn, 4);
|
|
|
|
|
|
2000-11-17 16:47:52 +08:00
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
dwarf2_emit_insn (4);
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Apply the fixups in order. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
for (i = 0; i < insn->nfixups; ++i)
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
const struct alpha_operand *operand = (const struct alpha_operand *) 0;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
struct alpha_fixup *fixup = &insn->fixups[i];
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
struct alpha_reloc_tag *info = NULL;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
int size, pcrel;
|
|
|
|
|
fixS *fixP;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Some fixups are only used internally and so have no howto. */
|
2001-01-19 20:03:34 +08:00
|
|
|
|
if ((int) fixup->reloc < 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
operand = &alpha_operands[-(int) fixup->reloc];
|
1999-05-03 15:29:11 +08:00
|
|
|
|
size = 4;
|
|
|
|
|
pcrel = ((operand->flags & AXP_OPERAND_RELATIVE) != 0);
|
|
|
|
|
}
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
else if (fixup->reloc > BFD_RELOC_UNUSED
|
|
|
|
|
|| fixup->reloc == BFD_RELOC_ALPHA_GPDISP_HI16
|
|
|
|
|
|| fixup->reloc == BFD_RELOC_ALPHA_GPDISP_LO16)
|
|
|
|
|
{
|
|
|
|
|
size = 2;
|
|
|
|
|
pcrel = 0;
|
|
|
|
|
}
|
2001-01-20 12:23:33 +08:00
|
|
|
|
else
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{
|
|
|
|
|
reloc_howto_type *reloc_howto
|
|
|
|
|
= bfd_reloc_type_lookup (stdoutput, fixup->reloc);
|
|
|
|
|
assert (reloc_howto);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
size = bfd_get_reloc_size (reloc_howto);
|
|
|
|
|
assert (size >= 1 && size <= 4);
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
pcrel = reloc_howto->pc_relative;
|
|
|
|
|
}
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
fixP = fix_new_exp (frag_now, f - frag_now->fr_literal, size,
|
|
|
|
|
&fixup->exp, pcrel, fixup->reloc);
|
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
/* Turn off complaints that the addend is too large for some fixups,
|
|
|
|
|
and copy in the sequence number for the explicit relocations. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
switch (fixup->reloc)
|
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_HINT:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
case BFD_RELOC_GPREL32:
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_GPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GPREL_LO16:
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GOTDTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_DTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_GOTTPREL16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_HI16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL_LO16:
|
|
|
|
|
case BFD_RELOC_ALPHA_TPREL16:
|
1999-05-03 15:29:11 +08:00
|
|
|
|
fixP->fx_no_overflow = 1;
|
|
|
|
|
break;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_HI16:
|
1999-11-29 08:46:16 +08:00
|
|
|
|
fixP->fx_no_overflow = 1;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
fixP->fx_addsy = section_symbol (now_seg);
|
|
|
|
|
fixP->fx_offset = 0;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
info = get_alpha_reloc_tag (insn->sequence);
|
|
|
|
|
if (++info->n_master > 1)
|
|
|
|
|
as_bad (_("too many ldah insns for !gpdisp!%ld"), insn->sequence);
|
|
|
|
|
if (info->segment != now_seg)
|
|
|
|
|
as_bad (_("both insns for !gpdisp!%ld must be in the same section"),
|
|
|
|
|
insn->sequence);
|
|
|
|
|
fixP->tc_fix_data.info = info;
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_GPDISP_LO16:
|
|
|
|
|
fixP->fx_no_overflow = 1;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
info = get_alpha_reloc_tag (insn->sequence);
|
|
|
|
|
if (++info->n_slaves > 1)
|
|
|
|
|
as_bad (_("too many lda insns for !gpdisp!%ld"), insn->sequence);
|
1999-11-29 08:46:16 +08:00
|
|
|
|
if (info->segment != now_seg)
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
as_bad (_("both insns for !gpdisp!%ld must be in the same section"),
|
|
|
|
|
insn->sequence);
|
1999-11-29 08:46:16 +08:00
|
|
|
|
fixP->tc_fix_data.info = info;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
info->slaves = fixP;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
break;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_LITERAL:
|
|
|
|
|
case BFD_RELOC_ALPHA_ELF_LITERAL:
|
|
|
|
|
fixP->fx_no_overflow = 1;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
if (insn->sequence == 0)
|
|
|
|
|
break;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
info = get_alpha_reloc_tag (insn->sequence);
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
info->master = fixP;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
info->n_master++;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
if (info->segment != now_seg)
|
|
|
|
|
info->multi_section_p = 1;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
fixP->tc_fix_data.info = info;
|
|
|
|
|
break;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
case DUMMY_RELOC_LITUSE_ADDR:
|
2002-06-02 10:28:45 +08:00
|
|
|
|
fixP->fx_offset = LITUSE_ALPHA_ADDR;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
goto do_lituse;
|
|
|
|
|
case DUMMY_RELOC_LITUSE_BASE:
|
2002-06-02 10:28:45 +08:00
|
|
|
|
fixP->fx_offset = LITUSE_ALPHA_BASE;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
goto do_lituse;
|
|
|
|
|
case DUMMY_RELOC_LITUSE_BYTOFF:
|
2002-06-02 10:28:45 +08:00
|
|
|
|
fixP->fx_offset = LITUSE_ALPHA_BYTOFF;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
goto do_lituse;
|
|
|
|
|
case DUMMY_RELOC_LITUSE_JSR:
|
2002-06-02 10:28:45 +08:00
|
|
|
|
fixP->fx_offset = LITUSE_ALPHA_JSR;
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
goto do_lituse;
|
|
|
|
|
case DUMMY_RELOC_LITUSE_TLSGD:
|
2002-06-02 10:28:45 +08:00
|
|
|
|
fixP->fx_offset = LITUSE_ALPHA_TLSGD;
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
goto do_lituse;
|
|
|
|
|
case DUMMY_RELOC_LITUSE_TLSLDM:
|
2002-06-02 10:28:45 +08:00
|
|
|
|
fixP->fx_offset = LITUSE_ALPHA_TLSLDM;
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
goto do_lituse;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
do_lituse:
|
|
|
|
|
fixP->fx_addsy = section_symbol (now_seg);
|
|
|
|
|
fixP->fx_r_type = BFD_RELOC_ALPHA_LITUSE;
|
|
|
|
|
|
|
|
|
|
info = get_alpha_reloc_tag (insn->sequence);
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
if (fixup->reloc == DUMMY_RELOC_LITUSE_TLSGD)
|
|
|
|
|
info->saw_lu_tlsgd = 1;
|
|
|
|
|
else if (fixup->reloc == DUMMY_RELOC_LITUSE_TLSLDM)
|
|
|
|
|
info->saw_lu_tlsldm = 1;
|
|
|
|
|
if (++info->n_slaves > 1)
|
|
|
|
|
{
|
|
|
|
|
if (info->saw_lu_tlsgd)
|
|
|
|
|
as_bad (_("too many lituse insns for !lituse_tlsgd!%ld"),
|
|
|
|
|
insn->sequence);
|
|
|
|
|
else if (info->saw_lu_tlsldm)
|
|
|
|
|
as_bad (_("too many lituse insns for !lituse_tlsldm!%ld"),
|
|
|
|
|
insn->sequence);
|
|
|
|
|
}
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
fixP->tc_fix_data.info = info;
|
|
|
|
|
fixP->tc_fix_data.next_reloc = info->slaves;
|
|
|
|
|
info->slaves = fixP;
|
|
|
|
|
if (info->segment != now_seg)
|
|
|
|
|
info->multi_section_p = 1;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
break;
|
|
|
|
|
|
include/elf/
* alpha.h (R_ALPHA_TLSGD, R_ALPHA_TLSLDM, R_ALPHA_DTPMOD64,
R_ALPHA_GOTDTPREL, R_ALPHA_DTPREL64, R_ALPHA_DTPRELHI,
R_ALPHA_DTPRELLO, R_ALPHA_DTPREL16, R_ALPHA_GOTTPREL, R_ALPHA_TPREL64,
R_ALPHA_TPRELHI, R_ALPHA_TPRELLO, R_ALPHA_TPREL16): New.
bfd/
* elf64-alpha.c (ALPHA_ELF_LINK_HASH_LU_TLSGD,
ALPHA_ELF_LINK_HASH_LU_TLSLDM, ALPHA_ELF_LINK_HASH_LU_FUNC): New.
(ALPHA_ELF_GOT_ENTRY_RELOCS_DONE): Remove.
(ALPHA_ELF_GOT_ENTRY_RELOCS_XLATED): Remove.
(struct alpha_elf_got_entry): Add reloc_type, reloc_done, reloc_xlated.
(struct alpha_elf_obj_tdata): Rename total_got_entries and
n_local_got_entries to total_got_size and local_got_size.
(elf64_alpha_howto, elf64_alpha_reloc_map): Update for TLS relocs.
(alpha_got_entry_size): New.
(elf64_alpha_relax_with_lituse): Use it.
(elf64_alpha_relax_without_lituse): Likewise.
(MAX_GOT_SIZE): Rename from MAX_GOT_ENTRIES.
(get_got_entry): New.
(elf64_alpha_check_relocs): Handle TLS relocs. Reorganize.
(elf64_alpha_adjust_dynamic_symbol): Test LU_FUNC as a mask.
(elf64_alpha_merge_ind_symbols): Check gotent->reloc_type.
(elf64_alpha_can_merge_gots, elf64_alpha_merge_gots): Likewise.
(elf64_alpha_calc_got_offsets_for_symbol): Use alpha_got_entry_size.
(elf64_alpha_calc_got_offsets): Likewise.
(alpha_dynamic_entries_for_reloc): New.
(elf64_alpha_calc_dynrel_sizes): Use it.
(elf64_alpha_size_dynamic_sections): Likewise.
(elf64_alpha_relocate_section): Handle TLS relocations.
* reloc.c: Add Alpha TLS relocations.
* bfd-in2.h, libbfd.h: Rebuild.
gas/
* expr.h (operatorT): Add O_md17..O_md32.
* config/tc-alpha.c (O_lituse_tlsgd, O_lituse_tlsldm, O_tlsgd,
O_tlsldm, O_gotdtprel, O_dtprelhi, O_dtprello, O_dtprel, O_gottprel,
O_tprelhi, O_tprello, O_tprel): New.
(USER_RELOC_P, alpha_reloc_op_tag, debug_exp): Include them.
(DUMMY_RELOC_LITUSE_TLSGD, DUMMY_RELOC_LITUSE_TLSLDM): New.
(LITUSE_TLSGD, LITUSE_TLSLDM): New.
(struct alpha_reloc_tag): Add master, saw_tlsgd, saw_tlsld,
saw_lu_tlsgd, saw_lu_tlsldm. Make multi_section_p a bit field.
(md_apply_fix3): Handle TLS relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Sort LITERAL relocs after the
associated TLS reloc. Check lituse_tls relocs match up.
(emit_insn): Handle TLS relocations.
(ldX_op): Remove.
gas/testsuite/
* gas/alpha/elf-tls-1.s, gas/alpha/elf-tls-1.d: New.
* gas/alpha/elf-tls-2.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/elf-tls-3.s, gas/alpha/elf-tls-1.l: New.
* gas/alpha/alpha.exp: Run them.
2002-05-31 06:01:38 +08:00
|
|
|
|
case BFD_RELOC_ALPHA_TLSGD:
|
|
|
|
|
fixP->fx_no_overflow = 1;
|
|
|
|
|
|
|
|
|
|
if (insn->sequence == 0)
|
|
|
|
|
break;
|
|
|
|
|
info = get_alpha_reloc_tag (insn->sequence);
|
|
|
|
|
if (info->saw_tlsgd)
|
|
|
|
|
as_bad (_("duplicate !tlsgd!%ld"), insn->sequence);
|
|
|
|
|
else if (info->saw_tlsldm)
|
|
|
|
|
as_bad (_("sequence number in use for !tlsldm!%ld"),
|
|
|
|
|
insn->sequence);
|
|
|
|
|
else
|
|
|
|
|
info->saw_tlsgd = 1;
|
|
|
|
|
fixP->tc_fix_data.info = info;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case BFD_RELOC_ALPHA_TLSLDM:
|
|
|
|
|
fixP->fx_no_overflow = 1;
|
|
|
|
|
|
|
|
|
|
if (insn->sequence == 0)
|
|
|
|
|
break;
|
|
|
|
|
info = get_alpha_reloc_tag (insn->sequence);
|
|
|
|
|
if (info->saw_tlsldm)
|
|
|
|
|
as_bad (_("duplicate !tlsldm!%ld"), insn->sequence);
|
|
|
|
|
else if (info->saw_tlsgd)
|
|
|
|
|
as_bad (_("sequence number in use for !tlsgd!%ld"),
|
|
|
|
|
insn->sequence);
|
|
|
|
|
else
|
|
|
|
|
info->saw_tlsldm = 1;
|
|
|
|
|
fixP->tc_fix_data.info = info;
|
|
|
|
|
break;
|
2002-08-14 21:27:06 +08:00
|
|
|
|
#endif
|
1999-05-03 15:29:11 +08:00
|
|
|
|
default:
|
2001-01-19 20:03:34 +08:00
|
|
|
|
if ((int) fixup->reloc < 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
if (operand->flags & AXP_OPERAND_NOOVERFLOW)
|
|
|
|
|
fixP->fx_no_overflow = 1;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Given an opcode name and a pre-tokenized set of arguments, assemble
|
|
|
|
|
the insn, but do not emit it.
|
|
|
|
|
|
|
|
|
|
Note that this implies no macros allowed, since we can't store more
|
|
|
|
|
than one insn in an insn structure. */
|
|
|
|
|
|
|
|
|
|
static void
|
2001-01-19 20:03:34 +08:00
|
|
|
|
assemble_tokens_to_insn (opname, tok, ntok, insn)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const char *opname;
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
struct alpha_insn *insn;
|
|
|
|
|
{
|
|
|
|
|
const struct alpha_opcode *opcode;
|
|
|
|
|
|
|
|
|
|
/* search opcodes */
|
|
|
|
|
opcode = (const struct alpha_opcode *) hash_find (alpha_opcode_hash, opname);
|
|
|
|
|
if (opcode)
|
|
|
|
|
{
|
|
|
|
|
int cpumatch;
|
|
|
|
|
opcode = find_opcode_match (opcode, tok, &ntok, &cpumatch);
|
|
|
|
|
if (opcode)
|
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assemble_insn (opcode, tok, ntok, insn, BFD_RELOC_UNUSED);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else if (cpumatch)
|
|
|
|
|
as_bad (_("inappropriate arguments for opcode `%s'"), opname);
|
|
|
|
|
else
|
|
|
|
|
as_bad (_("opcode `%s' not supported for target %s"), opname,
|
2001-01-20 12:23:33 +08:00
|
|
|
|
alpha_target_name);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
as_bad (_("unknown opcode `%s'"), opname);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Given an opcode name and a pre-tokenized set of arguments, take the
|
|
|
|
|
opcode all the way through emission. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
assemble_tokens (opname, tok, ntok, local_macros_on)
|
|
|
|
|
const char *opname;
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
int local_macros_on;
|
|
|
|
|
{
|
|
|
|
|
int found_something = 0;
|
|
|
|
|
const struct alpha_opcode *opcode;
|
|
|
|
|
const struct alpha_macro *macro;
|
|
|
|
|
int cpumatch = 1;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
bfd_reloc_code_real_type reloc = BFD_RELOC_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2002-05-23 18:12:04 +08:00
|
|
|
|
#ifdef RELOC_OP_P
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
/* If a user-specified relocation is present, this is not a macro. */
|
|
|
|
|
if (ntok && USER_RELOC_P (tok[ntok - 1].X_op))
|
|
|
|
|
{
|
|
|
|
|
reloc = ALPHA_RELOC_TABLE (tok[ntok - 1].X_op)->reloc;
|
|
|
|
|
ntok--;
|
|
|
|
|
}
|
2002-05-23 18:12:04 +08:00
|
|
|
|
else
|
|
|
|
|
#endif
|
|
|
|
|
if (local_macros_on)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
macro = ((const struct alpha_macro *)
|
|
|
|
|
hash_find (alpha_macro_hash, opname));
|
|
|
|
|
if (macro)
|
|
|
|
|
{
|
|
|
|
|
found_something = 1;
|
|
|
|
|
macro = find_macro_match (macro, tok, &ntok);
|
|
|
|
|
if (macro)
|
|
|
|
|
{
|
|
|
|
|
(*macro->emit) (tok, ntok, macro->arg);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Search opcodes. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
opcode = (const struct alpha_opcode *) hash_find (alpha_opcode_hash, opname);
|
|
|
|
|
if (opcode)
|
|
|
|
|
{
|
|
|
|
|
found_something = 1;
|
|
|
|
|
opcode = find_opcode_match (opcode, tok, &ntok, &cpumatch);
|
|
|
|
|
if (opcode)
|
|
|
|
|
{
|
|
|
|
|
struct alpha_insn insn;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assemble_insn (opcode, tok, ntok, &insn, reloc);
|
|
|
|
|
|
|
|
|
|
/* Copy the sequence number for the reloc from the reloc token. */
|
|
|
|
|
if (reloc != BFD_RELOC_UNUSED)
|
|
|
|
|
insn.sequence = tok[ntok].X_add_number;
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (found_something)
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
{
|
|
|
|
|
if (cpumatch)
|
|
|
|
|
as_bad (_("inappropriate arguments for opcode `%s'"), opname);
|
|
|
|
|
else
|
|
|
|
|
as_bad (_("opcode `%s' not supported for target %s"), opname,
|
|
|
|
|
alpha_target_name);
|
|
|
|
|
}
|
1999-05-03 15:29:11 +08:00
|
|
|
|
else
|
|
|
|
|
as_bad (_("unknown opcode `%s'"), opname);
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Some instruction sets indexed by lg(size). */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static const char * const sextX_op[] = { "sextb", "sextw", "sextl", NULL };
|
|
|
|
|
static const char * const insXl_op[] = { "insbl", "inswl", "insll", "insql" };
|
|
|
|
|
static const char * const insXh_op[] = { NULL, "inswh", "inslh", "insqh" };
|
|
|
|
|
static const char * const extXl_op[] = { "extbl", "extwl", "extll", "extql" };
|
|
|
|
|
static const char * const extXh_op[] = { NULL, "extwh", "extlh", "extqh" };
|
|
|
|
|
static const char * const mskXl_op[] = { "mskbl", "mskwl", "mskll", "mskql" };
|
|
|
|
|
static const char * const mskXh_op[] = { NULL, "mskwh", "msklh", "mskqh" };
|
|
|
|
|
static const char * const stX_op[] = { "stb", "stw", "stl", "stq" };
|
|
|
|
|
static const char * const ldXu_op[] = { "ldbu", "ldwu", NULL, NULL };
|
|
|
|
|
|
|
|
|
|
/* Implement the ldgp macro. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_ldgp (tok, ntok, unused)
|
|
|
|
|
const expressionS *tok;
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ntok ATTRIBUTE_UNUSED;
|
|
|
|
|
const PTR unused ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
#ifdef OBJ_AOUT
|
|
|
|
|
FIXME
|
|
|
|
|
#endif
|
|
|
|
|
#if defined(OBJ_ECOFF) || defined(OBJ_ELF)
|
|
|
|
|
/* from "ldgp r1,n(r2)", generate "ldah r1,X(R2); lda r1,Y(r1)"
|
|
|
|
|
with appropriate constants and relocations. */
|
|
|
|
|
struct alpha_insn insn;
|
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
expressionS addend;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
if (regno (tok[2].X_add_number) == AXP_REG_PV)
|
|
|
|
|
ecoff_set_gp_prolog_size (0);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
|
|
|
|
newtok[2] = tok[2];
|
|
|
|
|
|
|
|
|
|
assemble_tokens_to_insn ("ldah", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
addend = tok[1];
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
if (addend.X_op != O_constant)
|
|
|
|
|
as_bad (_("can not resolve expression"));
|
|
|
|
|
addend.X_op = O_symbol;
|
|
|
|
|
addend.X_add_symbol = alpha_gp_symbol;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
insn.nfixups = 1;
|
|
|
|
|
insn.fixups[0].exp = addend;
|
|
|
|
|
insn.fixups[0].reloc = BFD_RELOC_ALPHA_GPDISP_HI16;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = next_sequence_num;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
|
|
|
|
|
set_tok_preg (newtok[2], tok[0].X_add_number);
|
|
|
|
|
|
|
|
|
|
assemble_tokens_to_insn ("lda", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
addend.X_add_number += 4;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
insn.nfixups = 1;
|
|
|
|
|
insn.fixups[0].exp = addend;
|
|
|
|
|
insn.fixups[0].reloc = BFD_RELOC_ALPHA_GPDISP_LO16;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = next_sequence_num--;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
#endif /* OBJ_ECOFF || OBJ_ELF */
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
|
|
|
|
|
/* Add symbol+addend to link pool.
|
|
|
|
|
Return offset from basesym to entry in link pool.
|
|
|
|
|
|
|
|
|
|
Add new fixup only if offset isn't 16bit. */
|
|
|
|
|
|
|
|
|
|
valueT
|
|
|
|
|
add_to_link_pool (basesym, sym, addend)
|
|
|
|
|
symbolS *basesym;
|
|
|
|
|
symbolS *sym;
|
|
|
|
|
offsetT addend;
|
|
|
|
|
{
|
|
|
|
|
segT current_section = now_seg;
|
|
|
|
|
int current_subsec = now_subseg;
|
|
|
|
|
valueT offset;
|
|
|
|
|
bfd_reloc_code_real_type reloc_type;
|
|
|
|
|
char *p;
|
|
|
|
|
segment_info_type *seginfo = seg_info (alpha_link_section);
|
|
|
|
|
fixS *fixp;
|
|
|
|
|
|
1999-06-22 22:53:01 +08:00
|
|
|
|
offset = - *symbol_get_obj (basesym);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* @@ This assumes all entries in a given section will be of the same
|
|
|
|
|
size... Probably correct, but unwise to rely on. */
|
|
|
|
|
/* This must always be called with the same subsegment. */
|
|
|
|
|
|
|
|
|
|
if (seginfo->frchainP)
|
|
|
|
|
for (fixp = seginfo->frchainP->fix_root;
|
|
|
|
|
fixp != (fixS *) NULL;
|
|
|
|
|
fixp = fixp->fx_next, offset += 8)
|
|
|
|
|
{
|
|
|
|
|
if (fixp->fx_addsy == sym && fixp->fx_offset == addend)
|
|
|
|
|
{
|
|
|
|
|
if (range_signed_16 (offset))
|
|
|
|
|
{
|
2001-01-20 12:23:33 +08:00
|
|
|
|
return offset;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Not found in 16bit signed range. */
|
|
|
|
|
|
|
|
|
|
subseg_set (alpha_link_section, 0);
|
|
|
|
|
p = frag_more (8);
|
|
|
|
|
memset (p, 0, 8);
|
|
|
|
|
|
|
|
|
|
fix_new (frag_now, p - frag_now->fr_literal, 8, sym, addend, 0,
|
|
|
|
|
BFD_RELOC_64);
|
|
|
|
|
|
|
|
|
|
subseg_set (current_section, current_subsec);
|
|
|
|
|
seginfo->literal_pool_size += 8;
|
|
|
|
|
return offset;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif /* OBJ_EVAX */
|
|
|
|
|
|
|
|
|
|
/* Load a (partial) expression into a target register.
|
|
|
|
|
|
|
|
|
|
If poffset is not null, after the call it will either contain
|
|
|
|
|
O_constant 0, or a 16-bit offset appropriate for any MEM format
|
|
|
|
|
instruction. In addition, pbasereg will be modified to point to
|
|
|
|
|
the base register to use in that MEM format instruction.
|
|
|
|
|
|
|
|
|
|
In any case, *pbasereg should contain a base register to add to the
|
|
|
|
|
expression. This will normally be either AXP_REG_ZERO or
|
|
|
|
|
alpha_gp_register. Symbol addresses will always be loaded via $gp,
|
|
|
|
|
so "foo($0)" is interpreted as adding the address of foo to $0;
|
|
|
|
|
i.e. "ldq $targ, LIT($gp); addq $targ, $0, $targ". Odd, perhaps,
|
|
|
|
|
but this is what OSF/1 does.
|
|
|
|
|
|
1999-11-29 08:46:16 +08:00
|
|
|
|
If explicit relocations of the form !literal!<number> are allowed,
|
|
|
|
|
and used, then explict_reloc with be an expression pointer.
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
Finally, the return value is nonzero if the calling macro may emit
|
|
|
|
|
a LITUSE reloc if otherwise appropriate; the return value is the
|
|
|
|
|
sequence number to use. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
static long
|
|
|
|
|
load_expression (targreg, exp, pbasereg, poffset)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
int targreg;
|
|
|
|
|
const expressionS *exp;
|
|
|
|
|
int *pbasereg;
|
|
|
|
|
expressionS *poffset;
|
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
long emit_lituse = 0;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
offsetT addend = exp->X_add_number;
|
|
|
|
|
int basereg = *pbasereg;
|
|
|
|
|
struct alpha_insn insn;
|
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
|
|
|
|
|
switch (exp->X_op)
|
|
|
|
|
{
|
|
|
|
|
case O_symbol:
|
|
|
|
|
{
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
offsetT lit;
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Attempt to reduce .lit load by splitting the offset from
|
1999-05-03 15:29:11 +08:00
|
|
|
|
its symbol when possible, but don't create a situation in
|
|
|
|
|
which we'd fail. */
|
|
|
|
|
if (!range_signed_32 (addend) &&
|
|
|
|
|
(alpha_noat_on || targreg == AXP_REG_AT))
|
|
|
|
|
{
|
|
|
|
|
lit = add_to_literal_pool (exp->X_add_symbol, addend,
|
|
|
|
|
alpha_lita_section, 8);
|
|
|
|
|
addend = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
lit = add_to_literal_pool (exp->X_add_symbol, 0,
|
|
|
|
|
alpha_lita_section, 8);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (lit >= 0x8000)
|
|
|
|
|
as_fatal (_("overflow in literal (.lita) table"));
|
|
|
|
|
|
|
|
|
|
/* emit "ldq r, lit(gp)" */
|
|
|
|
|
|
|
|
|
|
if (basereg != alpha_gp_register && targreg == basereg)
|
|
|
|
|
{
|
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
if (targreg == AXP_REG_AT)
|
|
|
|
|
as_bad (_("macro requires $at while $at in use"));
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_AT);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
set_tok_sym (newtok[1], alpha_lita_symbol, lit);
|
|
|
|
|
set_tok_preg (newtok[2], alpha_gp_register);
|
|
|
|
|
|
|
|
|
|
assemble_tokens_to_insn ("ldq", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
assert (insn.nfixups == 1);
|
|
|
|
|
insn.fixups[0].reloc = BFD_RELOC_ALPHA_LITERAL;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = emit_lituse = next_sequence_num--;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif /* OBJ_ECOFF */
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
/* emit "ldq r, gotoff(gp)" */
|
|
|
|
|
|
|
|
|
|
if (basereg != alpha_gp_register && targreg == basereg)
|
|
|
|
|
{
|
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
if (targreg == AXP_REG_AT)
|
|
|
|
|
as_bad (_("macro requires $at while $at in use"));
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_AT);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
|
|
|
|
|
/* XXX: Disable this .got minimizing optimization so that we can get
|
|
|
|
|
better instruction offset knowledge in the compiler. This happens
|
|
|
|
|
very infrequently anyway. */
|
2001-01-23 04:24:11 +08:00
|
|
|
|
if (1
|
|
|
|
|
|| (!range_signed_32 (addend)
|
|
|
|
|
&& (alpha_noat_on || targreg == AXP_REG_AT)))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
newtok[1] = *exp;
|
|
|
|
|
addend = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
set_tok_sym (newtok[1], exp->X_add_symbol, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
set_tok_preg (newtok[2], alpha_gp_register);
|
|
|
|
|
|
|
|
|
|
assemble_tokens_to_insn ("ldq", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
assert (insn.nfixups == 1);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.fixups[0].reloc = BFD_RELOC_ALPHA_ELF_LITERAL;
|
|
|
|
|
insn.sequence = emit_lituse = next_sequence_num--;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#endif /* OBJ_ELF */
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
offsetT link;
|
|
|
|
|
|
|
|
|
|
/* Find symbol or symbol pointer in link section. */
|
|
|
|
|
|
|
|
|
|
if (exp->X_add_symbol == alpha_evax_proc.symbol)
|
|
|
|
|
{
|
|
|
|
|
if (range_signed_16 (addend))
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
set_tok_const (newtok[1], addend);
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
assemble_tokens_to_insn ("lda", newtok, 3, &insn);
|
|
|
|
|
addend = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
assemble_tokens_to_insn ("lda", newtok, 3, &insn);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (!range_signed_32 (addend))
|
|
|
|
|
{
|
|
|
|
|
link = add_to_link_pool (alpha_evax_proc.symbol,
|
|
|
|
|
exp->X_add_symbol, addend);
|
|
|
|
|
addend = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
link = add_to_link_pool (alpha_evax_proc.symbol,
|
|
|
|
|
exp->X_add_symbol, 0);
|
|
|
|
|
}
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
set_tok_const (newtok[1], link);
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
assemble_tokens_to_insn ("ldq", newtok, 3, &insn);
|
|
|
|
|
}
|
|
|
|
|
#endif /* OBJ_EVAX */
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
emit_insn (&insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
#ifndef OBJ_EVAX
|
|
|
|
|
if (basereg != alpha_gp_register && basereg != AXP_REG_ZERO)
|
|
|
|
|
{
|
|
|
|
|
/* emit "addq r, base, r" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[1], basereg);
|
|
|
|
|
set_tok_reg (newtok[2], targreg);
|
|
|
|
|
assemble_tokens ("addq", newtok, 3, 0);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
basereg = targreg;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case O_constant:
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case O_subtract:
|
|
|
|
|
/* Assume that this difference expression will be resolved to an
|
2000-09-15 09:06:52 +08:00
|
|
|
|
absolute value and that that value will fit in 16 bits. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
newtok[1] = *exp;
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
assemble_tokens ("lda", newtok, 3, 0);
|
|
|
|
|
|
|
|
|
|
if (poffset)
|
|
|
|
|
set_tok_const (*poffset, 0);
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
case O_big:
|
|
|
|
|
if (exp->X_add_number > 0)
|
|
|
|
|
as_bad (_("bignum invalid; zero assumed"));
|
|
|
|
|
else
|
|
|
|
|
as_bad (_("floating point number invalid; zero assumed"));
|
|
|
|
|
addend = 0;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
as_bad (_("can't handle expression"));
|
|
|
|
|
addend = 0;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!range_signed_32 (addend))
|
|
|
|
|
{
|
|
|
|
|
offsetT lit;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
long seq_num = next_sequence_num--;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
/* For 64-bit addends, just put it in the literal pool. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
/* emit "ldq targreg, lit(basereg)" */
|
|
|
|
|
lit = add_to_link_pool (alpha_evax_proc.symbol,
|
|
|
|
|
section_symbol (absolute_section), addend);
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
set_tok_const (newtok[1], lit);
|
|
|
|
|
set_tok_preg (newtok[2], alpha_gp_register);
|
|
|
|
|
assemble_tokens ("ldq", newtok, 3, 0);
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
|
|
if (alpha_lit8_section == NULL)
|
|
|
|
|
{
|
|
|
|
|
create_literal_section (".lit8",
|
|
|
|
|
&alpha_lit8_section,
|
|
|
|
|
&alpha_lit8_symbol);
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
alpha_lit8_literal = add_to_literal_pool (alpha_lit8_symbol, 0x8000,
|
|
|
|
|
alpha_lita_section, 8);
|
|
|
|
|
if (alpha_lit8_literal >= 0x8000)
|
|
|
|
|
as_fatal (_("overflow in literal (.lita) table"));
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
lit = add_to_literal_pool (NULL, addend, alpha_lit8_section, 8) - 0x8000;
|
|
|
|
|
if (lit >= 0x8000)
|
|
|
|
|
as_fatal (_("overflow in literal (.lit8) table"));
|
|
|
|
|
|
|
|
|
|
/* emit "lda litreg, .lit8+0x8000" */
|
|
|
|
|
|
|
|
|
|
if (targreg == basereg)
|
|
|
|
|
{
|
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
if (targreg == AXP_REG_AT)
|
|
|
|
|
as_bad (_("macro requires $at while $at in use"));
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_AT);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
set_tok_sym (newtok[1], alpha_lita_symbol, alpha_lit8_literal);
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
set_tok_sym (newtok[1], alpha_lit8_symbol, 0x8000);
|
|
|
|
|
#endif
|
|
|
|
|
set_tok_preg (newtok[2], alpha_gp_register);
|
|
|
|
|
|
|
|
|
|
assemble_tokens_to_insn ("ldq", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
assert (insn.nfixups == 1);
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
insn.fixups[0].reloc = BFD_RELOC_ALPHA_LITERAL;
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
insn.fixups[0].reloc = BFD_RELOC_ALPHA_ELF_LITERAL;
|
|
|
|
|
#endif
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = seq_num;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
|
|
|
|
|
/* emit "ldq litreg, lit(litreg)" */
|
|
|
|
|
|
|
|
|
|
set_tok_const (newtok[1], lit);
|
|
|
|
|
set_tok_preg (newtok[2], newtok[0].X_add_number);
|
|
|
|
|
|
|
|
|
|
assemble_tokens_to_insn ("ldq", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BASE;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
insn.nfixups++;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = seq_num;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
emit_lituse = 0;
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
|
|
|
|
|
/* emit "addq litreg, base, target" */
|
|
|
|
|
|
|
|
|
|
if (basereg != AXP_REG_ZERO)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[1], basereg);
|
|
|
|
|
set_tok_reg (newtok[2], targreg);
|
|
|
|
|
assemble_tokens ("addq", newtok, 3, 0);
|
|
|
|
|
}
|
|
|
|
|
#endif /* !OBJ_EVAX */
|
|
|
|
|
|
|
|
|
|
if (poffset)
|
|
|
|
|
set_tok_const (*poffset, 0);
|
|
|
|
|
*pbasereg = targreg;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
offsetT low, high, extra, tmp;
|
|
|
|
|
|
|
|
|
|
/* for 32-bit operands, break up the addend */
|
|
|
|
|
|
|
|
|
|
low = sign_extend_16 (addend);
|
|
|
|
|
tmp = addend - low;
|
|
|
|
|
high = sign_extend_16 (tmp >> 16);
|
|
|
|
|
|
|
|
|
|
if (tmp - (high << 16))
|
|
|
|
|
{
|
|
|
|
|
extra = 0x4000;
|
|
|
|
|
tmp -= 0x40000000;
|
|
|
|
|
high = sign_extend_16 (tmp >> 16);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
extra = 0;
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], targreg);
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
|
|
|
|
|
if (extra)
|
|
|
|
|
{
|
|
|
|
|
/* emit "ldah r, extra(r) */
|
|
|
|
|
set_tok_const (newtok[1], extra);
|
|
|
|
|
assemble_tokens ("ldah", newtok, 3, 0);
|
|
|
|
|
set_tok_preg (newtok[2], basereg = targreg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (high)
|
|
|
|
|
{
|
|
|
|
|
/* emit "ldah r, high(r) */
|
|
|
|
|
set_tok_const (newtok[1], high);
|
|
|
|
|
assemble_tokens ("ldah", newtok, 3, 0);
|
|
|
|
|
basereg = targreg;
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ((low && !poffset) || (!poffset && basereg != targreg))
|
|
|
|
|
{
|
|
|
|
|
/* emit "lda r, low(base)" */
|
|
|
|
|
set_tok_const (newtok[1], low);
|
|
|
|
|
assemble_tokens ("lda", newtok, 3, 0);
|
|
|
|
|
basereg = targreg;
|
|
|
|
|
low = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (poffset)
|
|
|
|
|
set_tok_const (*poffset, low);
|
|
|
|
|
*pbasereg = basereg;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return emit_lituse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The lda macro differs from the lda instruction in that it handles
|
|
|
|
|
most simple expressions, particualrly symbol address loads and
|
|
|
|
|
large constants. */
|
|
|
|
|
|
|
|
|
|
static void
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
emit_lda (tok, ntok, unused)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
const PTR unused ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
int basereg;
|
|
|
|
|
|
|
|
|
|
if (ntok == 2)
|
|
|
|
|
basereg = (tok[1].X_op == O_constant ? AXP_REG_ZERO : alpha_gp_register);
|
|
|
|
|
else
|
|
|
|
|
basereg = tok[2].X_add_number;
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
(void) load_expression (tok[0].X_add_number, &tok[1], &basereg, NULL);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The ldah macro differs from the ldah instruction in that it has $31
|
|
|
|
|
as an implied base register. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_ldah (tok, ntok, unused)
|
|
|
|
|
const expressionS *tok;
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ntok ATTRIBUTE_UNUSED;
|
|
|
|
|
const PTR unused ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
|
|
|
|
newtok[1] = tok[1];
|
|
|
|
|
set_tok_preg (newtok[2], AXP_REG_ZERO);
|
|
|
|
|
|
|
|
|
|
assemble_tokens ("ldah", newtok, 3, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle all "simple" integer register loads -- ldq, ldq_l, ldq_u,
|
|
|
|
|
etc. They differ from the real instructions in that they do simple
|
|
|
|
|
expressions like the lda macro. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_ir_load (tok, ntok, opname)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR opname;
|
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
int basereg;
|
|
|
|
|
long lituse;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
struct alpha_insn insn;
|
|
|
|
|
|
|
|
|
|
if (ntok == 2)
|
|
|
|
|
basereg = (tok[1].X_op == O_constant ? AXP_REG_ZERO : alpha_gp_register);
|
|
|
|
|
else
|
|
|
|
|
basereg = tok[2].X_add_number;
|
|
|
|
|
|
|
|
|
|
lituse = load_expression (tok[0].X_add_number, &tok[1], &basereg,
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
&newtok[1]);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
assemble_tokens_to_insn ((const char *) opname, newtok, 3, &insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BASE;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
insn.nfixups++;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = lituse;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle fp register loads, and both integer and fp register stores.
|
|
|
|
|
Again, we handle simple expressions. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_loadstore (tok, ntok, opname)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR opname;
|
|
|
|
|
{
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
int basereg;
|
|
|
|
|
long lituse;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
struct alpha_insn insn;
|
|
|
|
|
|
|
|
|
|
if (ntok == 2)
|
|
|
|
|
basereg = (tok[1].X_op == O_constant ? AXP_REG_ZERO : alpha_gp_register);
|
|
|
|
|
else
|
|
|
|
|
basereg = tok[2].X_add_number;
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
if (tok[1].X_op != O_constant || !range_signed_16 (tok[1].X_add_number))
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
lituse = load_expression (AXP_REG_AT, &tok[1], &basereg, &newtok[1]);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
newtok[1] = tok[1];
|
|
|
|
|
lituse = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
assemble_tokens_to_insn ((const char *) opname, newtok, 3, &insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BASE;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
insn.nfixups++;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = lituse;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Load a half-word or byte as an unsigned value. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_ldXu (tok, ntok, vlgsize)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vlgsize;
|
|
|
|
|
{
|
|
|
|
|
if (alpha_target & AXP_OPCODE_BWX)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
emit_ir_load (tok, ntok, ldXu_op[(long) vlgsize]);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
expressionS newtok[3];
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
struct alpha_insn insn;
|
|
|
|
|
int basereg;
|
|
|
|
|
long lituse;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
if (ntok == 2)
|
|
|
|
|
basereg = (tok[1].X_op == O_constant
|
|
|
|
|
? AXP_REG_ZERO : alpha_gp_register);
|
|
|
|
|
else
|
|
|
|
|
basereg = tok[2].X_add_number;
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* emit "lda $at, exp" */
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
lituse = load_expression (AXP_REG_AT, &tok[1], &basereg, NULL);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* emit "ldq_u targ, 0($at)" */
|
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
assemble_tokens_to_insn ("ldq_u", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BASE;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
|
|
|
|
insn.nfixups++;
|
|
|
|
|
insn.sequence = lituse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* emit "extXl targ, $at, targ" */
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
set_tok_reg (newtok[1], basereg);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
newtok[2] = newtok[0];
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assemble_tokens_to_insn (extXl_op[(long) vlgsize], newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BYTOFF;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
|
|
|
|
insn.nfixups++;
|
|
|
|
|
insn.sequence = lituse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Load a half-word or byte as a signed value. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_ldX (tok, ntok, vlgsize)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vlgsize;
|
|
|
|
|
{
|
|
|
|
|
emit_ldXu (tok, ntok, vlgsize);
|
2001-01-19 20:03:34 +08:00
|
|
|
|
assemble_tokens (sextX_op[(long) vlgsize], tok, 1, 1);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Load an integral value from an unaligned address as an unsigned
|
|
|
|
|
value. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_uldXu (tok, ntok, vlgsize)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vlgsize;
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
long lgsize = (long) vlgsize;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
|
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
|
|
|
|
|
/* emit "lda $at, exp" */
|
|
|
|
|
|
|
|
|
|
memcpy (newtok, tok, sizeof (expressionS) * ntok);
|
|
|
|
|
newtok[0].X_add_number = AXP_REG_AT;
|
|
|
|
|
assemble_tokens ("lda", newtok, ntok, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "ldq_u $t9, 0($at)" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
|
|
|
|
set_tok_preg (newtok[2], AXP_REG_AT);
|
|
|
|
|
assemble_tokens ("ldq_u", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "ldq_u $t10, size-1($at)" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
set_tok_const (newtok[1], (1 << lgsize) - 1);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
assemble_tokens ("ldq_u", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "extXl $t9, $at, $t9" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_AT);
|
|
|
|
|
set_tok_reg (newtok[2], AXP_REG_T9);
|
|
|
|
|
assemble_tokens (extXl_op[lgsize], newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "extXh $t10, $at, $t10" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
|
|
|
|
set_tok_reg (newtok[2], AXP_REG_T10);
|
|
|
|
|
assemble_tokens (extXh_op[lgsize], newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "or $t9, $t10, targ" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T10);
|
|
|
|
|
newtok[2] = tok[0];
|
|
|
|
|
assemble_tokens ("or", newtok, 3, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Load an integral value from an unaligned address as a signed value.
|
|
|
|
|
Note that quads should get funneled to the unsigned load since we
|
|
|
|
|
don't have to do the sign extension. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_uldX (tok, ntok, vlgsize)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vlgsize;
|
|
|
|
|
{
|
|
|
|
|
emit_uldXu (tok, ntok, vlgsize);
|
2001-01-19 20:03:34 +08:00
|
|
|
|
assemble_tokens (sextX_op[(long) vlgsize], tok, 1, 1);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Implement the ldil macro. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_ldil (tok, ntok, unused)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
1999-10-19 06:29:15 +08:00
|
|
|
|
const PTR unused ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
expressionS newtok[2];
|
|
|
|
|
|
2000-12-03 14:49:23 +08:00
|
|
|
|
memcpy (newtok, tok, sizeof (newtok));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
newtok[1].X_add_number = sign_extend_32 (tok[1].X_add_number);
|
|
|
|
|
|
|
|
|
|
assemble_tokens ("lda", newtok, ntok, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Store a half-word or byte. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_stX (tok, ntok, vlgsize)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vlgsize;
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
int lgsize = (int) (long) vlgsize;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (alpha_target & AXP_OPCODE_BWX)
|
|
|
|
|
emit_loadstore (tok, ntok, stX_op[lgsize]);
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
expressionS newtok[3];
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
struct alpha_insn insn;
|
|
|
|
|
int basereg;
|
|
|
|
|
long lituse;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (alpha_noat_on)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
if (ntok == 2)
|
|
|
|
|
basereg = (tok[1].X_op == O_constant
|
|
|
|
|
? AXP_REG_ZERO : alpha_gp_register);
|
|
|
|
|
else
|
|
|
|
|
basereg = tok[2].X_add_number;
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* emit "lda $at, exp" */
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
lituse = load_expression (AXP_REG_AT, &tok[1], &basereg, NULL);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* emit "ldq_u $t9, 0($at)" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
set_tok_preg (newtok[2], basereg);
|
|
|
|
|
assemble_tokens_to_insn ("ldq_u", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BASE;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
|
|
|
|
insn.nfixups++;
|
|
|
|
|
insn.sequence = lituse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* emit "insXl src, $at, $t10" */
|
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
set_tok_reg (newtok[1], basereg);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
set_tok_reg (newtok[2], AXP_REG_T10);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assemble_tokens_to_insn (insXl_op[lgsize], newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BYTOFF;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
|
|
|
|
insn.nfixups++;
|
|
|
|
|
insn.sequence = lituse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* emit "mskXl $t9, $at, $t9" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
newtok[2] = newtok[0];
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assemble_tokens_to_insn (mskXl_op[lgsize], newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BYTOFF;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
|
|
|
|
insn.nfixups++;
|
|
|
|
|
insn.sequence = lituse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* emit "or $t9, $t10, $t9" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T10);
|
|
|
|
|
assemble_tokens ("or", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "stq_u $t9, 0($at) */
|
|
|
|
|
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
set_tok_const(newtok[1], 0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
set_tok_preg (newtok[2], AXP_REG_AT);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
assemble_tokens_to_insn ("stq_u", newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_BASE;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
|
|
|
|
insn.nfixups++;
|
|
|
|
|
insn.sequence = lituse;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Store an integer to an unaligned address. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_ustX (tok, ntok, vlgsize)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vlgsize;
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
int lgsize = (int) (long) vlgsize;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
|
|
|
|
|
/* emit "lda $at, exp" */
|
|
|
|
|
|
|
|
|
|
memcpy (newtok, tok, sizeof (expressionS) * ntok);
|
|
|
|
|
newtok[0].X_add_number = AXP_REG_AT;
|
|
|
|
|
assemble_tokens ("lda", newtok, ntok, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "ldq_u $9, 0($at)" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
|
|
|
|
set_tok_preg (newtok[2], AXP_REG_AT);
|
|
|
|
|
assemble_tokens ("ldq_u", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "ldq_u $10, size-1($at)" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
set_tok_const (newtok[1], (1 << lgsize) - 1);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
assemble_tokens ("ldq_u", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "insXl src, $at, $t11" */
|
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_AT);
|
|
|
|
|
set_tok_reg (newtok[2], AXP_REG_T11);
|
|
|
|
|
assemble_tokens (insXl_op[lgsize], newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "insXh src, $at, $t12" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[2], AXP_REG_T12);
|
|
|
|
|
assemble_tokens (insXh_op[lgsize], newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "mskXl $t9, $at, $t9" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
newtok[2] = newtok[0];
|
|
|
|
|
assemble_tokens (mskXl_op[lgsize], newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "mskXh $t10, $at, $t10" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
|
|
|
|
newtok[2] = newtok[0];
|
|
|
|
|
assemble_tokens (mskXh_op[lgsize], newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "or $t9, $t11, $t9" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T11);
|
|
|
|
|
newtok[2] = newtok[0];
|
|
|
|
|
assemble_tokens ("or", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "or $t10, $t12, $t10" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T12);
|
|
|
|
|
newtok[2] = newtok[0];
|
|
|
|
|
assemble_tokens ("or", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "stq_u $t9, 0($at)" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
|
|
|
|
set_tok_preg (newtok[2], AXP_REG_AT);
|
|
|
|
|
assemble_tokens ("stq_u", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "stq_u $t10, size-1($at)" */
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
set_tok_const (newtok[1], (1 << lgsize) - 1);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
assemble_tokens ("stq_u", newtok, 3, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Sign extend a half-word or byte. The 32-bit sign extend is
|
|
|
|
|
implemented as "addl $31, $r, $t" in the opcode table. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_sextX (tok, ntok, vlgsize)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vlgsize;
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
long lgsize = (long) vlgsize;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (alpha_target & AXP_OPCODE_BWX)
|
|
|
|
|
assemble_tokens (sextX_op[lgsize], tok, ntok, 0);
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
int bitshift = 64 - 8 * (1 << lgsize);
|
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
|
|
|
|
|
/* emit "sll src,bits,dst" */
|
|
|
|
|
|
|
|
|
|
newtok[0] = tok[0];
|
|
|
|
|
set_tok_const (newtok[1], bitshift);
|
|
|
|
|
newtok[2] = tok[ntok - 1];
|
|
|
|
|
assemble_tokens ("sll", newtok, 3, 1);
|
|
|
|
|
|
|
|
|
|
/* emit "sra dst,bits,dst" */
|
|
|
|
|
|
|
|
|
|
newtok[0] = newtok[2];
|
|
|
|
|
assemble_tokens ("sra", newtok, 3, 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Implement the division and modulus macros. */
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
|
|
|
|
|
/* Make register usage like in normal procedure call.
|
|
|
|
|
Don't clobber PV and RA. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_division (tok, ntok, symname)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR symname;
|
|
|
|
|
{
|
|
|
|
|
/* DIVISION and MODULUS. Yech.
|
2002-08-14 21:27:06 +08:00
|
|
|
|
|
|
|
|
|
Convert
|
|
|
|
|
OP x,y,result
|
|
|
|
|
to
|
|
|
|
|
mov x,R16 # if x != R16
|
|
|
|
|
mov y,R17 # if y != R17
|
|
|
|
|
lda AT,__OP
|
|
|
|
|
jsr AT,(AT),0
|
|
|
|
|
mov R0,result
|
|
|
|
|
|
|
|
|
|
with appropriate optimizations if R0,R16,R17 are the registers
|
|
|
|
|
specified by the compiler. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
int xr, yr, rr;
|
|
|
|
|
symbolS *sym;
|
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
|
|
|
|
|
xr = regno (tok[0].X_add_number);
|
|
|
|
|
yr = regno (tok[1].X_add_number);
|
|
|
|
|
|
|
|
|
|
if (ntok < 3)
|
|
|
|
|
rr = xr;
|
|
|
|
|
else
|
|
|
|
|
rr = regno (tok[2].X_add_number);
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Move the operands into the right place. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (yr == AXP_REG_R16 && xr == AXP_REG_R17)
|
|
|
|
|
{
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* They are in exactly the wrong order -- swap through AT. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_R16);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_AT);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_R17);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_R16);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_AT);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_R17);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (yr == AXP_REG_R16)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_R16);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_R17);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (xr != AXP_REG_R16)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], xr);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_R16);
|
2001-01-20 12:23:33 +08:00
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (yr != AXP_REG_R16 && yr != AXP_REG_R17)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], yr);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_R17);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
sym = symbol_find_or_make ((const char *) symname);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_AT);
|
|
|
|
|
set_tok_sym (newtok[1], sym, 0);
|
|
|
|
|
assemble_tokens ("lda", newtok, 2, 1);
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Call the division routine. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_AT);
|
|
|
|
|
set_tok_cpreg (newtok[1], AXP_REG_AT);
|
|
|
|
|
set_tok_const (newtok[2], 0);
|
|
|
|
|
assemble_tokens ("jsr", newtok, 3, 1);
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Move the result to the right place. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (rr != AXP_REG_R0)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_R0);
|
|
|
|
|
set_tok_reg (newtok[1], rr);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#else /* !OBJ_EVAX */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_division (tok, ntok, symname)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR symname;
|
|
|
|
|
{
|
|
|
|
|
/* DIVISION and MODULUS. Yech.
|
2002-08-14 21:27:06 +08:00
|
|
|
|
Convert
|
|
|
|
|
OP x,y,result
|
|
|
|
|
to
|
|
|
|
|
lda pv,__OP
|
|
|
|
|
mov x,t10
|
|
|
|
|
mov y,t11
|
|
|
|
|
jsr t9,(pv),__OP
|
|
|
|
|
mov t12,result
|
|
|
|
|
|
|
|
|
|
with appropriate optimizations if t10,t11,t12 are the registers
|
|
|
|
|
specified by the compiler. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
int xr, yr, rr;
|
|
|
|
|
symbolS *sym;
|
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
|
|
|
|
|
xr = regno (tok[0].X_add_number);
|
|
|
|
|
yr = regno (tok[1].X_add_number);
|
|
|
|
|
|
|
|
|
|
if (ntok < 3)
|
|
|
|
|
rr = xr;
|
|
|
|
|
else
|
|
|
|
|
rr = regno (tok[2].X_add_number);
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
sym = symbol_find_or_make ((const char *) symname);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Move the operands into the right place. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (yr == AXP_REG_T10 && xr == AXP_REG_T11)
|
|
|
|
|
{
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* They are in exactly the wrong order -- swap through AT. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (alpha_noat_on)
|
|
|
|
|
as_bad (_("macro requires $at register while noat in effect"));
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_AT);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T11);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T10);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_AT);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T11);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (yr == AXP_REG_T10)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T10);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T11);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (xr != AXP_REG_T10)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], xr);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T10);
|
2001-01-20 12:23:33 +08:00
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (yr != AXP_REG_T10 && yr != AXP_REG_T11)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], yr);
|
|
|
|
|
set_tok_reg (newtok[1], AXP_REG_T11);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Call the division routine. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T9);
|
|
|
|
|
set_tok_sym (newtok[1], sym, 0);
|
|
|
|
|
assemble_tokens ("jsr", newtok, 2, 1);
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Reload the GP register. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#ifdef OBJ_AOUT
|
|
|
|
|
FIXME
|
|
|
|
|
#endif
|
|
|
|
|
#if defined(OBJ_ECOFF) || defined(OBJ_ELF)
|
|
|
|
|
set_tok_reg (newtok[0], alpha_gp_register);
|
|
|
|
|
set_tok_const (newtok[1], 0);
|
|
|
|
|
set_tok_preg (newtok[2], AXP_REG_T9);
|
|
|
|
|
assemble_tokens ("ldgp", newtok, 3, 1);
|
|
|
|
|
#endif
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Move the result to the right place. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (rr != AXP_REG_T12)
|
|
|
|
|
{
|
|
|
|
|
set_tok_reg (newtok[0], AXP_REG_T12);
|
|
|
|
|
set_tok_reg (newtok[1], rr);
|
|
|
|
|
assemble_tokens ("mov", newtok, 2, 1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif /* !OBJ_EVAX */
|
|
|
|
|
|
|
|
|
|
/* The jsr and jmp macros differ from their instruction counterparts
|
|
|
|
|
in that they can load the target address and default most
|
|
|
|
|
everything. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_jsrjmp (tok, ntok, vopname)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vopname;
|
|
|
|
|
{
|
|
|
|
|
const char *opname = (const char *) vopname;
|
|
|
|
|
struct alpha_insn insn;
|
|
|
|
|
expressionS newtok[3];
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
int r, tokidx = 0;
|
|
|
|
|
long lituse = 0;
|
1999-11-29 08:46:16 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (tokidx < ntok && tok[tokidx].X_op == O_register)
|
|
|
|
|
r = regno (tok[tokidx++].X_add_number);
|
|
|
|
|
else
|
|
|
|
|
r = strcmp (opname, "jmp") == 0 ? AXP_REG_ZERO : AXP_REG_RA;
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], r);
|
|
|
|
|
|
|
|
|
|
if (tokidx < ntok &&
|
|
|
|
|
(tok[tokidx].X_op == O_pregister || tok[tokidx].X_op == O_cpregister))
|
|
|
|
|
r = regno (tok[tokidx++].X_add_number);
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
/* keep register if jsr $n.<sym> */
|
|
|
|
|
#else
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
int basereg = alpha_gp_register;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
lituse = load_expression (r = AXP_REG_PV, &tok[tokidx], &basereg, NULL);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
set_tok_cpreg (newtok[1], r);
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
/* FIXME: Add hint relocs to BFD for evax. */
|
|
|
|
|
#else
|
|
|
|
|
if (tokidx < ntok)
|
|
|
|
|
newtok[2] = tok[tokidx];
|
|
|
|
|
else
|
|
|
|
|
#endif
|
|
|
|
|
set_tok_const (newtok[2], 0);
|
|
|
|
|
|
|
|
|
|
assemble_tokens_to_insn (opname, newtok, 3, &insn);
|
|
|
|
|
|
|
|
|
|
if (lituse)
|
|
|
|
|
{
|
|
|
|
|
assert (insn.nfixups < MAX_INSN_FIXUPS);
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.fixups[insn.nfixups].reloc = DUMMY_RELOC_LITUSE_JSR;
|
|
|
|
|
insn.fixups[insn.nfixups].exp.X_op = O_absent;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
insn.nfixups++;
|
* config/tc-alpha.c (struct alpha_insn): Make sequence scalar long.
(MACRO_LITERAL, MACRO_BASE, MACRO_BYTOFF, MACRO_JSR): Remove.
(alpha_macros): Remove occurrences of same.
(O_lituse_addr, O_gprel): New.
(DUMMY_RELOC_LITUSE_*): New.
(s_alpha_ucons, s_alpha_arch): Prototype.
(alpha_reloc_op): Construct elements via DEF macro.
(ALPHA_RELOC_SEQUENCE_OK): Remove.
(struct alpha_reloc_tag): Rename from alpha_literal_tag; rename
members to not be literal specific.
(next_sequence_num): New.
(md_apply_fix3): Cope with missing GPDISP_LO16. Adjust for
added/removed BFD relocations.
(alpha_force_relocation, alpha_fix_adjustable): Likewise.
(alpha_adjust_symtab_relocs): Handle GPDISP relocs as well.
(tokenize_arguments): Parse ! relocations properly.
(find_macro_match): Delete unused macro argument types.
(assemble_insn): Add reloc parameter; emit that instead of the
default as appropriate.
(get_alpha_reloc_tag): New. Split from ...
(emit_insn): ... here. Allocate a reloc tag for GPDISP.
(assemble_tokens): Don't search macros if user relocation present.
Copy reloc sequence number to insn struct.
(emit_ldgp): Remove user reloc handling.
(load_expression, emit_lda, emit_ldah, emit_ir_load): Likewise.
(emit_loadstore, emit_ldXu, emit_ldil, emit_stX): Likewise.
(emit_sextX, emit_division, emit_jsrjmp, emit_retjcr): Likewise.
* config/tc-alpha.h (tc_adjust_symtab): Always define.
(struct alpha_fix_tag): Name members less literal specific.
* gas/alpha/alpha.exp: New file.
* gas/alpha/elf-reloc-1.[sd]: New test.
* gas/alpha/elf-reloc-2.[sl]: New test.
* gas/alpha/elf-reloc-3.[sl]: New test.
* gas/alpha/elf-reloc-4.[sd]: New test.
* gas/alpha/fp.exp: Remove file.
* gas/alpha/fp.s: Output to .data not .rdata.
* gas/alpha/fp.d: Adjust to match.
2001-09-05 10:39:43 +08:00
|
|
|
|
insn.sequence = lituse;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
emit_insn (&insn);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The ret and jcr instructions differ from their instruction
|
|
|
|
|
counterparts in that everything can be defaulted. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
emit_retjcr (tok, ntok, vopname)
|
|
|
|
|
const expressionS *tok;
|
|
|
|
|
int ntok;
|
|
|
|
|
const PTR vopname;
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
const char *opname = (const char *) vopname;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
expressionS newtok[3];
|
|
|
|
|
int r, tokidx = 0;
|
|
|
|
|
|
|
|
|
|
if (tokidx < ntok && tok[tokidx].X_op == O_register)
|
|
|
|
|
r = regno (tok[tokidx++].X_add_number);
|
|
|
|
|
else
|
|
|
|
|
r = AXP_REG_ZERO;
|
|
|
|
|
|
|
|
|
|
set_tok_reg (newtok[0], r);
|
|
|
|
|
|
|
|
|
|
if (tokidx < ntok &&
|
|
|
|
|
(tok[tokidx].X_op == O_pregister || tok[tokidx].X_op == O_cpregister))
|
|
|
|
|
r = regno (tok[tokidx++].X_add_number);
|
|
|
|
|
else
|
|
|
|
|
r = AXP_REG_RA;
|
|
|
|
|
|
|
|
|
|
set_tok_cpreg (newtok[1], r);
|
|
|
|
|
|
|
|
|
|
if (tokidx < ntok)
|
|
|
|
|
newtok[2] = tok[tokidx];
|
|
|
|
|
else
|
2001-01-19 20:03:34 +08:00
|
|
|
|
set_tok_const (newtok[2], strcmp (opname, "ret") == 0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
assemble_tokens (opname, newtok, 3, 0);
|
|
|
|
|
}
|
|
|
|
|
|
2002-08-14 21:27:06 +08:00
|
|
|
|
/* Assembler directives. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* Handle the .text pseudo-op. This is like the usual one, but it
|
|
|
|
|
clears alpha_insn_label and restores auto alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_text (i)
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
{
|
2002-02-28 07:48:06 +08:00
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
obj_elf_text (i);
|
|
|
|
|
#else
|
1999-05-03 15:29:11 +08:00
|
|
|
|
s_text (i);
|
2002-02-28 07:48:06 +08:00
|
|
|
|
#endif
|
1999-05-03 15:29:11 +08:00
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
alpha_auto_align_on = 1;
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle the .data pseudo-op. This is like the usual one, but it
|
|
|
|
|
clears alpha_insn_label and restores auto alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_data (i)
|
|
|
|
|
int i;
|
|
|
|
|
{
|
2002-02-28 07:48:06 +08:00
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
obj_elf_data (i);
|
|
|
|
|
#else
|
1999-05-03 15:29:11 +08:00
|
|
|
|
s_data (i);
|
2002-02-28 07:48:06 +08:00
|
|
|
|
#endif
|
1999-05-03 15:29:11 +08:00
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
alpha_auto_align_on = 1;
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#if defined (OBJ_ECOFF) || defined (OBJ_EVAX)
|
|
|
|
|
|
|
|
|
|
/* Handle the OSF/1 and openVMS .comm pseudo quirks.
|
|
|
|
|
openVMS constructs a section for every common symbol. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_comm (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
register char *name;
|
|
|
|
|
register char c;
|
|
|
|
|
register char *p;
|
|
|
|
|
offsetT temp;
|
|
|
|
|
register symbolS *symbolP;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
segT current_section = now_seg;
|
|
|
|
|
int current_subsec = now_subseg;
|
|
|
|
|
segT new_seg;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
name = input_line_pointer;
|
|
|
|
|
c = get_symbol_end ();
|
|
|
|
|
|
|
|
|
|
/* just after name is now '\0' */
|
|
|
|
|
p = input_line_pointer;
|
|
|
|
|
*p = c;
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
|
|
|
|
|
/* Alpha OSF/1 compiler doesn't provide the comma, gcc does. */
|
|
|
|
|
if (*input_line_pointer == ',')
|
|
|
|
|
{
|
|
|
|
|
input_line_pointer++;
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
}
|
|
|
|
|
if ((temp = get_absolute_expression ()) < 0)
|
|
|
|
|
{
|
|
|
|
|
as_warn (_(".COMMon length (%ld.) <0! Ignored."), (long) temp);
|
|
|
|
|
ignore_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
*p = 0;
|
|
|
|
|
symbolP = symbol_find_or_make (name);
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
/* Make a section for the common symbol. */
|
|
|
|
|
new_seg = subseg_new (xstrdup (name), 0);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
*p = c;
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
/* alignment might follow */
|
|
|
|
|
if (*input_line_pointer == ',')
|
|
|
|
|
{
|
|
|
|
|
offsetT align;
|
|
|
|
|
|
2000-09-15 09:06:52 +08:00
|
|
|
|
input_line_pointer++;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
align = get_absolute_expression ();
|
|
|
|
|
bfd_set_section_alignment (stdoutput, new_seg, align);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
if (S_IS_DEFINED (symbolP) && ! S_IS_COMMON (symbolP))
|
|
|
|
|
{
|
|
|
|
|
as_bad (_("Ignoring attempt to re-define symbol"));
|
|
|
|
|
ignore_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
if (bfd_section_size (stdoutput, new_seg) > 0)
|
2000-09-15 09:06:52 +08:00
|
|
|
|
{
|
1999-05-03 15:29:11 +08:00
|
|
|
|
if (bfd_section_size (stdoutput, new_seg) != temp)
|
|
|
|
|
as_bad (_("Length of .comm \"%s\" is already %ld. Not changed to %ld."),
|
|
|
|
|
S_GET_NAME (symbolP),
|
|
|
|
|
(long) bfd_section_size (stdoutput, new_seg),
|
|
|
|
|
(long) temp);
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
if (S_GET_VALUE (symbolP))
|
|
|
|
|
{
|
|
|
|
|
if (S_GET_VALUE (symbolP) != (valueT) temp)
|
|
|
|
|
as_bad (_("Length of .comm \"%s\" is already %ld. Not changed to %ld."),
|
|
|
|
|
S_GET_NAME (symbolP),
|
|
|
|
|
(long) S_GET_VALUE (symbolP),
|
|
|
|
|
(long) temp);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
else
|
|
|
|
|
{
|
2000-09-15 09:06:52 +08:00
|
|
|
|
#ifdef OBJ_EVAX
|
1999-05-03 15:29:11 +08:00
|
|
|
|
subseg_set (new_seg, 0);
|
|
|
|
|
p = frag_more (temp);
|
|
|
|
|
new_seg->flags |= SEC_IS_COMMON;
|
|
|
|
|
if (! S_IS_DEFINED (symbolP))
|
1999-06-06 07:15:34 +08:00
|
|
|
|
S_SET_SEGMENT (symbolP, new_seg);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#else
|
|
|
|
|
S_SET_VALUE (symbolP, (valueT) temp);
|
|
|
|
|
#endif
|
|
|
|
|
S_SET_EXTERNAL (symbolP);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
subseg_set (current_section, current_subsec);
|
|
|
|
|
#endif
|
|
|
|
|
|
1999-06-22 22:53:01 +08:00
|
|
|
|
know (symbol_get_frag (symbolP) == &zero_address_frag);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif /* ! OBJ_ELF */
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
|
|
|
|
|
/* Handle the .rdata pseudo-op. This is like the usual one, but it
|
|
|
|
|
clears alpha_insn_label and restores auto alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_rdata (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
int temp;
|
|
|
|
|
|
|
|
|
|
temp = get_absolute_expression ();
|
|
|
|
|
subseg_new (".rdata", 0);
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
alpha_auto_align_on = 1;
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
|
|
|
|
|
/* Handle the .sdata pseudo-op. This is like the usual one, but it
|
|
|
|
|
clears alpha_insn_label and restores auto alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_sdata (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
int temp;
|
|
|
|
|
|
|
|
|
|
temp = get_absolute_expression ();
|
|
|
|
|
subseg_new (".sdata", 0);
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
alpha_auto_align_on = 1;
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
|
|
|
|
|
/* Handle the .section pseudo-op. This is like the usual one, but it
|
|
|
|
|
clears alpha_insn_label and restores auto alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_section (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
obj_elf_section (ignore);
|
|
|
|
|
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
alpha_auto_align_on = 1;
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_ent (dummy)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int dummy ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
ecoff_directive_ent (0);
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
char *name, name_end;
|
|
|
|
|
name = input_line_pointer;
|
|
|
|
|
name_end = get_symbol_end ();
|
|
|
|
|
|
|
|
|
|
if (! is_name_beginner (*name))
|
|
|
|
|
{
|
|
|
|
|
as_warn (_(".ent directive has no name"));
|
|
|
|
|
*input_line_pointer = name_end;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
symbolS *sym;
|
|
|
|
|
|
|
|
|
|
if (alpha_cur_ent_sym)
|
|
|
|
|
as_warn (_("nested .ent directives"));
|
|
|
|
|
|
|
|
|
|
sym = symbol_find_or_make (name);
|
Add support for storing local symbols in a small structure to save
memory when assembling large files.
* as.h: Don't include struc-symbol.h.
(symbolS): Add typedef.
* symbols.c: Include struc-symbol.h.
(local_hash): New static variable.
(save_symbol_name): New static function, from symbol_create.
(symbol_create): Call save_symbol_name.
(local_symbol_count): New static variable.
(local_symbol_conversion_count): Likewise.
(LOCAL_SYMBOL_CHECK): Define.
(local_symbol_make): New static function.
(local_symbol_convert): New static function.
(colon): Handle local symbols. Create local symbol for local
label name.
(symbol_table_insert): Handle local symbols.
(symbol_find_or_make): Create local symbol for local label name.
(symbol_find_base): Check for local symbol.
(symbol_append, symbol_insert): Check for local symbols.
(symbol_clear_list_pointers, symbol_remove): Likewise.
(verify_symbol_chain): Likewise.
(copy_symbol_attributes): Likewise.
(resolve_symbol_value): Handle local symbols.
(resolve_local_symbol): New static function.
(resolve_local_symbol_values): New function.
(S_GET_VALUE, S_SET_VALUE): Handle local symbols.
(S_IS_FUNCTION, S_IS_EXTERNAL, S_IS_WEAK, S_IS_COMMON): Likewise.
(S_IS_DEFINED, S_IS_DEBUG, S_IS_LOCAL, S_GET_NAME): Likewise.
(S_GET_SEGMENT, S_SET_SEGMENT, S_SET_EXTERNAL): Likewise.
(S_CLEAR_EXTERNAL, S_SET_WEAK, S_SET_NAME): Likewise.
(symbol_previous, symbol_next): New functions.
(symbol_get_value_expression): Likewise.
(symbol_set_value_expression): Likewise.
(symbol_set_frag, symbol_get_frag): Likewise.
(symbol_mark_used, symbol_clear_used, symbol_used_p): Likewise.
(symbol_mark_used_in_reloc): Likewise.
(symbol_clear_used_in_reloc, symbol_used_in_reloc_p): Likewise.
(symbol_mark_mri_common, symbol_clear_mri_common): Likewise.
(symbol_mri_common_p): Likewise.
(symbol_mark_written, symbol_clear_written): Likewise.
(symbol_written_p): Likewise.
(symbol_mark_resolved, symbol_resolved_p): Likewise.
(symbol_section_p, symbol_equated_p): Likewise.
(symbol_constant_p): Likewise.
(symbol_get_bfdsym, symbol_set_bfdsym): Likewise.
(symbol_get_obj, symbol_set_obj): Likewise.
(symbol_get_tc, symbol_set_tc): Likewise.
(symbol_begin): Initialize local_hash.
(print_symbol_value_1): Handle local symbols.
(symbol_print_statistics): Print local symbol statistics.
* symbols.h: Include "struc-symbol.h" if not BFD_ASSEMBLER.
Declare new symbols.c functions. Move many declarations here from
struc-symbol.h.
(SYMBOLS_NEED_BACKPOINTERS): Define if needed.
* struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Don't set.
(struct symbol): Move bsym to make it clearly the first field.
Remove TARGET_SYMBOL_FIELDS.
(symbolS): Don't typedef.
(struct broken_word): Remove.
(N_TYPE_seg, seg_N_TYPE): Move to symbol.h.
(SEGMENT_TO_SYMBOL_TYPE, N_REGISTER): Likewise.
(symbol_clear_list_pointers): Likewise.
(symbol_insert, symbol_remove): Likewise.
(symbol_previous, symbol_append): Likewise.
(verify_symbol_chain, verify_symbol_chain_2): Likewise.
(struct local_symbol): Define.
(local_symbol_converted_p, local_symbol_mark_converted): Define.
(local_symbol_resolved_p, local_symbol_mark_resolved): Define.
(local_symbol_get_frag, local_symbol_set_frag): Define.
(local_symbol_get_real_symbol): Define.
(local_symbol_set_real_symbol): Define.
Define.
* write.c (write_object_file): Call resolve_local_symbol_values.
* config/obj-ecoff.h (OBJ_SYMFIELD_TYPE): Define.
(TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-elf.h (OBJ_SYMFIELD_TYPE): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-multi.h (struct elf_obj_sy): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
(ECOFF_DEBUG_TARGET_SYMBOL_FIELDS): Don't define.
* config/tc-mcore.h: Don't include struc-symbol.h.
(TARGET_SYMBOL_FIELDS): Don't define.
(struct mcore_tc_sy): Define.
(TC_SYMFIELD_TYPE): Define.
* Many files: Use symbolS instead of struct symbol. Use new
accessor functions rather than referring to symbolS fields
directly.
* read.c (s_mri_common): Don't add in value of line_label.
* config/tc-mips.c (md_apply_fix): Correct parenthesization when
checking for SEC_LINK_ONCE.
* config/tc-sh.h (sh_fix_adjustable): Declare.
1999-06-03 08:29:48 +08:00
|
|
|
|
symbol_get_bfdsym (sym)->flags |= BSF_FUNCTION;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
alpha_cur_ent_sym = sym;
|
|
|
|
|
|
|
|
|
|
/* The .ent directive is sometimes followed by a number. Not sure
|
|
|
|
|
what it really means, but ignore it. */
|
|
|
|
|
*input_line_pointer = name_end;
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
if (*input_line_pointer == ',')
|
|
|
|
|
{
|
|
|
|
|
input_line_pointer++;
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
}
|
2001-09-19 13:33:36 +08:00
|
|
|
|
if (ISDIGIT (*input_line_pointer) || *input_line_pointer == '-')
|
1999-05-03 15:29:11 +08:00
|
|
|
|
(void) get_absolute_expression ();
|
|
|
|
|
}
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_end (dummy)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int dummy ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
ecoff_directive_end (0);
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
char *name, name_end;
|
|
|
|
|
name = input_line_pointer;
|
|
|
|
|
name_end = get_symbol_end ();
|
|
|
|
|
|
|
|
|
|
if (! is_name_beginner (*name))
|
|
|
|
|
{
|
|
|
|
|
as_warn (_(".end directive has no name"));
|
|
|
|
|
*input_line_pointer = name_end;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
symbolS *sym;
|
|
|
|
|
|
|
|
|
|
sym = symbol_find (name);
|
|
|
|
|
if (sym != alpha_cur_ent_sym)
|
|
|
|
|
as_warn (_(".end directive names different symbol than .ent"));
|
|
|
|
|
|
|
|
|
|
/* Create an expression to calculate the size of the function. */
|
|
|
|
|
if (sym)
|
|
|
|
|
{
|
Add support for storing local symbols in a small structure to save
memory when assembling large files.
* as.h: Don't include struc-symbol.h.
(symbolS): Add typedef.
* symbols.c: Include struc-symbol.h.
(local_hash): New static variable.
(save_symbol_name): New static function, from symbol_create.
(symbol_create): Call save_symbol_name.
(local_symbol_count): New static variable.
(local_symbol_conversion_count): Likewise.
(LOCAL_SYMBOL_CHECK): Define.
(local_symbol_make): New static function.
(local_symbol_convert): New static function.
(colon): Handle local symbols. Create local symbol for local
label name.
(symbol_table_insert): Handle local symbols.
(symbol_find_or_make): Create local symbol for local label name.
(symbol_find_base): Check for local symbol.
(symbol_append, symbol_insert): Check for local symbols.
(symbol_clear_list_pointers, symbol_remove): Likewise.
(verify_symbol_chain): Likewise.
(copy_symbol_attributes): Likewise.
(resolve_symbol_value): Handle local symbols.
(resolve_local_symbol): New static function.
(resolve_local_symbol_values): New function.
(S_GET_VALUE, S_SET_VALUE): Handle local symbols.
(S_IS_FUNCTION, S_IS_EXTERNAL, S_IS_WEAK, S_IS_COMMON): Likewise.
(S_IS_DEFINED, S_IS_DEBUG, S_IS_LOCAL, S_GET_NAME): Likewise.
(S_GET_SEGMENT, S_SET_SEGMENT, S_SET_EXTERNAL): Likewise.
(S_CLEAR_EXTERNAL, S_SET_WEAK, S_SET_NAME): Likewise.
(symbol_previous, symbol_next): New functions.
(symbol_get_value_expression): Likewise.
(symbol_set_value_expression): Likewise.
(symbol_set_frag, symbol_get_frag): Likewise.
(symbol_mark_used, symbol_clear_used, symbol_used_p): Likewise.
(symbol_mark_used_in_reloc): Likewise.
(symbol_clear_used_in_reloc, symbol_used_in_reloc_p): Likewise.
(symbol_mark_mri_common, symbol_clear_mri_common): Likewise.
(symbol_mri_common_p): Likewise.
(symbol_mark_written, symbol_clear_written): Likewise.
(symbol_written_p): Likewise.
(symbol_mark_resolved, symbol_resolved_p): Likewise.
(symbol_section_p, symbol_equated_p): Likewise.
(symbol_constant_p): Likewise.
(symbol_get_bfdsym, symbol_set_bfdsym): Likewise.
(symbol_get_obj, symbol_set_obj): Likewise.
(symbol_get_tc, symbol_set_tc): Likewise.
(symbol_begin): Initialize local_hash.
(print_symbol_value_1): Handle local symbols.
(symbol_print_statistics): Print local symbol statistics.
* symbols.h: Include "struc-symbol.h" if not BFD_ASSEMBLER.
Declare new symbols.c functions. Move many declarations here from
struc-symbol.h.
(SYMBOLS_NEED_BACKPOINTERS): Define if needed.
* struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Don't set.
(struct symbol): Move bsym to make it clearly the first field.
Remove TARGET_SYMBOL_FIELDS.
(symbolS): Don't typedef.
(struct broken_word): Remove.
(N_TYPE_seg, seg_N_TYPE): Move to symbol.h.
(SEGMENT_TO_SYMBOL_TYPE, N_REGISTER): Likewise.
(symbol_clear_list_pointers): Likewise.
(symbol_insert, symbol_remove): Likewise.
(symbol_previous, symbol_append): Likewise.
(verify_symbol_chain, verify_symbol_chain_2): Likewise.
(struct local_symbol): Define.
(local_symbol_converted_p, local_symbol_mark_converted): Define.
(local_symbol_resolved_p, local_symbol_mark_resolved): Define.
(local_symbol_get_frag, local_symbol_set_frag): Define.
(local_symbol_get_real_symbol): Define.
(local_symbol_set_real_symbol): Define.
Define.
* write.c (write_object_file): Call resolve_local_symbol_values.
* config/obj-ecoff.h (OBJ_SYMFIELD_TYPE): Define.
(TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-elf.h (OBJ_SYMFIELD_TYPE): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-multi.h (struct elf_obj_sy): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
(ECOFF_DEBUG_TARGET_SYMBOL_FIELDS): Don't define.
* config/tc-mcore.h: Don't include struc-symbol.h.
(TARGET_SYMBOL_FIELDS): Don't define.
(struct mcore_tc_sy): Define.
(TC_SYMFIELD_TYPE): Define.
* Many files: Use symbolS instead of struct symbol. Use new
accessor functions rather than referring to symbolS fields
directly.
* read.c (s_mri_common): Don't add in value of line_label.
* config/tc-mips.c (md_apply_fix): Correct parenthesization when
checking for SEC_LINK_ONCE.
* config/tc-sh.h (sh_fix_adjustable): Declare.
1999-06-03 08:29:48 +08:00
|
|
|
|
symbol_get_obj (sym)->size =
|
|
|
|
|
(expressionS *) xmalloc (sizeof (expressionS));
|
|
|
|
|
symbol_get_obj (sym)->size->X_op = O_subtract;
|
|
|
|
|
symbol_get_obj (sym)->size->X_add_symbol
|
2001-01-23 04:24:11 +08:00
|
|
|
|
= symbol_new ("L0\001", now_seg, frag_now_fix (), frag_now);
|
Add support for storing local symbols in a small structure to save
memory when assembling large files.
* as.h: Don't include struc-symbol.h.
(symbolS): Add typedef.
* symbols.c: Include struc-symbol.h.
(local_hash): New static variable.
(save_symbol_name): New static function, from symbol_create.
(symbol_create): Call save_symbol_name.
(local_symbol_count): New static variable.
(local_symbol_conversion_count): Likewise.
(LOCAL_SYMBOL_CHECK): Define.
(local_symbol_make): New static function.
(local_symbol_convert): New static function.
(colon): Handle local symbols. Create local symbol for local
label name.
(symbol_table_insert): Handle local symbols.
(symbol_find_or_make): Create local symbol for local label name.
(symbol_find_base): Check for local symbol.
(symbol_append, symbol_insert): Check for local symbols.
(symbol_clear_list_pointers, symbol_remove): Likewise.
(verify_symbol_chain): Likewise.
(copy_symbol_attributes): Likewise.
(resolve_symbol_value): Handle local symbols.
(resolve_local_symbol): New static function.
(resolve_local_symbol_values): New function.
(S_GET_VALUE, S_SET_VALUE): Handle local symbols.
(S_IS_FUNCTION, S_IS_EXTERNAL, S_IS_WEAK, S_IS_COMMON): Likewise.
(S_IS_DEFINED, S_IS_DEBUG, S_IS_LOCAL, S_GET_NAME): Likewise.
(S_GET_SEGMENT, S_SET_SEGMENT, S_SET_EXTERNAL): Likewise.
(S_CLEAR_EXTERNAL, S_SET_WEAK, S_SET_NAME): Likewise.
(symbol_previous, symbol_next): New functions.
(symbol_get_value_expression): Likewise.
(symbol_set_value_expression): Likewise.
(symbol_set_frag, symbol_get_frag): Likewise.
(symbol_mark_used, symbol_clear_used, symbol_used_p): Likewise.
(symbol_mark_used_in_reloc): Likewise.
(symbol_clear_used_in_reloc, symbol_used_in_reloc_p): Likewise.
(symbol_mark_mri_common, symbol_clear_mri_common): Likewise.
(symbol_mri_common_p): Likewise.
(symbol_mark_written, symbol_clear_written): Likewise.
(symbol_written_p): Likewise.
(symbol_mark_resolved, symbol_resolved_p): Likewise.
(symbol_section_p, symbol_equated_p): Likewise.
(symbol_constant_p): Likewise.
(symbol_get_bfdsym, symbol_set_bfdsym): Likewise.
(symbol_get_obj, symbol_set_obj): Likewise.
(symbol_get_tc, symbol_set_tc): Likewise.
(symbol_begin): Initialize local_hash.
(print_symbol_value_1): Handle local symbols.
(symbol_print_statistics): Print local symbol statistics.
* symbols.h: Include "struc-symbol.h" if not BFD_ASSEMBLER.
Declare new symbols.c functions. Move many declarations here from
struc-symbol.h.
(SYMBOLS_NEED_BACKPOINTERS): Define if needed.
* struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Don't set.
(struct symbol): Move bsym to make it clearly the first field.
Remove TARGET_SYMBOL_FIELDS.
(symbolS): Don't typedef.
(struct broken_word): Remove.
(N_TYPE_seg, seg_N_TYPE): Move to symbol.h.
(SEGMENT_TO_SYMBOL_TYPE, N_REGISTER): Likewise.
(symbol_clear_list_pointers): Likewise.
(symbol_insert, symbol_remove): Likewise.
(symbol_previous, symbol_append): Likewise.
(verify_symbol_chain, verify_symbol_chain_2): Likewise.
(struct local_symbol): Define.
(local_symbol_converted_p, local_symbol_mark_converted): Define.
(local_symbol_resolved_p, local_symbol_mark_resolved): Define.
(local_symbol_get_frag, local_symbol_set_frag): Define.
(local_symbol_get_real_symbol): Define.
(local_symbol_set_real_symbol): Define.
Define.
* write.c (write_object_file): Call resolve_local_symbol_values.
* config/obj-ecoff.h (OBJ_SYMFIELD_TYPE): Define.
(TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-elf.h (OBJ_SYMFIELD_TYPE): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-multi.h (struct elf_obj_sy): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
(ECOFF_DEBUG_TARGET_SYMBOL_FIELDS): Don't define.
* config/tc-mcore.h: Don't include struc-symbol.h.
(TARGET_SYMBOL_FIELDS): Don't define.
(struct mcore_tc_sy): Define.
(TC_SYMFIELD_TYPE): Define.
* Many files: Use symbolS instead of struct symbol. Use new
accessor functions rather than referring to symbolS fields
directly.
* read.c (s_mri_common): Don't add in value of line_label.
* config/tc-mips.c (md_apply_fix): Correct parenthesization when
checking for SEC_LINK_ONCE.
* config/tc-sh.h (sh_fix_adjustable): Declare.
1999-06-03 08:29:48 +08:00
|
|
|
|
symbol_get_obj (sym)->size->X_op_symbol = sym;
|
|
|
|
|
symbol_get_obj (sym)->size->X_add_number = 0;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
alpha_cur_ent_sym = NULL;
|
|
|
|
|
|
|
|
|
|
*input_line_pointer = name_end;
|
|
|
|
|
}
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_mask (fp)
|
|
|
|
|
int fp;
|
|
|
|
|
{
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
{
|
|
|
|
|
if (fp)
|
2001-01-20 12:23:33 +08:00
|
|
|
|
ecoff_directive_fmask (0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
else
|
2001-01-20 12:23:33 +08:00
|
|
|
|
ecoff_directive_mask (0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
discard_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_frame (dummy)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int dummy ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
ecoff_directive_frame (0);
|
|
|
|
|
else
|
|
|
|
|
discard_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_prologue (ignore)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
symbolS *sym;
|
|
|
|
|
int arg;
|
|
|
|
|
|
|
|
|
|
arg = get_absolute_expression ();
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
sym = ecoff_get_cur_proc_sym ();
|
|
|
|
|
else
|
|
|
|
|
sym = alpha_cur_ent_sym;
|
2002-11-19 15:32:28 +08:00
|
|
|
|
|
|
|
|
|
if (sym == NULL)
|
|
|
|
|
{
|
|
|
|
|
as_bad (_(".prologue directive without a preceding .ent directive"));
|
|
|
|
|
return;
|
|
|
|
|
}
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
switch (arg)
|
|
|
|
|
{
|
2001-01-20 12:23:33 +08:00
|
|
|
|
case 0: /* No PV required. */
|
|
|
|
|
S_SET_OTHER (sym, STO_ALPHA_NOPV
|
|
|
|
|
| (S_GET_OTHER (sym) & ~STO_ALPHA_STD_GPLOAD));
|
|
|
|
|
break;
|
|
|
|
|
case 1: /* Std GP load. */
|
|
|
|
|
S_SET_OTHER (sym, STO_ALPHA_STD_GPLOAD
|
|
|
|
|
| (S_GET_OTHER (sym) & ~STO_ALPHA_STD_GPLOAD));
|
|
|
|
|
break;
|
|
|
|
|
case 2: /* Non-std use of PV. */
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
as_bad (_("Invalid argument %d to .prologue."), arg);
|
|
|
|
|
break;
|
2000-09-15 09:06:52 +08:00
|
|
|
|
}
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
static char *first_file_directive;
|
2000-11-18 02:07:33 +08:00
|
|
|
|
|
2000-11-17 16:47:52 +08:00
|
|
|
|
static void
|
|
|
|
|
s_alpha_file (ignore)
|
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
|
|
|
|
{
|
2000-11-18 02:07:33 +08:00
|
|
|
|
/* Save the first .file directive we see, so that we can change our
|
|
|
|
|
minds about whether ecoff debugging should or shouldn't be enabled. */
|
|
|
|
|
if (alpha_flag_mdebug < 0 && ! first_file_directive)
|
|
|
|
|
{
|
|
|
|
|
char *start = input_line_pointer;
|
|
|
|
|
size_t len;
|
|
|
|
|
|
|
|
|
|
discard_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
len = input_line_pointer - start;
|
|
|
|
|
first_file_directive = xmalloc (len + 1);
|
|
|
|
|
memcpy (first_file_directive, start, len);
|
|
|
|
|
first_file_directive[len] = '\0';
|
|
|
|
|
|
|
|
|
|
input_line_pointer = start;
|
|
|
|
|
}
|
|
|
|
|
|
2000-11-17 16:47:52 +08:00
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
ecoff_directive_file (0);
|
|
|
|
|
else
|
|
|
|
|
dwarf2_directive_file (0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_loc (ignore)
|
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
|
|
|
|
{
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
|
|
|
|
ecoff_directive_loc (0);
|
|
|
|
|
else
|
|
|
|
|
dwarf2_directive_loc (0);
|
|
|
|
|
}
|
|
|
|
|
|
2000-11-18 02:07:33 +08:00
|
|
|
|
static void
|
|
|
|
|
s_alpha_stab (n)
|
|
|
|
|
int n;
|
|
|
|
|
{
|
|
|
|
|
/* If we've been undecided about mdebug, make up our minds in favour. */
|
|
|
|
|
if (alpha_flag_mdebug < 0)
|
|
|
|
|
{
|
2001-01-19 20:03:34 +08:00
|
|
|
|
segT sec = subseg_new (".mdebug", 0);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
bfd_set_section_flags (stdoutput, sec, SEC_HAS_CONTENTS | SEC_READONLY);
|
2001-01-19 20:03:34 +08:00
|
|
|
|
bfd_set_section_alignment (stdoutput, sec, 3);
|
2000-11-18 02:07:33 +08:00
|
|
|
|
|
|
|
|
|
ecoff_read_begin_hook ();
|
|
|
|
|
|
|
|
|
|
if (first_file_directive)
|
|
|
|
|
{
|
|
|
|
|
char *save_ilp = input_line_pointer;
|
2001-01-23 04:24:11 +08:00
|
|
|
|
input_line_pointer = first_file_directive;
|
2000-11-18 02:07:33 +08:00
|
|
|
|
ecoff_directive_file (0);
|
|
|
|
|
input_line_pointer = save_ilp;
|
|
|
|
|
free (first_file_directive);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
alpha_flag_mdebug = 1;
|
|
|
|
|
}
|
|
|
|
|
s_stab (n);
|
|
|
|
|
}
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static void
|
|
|
|
|
s_alpha_coff_wrapper (which)
|
|
|
|
|
int which;
|
|
|
|
|
{
|
|
|
|
|
static void (* const fns[]) PARAMS ((int)) = {
|
|
|
|
|
ecoff_directive_begin,
|
|
|
|
|
ecoff_directive_bend,
|
|
|
|
|
ecoff_directive_def,
|
|
|
|
|
ecoff_directive_dim,
|
|
|
|
|
ecoff_directive_endef,
|
|
|
|
|
ecoff_directive_scl,
|
|
|
|
|
ecoff_directive_tag,
|
|
|
|
|
ecoff_directive_val,
|
|
|
|
|
};
|
|
|
|
|
|
2000-12-03 14:49:23 +08:00
|
|
|
|
assert (which >= 0 && which < (int) (sizeof (fns)/sizeof (*fns)));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (ECOFF_DEBUGGING)
|
2000-12-03 14:49:23 +08:00
|
|
|
|
(*fns[which]) (0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
as_bad (_("ECOFF debugging is disabled."));
|
|
|
|
|
ignore_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif /* OBJ_ELF */
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_EVAX
|
2000-09-15 09:06:52 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* Handle the section specific pseudo-op. */
|
2000-09-15 09:06:52 +08:00
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
static void
|
|
|
|
|
s_alpha_section (secid)
|
|
|
|
|
int secid;
|
|
|
|
|
{
|
|
|
|
|
int temp;
|
|
|
|
|
#define EVAX_SECTION_COUNT 5
|
2001-01-23 04:24:11 +08:00
|
|
|
|
static char *section_name[EVAX_SECTION_COUNT + 1] =
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{ "NULL", ".rdata", ".comm", ".link", ".ctors", ".dtors" };
|
|
|
|
|
|
|
|
|
|
if ((secid <= 0) || (secid > EVAX_SECTION_COUNT))
|
|
|
|
|
{
|
|
|
|
|
as_fatal (_("Unknown section directive"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
temp = get_absolute_expression ();
|
|
|
|
|
subseg_new (section_name[secid], 0);
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
alpha_auto_align_on = 1;
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Parse .ent directives. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_ent (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
symbolS *symbol;
|
|
|
|
|
expressionS symexpr;
|
|
|
|
|
|
|
|
|
|
alpha_evax_proc.pdsckind = 0;
|
|
|
|
|
alpha_evax_proc.framereg = -1;
|
|
|
|
|
alpha_evax_proc.framesize = 0;
|
|
|
|
|
alpha_evax_proc.rsa_offset = 0;
|
|
|
|
|
alpha_evax_proc.ra_save = AXP_REG_RA;
|
|
|
|
|
alpha_evax_proc.fp_save = -1;
|
|
|
|
|
alpha_evax_proc.imask = 0;
|
|
|
|
|
alpha_evax_proc.fmask = 0;
|
|
|
|
|
alpha_evax_proc.prologue = 0;
|
|
|
|
|
alpha_evax_proc.type = 0;
|
|
|
|
|
|
|
|
|
|
expression (&symexpr);
|
|
|
|
|
|
|
|
|
|
if (symexpr.X_op != O_symbol)
|
|
|
|
|
{
|
|
|
|
|
as_fatal (_(".ent directive has no symbol"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
symbol = make_expr_symbol (&symexpr);
|
1999-06-06 07:15:34 +08:00
|
|
|
|
symbol_get_bfdsym (symbol)->flags |= BSF_FUNCTION;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
alpha_evax_proc.symbol = symbol;
|
|
|
|
|
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Parse .frame <framreg>,<framesize>,RA,<rsa_offset> directives. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_frame (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
long val;
|
|
|
|
|
|
|
|
|
|
alpha_evax_proc.framereg = tc_get_register (1);
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
if (*input_line_pointer++ != ','
|
|
|
|
|
|| get_absolute_expression_and_terminator (&val) != ',')
|
|
|
|
|
{
|
|
|
|
|
as_warn (_("Bad .frame directive 1./2. param"));
|
|
|
|
|
--input_line_pointer;
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
alpha_evax_proc.framesize = val;
|
|
|
|
|
|
|
|
|
|
(void) tc_get_register (1);
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
if (*input_line_pointer++ != ',')
|
|
|
|
|
{
|
|
|
|
|
as_warn (_("Bad .frame directive 3./4. param"));
|
|
|
|
|
--input_line_pointer;
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
alpha_evax_proc.rsa_offset = get_absolute_expression ();
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_pdesc (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
char *name;
|
|
|
|
|
char name_end;
|
|
|
|
|
long val;
|
|
|
|
|
register char *p;
|
|
|
|
|
expressionS exp;
|
|
|
|
|
symbolS *entry_sym;
|
|
|
|
|
fixS *fixp;
|
|
|
|
|
segment_info_type *seginfo = seg_info (alpha_link_section);
|
|
|
|
|
|
|
|
|
|
if (now_seg != alpha_link_section)
|
|
|
|
|
{
|
|
|
|
|
as_bad (_(".pdesc directive not in link (.link) section"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ((alpha_evax_proc.symbol == 0)
|
|
|
|
|
|| (!S_IS_DEFINED (alpha_evax_proc.symbol)))
|
|
|
|
|
{
|
|
|
|
|
as_fatal (_(".pdesc has no matching .ent"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
1999-06-22 22:53:01 +08:00
|
|
|
|
*symbol_get_obj (alpha_evax_proc.symbol) =
|
|
|
|
|
(valueT) seginfo->literal_pool_size;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
expression (&exp);
|
|
|
|
|
if (exp.X_op != O_symbol)
|
|
|
|
|
{
|
|
|
|
|
as_warn (_(".pdesc directive has no entry symbol"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
entry_sym = make_expr_symbol (&exp);
|
|
|
|
|
/* Save bfd symbol of proc desc in function symbol. */
|
1999-06-06 07:15:34 +08:00
|
|
|
|
symbol_get_bfdsym (alpha_evax_proc.symbol)->udata.p
|
|
|
|
|
= symbol_get_bfdsym (entry_sym);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
if (*input_line_pointer++ != ',')
|
|
|
|
|
{
|
|
|
|
|
as_warn (_("No comma after .pdesc <entryname>"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
name = input_line_pointer;
|
|
|
|
|
name_end = get_symbol_end ();
|
|
|
|
|
|
2001-01-19 20:03:34 +08:00
|
|
|
|
if (strncmp (name, "stack", 5) == 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
alpha_evax_proc.pdsckind = PDSC_S_K_KIND_FP_STACK;
|
|
|
|
|
}
|
2001-01-19 20:03:34 +08:00
|
|
|
|
else if (strncmp (name, "reg", 3) == 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
alpha_evax_proc.pdsckind = PDSC_S_K_KIND_FP_REGISTER;
|
|
|
|
|
}
|
2001-01-19 20:03:34 +08:00
|
|
|
|
else if (strncmp (name, "null", 4) == 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
alpha_evax_proc.pdsckind = PDSC_S_K_KIND_NULL;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
as_fatal (_("unknown procedure kind"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
*input_line_pointer = name_end;
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
#ifdef md_flush_pending_output
|
|
|
|
|
md_flush_pending_output ();
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
frag_align (3, 0, 0);
|
|
|
|
|
p = frag_more (16);
|
|
|
|
|
fixp = fix_new (frag_now, p - frag_now->fr_literal, 8, 0, 0, 0, 0);
|
|
|
|
|
fixp->fx_done = 1;
|
|
|
|
|
seginfo->literal_pool_size += 16;
|
|
|
|
|
|
|
|
|
|
*p = alpha_evax_proc.pdsckind
|
2001-01-20 12:23:33 +08:00
|
|
|
|
| ((alpha_evax_proc.framereg == 29) ? PDSC_S_M_BASE_REG_IS_FP : 0);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
*(p + 1) = PDSC_S_M_NATIVE | PDSC_S_M_NO_JACKET;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
switch (alpha_evax_proc.pdsckind)
|
|
|
|
|
{
|
2001-01-20 12:23:33 +08:00
|
|
|
|
case PDSC_S_K_KIND_NULL:
|
2001-01-23 04:24:11 +08:00
|
|
|
|
*(p + 2) = 0;
|
|
|
|
|
*(p + 3) = 0;
|
2001-01-20 12:23:33 +08:00
|
|
|
|
break;
|
|
|
|
|
case PDSC_S_K_KIND_FP_REGISTER:
|
2001-01-23 04:24:11 +08:00
|
|
|
|
*(p + 2) = alpha_evax_proc.fp_save;
|
|
|
|
|
*(p + 3) = alpha_evax_proc.ra_save;
|
2001-01-20 12:23:33 +08:00
|
|
|
|
break;
|
|
|
|
|
case PDSC_S_K_KIND_FP_STACK:
|
2001-01-23 04:24:11 +08:00
|
|
|
|
md_number_to_chars (p + 2, (valueT) alpha_evax_proc.rsa_offset, 2);
|
2001-01-20 12:23:33 +08:00
|
|
|
|
break;
|
|
|
|
|
default: /* impossible */
|
|
|
|
|
break;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
*(p + 4) = 0;
|
|
|
|
|
*(p + 5) = alpha_evax_proc.type & 0x0f;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* Signature offset. */
|
2001-01-23 04:24:11 +08:00
|
|
|
|
md_number_to_chars (p + 6, (valueT) 0, 2);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
fix_new_exp (frag_now, p - frag_now->fr_literal+8, 8, &exp, 0, BFD_RELOC_64);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (alpha_evax_proc.pdsckind == PDSC_S_K_KIND_NULL)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/* Add dummy fix to make add_to_link_pool work. */
|
|
|
|
|
p = frag_more (8);
|
|
|
|
|
fixp = fix_new (frag_now, p - frag_now->fr_literal, 8, 0, 0, 0, 0);
|
|
|
|
|
fixp->fx_done = 1;
|
|
|
|
|
seginfo->literal_pool_size += 8;
|
|
|
|
|
|
|
|
|
|
/* pdesc+16: Size. */
|
2001-01-19 20:03:34 +08:00
|
|
|
|
md_number_to_chars (p, (valueT) alpha_evax_proc.framesize, 4);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
md_number_to_chars (p + 4, (valueT) 0, 2);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* Entry length. */
|
2001-01-23 04:24:11 +08:00
|
|
|
|
md_number_to_chars (p + 6, alpha_evax_proc.prologue, 2);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
if (alpha_evax_proc.pdsckind == PDSC_S_K_KIND_FP_REGISTER)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/* Add dummy fix to make add_to_link_pool work. */
|
|
|
|
|
p = frag_more (8);
|
|
|
|
|
fixp = fix_new (frag_now, p - frag_now->fr_literal, 8, 0, 0, 0, 0);
|
|
|
|
|
fixp->fx_done = 1;
|
|
|
|
|
seginfo->literal_pool_size += 8;
|
|
|
|
|
|
|
|
|
|
/* pdesc+24: register masks. */
|
|
|
|
|
|
|
|
|
|
md_number_to_chars (p, alpha_evax_proc.imask, 4);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
md_number_to_chars (p + 4, alpha_evax_proc.fmask, 4);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Support for crash debug on vms. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_name (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
register char *p;
|
|
|
|
|
expressionS exp;
|
|
|
|
|
segment_info_type *seginfo = seg_info (alpha_link_section);
|
|
|
|
|
|
|
|
|
|
if (now_seg != alpha_link_section)
|
|
|
|
|
{
|
|
|
|
|
as_bad (_(".name directive not in link (.link) section"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
expression (&exp);
|
|
|
|
|
if (exp.X_op != O_symbol)
|
|
|
|
|
{
|
|
|
|
|
as_warn (_(".name directive has no symbol"));
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
#ifdef md_flush_pending_output
|
|
|
|
|
md_flush_pending_output ();
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
frag_align (3, 0, 0);
|
|
|
|
|
p = frag_more (8);
|
|
|
|
|
seginfo->literal_pool_size += 8;
|
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
fix_new_exp (frag_now, p - frag_now->fr_literal, 8, &exp, 0, BFD_RELOC_64);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_linkage (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
expressionS exp;
|
|
|
|
|
char *p;
|
|
|
|
|
|
|
|
|
|
#ifdef md_flush_pending_output
|
|
|
|
|
md_flush_pending_output ();
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
expression (&exp);
|
|
|
|
|
if (exp.X_op != O_symbol)
|
|
|
|
|
{
|
|
|
|
|
as_fatal (_("No symbol after .linkage"));
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
p = frag_more (LKP_S_K_SIZE);
|
|
|
|
|
memset (p, 0, LKP_S_K_SIZE);
|
|
|
|
|
fix_new_exp (frag_now, p - frag_now->fr_literal, LKP_S_K_SIZE, &exp, 0,\
|
|
|
|
|
BFD_RELOC_ALPHA_LINKAGE);
|
|
|
|
|
}
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_code_address (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
expressionS exp;
|
|
|
|
|
char *p;
|
|
|
|
|
|
|
|
|
|
#ifdef md_flush_pending_output
|
|
|
|
|
md_flush_pending_output ();
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
expression (&exp);
|
|
|
|
|
if (exp.X_op != O_symbol)
|
|
|
|
|
{
|
|
|
|
|
as_fatal (_("No symbol after .code_address"));
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
p = frag_more (8);
|
|
|
|
|
memset (p, 0, 8);
|
|
|
|
|
fix_new_exp (frag_now, p - frag_now->fr_literal, 8, &exp, 0,\
|
|
|
|
|
BFD_RELOC_ALPHA_CODEADDR);
|
|
|
|
|
}
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_fp_save (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
alpha_evax_proc.fp_save = tc_get_register (1);
|
|
|
|
|
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_mask (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
long val;
|
|
|
|
|
|
|
|
|
|
if (get_absolute_expression_and_terminator (&val) != ',')
|
|
|
|
|
{
|
|
|
|
|
as_warn (_("Bad .mask directive"));
|
|
|
|
|
--input_line_pointer;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
alpha_evax_proc.imask = val;
|
2001-01-19 20:03:34 +08:00
|
|
|
|
(void) get_absolute_expression ();
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_fmask (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
long val;
|
|
|
|
|
|
|
|
|
|
if (get_absolute_expression_and_terminator (&val) != ',')
|
|
|
|
|
{
|
|
|
|
|
as_warn (_("Bad .fmask directive"));
|
|
|
|
|
--input_line_pointer;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
alpha_evax_proc.fmask = val;
|
|
|
|
|
(void) get_absolute_expression ();
|
|
|
|
|
}
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_end (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
char c;
|
|
|
|
|
|
|
|
|
|
c = get_symbol_end ();
|
|
|
|
|
*input_line_pointer = c;
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
alpha_evax_proc.symbol = 0;
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_file (ignore)
|
2002-08-14 21:27:06 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
symbolS *s;
|
|
|
|
|
int length;
|
|
|
|
|
static char case_hack[32];
|
|
|
|
|
|
|
|
|
|
sprintf (case_hack, "<CASE:%01d%01d>",
|
1999-06-06 07:15:34 +08:00
|
|
|
|
alpha_flag_hash_long_names, alpha_flag_show_after_trunc);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
s = symbol_find_or_make (case_hack);
|
1999-06-06 07:15:34 +08:00
|
|
|
|
symbol_get_bfdsym (s)->flags |= BSF_FILE;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
get_absolute_expression ();
|
|
|
|
|
s = symbol_find_or_make (demand_copy_string (&length));
|
1999-06-06 07:15:34 +08:00
|
|
|
|
symbol_get_bfdsym (s)->flags |= BSF_FILE;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
#endif /* OBJ_EVAX */
|
|
|
|
|
|
|
|
|
|
/* Handle the .gprel32 pseudo op. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_gprel32 (ignore)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
expressionS e;
|
|
|
|
|
char *p;
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
expression (&e);
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
switch (e.X_op)
|
|
|
|
|
{
|
|
|
|
|
case O_constant:
|
2001-01-19 20:03:34 +08:00
|
|
|
|
e.X_add_symbol = section_symbol (absolute_section);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
e.X_op = O_symbol;
|
|
|
|
|
/* FALLTHRU */
|
|
|
|
|
case O_symbol:
|
|
|
|
|
break;
|
|
|
|
|
default:
|
2000-12-03 14:49:23 +08:00
|
|
|
|
abort ();
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
switch (e.X_op)
|
|
|
|
|
{
|
|
|
|
|
case O_constant:
|
|
|
|
|
e.X_add_symbol = section_symbol (absolute_section);
|
|
|
|
|
/* fall through */
|
|
|
|
|
case O_symbol:
|
|
|
|
|
e.X_op = O_subtract;
|
|
|
|
|
e.X_op_symbol = alpha_gp_symbol;
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
abort ();
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
if (alpha_auto_align_on && alpha_current_align < 2)
|
|
|
|
|
alpha_align (2, (char *) NULL, alpha_insn_label, 0);
|
|
|
|
|
if (alpha_current_align > 2)
|
|
|
|
|
alpha_current_align = 2;
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
|
|
|
|
|
p = frag_more (4);
|
|
|
|
|
memset (p, 0, 4);
|
2001-01-23 04:24:11 +08:00
|
|
|
|
fix_new_exp (frag_now, p - frag_now->fr_literal, 4,
|
1999-05-03 15:29:11 +08:00
|
|
|
|
&e, 0, BFD_RELOC_GPREL32);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle floating point allocation pseudo-ops. This is like the
|
|
|
|
|
generic vresion, but it makes sure the current label, if any, is
|
|
|
|
|
correctly aligned. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_float_cons (type)
|
|
|
|
|
int type;
|
|
|
|
|
{
|
|
|
|
|
int log_size;
|
|
|
|
|
|
|
|
|
|
switch (type)
|
|
|
|
|
{
|
|
|
|
|
default:
|
|
|
|
|
case 'f':
|
|
|
|
|
case 'F':
|
|
|
|
|
log_size = 2;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'd':
|
|
|
|
|
case 'D':
|
|
|
|
|
case 'G':
|
|
|
|
|
log_size = 3;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'x':
|
|
|
|
|
case 'X':
|
|
|
|
|
case 'p':
|
|
|
|
|
case 'P':
|
|
|
|
|
log_size = 4;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (alpha_auto_align_on && alpha_current_align < log_size)
|
|
|
|
|
alpha_align (log_size, (char *) NULL, alpha_insn_label, 0);
|
|
|
|
|
if (alpha_current_align > log_size)
|
|
|
|
|
alpha_current_align = log_size;
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
|
|
|
|
|
float_cons (type);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle the .proc pseudo op. We don't really do much with it except
|
|
|
|
|
parse it. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_proc (is_static)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int is_static ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
char *name;
|
|
|
|
|
char c;
|
|
|
|
|
char *p;
|
|
|
|
|
symbolS *symbolP;
|
|
|
|
|
int temp;
|
|
|
|
|
|
|
|
|
|
/* Takes ".proc name,nargs" */
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
name = input_line_pointer;
|
|
|
|
|
c = get_symbol_end ();
|
|
|
|
|
p = input_line_pointer;
|
|
|
|
|
symbolP = symbol_find_or_make (name);
|
|
|
|
|
*p = c;
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
if (*input_line_pointer != ',')
|
|
|
|
|
{
|
|
|
|
|
*p = 0;
|
|
|
|
|
as_warn (_("Expected comma after name \"%s\""), name);
|
|
|
|
|
*p = c;
|
|
|
|
|
temp = 0;
|
|
|
|
|
ignore_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
input_line_pointer++;
|
|
|
|
|
temp = get_absolute_expression ();
|
|
|
|
|
}
|
1999-06-22 22:53:01 +08:00
|
|
|
|
/* *symbol_get_obj (symbolP) = (signed char) temp; */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
as_warn (_("unhandled: .proc %s,%d"), name, temp);
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle the .set pseudo op. This is used to turn on and off most of
|
|
|
|
|
the assembler features. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_set (x)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int x ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
char *name, ch, *s;
|
|
|
|
|
int yesno = 1;
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
name = input_line_pointer;
|
|
|
|
|
ch = get_symbol_end ();
|
|
|
|
|
|
|
|
|
|
s = name;
|
|
|
|
|
if (s[0] == 'n' && s[1] == 'o')
|
|
|
|
|
{
|
|
|
|
|
yesno = 0;
|
|
|
|
|
s += 2;
|
|
|
|
|
}
|
|
|
|
|
if (!strcmp ("reorder", s))
|
|
|
|
|
/* ignore */ ;
|
|
|
|
|
else if (!strcmp ("at", s))
|
|
|
|
|
alpha_noat_on = !yesno;
|
|
|
|
|
else if (!strcmp ("macro", s))
|
|
|
|
|
alpha_macros_on = yesno;
|
|
|
|
|
else if (!strcmp ("move", s))
|
|
|
|
|
/* ignore */ ;
|
|
|
|
|
else if (!strcmp ("volatile", s))
|
|
|
|
|
/* ignore */ ;
|
|
|
|
|
else
|
|
|
|
|
as_warn (_("Tried to .set unrecognized mode `%s'"), name);
|
|
|
|
|
|
|
|
|
|
*input_line_pointer = ch;
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle the .base pseudo op. This changes the assembler's notion of
|
|
|
|
|
the $gp register. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_base (ignore)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
#if 0
|
|
|
|
|
if (first_32bit_quadrant)
|
|
|
|
|
{
|
|
|
|
|
/* not fatal, but it might not work in the end */
|
|
|
|
|
as_warn (_("File overrides no-base-register option."));
|
|
|
|
|
first_32bit_quadrant = 0;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
if (*input_line_pointer == '$')
|
|
|
|
|
{ /* $rNN form */
|
|
|
|
|
input_line_pointer++;
|
|
|
|
|
if (*input_line_pointer == 'r')
|
|
|
|
|
input_line_pointer++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
alpha_gp_register = get_absolute_expression ();
|
|
|
|
|
if (alpha_gp_register < 0 || alpha_gp_register > 31)
|
|
|
|
|
{
|
|
|
|
|
alpha_gp_register = AXP_REG_GP;
|
|
|
|
|
as_warn (_("Bad base register, using $%d."), alpha_gp_register);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Handle the .align pseudo-op. This aligns to a power of two. It
|
|
|
|
|
also adjusts any current instruction label. We treat this the same
|
|
|
|
|
way the MIPS port does: .align 0 turns off auto alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_align (ignore)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ignore ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
int align;
|
|
|
|
|
char fill, *pfill;
|
|
|
|
|
long max_alignment = 15;
|
|
|
|
|
|
|
|
|
|
align = get_absolute_expression ();
|
|
|
|
|
if (align > max_alignment)
|
|
|
|
|
{
|
|
|
|
|
align = max_alignment;
|
|
|
|
|
as_bad (_("Alignment too large: %d. assumed"), align);
|
|
|
|
|
}
|
|
|
|
|
else if (align < 0)
|
|
|
|
|
{
|
|
|
|
|
as_warn (_("Alignment negative: 0 assumed"));
|
|
|
|
|
align = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (*input_line_pointer == ',')
|
|
|
|
|
{
|
|
|
|
|
input_line_pointer++;
|
|
|
|
|
fill = get_absolute_expression ();
|
|
|
|
|
pfill = &fill;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
pfill = NULL;
|
|
|
|
|
|
|
|
|
|
if (align != 0)
|
|
|
|
|
{
|
|
|
|
|
alpha_auto_align_on = 1;
|
|
|
|
|
alpha_align (align, pfill, alpha_insn_label, 1);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
alpha_auto_align_on = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Hook the normal string processor to reset known alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_stringer (terminate)
|
|
|
|
|
int terminate;
|
|
|
|
|
{
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
stringer (terminate);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Hook the normal space processing to reset known alignment. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_space (ignore)
|
|
|
|
|
int ignore;
|
|
|
|
|
{
|
|
|
|
|
alpha_current_align = 0;
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
s_space (ignore);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Hook into cons for auto-alignment. */
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
alpha_cons_align (size)
|
|
|
|
|
int size;
|
|
|
|
|
{
|
|
|
|
|
int log_size;
|
|
|
|
|
|
|
|
|
|
log_size = 0;
|
|
|
|
|
while ((size >>= 1) != 0)
|
|
|
|
|
++log_size;
|
|
|
|
|
|
|
|
|
|
if (alpha_auto_align_on && alpha_current_align < log_size)
|
|
|
|
|
alpha_align (log_size, (char *) NULL, alpha_insn_label, 0);
|
|
|
|
|
if (alpha_current_align > log_size)
|
|
|
|
|
alpha_current_align = log_size;
|
|
|
|
|
alpha_insn_label = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Here come the .uword, .ulong, and .uquad explicitly unaligned
|
|
|
|
|
pseudos. We just turn off auto-alignment and call down to cons. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_ucons (bytes)
|
|
|
|
|
int bytes;
|
|
|
|
|
{
|
|
|
|
|
int hold = alpha_auto_align_on;
|
|
|
|
|
alpha_auto_align_on = 0;
|
|
|
|
|
cons (bytes);
|
|
|
|
|
alpha_auto_align_on = hold;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Switch the working cpu type. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
s_alpha_arch (ignored)
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int ignored ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
char *name, ch;
|
|
|
|
|
const struct cpu_type *p;
|
|
|
|
|
|
|
|
|
|
SKIP_WHITESPACE ();
|
|
|
|
|
name = input_line_pointer;
|
|
|
|
|
ch = get_symbol_end ();
|
|
|
|
|
|
|
|
|
|
for (p = cpu_types; p->name; ++p)
|
2001-01-19 20:03:34 +08:00
|
|
|
|
if (strcmp (name, p->name) == 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
2001-01-20 12:23:33 +08:00
|
|
|
|
alpha_target_name = p->name, alpha_target = p->flags;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
goto found;
|
|
|
|
|
}
|
2001-01-19 20:03:34 +08:00
|
|
|
|
as_warn ("Unknown CPU identifier `%s'", name);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
found:
|
|
|
|
|
*input_line_pointer = ch;
|
|
|
|
|
demand_empty_rest_of_line ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef DEBUG1
|
|
|
|
|
/* print token expression with alpha specific extension. */
|
|
|
|
|
|
|
|
|
|
static void
|
2001-01-19 20:03:34 +08:00
|
|
|
|
alpha_print_token (f, exp)
|
2001-01-20 12:23:33 +08:00
|
|
|
|
FILE *f;
|
|
|
|
|
const expressionS *exp;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
switch (exp->X_op)
|
|
|
|
|
{
|
2001-01-20 12:23:33 +08:00
|
|
|
|
case O_cpregister:
|
|
|
|
|
putc (',', f);
|
|
|
|
|
/* FALLTHRU */
|
|
|
|
|
case O_pregister:
|
|
|
|
|
putc ('(', f);
|
|
|
|
|
{
|
|
|
|
|
expressionS nexp = *exp;
|
|
|
|
|
nexp.X_op = O_register;
|
|
|
|
|
print_expr (f, &nexp);
|
|
|
|
|
}
|
|
|
|
|
putc (')', f);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
print_expr (f, exp);
|
|
|
|
|
break;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
}
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* The target specific pseudo-ops which we support. */
|
|
|
|
|
|
2001-01-23 04:24:11 +08:00
|
|
|
|
const pseudo_typeS md_pseudo_table[] = {
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
{"comm", s_alpha_comm, 0}, /* osf1 compiler does this */
|
|
|
|
|
{"rdata", s_alpha_rdata, 0},
|
|
|
|
|
#endif
|
|
|
|
|
{"text", s_alpha_text, 0},
|
|
|
|
|
{"data", s_alpha_data, 0},
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
{"sdata", s_alpha_sdata, 0},
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
{"section", s_alpha_section, 0},
|
|
|
|
|
{"section.s", s_alpha_section, 0},
|
|
|
|
|
{"sect", s_alpha_section, 0},
|
|
|
|
|
{"sect.s", s_alpha_section, 0},
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_EVAX
|
|
|
|
|
{ "pdesc", s_alpha_pdesc, 0},
|
|
|
|
|
{ "name", s_alpha_name, 0},
|
|
|
|
|
{ "linkage", s_alpha_linkage, 0},
|
|
|
|
|
{ "code_address", s_alpha_code_address, 0},
|
|
|
|
|
{ "ent", s_alpha_ent, 0},
|
|
|
|
|
{ "frame", s_alpha_frame, 0},
|
|
|
|
|
{ "fp_save", s_alpha_fp_save, 0},
|
|
|
|
|
{ "mask", s_alpha_mask, 0},
|
|
|
|
|
{ "fmask", s_alpha_fmask, 0},
|
|
|
|
|
{ "end", s_alpha_end, 0},
|
|
|
|
|
{ "file", s_alpha_file, 0},
|
|
|
|
|
{ "rdata", s_alpha_section, 1},
|
|
|
|
|
{ "comm", s_alpha_comm, 0},
|
|
|
|
|
{ "link", s_alpha_section, 3},
|
|
|
|
|
{ "ctors", s_alpha_section, 4},
|
|
|
|
|
{ "dtors", s_alpha_section, 5},
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
/* Frame related pseudos. */
|
|
|
|
|
{"ent", s_alpha_ent, 0},
|
|
|
|
|
{"end", s_alpha_end, 0},
|
|
|
|
|
{"mask", s_alpha_mask, 0},
|
|
|
|
|
{"fmask", s_alpha_mask, 1},
|
|
|
|
|
{"frame", s_alpha_frame, 0},
|
|
|
|
|
{"prologue", s_alpha_prologue, 0},
|
2000-11-17 16:47:52 +08:00
|
|
|
|
{"file", s_alpha_file, 5},
|
|
|
|
|
{"loc", s_alpha_loc, 9},
|
2000-11-18 02:07:33 +08:00
|
|
|
|
{"stabs", s_alpha_stab, 's'},
|
|
|
|
|
{"stabn", s_alpha_stab, 'n'},
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* COFF debugging related pseudos. */
|
|
|
|
|
{"begin", s_alpha_coff_wrapper, 0},
|
|
|
|
|
{"bend", s_alpha_coff_wrapper, 1},
|
|
|
|
|
{"def", s_alpha_coff_wrapper, 2},
|
|
|
|
|
{"dim", s_alpha_coff_wrapper, 3},
|
|
|
|
|
{"endef", s_alpha_coff_wrapper, 4},
|
2000-11-17 16:47:52 +08:00
|
|
|
|
{"scl", s_alpha_coff_wrapper, 5},
|
|
|
|
|
{"tag", s_alpha_coff_wrapper, 6},
|
|
|
|
|
{"val", s_alpha_coff_wrapper, 7},
|
1999-05-03 15:29:11 +08:00
|
|
|
|
#else
|
|
|
|
|
{"prologue", s_ignore, 0},
|
|
|
|
|
#endif
|
|
|
|
|
{"gprel32", s_alpha_gprel32, 0},
|
|
|
|
|
{"t_floating", s_alpha_float_cons, 'd'},
|
|
|
|
|
{"s_floating", s_alpha_float_cons, 'f'},
|
|
|
|
|
{"f_floating", s_alpha_float_cons, 'F'},
|
|
|
|
|
{"g_floating", s_alpha_float_cons, 'G'},
|
|
|
|
|
{"d_floating", s_alpha_float_cons, 'D'},
|
|
|
|
|
|
|
|
|
|
{"proc", s_alpha_proc, 0},
|
|
|
|
|
{"aproc", s_alpha_proc, 1},
|
|
|
|
|
{"set", s_alpha_set, 0},
|
|
|
|
|
{"reguse", s_ignore, 0},
|
|
|
|
|
{"livereg", s_ignore, 0},
|
|
|
|
|
{"base", s_alpha_base, 0}, /*??*/
|
|
|
|
|
{"option", s_ignore, 0},
|
|
|
|
|
{"aent", s_ignore, 0},
|
|
|
|
|
{"ugen", s_ignore, 0},
|
|
|
|
|
{"eflag", s_ignore, 0},
|
|
|
|
|
|
|
|
|
|
{"align", s_alpha_align, 0},
|
|
|
|
|
{"double", s_alpha_float_cons, 'd'},
|
|
|
|
|
{"float", s_alpha_float_cons, 'f'},
|
|
|
|
|
{"single", s_alpha_float_cons, 'f'},
|
|
|
|
|
{"ascii", s_alpha_stringer, 0},
|
|
|
|
|
{"asciz", s_alpha_stringer, 1},
|
|
|
|
|
{"string", s_alpha_stringer, 1},
|
|
|
|
|
{"space", s_alpha_space, 0},
|
|
|
|
|
{"skip", s_alpha_space, 0},
|
|
|
|
|
{"zero", s_alpha_space, 0},
|
|
|
|
|
|
|
|
|
|
/* Unaligned data pseudos. */
|
|
|
|
|
{"uword", s_alpha_ucons, 2},
|
|
|
|
|
{"ulong", s_alpha_ucons, 4},
|
|
|
|
|
{"uquad", s_alpha_ucons, 8},
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
/* Dwarf wants these versions of unaligned. */
|
|
|
|
|
{"2byte", s_alpha_ucons, 2},
|
|
|
|
|
{"4byte", s_alpha_ucons, 4},
|
|
|
|
|
{"8byte", s_alpha_ucons, 8},
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* We don't do any optimizing, so we can safely ignore these. */
|
|
|
|
|
{"noalias", s_ignore, 0},
|
|
|
|
|
{"alias", s_ignore, 0},
|
|
|
|
|
|
|
|
|
|
{"arch", s_alpha_arch, 0},
|
|
|
|
|
|
|
|
|
|
{NULL, 0, 0},
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Build a BFD section with its flags set appropriately for the .lita,
|
|
|
|
|
.lit8, or .lit4 sections. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
create_literal_section (name, secp, symp)
|
|
|
|
|
const char *name;
|
|
|
|
|
segT *secp;
|
|
|
|
|
symbolS **symp;
|
|
|
|
|
{
|
|
|
|
|
segT current_section = now_seg;
|
|
|
|
|
int current_subsec = now_subseg;
|
|
|
|
|
segT new_sec;
|
|
|
|
|
|
|
|
|
|
*secp = new_sec = subseg_new (name, 0);
|
|
|
|
|
subseg_set (current_section, current_subsec);
|
|
|
|
|
bfd_set_section_alignment (stdoutput, new_sec, 4);
|
|
|
|
|
bfd_set_section_flags (stdoutput, new_sec,
|
|
|
|
|
SEC_RELOC | SEC_ALLOC | SEC_LOAD | SEC_READONLY
|
|
|
|
|
| SEC_DATA);
|
|
|
|
|
|
|
|
|
|
S_CLEAR_EXTERNAL (*symp = section_symbol (new_sec));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef OBJ_ECOFF
|
|
|
|
|
|
|
|
|
|
/* @@@ GP selection voodoo. All of this seems overly complicated and
|
|
|
|
|
unnecessary; which is the primary reason it's for ECOFF only. */
|
2002-08-14 21:27:06 +08:00
|
|
|
|
static inline void maybe_set_gp PARAMS ((asection *));
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
|
maybe_set_gp (sec)
|
|
|
|
|
asection *sec;
|
|
|
|
|
{
|
|
|
|
|
bfd_vma vma;
|
|
|
|
|
if (!sec)
|
|
|
|
|
return;
|
|
|
|
|
vma = bfd_get_section_vma (foo, sec);
|
|
|
|
|
if (vma && vma < alpha_gp_value)
|
|
|
|
|
alpha_gp_value = vma;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
select_gp_value ()
|
|
|
|
|
{
|
|
|
|
|
assert (alpha_gp_value == 0);
|
|
|
|
|
|
|
|
|
|
/* Get minus-one in whatever width... */
|
2001-01-23 04:24:11 +08:00
|
|
|
|
alpha_gp_value = 0;
|
|
|
|
|
alpha_gp_value--;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
|
|
/* Select the smallest VMA of these existing sections. */
|
|
|
|
|
maybe_set_gp (alpha_lita_section);
|
|
|
|
|
#if 0
|
|
|
|
|
/* These were disabled before -- should we use them? */
|
|
|
|
|
maybe_set_gp (sdata);
|
|
|
|
|
maybe_set_gp (lit8_sec);
|
|
|
|
|
maybe_set_gp (lit4_sec);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/* @@ Will a simple 0x8000 work here? If not, why not? */
|
|
|
|
|
#define GP_ADJUSTMENT (0x8000 - 0x10)
|
|
|
|
|
|
|
|
|
|
alpha_gp_value += GP_ADJUSTMENT;
|
|
|
|
|
|
|
|
|
|
S_SET_VALUE (alpha_gp_symbol, alpha_gp_value);
|
|
|
|
|
|
|
|
|
|
#ifdef DEBUG1
|
|
|
|
|
printf (_("Chose GP value of %lx\n"), alpha_gp_value);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
#endif /* OBJ_ECOFF */
|
|
|
|
|
|
2001-09-12 02:26:04 +08:00
|
|
|
|
#ifdef OBJ_ELF
|
|
|
|
|
/* Map 's' to SHF_ALPHA_GPREL. */
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
alpha_elf_section_letter (letter, ptr_msg)
|
|
|
|
|
int letter;
|
|
|
|
|
char **ptr_msg;
|
|
|
|
|
{
|
|
|
|
|
if (letter == 's')
|
|
|
|
|
return SHF_ALPHA_GPREL;
|
|
|
|
|
|
* elf.c (_bfd_elf_make_section_from_shdr): Set SEC_THREAD_LOCAL
for symbols from SHF_TLS section.
(_bfd_elf_print_private_bfd_data): Add PT_TLS.
(elf_fake_sections): Set SHF_TLS for SEC_THREAD_LOCAL sections.
(map_sections_to_segments): Build PT_TLS segment if necessary.
(assign_file_positions_for_segments): Likewise.
(get_program_header_size): Account for PT_TLS segment.
(swap_out_syms): Set type of BSF_THREAD_LOCAL symbols and symbols from
SEC_THREAD_LOCAL sections to STT_TLS.
* reloc.c: Add 386 and IA-64 TLS relocs.
* section.c (SEC_THREAD_LOCAL): Define.
(SEC_CONSTRUCTOR_TEXT, SEC_CONSTRUCTOR_DATA, SEC_CONSTRUCTOR_BSS):
Remove.
* elflink.h (elf_link_add_object_symbols): Support .tcommon.
(size_dynamic_sections): If DF_STATIC_TLS, set DF_FLAGS
unconditionally.
(struct elf_final_link_info): Add first_tls_sec.
(elf_bfd_final_link): Set first_tls_sec.
Compute elf_hash_table (info)->tls_segment.
(elf_link_output_extsym): Handle STT_TLS symbols.
(elf_link_input_bfd): Likewise.
* syms.c (BSF_THREAD_LOCAL): Define.
* bfd-in2.h: Rebuilt.
* libbfd.h: Rebuilt.
* elf32-i386.c (elf_i386_tls_transition, dtpoff_base, tpoff,
elf_i386_mkobject, elf_i386_object_p): New functions.
(elf_howto_table): Add TLS relocs.
(elf_i386_reloc_type_lookup): Support TLS relocs.
(elf_i386_info_to_howto_rel): Likewise.
(struct elf_i386_link_hash_entry): Add tls_type.
(struct elf_i386_obj_tdata): New.
(elf_i386_hash_entry, elf_i386_tdata, elf_i386_local_got_tls_type):
New macros.
(struct elf_i386_link_hash_table): Add tls_ldm_got.
(link_hash_newfunc): Clear tls_type.
(elf_i386_check_relocs): Support TLS relocs.
(elf_i386_gc_sweep_hook): Likewise.
(allocate_dynrelocs): Likewise.
(elf_i386_size_dynamic_sections): Likewise.
(elf_i386_relocate_section): Likewise.
(elf_i386_finish_dynamic_symbol): Likewise.
(bfd_elf32_mkobject, elf_backend_object_p): Define.
* elfxx-ia64.c (struct elfNN_ia64_dyn_sym_info): Add tprel_offset,
dtpmod_offset, dtprel_offset, tprel_done, dtpmod_done, dtprel_done,
want_tprel, want_dtpmod, want_dtprel.
(elfNN_ia64_tprel_base, elfNN_ia64_dtprel_base): New functions.
(ia64_howto_table): Add TLS relocs, rename R_IA64_LTOFF_TP22 to
R_IA64_LTOFF_TPREL22.
(elf_code_to_howto_index): Add TLS relocs.
(elfNN_ia64_check_relocs): Support TLS relocs.
(allocate_global_data_got): Account for TLS .got data.
(allocate_dynrel_entries): Account for TLS dynamic relocations.
(elfNN_ia64_install_value): Supprt TLS relocs.
(set_got_entry): Support TLS relocs.
(elfNN_ia64_relocate_section): Likewise.
* config/obj-elf.c (elf_common): Renamed from obj_elf_common.
(obj_elf_common): Call elf_common.
(obj_elf_tls_common): New function.
(elf_pseudo_tab): Support .tls_common.
(special_sections): Add .tdata and .tbss.
(obj_elf_change_section): Set SEC_THREAD_LOCAL for SHF_TLS
sections.
(obj_elf_parse_section_letters): Support T in section flags (SHF_TLS).
(obj_elf_parse_section_letters): Include T in error message.
* config/tc-ppc.c (ppc_section_letter): Likewise.
* config/tc-alpha.c (alpha_elf_section_letter): Likewise.
(tc_gen_reloc): Handle SEC_THREAD_LOCAL the same way as
SEC_MERGE.
* config/tc-sparc.c (md_apply_fix3): Likewise.
* config/tc-i386.c (tc_i386_fix_adjustable): Add TLS relocs.
Define them if not BFD_ASSEMBLER.
(lex_got): Support @TLSGD, @TLSLDM, @GOTTPOFF, @TPOFF, @DTPOFF
and @NTPOFF.
(md_apply_fix3): Add TLS relocs.
* config/tc-ia64.c (enum reloc_func): Add FUNC_DTP_MODULE,
FUNC_DTP_RELATIVE, FUNC_TP_RELATIVE, FUNC_LT_DTP_MODULE,
FUNC_LT_DTP_RELATIVE, FUNC_LT_TP_RELATIVE.
(pseudo_func): Support @dtpmod(), @dtprel() and @tprel().
(ia64_elf_section_letter): Include T in error message.
(md_begin): Support TLS operators.
(md_operand): Likewise.
(ia64_gen_real_reloc_type): Support TLS relocs.
* testsuite/gas/i386/tlspic.s: New file.
* testsuite/gas/i386/tlsd.s: New file.
* testsuite/gas/i386/tlsnopic.s: New file.
* testsuite/gas/i386/tlsd.d: New file.
* testsuite/gas/i386/tlsnopic.d: New file.
* testsuite/gas/i386/tlspic.d: New file.
* testsuite/gas/i386/i386.exp: Add tlsd, tlsnopic and tlspic tests.
* testsuite/gas/ia64/tls.s: New file.
* testsuite/gas/ia64/tls.d: New file.
* testsuite/gas/ia64/ia64.exp: Add tls test.
* write.c (adjust_reloc_syms): Don't change symbols in
SEC_THREAD_LOCAL sections to STT_SECTION + addend.
* elf/common.h (PT_TLS, SHF_TLS, STT_TLS, DF_STATIC_TLS): Define.
* elf/ia64.h (R_IA64_LTOFF_TPREL22): Renamed from R_IA64_LTOFF_TP22.
* elf/i386.h: Add TLS relocs.
* scripttempl/elf.sc: Add .rel{,a}.t{bss,data}, .tdata and .tbss.
* ldlang.c (lang_add_section): Set SEC_THREAD_LOCAL for
output section if necessary. Handle .tbss.
(lang_size_sections): Clear _raw_size for .tbss section
(it allocates space in PT_TLS segment only).
* ldwrite.c (build_link_order): Build link order for .tbss too.
* readelf.c (get_segment_type): Add PT_TLS.
(get_elf_section_flags): Add SHF_TLS.
(get_dynamic_flags): Optimize. Add DF_STATIC_TLS.
(process_dynamic_segment): Use puts instead of printf.
(get_symbol_type): Support STT_TLS.
* objdump.c (dump_section_header): Remove SEC_CONSTRUCTOR_TEXT,
SEC_CONSTRUCTOR_DATA, SEC_CONSTRUCTOR_BSS.
Add SEC_THREAD_LOCAL.
2002-05-23 21:12:53 +08:00
|
|
|
|
*ptr_msg = _("Bad .section directive: want a,s,w,x,M,S,G,T in string");
|
2003-05-04 00:04:12 +08:00
|
|
|
|
return -1;
|
2001-09-12 02:26:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Map SHF_ALPHA_GPREL to SEC_SMALL_DATA. */
|
|
|
|
|
|
|
|
|
|
flagword
|
|
|
|
|
alpha_elf_section_flags (flags, attr, type)
|
|
|
|
|
flagword flags;
|
|
|
|
|
int attr, type ATTRIBUTE_UNUSED;
|
|
|
|
|
{
|
|
|
|
|
if (attr & SHF_ALPHA_GPREL)
|
|
|
|
|
flags |= SEC_SMALL_DATA;
|
|
|
|
|
return flags;
|
|
|
|
|
}
|
|
|
|
|
#endif /* OBJ_ELF */
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* Called internally to handle all alignment needs. This takes care
|
|
|
|
|
of eliding calls to frag_align if'n the cached current alignment
|
|
|
|
|
says we've already got it, as well as taking care of the auto-align
|
|
|
|
|
feature wrt labels. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
alpha_align (n, pfill, label, force)
|
|
|
|
|
int n;
|
|
|
|
|
char *pfill;
|
|
|
|
|
symbolS *label;
|
1999-10-19 06:29:15 +08:00
|
|
|
|
int force ATTRIBUTE_UNUSED;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
|
|
|
|
if (alpha_current_align >= n)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
if (pfill == NULL)
|
|
|
|
|
{
|
2000-12-28 18:07:56 +08:00
|
|
|
|
if (subseg_text_p (now_seg))
|
|
|
|
|
frag_align_code (n, 0);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
else
|
|
|
|
|
frag_align (n, 0, 0);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
frag_align (n, *pfill, 0);
|
|
|
|
|
|
|
|
|
|
alpha_current_align = n;
|
|
|
|
|
|
1999-11-08 08:44:52 +08:00
|
|
|
|
if (label != NULL && S_GET_SEGMENT (label) == now_seg)
|
1999-05-03 15:29:11 +08:00
|
|
|
|
{
|
Add support for storing local symbols in a small structure to save
memory when assembling large files.
* as.h: Don't include struc-symbol.h.
(symbolS): Add typedef.
* symbols.c: Include struc-symbol.h.
(local_hash): New static variable.
(save_symbol_name): New static function, from symbol_create.
(symbol_create): Call save_symbol_name.
(local_symbol_count): New static variable.
(local_symbol_conversion_count): Likewise.
(LOCAL_SYMBOL_CHECK): Define.
(local_symbol_make): New static function.
(local_symbol_convert): New static function.
(colon): Handle local symbols. Create local symbol for local
label name.
(symbol_table_insert): Handle local symbols.
(symbol_find_or_make): Create local symbol for local label name.
(symbol_find_base): Check for local symbol.
(symbol_append, symbol_insert): Check for local symbols.
(symbol_clear_list_pointers, symbol_remove): Likewise.
(verify_symbol_chain): Likewise.
(copy_symbol_attributes): Likewise.
(resolve_symbol_value): Handle local symbols.
(resolve_local_symbol): New static function.
(resolve_local_symbol_values): New function.
(S_GET_VALUE, S_SET_VALUE): Handle local symbols.
(S_IS_FUNCTION, S_IS_EXTERNAL, S_IS_WEAK, S_IS_COMMON): Likewise.
(S_IS_DEFINED, S_IS_DEBUG, S_IS_LOCAL, S_GET_NAME): Likewise.
(S_GET_SEGMENT, S_SET_SEGMENT, S_SET_EXTERNAL): Likewise.
(S_CLEAR_EXTERNAL, S_SET_WEAK, S_SET_NAME): Likewise.
(symbol_previous, symbol_next): New functions.
(symbol_get_value_expression): Likewise.
(symbol_set_value_expression): Likewise.
(symbol_set_frag, symbol_get_frag): Likewise.
(symbol_mark_used, symbol_clear_used, symbol_used_p): Likewise.
(symbol_mark_used_in_reloc): Likewise.
(symbol_clear_used_in_reloc, symbol_used_in_reloc_p): Likewise.
(symbol_mark_mri_common, symbol_clear_mri_common): Likewise.
(symbol_mri_common_p): Likewise.
(symbol_mark_written, symbol_clear_written): Likewise.
(symbol_written_p): Likewise.
(symbol_mark_resolved, symbol_resolved_p): Likewise.
(symbol_section_p, symbol_equated_p): Likewise.
(symbol_constant_p): Likewise.
(symbol_get_bfdsym, symbol_set_bfdsym): Likewise.
(symbol_get_obj, symbol_set_obj): Likewise.
(symbol_get_tc, symbol_set_tc): Likewise.
(symbol_begin): Initialize local_hash.
(print_symbol_value_1): Handle local symbols.
(symbol_print_statistics): Print local symbol statistics.
* symbols.h: Include "struc-symbol.h" if not BFD_ASSEMBLER.
Declare new symbols.c functions. Move many declarations here from
struc-symbol.h.
(SYMBOLS_NEED_BACKPOINTERS): Define if needed.
* struc-symbol.h (SYMBOLS_NEED_BACKPOINTERS): Don't set.
(struct symbol): Move bsym to make it clearly the first field.
Remove TARGET_SYMBOL_FIELDS.
(symbolS): Don't typedef.
(struct broken_word): Remove.
(N_TYPE_seg, seg_N_TYPE): Move to symbol.h.
(SEGMENT_TO_SYMBOL_TYPE, N_REGISTER): Likewise.
(symbol_clear_list_pointers): Likewise.
(symbol_insert, symbol_remove): Likewise.
(symbol_previous, symbol_append): Likewise.
(verify_symbol_chain, verify_symbol_chain_2): Likewise.
(struct local_symbol): Define.
(local_symbol_converted_p, local_symbol_mark_converted): Define.
(local_symbol_resolved_p, local_symbol_mark_resolved): Define.
(local_symbol_get_frag, local_symbol_set_frag): Define.
(local_symbol_get_real_symbol): Define.
(local_symbol_set_real_symbol): Define.
Define.
* write.c (write_object_file): Call resolve_local_symbol_values.
* config/obj-ecoff.h (OBJ_SYMFIELD_TYPE): Define.
(TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-elf.h (OBJ_SYMFIELD_TYPE): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
* config/obj-multi.h (struct elf_obj_sy): Add local field. If
ECOFF_DEBUGGING, add ECOFF fields.
(ELF_TARGET_SYMBOL_FIELDS, TARGET_SYMBOL_FIELDS): Don't define.
(ECOFF_DEBUG_TARGET_SYMBOL_FIELDS): Don't define.
* config/tc-mcore.h: Don't include struc-symbol.h.
(TARGET_SYMBOL_FIELDS): Don't define.
(struct mcore_tc_sy): Define.
(TC_SYMFIELD_TYPE): Define.
* Many files: Use symbolS instead of struct symbol. Use new
accessor functions rather than referring to symbolS fields
directly.
* read.c (s_mri_common): Don't add in value of line_label.
* config/tc-mips.c (md_apply_fix): Correct parenthesization when
checking for SEC_LINK_ONCE.
* config/tc-sh.h (sh_fix_adjustable): Declare.
1999-06-03 08:29:48 +08:00
|
|
|
|
symbol_set_frag (label, frag_now);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
S_SET_VALUE (label, (valueT) frag_now_fix ());
|
|
|
|
|
}
|
|
|
|
|
|
1999-11-08 08:44:52 +08:00
|
|
|
|
record_alignment (now_seg, n);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
2000-12-28 18:07:56 +08:00
|
|
|
|
/* ??? If alpha_flag_relax && force && elf, record the requested alignment
|
1999-05-03 15:29:11 +08:00
|
|
|
|
in a reloc for the linker to see. */
|
|
|
|
|
}
|
|
|
|
|
|
2000-12-28 18:07:56 +08:00
|
|
|
|
/* This is called from HANDLE_ALIGN in write.c. Fill in the contents
|
|
|
|
|
of an rs_align_code fragment. */
|
|
|
|
|
|
2001-01-15 02:54:06 +08:00
|
|
|
|
void
|
2000-12-28 18:07:56 +08:00
|
|
|
|
alpha_handle_align (fragp)
|
|
|
|
|
fragS *fragp;
|
|
|
|
|
{
|
2001-12-18 08:24:47 +08:00
|
|
|
|
static char const unop[4] = { 0x00, 0x00, 0xfe, 0x2f };
|
2000-12-28 18:07:56 +08:00
|
|
|
|
static char const nopunop[8] = {
|
2001-01-20 12:23:33 +08:00
|
|
|
|
0x1f, 0x04, 0xff, 0x47,
|
2001-12-18 08:24:47 +08:00
|
|
|
|
0x00, 0x00, 0xfe, 0x2f
|
2000-12-28 18:07:56 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
int bytes, fix;
|
|
|
|
|
char *p;
|
|
|
|
|
|
|
|
|
|
if (fragp->fr_type != rs_align_code)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
bytes = fragp->fr_next->fr_address - fragp->fr_address - fragp->fr_fix;
|
|
|
|
|
p = fragp->fr_literal + fragp->fr_fix;
|
|
|
|
|
fix = 0;
|
|
|
|
|
|
|
|
|
|
if (bytes & 3)
|
|
|
|
|
{
|
|
|
|
|
fix = bytes & 3;
|
|
|
|
|
memset (p, 0, fix);
|
|
|
|
|
p += fix;
|
|
|
|
|
bytes -= fix;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (bytes & 4)
|
|
|
|
|
{
|
|
|
|
|
memcpy (p, unop, 4);
|
|
|
|
|
p += 4;
|
|
|
|
|
bytes -= 4;
|
|
|
|
|
fix += 4;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
memcpy (p, nopunop, 8);
|
|
|
|
|
|
|
|
|
|
fragp->fr_fix += fix;
|
|
|
|
|
fragp->fr_var = 8;
|
|
|
|
|
}
|
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
|
/* The Alpha has support for some VAX floating point types, as well as for
|
|
|
|
|
IEEE floating point. We consider IEEE to be the primary floating point
|
|
|
|
|
format, and sneak in the VAX floating point support here. */
|
|
|
|
|
#define md_atof vax_md_atof
|
|
|
|
|
#include "config/atof-vax.c"
|