binutils-gdb/gdb/testsuite/gdb.arch/arc-decode-insn.S
Anton Kolesov eea787570f arc: Add disassembler helper
Add disassembler helper for GDB, that uses opcodes structure arc_instruction
and adds convenience functions to handle instruction operands.  This interface
solves at least those problems with arc_instruction:

  * Some instructions, like "push_s", have implicit operands which are not
    directly present in arc_instruction.
  * Operands of particular meaning, like branch/jump targets, have various
    locations and meaning depending on type of branch/target.
  * Access to operand value is abstracted into a separate function, so callee
    code shouldn't bother if operand value is an immediate value or in a
    register.

Testcases included in this commit are fairly limited - they test exclusively
branch instructions, something that will be used in software single stepping.
Most of the other parts of this disassembler helper are tested during prologue
analysis testing.

gdb/ChangeLog:

yyyy-mm-dd  Anton Kolesov  <anton.kolesov@synopsys.com>

	* configure.tgt: Add arc-insn.o.
	* arc-tdep.c (arc_delayed_print_insn): Make non-static.
	(dump_arc_instruction_command): New function.
	(arc_fprintf_disasm): Likewise.
	(arc_disassemble_info): Likewise.
	(arc_insn_get_operand_value): Likewise.
	(arc_insn_get_operand_value_signed): Likewise.
	(arc_insn_get_memory_base_reg): Likewise.
	(arc_insn_get_memory_offset): Likewise.
	(arc_insn_get_branch_target): Likewise.
	(arc_insn_dump): Likewise.
	(arc_insn_get_linear_next_pc): Likewise.
	* arc-tdep.h (arc_delayed_print_insn): Add function declaration.
	(arc_disassemble_info): Likewise.
	(arc_insn_get_branch_target): Likewise.
	(arc_insn_get_linear_next_pc): Likewise.
	* NEWS: Mention new "maint print arc arc-instruction".

gdb/doc/ChangeLog:

yyyy-mm-dd  Anton Kolesov  <anton.kolesov@synopsys.com>

	* gdb.texinfo (Synopsys ARC): Add "maint print arc arc-instruction".

gdb/testsuite/ChangeLog:

yyyy-mm-dd  Anton Kolesov  <anton.kolesov@synopsys.com>

	* gdb.arch/arc-decode-insn.S: New file.
	* gdb.arch/arc-decode-insn.exp: Likewise.
2017-03-28 21:36:35 +03:00

1003 lines
24 KiB
ArmAsm

; This testcase is part of GDB, the GNU debugger.
; Copyright 2017 Free Software Foundation, Inc.
; This program 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 3 of the License, or
; (at your option) any later version.
;
; This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
.section .text
.global main
#define TEST_J
#define TEST_JCC
#define TEST_JL
#define TEST_JLCC
#define TEST_B
#define TEST_BBIT
#define TEST_BCC
#define TEST_BI
#define TEST_BL
#define TEST_BRCC
#define TEST_JLI
#define TEST_LEAVE_S
#define TEST_LPCC
; JLI-specific stuff
#ifdef TEST_JLI
jli_table:
.word 0xdeadbeea
.word 0xdeadbeea
jli_target:
.word 0xdeadbeea
.word 0xdeadbeea
.set jli_offset, 3
#endif
main:
; Each test case requires several symbols to be set, that identify expected
; parameters of this instruction. Required symbols:
; ${test}_start: symbol points to start of the test
; ${test}_end: symbol points to the instruction after the jump/branch
; instruction.
; ${test}_target: branch target address.
; ${test}_has_delay_slot: whether instruction has delay slot.
; ${test}_cc: condition code numeric value.
.set r12_value, 0xdead0000
.set blink_value, 0xdead0004
.set limm_value, 0xdead0008
; Just an integer
.set r4_value, 0xdead000c
; Just an integer
.set r5_value, 0xdead0010
; offset index for BI [c]
.set r7_value, 4
.set u6_value, 0x20
.set s12_target, 0x100
mov r12, @r12_value
mov r4, @r4_value
mov r5, @r5_value
mov r7, @r7_value
mov blink, @blink_value
#ifdef TEST_JLI
; jli_base aux regnum = 0x290
sr jli_table, [0x290]
#endif
start_branch_tests:
#ifdef TEST_J
#define TEST_NAME j_c
; j [c]
.set j_c_target, @r4_value
.set j_c_has_delay_slot, 0
.set j_c_cc, 0
j_c_start:
j [r4]
j_c_end:
; j [blink]
.set j_blink_target, @blink_value
.set j_blink_has_delay_slot, 0
.set j_blink_cc, 0
mov blink, @j_blink_target
j_blink_start:
j [blink]
j_blink_end:
; j limm
.set j_limm_target, @limm_value
.set j_limm_has_delay_slot, 0
.set j_limm_cc, 0
j_limm_start:
j @j_limm_target
j_limm_end:
; j u6
.set j_u6_target, @u6_value
.set j_u6_has_delay_slot, 0
.set j_u6_cc, 0
j_u6_start:
j @j_u6_target
j_u6_end:
; j s12
.set j_s12_target, @s12_target
.set j_s12_has_delay_slot, 0
.set j_s12_cc, 0
j_s12_start:
j @j_s12_target
j_s12_end:
; j.d [c]
.set j_d_c_target, @r4_value
.set j_d_c_has_delay_slot, 1
.set j_d_c_cc, 0
j_d_c_start:
j.d [r4]
j_d_c_end:
nop_s
; j.d [blink]
.set j_d_blink_target, @blink_value
.set j_d_blink_has_delay_slot, 1
.set j_d_blink_cc, 0
j_d_blink_start:
j.d [blink]
j_d_blink_end:
nop_s
; j.d u6
.set j_d_u6_target, @u6_value
.set j_d_u6_has_delay_slot, 1
.set j_d_u6_cc, 0
j_d_u6_start:
j.d @j_d_u6_target
j_d_u6_end:
nop_s
; j.d s12
.set j_d_s12_target, @s12_target
.set j_d_s12_has_delay_slot, 1
.set j_d_s12_cc, 0
j_d_s12_start:
j.d @j_d_s12_target
j_d_s12_end:
nop_s
; j_s [b]
.set j_s_b_target, @r12_value
.set j_s_b_has_delay_slot, 0
.set j_s_b_cc, 0
j_s_b_start:
j_s [r12]
j_s_b_end:
; j_s.d [b]
.set j_s_d_b_target, @r12_value
.set j_s_d_b_has_delay_slot, 1
.set j_s_d_b_cc, 0
j_s_d_b_start:
j_s.d [r12]
j_s_d_b_end:
nop_s
; j_s [blink]
.set j_s_blink_target, @blink_value
.set j_s_blink_has_delay_slot, 0
.set j_s_blink_cc, 0
j_s_blink_start:
j_s [blink]
j_s_blink_end:
; j_s.d [blink]
.set j_s_d_blink_target, @blink_value
.set j_s_d_blink_has_delay_slot, 1
.set j_c_cc, 0
j_s_d_blink_start:
j_s.d [blink]
j_s_d_blink_end:
nop_s
#endif /* TEST_J */
#ifdef TEST_JCC
; jcc [c]
.set jcc_c_target, @r4_value
.set jcc_c_has_delay_slot, 0
.set jcc_c_cc, 1
jcc_c_start:
jeq [r4]
jcc_c_end:
; jcc [blink]
.set jcc_blink_target, @blink_value
.set jcc_blink_has_delay_slot, 0
.set jcc_blink_cc, 2
jcc_blink_start:
jnz [blink]
jcc_blink_end:
; jcc limm
.set jcc_limm_target, @limm_value
.set jcc_limm_has_delay_slot, 0
.set jcc_limm_cc, 9
jcc_limm_start:
jgt @jcc_limm_target
jcc_limm_end:
; jcc u6
.set jcc_u6_target, @u6_value
.set jcc_u6_has_delay_slot, 0
.set jcc_u6_cc, 0xA
jcc_u6_start:
jge @jcc_u6_target
jcc_u6_end:
; jcc.d [c]
.set jcc_d_c_target, @r4_value
.set jcc_d_c_has_delay_slot, 1
.set jcc_d_c_cc, 0xB
jcc_d_c_start:
jlt.d [r4]
jcc_d_c_end:
nop_s
; jcc.d [blink]
.set jcc_d_blink_target, @blink_value
.set jcc_d_blink_has_delay_slot, 1
.set jcc_d_blink_cc, 0xC
jcc_d_blink_start:
jle.d [blink]
jcc_d_blink_end:
nop_s
; jcc.d u6
.set jcc_d_u6_target, @u6_value
.set jcc_d_u6_has_delay_slot, 1
.set jcc_d_u6_cc, 0xE
jcc_d_u6_start:
jls.d @jcc_d_u6_target
jcc_d_u6_end:
nop_s
; jeq_s [blink]
.set jcc_eq_s_blink_target, @blink_value
.set jcc_eq_s_blink_has_delay_slot, 0
.set jcc_eq_s_blink_cc, 1
jcc_eq_s_blink_start:
jeq_s [blink]
jcc_eq_s_blink_end:
; jne_s [blink]
.set jcc_ne_s_blink_target, @blink_value
.set jcc_ne_s_blink_has_delay_slot, 0
.set jcc_ne_s_blink_cc, 2
jcc_ne_s_blink_start:
jne_s [blink]
jcc_ne_s_blink_end:
#endif /* TEST_JCC */
#ifdef TEST_JL
; jl [c]
.set jl_c_target, @r4_value
.set jl_c_has_delay_slot, 0
.set jl_c_cc, 0
jl_c_start:
jl [r4]
jl_c_end:
; jl limm
.set jl_limm_target, @limm_value
.set jl_limm_has_delay_slot, 0
.set jl_limm_cc, 0
jl_limm_start:
jl @jl_limm_target
jl_limm_end:
; jl u6
.set jl_u6_target, @u6_value
.set jl_u6_has_delay_slot, 0
.set jl_u6_cc, 0
jl_u6_start:
jl @jl_u6_target
jl_u6_end:
; jl s12
.set jl_s12_target, @s12_target
.set jl_s12_has_delay_slot, 0
.set jl_s12_cc, 0
jl_s12_start:
jl @jl_s12_target
jl_s12_end:
; jl.d [c]
.set jl_d_c_target, @r4_value
.set jl_d_c_has_delay_slot, 1
.set jl_d_c_cc, 0
jl_d_c_start:
jl.d [r4]
jl_d_c_end:
nop_s
; jl.d u6
.set jl_d_u6_target, @u6_value
.set jl_d_u6_has_delay_slot, 1
.set jl_d_u6_cc, 0
jl_d_u6_start:
jl.d @jl_d_u6_target
jl_d_u6_end:
nop_s
; jl.d s12
.set jl_d_s12_target, @s12_target
.set jl_d_s12_has_delay_slot, 1
.set jl_d_s12_cc, 0
jl_d_s12_start:
jl.d @jl_d_s12_target
jl_d_s12_end:
nop_s
; jl_s [b]
.set jl_s_b_target, @r12_value
.set jl_s_b_has_delay_slot, 0
.set jl_s_b_cc, 0
jl_s_b_start:
jl_s [r12]
jl_s_b_end:
; jl_s.d [b]
.set jl_s_d_b_target, @r12_value
.set jl_s_d_b_has_delay_slot, 1
.set jl_s_d_b_cc, 0
jl_s_d_b_start:
jl_s.d [r12]
jl_s_d_b_end:
nop_s
#endif /* TEST_JL */
#ifdef TEST_JLCC
; jlcc [c]
.set jlcc_c_target, @r4_value
.set jlcc_c_has_delay_slot, 0
.set jlcc_c_cc, 1
jlcc_c_start:
jleq [r4]
jlcc_c_end:
; jlcc limm
.set jlcc_limm_target, @limm_value
.set jlcc_limm_has_delay_slot, 0
.set jlcc_limm_cc, 0x9
jlcc_limm_start:
jlgt @jlcc_limm_target
jlcc_limm_end:
; jlcc u6
.set jlcc_u6_target, @u6_value
.set jlcc_u6_has_delay_slot, 0
.set jlcc_u6_cc, 0xA
jlcc_u6_start:
jlge @jlcc_u6_target
jlcc_u6_end:
; jlcc.d [c]
.set jlcc_d_c_target, @r4_value
.set jlcc_d_c_has_delay_slot, 1
.set jlcc_d_c_cc, 0xB
jlcc_d_c_start:
jllt.d [r4]
jlcc_d_c_end:
nop_s
; jlcc.d u6
.set jlcc_d_u6_target, @u6_value
.set jlcc_d_u6_has_delay_slot, 1
.set jlcc_d_u6_cc, 0xE
jlcc_d_u6_start:
jlls.d @jlcc_d_u6_target
jlcc_d_u6_end:
nop_s
#endif /* TEST_JLCC */
#ifdef TEST_B
.Lb_target:
; Artifical nop, so that first b will not branch to itself.
nop_s
; b s25
.set b_s25_target, @.Lb_target
.set b_s25_has_delay_slot, 0
.set b_s25_cc, 0
b_s25_start:
b @b_s25_target
b_s25_end:
; b.d s25
.set b_d_s25_target, @.Lb_target
.set b_d_s25_has_delay_slot, 1
.set b_d_s25_cc, 0
b_d_s25_start:
b.d @b_d_s25_target
b_d_s25_end:
nop_s
; b_s s10
.set b_s_s10_target, @.Lb_target
.set b_s_s10_has_delay_slot, 0
.set b_s_s10_cc, 0
b_s_s10_start:
b_s @b_s_s10_target
b_s_s10_end:
#endif /* TEST_B */
#ifdef TEST_BBIT
; Due to specifics of bbit implementation in assembler, only local symbols can
; be used as a branch targets for bbit and brcc.
; bbits and brcc don't have condition code set to anything.
.Lbbit_target:
nop_s
; bbit0.nt b,c,s9
.set bbit0_nt_b_c_s9_target, @.Lbbit_target
.set bbit0_nt_b_c_s9_has_delay_slot, 0
.set bbit0_nt_b_c_s9_cc, 0
bbit0_nt_b_c_s9_start:
bbit0.nt r4,r5,@bbit0_nt_b_c_s9_target
bbit0_nt_b_c_s9_end:
; bbit0.d.nt b,c,s9
.set bbit0_d_nt_b_c_s9_target, @.Lbbit_target
.set bbit0_d_nt_b_c_s9_has_delay_slot, 1
.set bbit0_d_nt_b_c_s9_cc, 0
bbit0_d_nt_b_c_s9_start:
bbit0.d.nt r4,r5,@.Lbbit_target
bbit0_d_nt_b_c_s9_end:
nop_s
; bbit0.t b,c,s9
.set bbit0_t_b_c_s9_target, @.Lbbit_target
.set bbit0_t_b_c_s9_has_delay_slot, 0
.set bbit0_t_b_c_s9_cc, 0
bbit0_t_b_c_s9_start:
bbit0.t r4,r5,@.Lbbit_target
bbit0_t_b_c_s9_end:
; bbit0.d.t b,c,s9
.set bbit0_d_t_b_c_s9_target, @.Lbbit_target
.set bbit0_d_t_b_c_s9_has_delay_slot, 1
.set bbit0_d_t_b_c_s9_cc, 0
bbit0_d_t_b_c_s9_start:
bbit0.d.t r4,r5,@.Lbbit_target
bbit0_d_t_b_c_s9_end:
nop_s
; bbit0.nt b,u6,s9
.set bbit0_nt_b_u6_s9_target, @.Lbbit_target
.set bbit0_nt_b_u6_s9_has_delay_slot, 0
.set bbit0_nt_b_u6_s9_cc, 0
bbit0_nt_b_u6_s9_start:
bbit0.nt r4,u6_value,@.Lbbit_target
bbit0_nt_b_u6_s9_end:
; bbit0.d.nt b,u6,s9
.set bbit0_d_nt_b_u6_s9_target, @.Lbbit_target
.set bbit0_d_nt_b_u6_s9_has_delay_slot, 1
.set bbit0_d_nt_b_u6_s9_cc, 0
bbit0_d_nt_b_u6_s9_start:
bbit0.d.nt r4,u6_value,@.Lbbit_target
bbit0_d_nt_b_u6_s9_end:
nop_s
; bbit0.nt b,u6,s9
.set bbit0_t_b_u6_s9_target, @.Lbbit_target
.set bbit0_t_b_u6_s9_has_delay_slot, 0
.set bbit0_t_b_u6_s9_cc, 0
bbit0_t_b_u6_s9_start:
bbit0.t r4,u6_value,@.Lbbit_target
bbit0_t_b_u6_s9_end:
; bbit0.d.nt b,u6,s9
.set bbit0_d_t_b_u6_s9_target, @.Lbbit_target
.set bbit0_d_t_b_u6_s9_has_delay_slot, 1
.set bbit0_d_t_b_u6_s9_cc, 0
bbit0_d_t_b_u6_s9_start:
bbit0.d.t r4,u6_value,@.Lbbit_target
bbit0_d_t_b_u6_s9_end:
nop_s
; bbit0.nt b,limm,s9
.set bbit0_nt_b_limm_s9_target, @.Lbbit_target
.set bbit0_nt_b_limm_s9_has_delay_slot, 0
.set bbit0_nt_b_limm_s9_cc, 0
bbit0_nt_b_limm_s9_start:
bbit0.nt r4,limm_value,@.Lbbit_target
bbit0_nt_b_limm_s9_end:
; bbit0.t b,limm,s9
.set bbit0_t_b_limm_s9_target, @.Lbbit_target
.set bbit0_t_b_limm_s9_has_delay_slot, 0
.set bbit0_t_b_limm_s9_cc, 0
bbit0_t_b_limm_s9_start:
bbit0.t r4,limm_value,@.Lbbit_target
bbit0_t_b_limm_s9_end:
; bbit0.nt limm,c,s9
.set bbit0_nt_limm_c_s9_target, @.Lbbit_target
.set bbit0_nt_limm_c_s9_has_delay_slot, 0
.set bbit0_nt_limm_c_s9_cc, 0
bbit0_nt_limm_c_s9_start:
bbit0.nt limm_value,r4,@.Lbbit_target
bbit0_nt_limm_c_s9_end:
; bbit0.t limm,c,s9
.set bbit0_t_limm_c_s9_target, @.Lbbit_target
.set bbit0_t_limm_c_s9_has_delay_slot, 0
.set bbit0_t_limm_c_s9_cc, 0
bbit0_t_limm_c_s9_start:
bbit0.t limm_value,r4,@.Lbbit_target
bbit0_t_limm_c_s9_end:
; bbit0.nt limm,u6,s9
.set bbit0_nt_limm_u6_s9_target, @.Lbbit_target
.set bbit0_nt_limm_u6_s9_has_delay_slot, 0
.set bbit0_nt_limm_u6_s9_cc, 0
bbit0_nt_limm_u6_s9_start:
bbit0.nt limm_value,u6_value,@.Lbbit_target
bbit0_nt_limm_u6_s9_end:
; bbit0.t limm,u6,s9
.set bbit0_t_limm_u6_s9_target, @.Lbbit_target
.set bbit0_t_limm_u6_s9_has_delay_slot, 0
.set bbit0_t_limm_u6_s9_cc, 0
bbit0_t_limm_u6_s9_start:
bbit0.t limm_value,u6_value,@.Lbbit_target
bbit0_t_limm_u6_s9_end:
; bbit1.nt b,c,s9
.set bbit1_nt_b_c_s9_target, @.Lbbit_target
.set bbit1_nt_b_c_s9_has_delay_slot, 0
.set bbit1_nt_b_c_s9_cc, 0
bbit1_nt_b_c_s9_start:
bbit1.nt r4,r5,@.Lbbit_target
bbit1_nt_b_c_s9_end:
; bbit1.d.nt b,c,s9
.set bbit1_d_nt_b_c_s9_target, @.Lbbit_target
.set bbit1_d_nt_b_c_s9_has_delay_slot, 1
.set bbit1_d_nt_b_c_s9_cc, 0
bbit1_d_nt_b_c_s9_start:
bbit1.d.nt r4,r5,@.Lbbit_target
bbit1_d_nt_b_c_s9_end:
nop_s
; bbit1.t b,c,s9
.set bbit1_t_b_c_s9_target, @.Lbbit_target
.set bbit1_t_b_c_s9_has_delay_slot, 0
.set bbit1_t_b_c_s9_cc, 0
bbit1_t_b_c_s9_start:
bbit1.t r4,r5,@.Lbbit_target
bbit1_t_b_c_s9_end:
; bbit1.d.t b,c,s9
.set bbit1_d_t_b_c_s9_target, @.Lbbit_target
.set bbit1_d_t_b_c_s9_has_delay_slot, 1
.set bbit1_d_t_b_c_s9_cc, 0
bbit1_d_t_b_c_s9_start:
bbit1.d.t r4,r5,@.Lbbit_target
bbit1_d_t_b_c_s9_end:
nop_s
; bbit1.nt b,u6,s9
.set bbit1_nt_b_u6_s9_target, @.Lbbit_target
.set bbit1_nt_b_u6_s9_has_delay_slot, 0
.set bbit1_nt_b_u6_s9_cc, 0
bbit1_nt_b_u6_s9_start:
bbit1.nt r4,u6_value,@.Lbbit_target
bbit1_nt_b_u6_s9_end:
; bbit1.d.nt b,u6,s9
.set bbit1_d_nt_b_u6_s9_target, @.Lbbit_target
.set bbit1_d_nt_b_u6_s9_has_delay_slot, 1
.set bbit1_d_nt_b_u6_s9_cc, 0
bbit1_d_nt_b_u6_s9_start:
bbit1.d.nt r4,u6_value,@.Lbbit_target
bbit1_d_nt_b_u6_s9_end:
nop_s
; bbit1.nt b,u6,s9
.set bbit1_t_b_u6_s9_target, @.Lbbit_target
.set bbit1_t_b_u6_s9_has_delay_slot, 0
.set bbit1_t_b_u6_s9_cc, 0
bbit1_t_b_u6_s9_start:
bbit1.t r4,u6_value,@.Lbbit_target
bbit1_t_b_u6_s9_end:
; bbit1.d.nt b,u6,s9
.set bbit1_d_t_b_u6_s9_target, @.Lbbit_target
.set bbit1_d_t_b_u6_s9_has_delay_slot, 1
.set bbit1_d_t_b_u6_s9_cc, 0
bbit1_d_t_b_u6_s9_start:
bbit1.d.t r4,u6_value,@.Lbbit_target
bbit1_d_t_b_u6_s9_end:
nop_s
; bbit1.nt b,limm,s9
.set bbit1_nt_b_limm_s9_target, @.Lbbit_target
.set bbit1_nt_b_limm_s9_has_delay_slot, 0
.set bbit1_nt_b_limm_s9_cc, 0
bbit1_nt_b_limm_s9_start:
bbit1.nt r4,limm_value,@.Lbbit_target
bbit1_nt_b_limm_s9_end:
; bbit1.t b,limm,s9
.set bbit1_t_b_limm_s9_target, @.Lbbit_target
.set bbit1_t_b_limm_s9_has_delay_slot, 0
.set bbit1_t_b_limm_s9_cc, 0
bbit1_t_b_limm_s9_start:
bbit1.t r4,limm_value,@.Lbbit_target
bbit1_t_b_limm_s9_end:
; bbit1.nt limm,c,s9
.set bbit1_nt_limm_c_s9_target, @.Lbbit_target
.set bbit1_nt_limm_c_s9_has_delay_slot, 0
.set bbit1_nt_limm_c_s9_cc, 0
bbit1_nt_limm_c_s9_start:
bbit1.nt limm_value,r4,@.Lbbit_target
bbit1_nt_limm_c_s9_end:
; bbit1.t limm,c,s9
.set bbit1_t_limm_c_s9_target, @.Lbbit_target
.set bbit1_t_limm_c_s9_has_delay_slot, 0
.set bbit1_t_limm_c_s9_cc, 0
bbit1_t_limm_c_s9_start:
bbit1.t limm_value,r4,@.Lbbit_target
bbit1_t_limm_c_s9_end:
; bbit1.nt limm,u6,s9
.set bbit1_nt_limm_u6_s9_target, @.Lbbit_target
.set bbit1_nt_limm_u6_s9_has_delay_slot, 0
.set bbit1_nt_limm_u6_s9_cc, 0
bbit1_nt_limm_u6_s9_start:
bbit1.nt limm_value,u6_value,@.Lbbit_target
bbit1_nt_limm_u6_s9_end:
; bbit1.t limm,u6,s9
.set bbit1_t_limm_u6_s9_target, @.Lbbit_target
.set bbit1_t_limm_u6_s9_has_delay_slot, 0
.set bbit1_t_limm_u6_s9_cc, 0
bbit1_t_limm_u6_s9_start:
bbit1.t limm_value,u6_value,@.Lbbit_target
bbit1_t_limm_u6_s9_end:
#endif /* TEST_BBIT */
#ifdef TEST_BCC
.Lbcc_target:
; bcc s21
.set bcc_s21_target, @.Lbcc_target
.set bcc_s21_has_delay_slot, 0
.set bcc_s21_cc, 1
bcc_s21_start:
; beq @bcc_s21_target
beq @.Lbcc_target
bcc_s21_end:
; bcc.d s21
.set bcc_d_s21_target, @.Lbcc_target
.set bcc_d_s21_has_delay_slot, 1
.set bcc_d_s21_cc, 1
bcc_d_s21_start:
beq.d @bcc_d_s21_target
bcc_d_s21_end:
nop_s
.Lbcc_s_target:
; beq_s s10
.set beq_s_s10_target, @.Lbcc_s_target
.set beq_s_s10_has_delay_slot, 0
.set beq_s_s10_cc, 1
beq_s_s10_start:
# beq_s.d @beq_s_s10_target
beq_s @.Lbcc_s_target
beq_s_s10_end:
; bne_s s10
.set bne_s_s10_target, @.Lbcc_s_target
.set bne_s_s10_has_delay_slot, 0
.set bne_s_s10_cc, 2
bne_s_s10_start:
bne_s @bne_s_s10_target
bne_s_s10_end:
; bgt_s s7
.set bgt_s_s7_target, @.Lbcc_s_target
.set bgt_s_s7_has_delay_slot, 0
.set bgt_s_s7_cc, 0x9
bgt_s_s7_start:
bgt_s @bgt_s_s7_target
bgt_s_s7_end:
; bge_s s7
.set bge_s_s7_target, @.Lbcc_s_target
.set bge_s_s7_has_delay_slot, 0
.set bge_s_s7_cc, 0xA
bge_s_s7_start:
bge_s @bge_s_s7_target
bge_s_s7_end:
; blt_s s7
.set blt_s_s7_target, @.Lbcc_s_target
.set blt_s_s7_has_delay_slot, 0
.set blt_s_s7_cc, 0xB
blt_s_s7_start:
blt_s @blt_s_s7_target
blt_s_s7_end:
; ble_s s7
.set ble_s_s7_target, @.Lbcc_s_target
.set ble_s_s7_has_delay_slot, 0
.set ble_s_s7_cc, 0xC
ble_s_s7_start:
ble_s @ble_s_s7_target
ble_s_s7_end:
; bhi_s s7
.set bhi_s_s7_target, @.Lbcc_s_target
.set bhi_s_s7_has_delay_slot, 0
.set bhi_s_s7_cc, 0xD
bhi_s_s7_start:
bhi_s @bhi_s_s7_target
bhi_s_s7_end:
; bhs_s s7
.set bhs_s_s7_target, @.Lbcc_s_target
.set bhs_s_s7_has_delay_slot, 0
.set bhs_s_s7_cc, 0x6
bhs_s_s7_start:
bhs_s @bhs_s_s7_target
bhs_s_s7_end:
; blo_s s7
.set blo_s_s7_target, @.Lbcc_s_target
.set blo_s_s7_has_delay_slot, 0
.set blo_s_s7_cc, 0x5
blo_s_s7_start:
blo_s @blo_s_s7_target
blo_s_s7_end:
; bls_s s7
.set bls_s_s7_target, @.Lbcc_s_target
.set bls_s_s7_has_delay_slot, 0
.set bls_s_s7_cc, 0xE
bls_s_s7_start:
bls_s @bls_s_s7_target
bls_s_s7_end:
#endif /* TEST_BCC */
#ifdef TEST_BI
; bi [c]
.set bi_c_target, @bi_c_end + (@r7_value << 2)
.set bi_c_has_delay_slot, 0
.set bi_c_cc, 0
bi_c_start:
bi [r7]
bi_c_end:
; bih [c]
.set bih_c_target, @bih_c_end + (@r7_value << 1)
.set bih_c_has_delay_slot, 0
.set bih_c_cc, 0
bih_c_start:
bih [r7]
bih_c_end:
#endif /* TEST_BI */
#ifdef TEST_BL
.Lbl_target:
; bl s25
.set bl_s25_target, @.Lbl_target
.set bl_s25_has_delay_slot, 0
.set bl_s25_cc, 0
bl_s25_start:
bl @bl_s25_target
bl_s25_end:
; bl.d s25
.set bl_d_s25_target, @.Lbl_target
.set bl_d_s25_has_delay_slot, 1
.set bl_d_s25_cc, 0
bl_d_s25_start:
bl.d @bl_d_s25_target
bl_d_s25_end:
nop_s
; bl_s s13
.set bl_s_s13_target, @.Lbl_target
.set bl_s_s13_has_delay_slot, 0
.set bl_s_s13_cc, 0
bl_s_s13_start:
bl_s @bl_s_s13_target
bl_s_s13_end:
; blcc s21
.set blcc_s21_target, @.Lbl_target
.set blcc_s21_has_delay_slot, 0
.set blcc_s21_cc, 1
blcc_s21_start:
bleq @blcc_s21_target
blcc_s21_end:
; blcc.d s21
.set blcc_d_s21_target, @.Lbl_target
.set blcc_d_s21_has_delay_slot, 1
.set blcc_d_s21_cc, 2
blcc_d_s21_start:
blnz.d @blcc_d_s21_target
blcc_d_s21_end:
nop_s
#endif /* TEST_BL */
#ifdef TEST_BRCC
.Lbrcc_target:
; breq.nt b,c,s9
.set breq_nt_b_c_s9_target, @.Lbrcc_target
.set breq_nt_b_c_s9_has_delay_slot, 0
.set breq_nt_b_c_s9_cc, 1
breq_nt_b_c_s9_start:
breq.nt r4,r5,@.Lbrcc_target
breq_nt_b_c_s9_end:
; breq.d.nt b,c,s9
.set breq_d_nt_b_c_s9_target, @.Lbrcc_target
.set breq_d_nt_b_c_s9_has_delay_slot, 1
.set breq_d_nt_b_c_s9_cc, 1
breq_d_nt_b_c_s9_start:
breq.d.nt r4,r5,@.Lbrcc_target
breq_d_nt_b_c_s9_end:
nop_s
; breq.t b,c,s9
.set breq_t_b_c_s9_target, @.Lbrcc_target
.set breq_t_b_c_s9_has_delay_slot, 0
.set breq_t_b_c_s9_cc, 1
breq_t_b_c_s9_start:
breq.t r4,r5,@.Lbrcc_target
breq_t_b_c_s9_end:
; breq.d.t b,c,s9
.set breq_d_t_b_c_s9_target, @.Lbrcc_target
.set breq_d_t_b_c_s9_has_delay_slot, 1
.set breq_d_t_b_c_s9_cc, 1
breq_d_t_b_c_s9_start:
breq.d.t r4,r5,@.Lbrcc_target
breq_d_t_b_c_s9_end:
nop_s
; breq.nt b,u6,s9
.set breq_nt_b_u6_s9_target, @.Lbrcc_target
.set breq_nt_b_u6_s9_has_delay_slot, 0
.set breq_nt_b_u6_s9_cc, 1
breq_nt_b_u6_s9_start:
breq.nt r4,u6_value,@.Lbrcc_target
breq_nt_b_u6_s9_end:
; breq.d.nt b,u6,s9
.set breq_d_nt_b_u6_s9_target, @.Lbrcc_target
.set breq_d_nt_b_u6_s9_has_delay_slot, 1
.set breq_d_nt_b_u6_s9_cc, 1
breq_d_nt_b_u6_s9_start:
breq.d.nt r4,u6_value,@.Lbrcc_target
breq_d_nt_b_u6_s9_end:
nop_s
; breq.nt b,u6,s9
.set breq_t_b_u6_s9_target, @.Lbrcc_target
.set breq_t_b_u6_s9_has_delay_slot, 0
.set breq_t_b_u6_s9_cc, 1
breq_t_b_u6_s9_start:
breq.t r4,u6_value,@.Lbrcc_target
breq_t_b_u6_s9_end:
; breq.d.nt b,u6,s9
.set breq_d_t_b_u6_s9_target, @.Lbrcc_target
.set breq_d_t_b_u6_s9_has_delay_slot, 1
.set breq_d_t_b_u6_s9_cc, 1
breq_d_t_b_u6_s9_start:
breq.d.t r4,u6_value,@.Lbrcc_target
breq_d_t_b_u6_s9_end:
nop_s
; breq.nt b,limm,s9
.set breq_nt_b_limm_s9_target, @.Lbrcc_target
.set breq_nt_b_limm_s9_has_delay_slot, 0
.set breq_nt_b_limm_s9_cc, 1
breq_nt_b_limm_s9_start:
breq.nt r4,limm_value,@.Lbrcc_target
breq_nt_b_limm_s9_end:
; breq.t b,limm,s9
.set breq_t_b_limm_s9_target, @.Lbrcc_target
.set breq_t_b_limm_s9_has_delay_slot, 0
.set breq_t_b_limm_s9_cc, 1
breq_t_b_limm_s9_start:
breq.t r4,limm_value,@.Lbrcc_target
breq_t_b_limm_s9_end:
; breq.nt limm,c,s9
.set breq_nt_limm_c_s9_target, @.Lbrcc_target
.set breq_nt_limm_c_s9_has_delay_slot, 0
.set breq_nt_limm_c_s9_cc, 1
breq_nt_limm_c_s9_start:
breq.nt limm_value,r4,@.Lbrcc_target
breq_nt_limm_c_s9_end:
; breq.t limm,c,s9
.set breq_t_limm_c_s9_target, @.Lbrcc_target
.set breq_t_limm_c_s9_has_delay_slot, 0
.set breq_t_limm_c_s9_cc, 1
breq_t_limm_c_s9_start:
breq.t limm_value,r4,@.Lbrcc_target
breq_t_limm_c_s9_end:
; breq.nt limm,u6,s9
.set breq_nt_limm_u6_s9_target, @.Lbrcc_target
.set breq_nt_limm_u6_s9_has_delay_slot, 0
.set breq_nt_limm_u6_s9_cc, 1
breq_nt_limm_u6_s9_start:
breq.nt limm_value,u6_value,@.Lbrcc_target
breq_nt_limm_u6_s9_end:
; breq.t limm,u6,s9
.set breq_t_limm_u6_s9_target, @.Lbrcc_target
.set breq_t_limm_u6_s9_has_delay_slot, 0
.set breq_t_limm_u6_s9_cc, 1
breq_t_limm_u6_s9_start:
breq.t limm_value,u6_value,@.Lbrcc_target
breq_t_limm_u6_s9_end:
; brne_s b,0,s8
.set brne_s_b_0_s8_target, @.Lbrcc_target
.set brne_s_b_0_s8_has_delay_slot, 0
.set brne_s_b_0_s8_cc, 1
brne_s_b_0_s8_start:
brne r12,0,@.Lbrcc_target
brne_s_b_0_s8_end:
; breq_s b,0,s8
.set breq_s_b_0_s8_target, @.Lbrcc_target
.set breq_s_b_0_s8_has_delay_slot, 0
.set breq_s_b_0_s8_cc, 1
breq_s_b_0_s8_start:
breq r12,0,@.Lbrcc_target
breq_s_b_0_s8_end:
#endif /* TEST_BRCC */
#ifdef TEST_JLI
; jli_s u10
.set jli_s_u10_target, @jli_target
.set jli_s_u10_has_delay_slot, 0
.set jli_s_u10_cc, 0
jli_s_u10_start:
jli_s jli_offset
jli_s_u10_end:
#endif
#ifdef TEST_LEAVE_S
; leave_s
.set leave_s_target, @blink_value
.set leave_s_has_delay_slot, 0
.set leave_s_cc, 0
leave_s_start:
; leave_s [r13-gp,fp,blink,pcl]
leave_s (14 + 16 + 32 + 64)
leave_s_end:
#endif
#ifdef TEST_LPCC
; lpcc
.set lpcc_u7_target, @.Llpcc_end
.set lpcc_u7_has_delay_slot, 0
.set lpcc_u7_cc, 1
lpcc_u7_start:
lpeq @lpcc_u7_target
lpcc_u7_end:
nop
nop
.Llpcc_end:
#endif
.Lend: