diff options
Diffstat (limited to 'sim/testsuite/sim/frv/cldu.cgs')
-rw-r--r-- | sim/testsuite/sim/frv/cldu.cgs | 172 |
1 files changed, 172 insertions, 0 deletions
diff --git a/sim/testsuite/sim/frv/cldu.cgs b/sim/testsuite/sim/frv/cldu.cgs new file mode 100644 index 0000000..61cf606 --- /dev/null +++ b/sim/testsuite/sim/frv/cldu.cgs @@ -0,0 +1,172 @@ +# frv testcase for cldu @($GRi,$GRj),$GRk,$CCi,$cond +# mach: all + + .include "testutils.inc" + + start + + .global cldu +cldu: + set_spr_immed 0x1b1b,cccr + set_gr_gr sp,gr20 + + set_mem_limmed 0xdead,0xbeef,sp + set_gr_limmed 0xbeef,0xdead,gr8 + + set_gr_gr sp,gr9 + set_gr_immed 0,gr7 + cldu @(sp,gr7),gr8,cc0,1 + test_gr_limmed 0xdead,0xbeef,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed -4,sp + set_gr_immed 4,gr7 + cldu @(sp,gr7),gr8,cc0,1 + test_gr_limmed 0xdead,0xbeef,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed 4,sp + set_gr_immed -4,gr7 + cldu @(sp,gr7),gr8,cc4,1 + test_gr_limmed 0xdead,0xbeef,gr8 + test_gr_gr sp,gr9 + + set_gr_gr sp,gr20 + set_mem_limmed 0xdead,0xbeef,sp + set_gr_limmed 0xbeef,0xdead,gr8 + + set_gr_gr sp,gr9 + set_gr_immed 0,gr7 + cldu @(sp,gr7),gr8,cc0,0 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed -4,gr9 + inc_gr_immed -4,sp + set_gr_immed 4,gr7 + cldu @(sp,gr7),gr8,cc0,0 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed 8,gr9 + inc_gr_immed 8,sp + set_gr_immed -4,gr7 + cldu @(sp,gr7),gr8,cc4,0 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_gr sp,gr20 + set_mem_limmed 0xdead,0xbeef,sp + set_gr_limmed 0xbeef,0xdead,gr8 + + set_gr_gr sp,gr9 + set_gr_immed 0,gr7 + cldu @(sp,gr7),gr8,cc1,0 + test_gr_limmed 0xdead,0xbeef,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed -4,sp + set_gr_immed 4,gr7 + cldu @(sp,gr7),gr8,cc1,0 + test_gr_limmed 0xdead,0xbeef,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed 4,sp + set_gr_immed -4,gr7 + cldu @(sp,gr7),gr8,cc5,0 + test_gr_limmed 0xdead,0xbeef,gr8 + test_gr_gr sp,gr9 + + set_gr_gr sp,gr20 + set_mem_limmed 0xdead,0xbeef,sp + set_gr_limmed 0xbeef,0xdead,gr8 + + set_gr_gr sp,gr9 + set_gr_immed 0,gr7 + cldu @(sp,gr7),gr8,cc1,1 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed -4,gr9 + inc_gr_immed -4,sp + set_gr_immed 4,gr7 + cldu @(sp,gr7),gr8,cc1,1 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed 8,gr9 + inc_gr_immed 8,sp + set_gr_immed -4,gr7 + cldu @(sp,gr7),gr8,cc5,1 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_gr sp,gr20 + set_mem_limmed 0xdead,0xbeef,sp + set_gr_limmed 0xbeef,0xdead,gr8 + + set_gr_gr sp,gr9 + set_gr_immed 0,gr7 + cldu @(sp,gr7),gr8,cc2,0 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed -4,gr9 + inc_gr_immed -4,sp + set_gr_immed 4,gr7 + cldu @(sp,gr7),gr8,cc2,1 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed 8,gr9 + inc_gr_immed 8,sp + set_gr_immed -4,gr7 + cldu @(sp,gr7),gr8,cc6,0 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_gr sp,gr20 + set_mem_limmed 0xdead,0xbeef,sp + set_gr_limmed 0xbeef,0xdead,gr8 + + set_gr_gr sp,gr9 + set_gr_immed 0,gr7 + cldu @(sp,gr7),gr8,cc3,1 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed -4,gr9 + inc_gr_immed -4,sp + set_gr_immed 4,gr7 + cldu @(sp,gr7),gr8,cc3,0 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_limmed 0xbeef,0xdead,gr8 + inc_gr_immed 8,gr9 + inc_gr_immed 8,sp + set_gr_immed -4,gr7 + cldu @(sp,gr7),gr8,cc7,1 + test_gr_limmed 0xbeef,0xdead,gr8 + test_gr_gr sp,gr9 + + set_gr_gr gr20,sp + set_mem_limmed 0xdead,0xbeef,sp + set_gr_gr sp,gr8 + inc_gr_immed -4,gr8 + set_gr_immed 4,gr7 + cldu @(gr8,gr7),gr8,cc0,1 + test_gr_limmed 0xdead,0xbeef,gr8 + + pass |