mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-16 11:31:00 +08:00
96d3d07383
keyword in c++. * bfd/aoutx.h (NAME (aout, make_empty_symbol)): Rename variable new to new_symbol. * bfd/coffgen.c (coff_make_empty_symbol) (coff_bfd_make_debug_symbol): Rename variable new to new_symbol. * bfd/cpu-ia64-opc.c (ext_reg, ins_imms_scaled): Rename variable new to new_insn. * bfd/doc/chew.c (newentry, add_intrinsic): Rename variable new to new_d. * bfd/ecoff.c (_bfd_ecoff_make_empty_symbol): Rename variable new to new_symbol. * bfd/elf32-m68k.c (elf_m68k_get_got_entry_type): Rename argument new to new_reloc. * bfd/hash.c (bfd_hash_lookup): Rename variable new to new_string. * bfd/ieee.c (ieee_make_empty_symbol): Rename variable new to new_symbol. * bfd/linker.c (bfd_new_link_order): Rename variable new to new_lo. * bfd/mach-o.c (bfd_mach_o_sizeof_headers): Rename variable new to symbol. * bfd/oasys.c (oasys_make_empty_symbol): Rename variable new to new_symbol_type. * bfd/pdp11.c (NAME (aout, make_empty_symbol)): Rename variable new to new_symbol_type. * bfd/plugin.c (bfd_plugin_make_empty_symbol): Rename variable new to new_symbol. * bfd/rs6000-core.c (CoreHdr, VmInfo): Rename union member new to new_dump. (read_hdr, rs6000coff_core_p) (rs6000coff_core_file_matches_executable_p) (rs6000coff_core_file_failing_command) (rs6000coff_core_file_failing_signal): Updated function to use new union member name. * bfd/som.c (som_make_empty_symbol): Rename variable new to new_symbol_type. * bfd/syms.c (_bfd_generic_make_empty_symbol): Rename variable new to new_symbol. * bfd/tekhex.c (first_phase, tekhex_make_empty_symbol): Rename variable new to new_symbol. * binutils/nlmconv.c (main): Rename variable new to new_name. * gas/config/tc-arm.c (insert_reg_alias): Rename variable new to new_reg. * gas/config/tc-dlx.c (parse_operand): Rename variable new to new_pos. * gas/config/tc-ia64.c (ia64_gen_real_reloc_type): Rename variable new to newr. * gas/config/tc-mcore.c (parse_exp, parse_imm): Rename variable new to new_pointer. * gas/config/tc-microblaze.c (parse_exp, parse_imm, check_got): Change name from new to new_pointer. * gas/config/tc-or32.c (parse_operand): Rename variable new to new_pointer. * gas/config/tc-pdp11.c (md_assemble): Rename variable new to new_pointer. * gas/config/tc-pj.c (alias): Change argument new to new_name. * gas/config/tc-score.c (s3_build_score_ops_hsh): Rename variable new to new_opcode. (s3_build_dependency_insn_hsh) Rename variable new to new_i2n. (s3_convert): Rename variables old and new to r_old and r_new. * gas/config/tc-score7.c (s7_build_score_ops_hsh): Rename variable new to new_opcode. (s7_build_dependency_insn_hsh): Rename variable new to new_i2d. (s7_b32_relax_to_b16, s7_convert_frag): Rename variables old and new to r_old and r_new. * gas/config/tc-sh.c (parse_exp): Rename variable new to new_pointer. * gas/config/tc-sh64.c (shmedia_parse_exp): Rename variable new to new_pointer. * gas/config/tc-tic4x.c (tic4x_operand_parse): Rename variable new to new_pointer. * gas/config/tc-z8k.c (parse_exp): Rename variable new to new_pointer. * gas/listing.c (listing_newline): Rename variable new to new_i. * ld/ldexp.c (exp_intop, exp_bigintop, exp_relop, exp_binop) (exp_trinop, exp_unop, exp_nameop, exp_assop): Rename variable new to new_e. * ld/ldfile.c (ldfile_add_library_path): Rename variable new to new_dirs. (ldfile_add_arch): Rename variable new to new_arch. * ld/ldlang.c (new_statement, lang_final, lang_add_wild) (lang_target, lang_add_fill, lang_add_data, lang_add_assignment) (lang_add_insert): Rename variable new to new_stmt. (new_afile): Added missing cast. (lang_memory_region_lookup): Rename variable new to new_region. (init_os): Rename variable new to new_userdata. (lang_add_section): Rename variable new to new_section. (ldlang_add_undef): Rename variable new to new_undef. (realsymbol): Rename variable new to new_name. * opcodes/z8kgen.c (internal, gas): Rename variable new to new_op. Updated sources to avoid using the identifier name "template", which is a keyword in c++. * bfd/elf32-arm.c (struct stub_def): Rename member template to template_sequence. (arm_build_one_stub, find_stub_size_and_template, arm_size_one_stub, arm_map_one_stub): Rename variable template to template_sequence. * bfd/elfxx-ia64.c (elfNN_ia64_relax_br, elfNN_ia64_relax_brl): Rename variable template to template_val. * gas/config/tc-arm.c (struct asm_cond, struct asm_psr, struct asm_barrier_opt): Change member template to template_name. (md_begin): Update code to reflect new member names. * gas/config/tc-i386.c (struct templates, struct _i386_insn) (match_template, cpu_flags_match, match_reg_size, match_mem_size) (operand_size_match, md_begin, i386_print_statistics, pi) (build_vex_prefix, md_assemble, parse_insn, optimize_imm) (optimize_disp): Updated code to use new names. (parse_insn): Added casts. * gas/config/tc-ia64.c (dot_template, emit_one_bundle): Updated code to use new names. * gas/config/tc-score.c (struct s3_asm_opcode): Renamed member template to template_name. (s3_parse_16_32_inst, s3_parse_48_inst, s3_do_macro_ldst_label, s3_build_score_ops_hsh): Update code to use new names. * gas/config/tc-score7.c (struct s7_asm_opcode): Renamed member template to template_name. (s7_parse_16_32_inst, s7_do_macro_ldst_label, s7_build_score_ops_hsh): Update code to use new names. * gas/config/tc-tic30.c (md_begin, struct tic30_insn) (md_assemble): Update code to use new names. * gas/config/tc-tic54x.c (struct _tic54x_insn, md_begin) (optimize_insn, tic54x_parse_insn, next_line_shows_parallel): Update code to use new names. * include/opcode/tic30.h (template): Rename type template to insn_template. Updated code to use new name. * include/opcode/tic54x.h (template): Rename type template to insn_template. * opcodes/cris-dis.c (bytes_to_skip): Update code to use new name. * opcodes/i386-dis.c (putop): Update code to use new name. * opcodes/i386-gen.c (process_i386_opcodes): Update code to use new name. * opcodes/i386-opc.h (struct template): Rename struct template to insn_template. Update code accordingly. * opcodes/i386-tbl.h (i386_optab): Update type to use new name. * opcodes/ia64-dis.c (print_insn_ia64): Rename variable template to template_val. * opcodes/tic30-dis.c (struct instruction, get_tic30_instruction): Update code to use new name. * opcodes/tic54x-dis.c (has_lkaddr, get_insn_size) (print_parallel_instruction, print_insn_tic54x, tic54x_get_insn): Update code to use new name. * opcodes/tic54x-opc.c (tic54x_unknown_opcode, tic54x_optab): Update type to new name.
164 lines
5.2 KiB
C
164 lines
5.2 KiB
C
/* tic54x.h -- Header file for TI TMS320C54X opcode table
|
|
Copyright 1999, 2000, 2001 Free Software Foundation, Inc.
|
|
Written by Timothy Wall (twall@cygnus.com)
|
|
|
|
This file is part of GDB, GAS, and the GNU binutils.
|
|
|
|
GDB, GAS, and the GNU binutils are free software; you can redistribute
|
|
them and/or modify them under the terms of the GNU General Public
|
|
License as published by the Free Software Foundation; either version
|
|
1, or (at your option) any later version.
|
|
|
|
GDB, GAS, and the GNU binutils are distributed in the hope that they
|
|
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 this file; see the file COPYING. If not, write to the Free
|
|
Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
|
|
02110-1301, USA. */
|
|
|
|
#ifndef _opcode_tic54x_h_
|
|
#define _opcode_tic54x_h_
|
|
|
|
typedef struct _symbol
|
|
{
|
|
const char *name;
|
|
unsigned short value;
|
|
} symbol;
|
|
|
|
enum optype {
|
|
OPT = 0x8000,
|
|
OP_None = 0x0,
|
|
|
|
OP_Xmem, /* AR3 or AR4, indirect */
|
|
OP_Ymem, /* AR3 or AR4, indirect */
|
|
OP_pmad, /* PROG mem, direct */
|
|
OP_dmad, /* DATA mem, direct */
|
|
OP_Smem,
|
|
OP_Lmem, /* 32-bit single-addressed (direct/indirect) */
|
|
OP_MMR,
|
|
OP_PA,
|
|
OP_Sind,
|
|
OP_xpmad,
|
|
OP_xpmad_ms7,
|
|
OP_MMRX,
|
|
OP_MMRY,
|
|
|
|
OP_SRC1, /* src accumulator in bit 8 */
|
|
OP_SRC, /* src accumulator in bit 9 */
|
|
OP_RND, /* rounded result dst accumulator, opposite of bit 8 */
|
|
OP_DST, /* dst accumulator in bit 8 */
|
|
OP_ARX, /* arX in bits 0-3 */
|
|
OP_SHIFT, /* -16 to 15 (SHIFT), bits 0-4 */
|
|
OP_SHFT, /* 0 to 15 (SHIFT1 in summary), bits 0-3 */
|
|
OP_B, /* ACC B only */
|
|
OP_A, /* ACC A only */
|
|
|
|
OP_lk, /* 16-bit immediate, '#' optional */
|
|
OP_TS,
|
|
OP_k8, /* -128 <= k <= 128 */
|
|
OP_16, /* literal "16" */
|
|
OP_BITC, /* 0 to 16 */
|
|
OP_CC, /* condition code */
|
|
OP_CC2, /* 4-bit condition code */
|
|
OP_CC3, /* 2-bit condition code */
|
|
OP_123, /* 1, 2, or 3 */
|
|
OP_031, /* 0-31, numeric */
|
|
OP_k5, /* 0 to 31 */
|
|
OP_k8u, /* 0 to 255 */
|
|
OP_ASM, /* "ASM" */
|
|
OP_T, /* "T" */
|
|
OP_DP, /* "DP" */
|
|
OP_ARP, /* "ARP" */
|
|
OP_k3, /* 0-7 */
|
|
OP_lku, /* 0 to 65535 */
|
|
OP_N, /* 0/1 or ST0/ST1 */
|
|
OP_SBIT, /* status bit or 0-15 */
|
|
OP_12, /* one or two */
|
|
OP_k9, /* 9 bits of data page (DP) address */
|
|
OP_TRN, /* "TRN" */
|
|
|
|
};
|
|
|
|
typedef struct _template
|
|
{
|
|
/* The opcode mnemonic */
|
|
const char *name;
|
|
unsigned int words; /* insn size in words */
|
|
int minops, maxops; /* min/max operand count */
|
|
/* The significant bits in the opcode. Other bits are zero.
|
|
Instructions with more than 16 bits of opcode store the rest in the upper
|
|
16 bits.
|
|
*/
|
|
unsigned short opcode;
|
|
#define INDIRECT(OP) ((OP)&0x80)
|
|
#define MOD(OP) (((OP)>>3)&0xF)
|
|
#define ARF(OP) ((OP)&0x7)
|
|
#define IS_LKADDR(OP) (INDIRECT(OP) && MOD(OP)>=12)
|
|
#define SRC(OP) ((OP)&0x200)
|
|
#define DST(OP) ((OP)&0x100)
|
|
#define SRC1(OP) ((OP)&0x100)
|
|
#define SHIFT(OP) (((OP)&0x10)?(((OP)&0x1F)-32):((OP)&0x1F))
|
|
#define SHFT(OP) ((OP)&0xF)
|
|
#define ARX(OP) ((OP)&0x7)
|
|
#define XMEM(OP) (((OP)&0x00F0)>>4)
|
|
#define YMEM(OP) ((OP)&0x000F)
|
|
#define XMOD(C) (((C)&0xC)>>2)
|
|
#define XARX(C) (((C)&0x3)+2)
|
|
#define CC3(OP) (((OP)>>8)&0x3)
|
|
#define SBIT(OP) ((OP)&0xF)
|
|
#define MMR(OP) ((OP)&0x7F)
|
|
#define MMRX(OP) ((((OP)>>4)&0xF)+16)
|
|
#define MMRY(OP) (((OP)&0xF)+16)
|
|
|
|
#define OPTYPE(X) ((X)&~OPT)
|
|
|
|
/* Ones in this mask indicate which bits must match the opcode field.
|
|
Zeroes indicate don't care bits (operands and/or opcode options) */
|
|
unsigned short mask;
|
|
|
|
/* An array of operand codes (at most 4 operands) */
|
|
#define MAX_OPERANDS 4
|
|
enum optype operand_types[MAX_OPERANDS];
|
|
|
|
/* Special purpose flags (e.g. branch type, parallel, delay, etc)
|
|
*/
|
|
unsigned short flags;
|
|
#define B_NEXT 0 /* normal execution, next insn is next address */
|
|
#define B_BRANCH 1 /* next insn is in opcode */
|
|
#define B_RET 2 /* next insn is on stack */
|
|
#define B_BACC 3 /* next insn is in acc */
|
|
#define B_REPEAT 4 /* next insn repeats */
|
|
#define FL_BMASK 0x07
|
|
|
|
#define FL_DELAY 0x10 /* instruction uses delay slots */
|
|
#define FL_EXT 0x20 /* instruction takes two words */
|
|
#define FL_FAR 0x40 /* far mode addressing */
|
|
#define FL_LP 0x80 /* LP-only instruction */
|
|
#define FL_NR 0x100 /* no repeat allowed */
|
|
#define FL_SMR 0x200 /* Smem read (for flagging write-only *+ARx */
|
|
|
|
#define FL_PAR 0x400 /* Parallel instruction. */
|
|
|
|
unsigned short opcode2, mask2; /* some insns have an extended opcode */
|
|
|
|
const char* parname;
|
|
enum optype paroperand_types[MAX_OPERANDS];
|
|
|
|
} insn_template;
|
|
|
|
extern const insn_template tic54x_unknown_opcode;
|
|
extern const insn_template tic54x_optab[];
|
|
extern const insn_template tic54x_paroptab[];
|
|
extern const symbol mmregs[], regs[];
|
|
extern const symbol condition_codes[], cc2_codes[], status_bits[];
|
|
extern const symbol cc3_codes[];
|
|
extern const char *misc_symbols[];
|
|
struct disassemble_info;
|
|
extern const insn_template* tic54x_get_insn (struct disassemble_info *,
|
|
bfd_vma, unsigned short, int *);
|
|
|
|
#endif /* _opcode_tic54x_h_ */
|