From 735979c78294364af204d7fe2fbe1ca14c0923d3 Mon Sep 17 00:00:00 2001 From: Michael Snyder Date: Tue, 29 Jul 2003 21:07:40 +0000 Subject: [PATCH] 2003-07-22 Michael Snyder * cmpw.s: Add test for less-than-zero immediate. * shll.s: Test for shll reg, reg. * shlr.s: Test for shlr reg, reg. * mova.s: Add dozens of new mova tests. --- sim/testsuite/sim/h8300/ChangeLog | 7 + sim/testsuite/sim/h8300/cmpw.s | 18 +- sim/testsuite/sim/h8300/mova.s | 629 ++++++++++++++++++++++++++++++++++++++ sim/testsuite/sim/h8300/shll.s | 67 ++++ sim/testsuite/sim/h8300/shlr.s | 67 ++++ 5 files changed, 787 insertions(+), 1 deletion(-) diff --git a/sim/testsuite/sim/h8300/ChangeLog b/sim/testsuite/sim/h8300/ChangeLog index 3f1c1d3..4dc6559 100644 --- a/sim/testsuite/sim/h8300/ChangeLog +++ b/sim/testsuite/sim/h8300/ChangeLog @@ -1,3 +1,10 @@ +2003-07-22 Michael Snyder + + * cmpw.s: Add test for less-than-zero immediate. + * shll.s: Test for shll reg, reg. + * shlr.s: Test for shlr reg, reg. + * mova.s: Add dozens of new mova tests. + 2003-05-30 Alexandre Oliva * allinsn.exp: Fix typos introduced on 2003-05-27. diff --git a/sim/testsuite/sim/h8300/cmpw.s b/sim/testsuite/sim/h8300/cmpw.s index 2c69dbd..872c56c 100644 --- a/sim/testsuite/sim/h8300/cmpw.s +++ b/sim/testsuite/sim/h8300/cmpw.s @@ -48,7 +48,7 @@ cmp_w_imm16: ; cmp.w immediate not available in h8300 mode. set_grs_a5a5 ; Fill all general regs with a fixed pattern ;; fixme set ccr - ;; cmp.w #xx:8,Rd + ;; cmp.w #xx:16,Rd cmp.w #0xa5a5, r0 ; Immediate 16-bit operand beq eqi fail @@ -71,6 +71,22 @@ gti: test_gr_a5a5 5 test_gr_a5a5 6 test_gr_a5a5 7 + +cmp_w_imm16_less_than_zero: ; Test for less-than-zero immediate + set_grs_a5a5 + ;; cmp.w #xx:16, Rd, where #xx < 0 (ie. #xx > 0x7fff). + sub.w r0, r0 + cmp.w #0x8001, r0 + bls ltz + fail +ltz: test_gr_a5a5 1 + test_gr_a5a5 2 + test_gr_a5a5 3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 + .endif cmp_w_reg: diff --git a/sim/testsuite/sim/h8300/mova.s b/sim/testsuite/sim/h8300/mova.s index 03c6adc..a4bcfd6 100644 --- a/sim/testsuite/sim/h8300/mova.s +++ b/sim/testsuite/sim/h8300/mova.s @@ -10,6 +10,11 @@ .include "testutils.inc" + .data +foo: .long 0x01010101 + .long 0x10101010 + .long 0x11111111 + start movabl16_reg8: @@ -204,6 +209,630 @@ movall32_reg16: test_gr_a5a5 6 test_gr_a5a5 7 +t02_mova: + set_grs_a5a5 + set_ccr_zero + + mov.l #0x01010101, er1 + mova/b.c @(0x1234:16,r1l.b),er1 ; 7A891234 + test_h_gr32 0x1235, er1 ; 1s + mov.l #0x01010101, er1 + mova/b.c @(0x1234:16,r1.w),er1 ; 7A991234 + test_h_gr32 0x1335, er1 ; 2s + mov.l #0x01010101, er1 + mova/w.c @(0x1234:16,r1l.b),er1 ; 7AA91234 + test_h_gr32 0x1236, er1 ; 3s + mov.l #0x01010101, er1 + mova/w.c @(0x1234:16,r1.w),er1 ; 7AB91234 + test_h_gr32 0x1436, er1 ; 4s + mov.l #0x01010101, er1 + mova/l.c @(0x1234:16,r1l.b),er1 ; 7AC91234 + test_h_gr32 0x1238, er1 ; 5s + mov.l #0x01010101, er1 + mova/l.c @(0x1234:16,r1.w),er1 ; 7AD91234 + test_h_gr32 0x1638, er1 ; 6s + mov.l #0x01010101, er1 + mova/b.c @(0x12345678:32,r1l.b),er1 ; 7A8112345678 + test_h_gr32 0x12345679, er1 ; 7s + mov.l #0x01010101, er1 + mova/b.c @(0x12345678:32,r1.w),er1 ; 7A9112345678 + test_h_gr32 0x12345779, er1 ; 8s + mov.l #0x01010101, er1 + mova/w.c @(0x12345678:32,r1l.b),er1 ; 7AA112345678 + test_h_gr32 0x1234567a, er1 ; 9s + mov.l #0x01010101, er1 + mova/w.c @(0x12345678:32,r1.w),er1 ; 7AB112345678 + test_h_gr32 0x1234587a, er1 ; 10s + mov.l #0x01010101, er1 + mova/l.c @(0x12345678:32,r1l.b),er1 ; 7AC112345678 + test_h_gr32 0x1234567c, er1 ; 11s + mov.l #0x01010101, er1 + mova/l.c @(0x12345678:32,r1.w),er1 ; 7AD112345678 + test_h_gr32 0x12345a7c, er1 ; 12s + +t02b: + mov.l #0x01010101, er3 + mova/b.l @(0x1234:16,r3l.b),er1 ; 78B87A891234 + test_h_gr32 0x1235, er1 ; 1 + mova/b.l @(0x1234:16,r3.w),er1 ; 78397A991234 + test_h_gr32 0x1335, er1 ; 2 + mova/w.l @(0x1234:16,r3l.b),er1 ; 78B87AA91234 + test_h_gr32 0x1236, er1 ; 3 + mova/w.l @(0x1234:16,r3.w),er1 ; 78397AB91234 + test_h_gr32 0x1436, er1 ; 4 + mova/l.l @(0x1234:16,r3l.b),er1 ; 78B87AC91234 + test_h_gr32 0x1238, er1 ; 5 + mova/l.l @(0x1234:16,r3.w),er1 ; 78397AD91234 + test_h_gr32 0x1638, er1 ; 6 + mova/b.l @(0x12345678:32,r3l.b),er1 ; 78B87A8112345678 + test_h_gr32 0x12345679, er1 ; 7 + mova/b.l @(0x12345678:32,r3.w),er1 ; 78397A9112345678 + test_h_gr32 0x12345779, er1 ; 8 + mova/w.l @(0x12345678:32,r3l.b),er1 ; 78B87AA112345678 + test_h_gr32 0x1234567a, er1 ; 9 + mova/w.l @(0x12345678:32,r3.w),er1 ; 78397AB112345678 + test_h_gr32 0x1234587a, er1 ; 10 + mova/l.l @(0x12345678:32,r3l.b),er1 ; 78B87AC112345678 + test_h_gr32 0x1234567c, er1 ; 11 + mova/l.l @(0x12345678:32,r3.w),er1 ; 78397AD112345678 + test_h_gr32 0x12345a7c, er1 ; 12 + test_h_gr32 0x01010101, er3 +t02c: + mov.l #foo, er2 + mova/b.l @(0x1234:16,@er2.b),er1 ;017F02811234 + test_h_gr32 0x1235, er1 ; 13 + test_h_gr32 foo, er2 + mova/b.l @(0x1234:16,@(0x1:2,er2).b),er1 ;017F12811234 + test_h_gr32 0x1235, er1 ; 18 + test_h_gr32 foo, er2 + mova/b.l @(0x1234:16,@er2+.b),er1 ;017F82811234 + test_h_gr32 0x1235, er1 ; 14 + test_h_gr32 foo+1, er2 + mova/b.l @(0x1234:16,@-er2.b),er1 ;017FB2811234 + test_h_gr32 0x1235, er1 ; 17 + test_h_gr32 foo, er2 + mova/b.l @(0x1234:16,@+er2.b),er1 ;017F92811234 + test_h_gr32 0x1235, er1 ; 16 + test_h_gr32 foo+1, er2 + mova/b.l @(0x1234:16,@er2-.b),er1 ;017FA2811234 + test_h_gr32 0x1235, er1 ; 15 + test_h_gr32 foo, er2 +t02d: + mov.l #4, er2 + mova/b.l @(0x1234:16, @(foo:16, er2).b), er1 + test_h_gr32 0x1244, er1 ; 19 + mova/b.l @(0x1234:16, @(foo:16, r2L.b).b), er1 + test_h_gr32 0x1244, er1 ; 21 + mova/b.l @(0x1234:16, @(foo:16, r2.w).b), er1 + test_h_gr32 0x1244, er1 ; 22 + mova/b.l @(0x1234:16, @(foo:16, er2.l).b), er1 + test_h_gr32 0x1244, er1 ; 23 + + mov.l #4, er2 + mova/b.l @(0x1234:16, @(foo:32, er2).b), er1 + test_h_gr32 0x1244, er1 ; 20 + mova/b.l @(0x1234:16, @(foo:32, r2L.b).b), er1 + test_h_gr32 0x1244, er1 ; 24 + mova/b.l @(0x1234:16, @(foo:32, r2.w).b), er1 + test_h_gr32 0x1244, er1 ; 25 + mova/b.l @(0x1234:16, @(foo:32, er2.l).b), er1 + test_h_gr32 0x1244, er1 ; 26 + + mova/b.l @(0x1234:16,@foo:16.b),er1 + test_h_gr32 0x1235, er1 ; 27 + mova/b.l @(0x1234:16,@foo:32.b),er1 + test_h_gr32 0x1235, er1 ; 28 + +t02e: + mov.l #foo, er2 + mova/b.l @(0x1234:16,@er2.w),er1 ;015F02911234 + test_h_gr32 0x1335, er1 ; 29 + test_h_gr32 foo, er2 + mova/b.l @(0x1234:16,@(0x2:2,er2).w),er1 ;015F12911234 + test_h_gr32 0x1335, er1 ; 34 + test_h_gr32 foo, er2 + mova/b.l @(0x1234:16,@er2+.w),er1 ;015F82911234 + test_h_gr32 0x1335, er1 ; 30 + test_h_gr32 foo+2, er2 + mova/b.l @(0x1234:16,@-er2.w),er1 ;015FB2911234 + test_h_gr32 0x1335, er1 ; 33 + test_h_gr32 foo, er2 + mova/b.l @(0x1234:16,@+er2.w),er1 ;015F92911234 + test_h_gr32 0x1335, er1 ; 32 + test_h_gr32 foo+2, er2 + mova/b.l @(0x1234:16,@er2-.w),er1 ;015FA2911234 + test_h_gr32 0x1335, er1 ; 31 + test_h_gr32 foo, er2 + + mov.l #4, er2 + mova/b.l @(0x1234:16, @(foo:16, er2).w), er1 + test_h_gr32 0x2244, er1 ; 35 + shar.l er2 + mova/b.l @(0x1234:16, @(foo:16, r2L.b).w), er1 + test_h_gr32 0x2244, er1 ; 37 + mova/b.l @(0x1234:16, @(foo:16, r2.w).w), er1 + test_h_gr32 0x2244, er1 ; 38 + mova/b.l @(0x1234:16, @(foo:16, er2.l).w), er1 + test_h_gr32 0x2244, er1 ; 39 + + mov.l #4, er2 + mova/b.l @(0x1234:16, @(foo:32, er2).w), er1 + test_h_gr32 0x2244, er1 ; 36 + shar.l er2 + mova/b.l @(0x1234:16, @(foo:32, r2L.b).w), er1 + test_h_gr32 0x2244, er1 ; 40 + mova/b.l @(0x1234:16, @(foo:32, r2.w).w), er1 + test_h_gr32 0x2244, er1 ; 41 + mova/b.l @(0x1234:16, @(foo:32, er2.l).w), er1 + test_h_gr32 0x2244, er1 ; 42 + + mova/b.l @(0x1234:16,@foo:16.w),er1 ;015F40919ABC1234 + test_h_gr32 0x1335, er1 ; 43 + mova/b.l @(0x1234:16,@foo:32.w),er1 ;015F48919ABCDEF01234 + test_h_gr32 0x1335, er1 ; 44 + +t02f: + mov.l #foo, er2 + mova/w.l @(0x1234:16,@er2.b),er1 ;017F02A11234 + test_h_gr32 0x1236, er1 ; 45 + mova/w.l @(0x1234:16,@(0x1:2,er2).b),er1 ;017F12A11234 + test_h_gr32 0x1236, er1 ; 50 + mova/w.l @(0x1234:16,@er2+.b),er1 ;017F82A11234 + test_h_gr32 0x1236, er1 ; 46 + test_h_gr32 foo+1, er2 + mova/w.l @(0x1234:16,@-er2.b),er1 ;017FB2A11234 + test_h_gr32 0x1236, er1 ; 49 + test_h_gr32 foo, er2 + mova/w.l @(0x1234:16,@+er2.b),er1 ;017F92A11234 + test_h_gr32 0x1236, er1 ; 48 + test_h_gr32 foo+1, er2 + mova/w.l @(0x1234:16,@er2-.b),er1 ;017FA2A11234 + test_h_gr32 0x1236, er1 ; 47 + test_h_gr32 foo, er2 + +t02g: + mov.l #4, er2 + mova/w.l @(0x1234:16, @(foo:16, er2).b), er1 + test_h_gr32 0x1254, er1 ; 51 + mova/w.l @(0x1234:16, @(foo:16, r2L.b).b), er1 + test_h_gr32 0x1254, er1 ; 53 + mova/w.l @(0x1234:16, @(foo:16, r2.w).b), er1 + test_h_gr32 0x1254, er1 ; 54 + mova/w.l @(0x1234:16, @(foo:16, er2.l).b), er1 + test_h_gr32 0x1254, er1 ; 55 + + mov.l #4, er2 + mova/w.l @(0x1234:16, @(foo:32, er2).b), er1 + test_h_gr32 0x1254, er1 ; 52 + mova/w.l @(0x1234:16, @(foo:32, r2L.b).b), er1 + test_h_gr32 0x1254, er1 ; 56 + mova/w.l @(0x1234:16, @(foo:32, r2.w).b), er1 + test_h_gr32 0x1254, er1 ; 57 + mova/w.l @(0x1234:16, @(foo:32, er2.l).b), er1 + test_h_gr32 0x1254, er1 ; 58 + + mova/w.l @(0x1234:16,@foo:16.b),er1 ;017F40A19ABC1234 + test_h_gr32 0x1236, er1 ; 59 (can't test -- points into the woods) + mova/w.l @(0x1234:16,@foo:32.b),er1 ;017F48A19ABCDEF01234 + test_h_gr32 0x1236, er1 ; 60 (can't test -- points into the woods) + +t02h: + mov.l #foo, er2 + mova/w.l @(0x1234:16,@er2.w),er1 ;015F02B11234 + test_h_gr32 0x1436, er1 ; 61 + mova/w.l @(0x1234:16,@(0x2:2,er2).w),er1 ;015F12B11234 + test_h_gr32 0x1436, er1 ; 66, 0x1234 + (@(4+foo).w << 1 + mova/w.l @(0x1234:16,@er2+.w),er1 ;015F82B11234 + test_h_gr32 0x1436, er1 ; 62 + test_h_gr32 foo+2, er2 + mova/w.l @(0x1234:16,@-er2.w),er1 ;015FB2B11234 + test_h_gr32 0x1436, er1 ; 63 + test_h_gr32 foo, er2 + mova/w.l @(0x1234:16,@+er2.w),er1 ;015F92B11234 + test_h_gr32 0x1436, er1 ; 64 + test_h_gr32 foo+2, er2 + mova/w.l @(0x1234:16,@er2-.w),er1 ;015FA2B11234 + test_h_gr32 0x1436, er1 ; 65 + test_h_gr32 foo, er2 +t02i: + mov.l #4, er2 + mova/w.l @(0x1234:16, @(foo:16, er2).w), er1 + test_h_gr32 0x3254, er1 ; 67 + shar.l er2 + mova/w.l @(0x1234:16, @(foo:16, r2L.b).w), er1 + test_h_gr32 0x3254, er1 ; 69 + mova/w.l @(0x1234:16, @(foo:16, r2.w).w), er1 + test_h_gr32 0x3254, er1 ; 70 + mova/w.l @(0x1234:16, @(foo:16, er2.l).w), er1 + test_h_gr32 0x3254, er1 ; 71 + + mov.l #4, er2 + mova/w.l @(0x1234:16, @(foo:32, er2).w), er1 + test_h_gr32 0x3254, er1 ; 68 + shar.l er2 + mova/w.l @(0x1234:16, @(foo:32, r2L.b).w), er1 + test_h_gr32 0x3254, er1 ; 72 + mova/w.l @(0x1234:16, @(foo:32, r2.w).w), er1 + test_h_gr32 0x3254, er1 ; 73 + mova/w.l @(0x1234:16, @(foo:32, er2.l).w), er1 + test_h_gr32 0x3254, er1 ; 74 + + mova/w.l @(0x1234:16,@foo:16.w),er1 ;015F40B19ABC1234 + test_h_gr32 0x1436, er1 ; 75 (can't test -- points into the woods) + mova/w.l @(0x1234:16,@foo:32.w),er1 ;015F48B19ABCDEF01234 + test_h_gr32 0x1436, er1 ; 76 (can't test -- points into the woods) + +t02j: + mov.l #foo, er2 + mova/l.l @(0x1234:16,@er2.b),er1 ;017F02C11234 + test_h_gr32 0x1238, er1 ; 77 + mova/l.l @(0x1234:16,@(0x1:2,er2).b),er1 ;017F12C11234 + test_h_gr32 0x1238, er1 ; 82 + mova/l.l @(0x1234:16,@er2+.b),er1 ;017F82C11234 + test_h_gr32 0x1238, er1 ; 78 + test_h_gr32 foo+1, er2 + mova/l.l @(0x1234:16,@-er2.b),er1 ;017FB2C11234 + test_h_gr32 0x1238, er1 ; 79 + test_h_gr32 foo, er2 + mova/l.l @(0x1234:16,@+er2.b),er1 ;017F92C11234 + test_h_gr32 0x1238, er1 ; 80 + test_h_gr32 foo+1, er2 + mova/l.l @(0x1234:16,@er2-.b),er1 ;017FA2C11234 + test_h_gr32 0x1238, er1 ; 81 + test_h_gr32 foo, er2 + +t02k: + mov.l #4, er2 + mova/l.l @(0x1234:16, @(foo:16, er2).b), er1 + test_h_gr32 0x1274, er1 ; 83 + mova/l.l @(0x1234:16, @(foo:16, r2L.b).b), er1 + test_h_gr32 0x1274, er1 ; 85 + mova/l.l @(0x1234:16, @(foo:16, r2.w).b), er1 + test_h_gr32 0x1274, er1 ; 86 + mova/l.l @(0x1234:16, @(foo:16, er2.l).b), er1 + test_h_gr32 0x1274, er1 ; 87 + + mov.l #4, er2 + mova/l.l @(0x1234:16, @(foo:32, er2).b), er1 + test_h_gr32 0x1274, er1 ; 84 + mova/l.l @(0x1234:16, @(foo:32, r2L.b).b), er1 + test_h_gr32 0x1274, er1 ; 88 + mova/l.l @(0x1234:16, @(foo:32, r2.w).b), er1 + test_h_gr32 0x1274, er1 ; 89 + mova/l.l @(0x1234:16, @(foo:32, er2.l).b), er1 + test_h_gr32 0x1274, er1 ; 90 + + mova/l.l @(0x1234:16,@foo:16.b),er1 ;017F40C19ABC1234 + test_h_gr32 0x1238, er1 ; 91 (can't test -- points into the woods) + mova/l.l @(0x1234:16,@foo:32.b),er1 ;017F48C19ABCDEF01234 + test_h_gr32 0x1238, er1 ; 92 (can't test -- points into the woods) + +t02l: + mov.l #foo, er2 + mova/l.l @(0x1234:16,@er2.w),er1 ;015F02D11234 + test_h_gr32 0x1638, er1 ; 93 + mova/l.l @(0x1234:16,@(0x2:2,er2).w),er1 ;015F12D11234 + test_h_gr32 0x1638, er1 ; 98 + mova/l.l @(0x1234:16,@er2+.w),er1 ;015F82D11234 + test_h_gr32 0x1638, er1 ; 94 + test_h_gr32 foo+2, er2 + mova/l.l @(0x1234:16,@-er2.w),er1 ;015FB2D11234 + test_h_gr32 0x1638, er1 ; 97 + test_h_gr32 foo, er2 + mova/l.l @(0x1234:16,@+er2.w),er1 ;015F92D11234 + test_h_gr32 0x1638, er1 ; 96 + test_h_gr32 foo+2, er2 + mova/l.l @(0x1234:16,@er2-.w),er1 ;015FA2D11234 + test_h_gr32 0x1638, er1 ; 95 + test_h_gr32 foo, er2 + +t02o: + mov.l #4, er2 + mova/l.l @(0x1234:16, @(foo:16, er2).w), er1 + test_h_gr32 0x5274, er1 ; 99 + shar.l er2 + mova/l.l @(0x1234:16, @(foo:16, r2L.b).w), er1 + test_h_gr32 0x5274, er1 ; 101 + mova/l.l @(0x1234:16, @(foo:16, r2.w).w), er1 + test_h_gr32 0x5274, er1 ; 102 + mova/l.l @(0x1234:16, @(foo:16, er2.l).w), er1 + test_h_gr32 0x5274, er1 ; 103 + + mov.l #4, er2 + mova/l.l @(0x1234:16, @(foo:32, er2).w), er1 + test_h_gr32 0x5274, er1 ; 100 + shar.l er2 + mova/l.l @(0x1234:16, @(foo:32, r2L.b).w), er1 + test_h_gr32 0x5274, er1 ; 104 + mova/l.l @(0x1234:16, @(foo:32, r2.w).w), er1 + test_h_gr32 0x5274, er1 ; 105 + mova/l.l @(0x1234:16, @(foo:32, er2.l).w), er1 + test_h_gr32 0x5274, er1 ; 106 + + mova/l.l @(0x1234:16,@foo:16.w),er1 ;015F40D19ABC1234 + test_h_gr32 0x1638, er1 ; 107 (can't test -- points into the woods) + mova/l.l @(0x1234:16,@foo:32.w),er1 ;015F48D19ABCDEF01234 + test_h_gr32 0x1638, er1 ; 108 (can't test -- points into the woods) + +t02p: + mov.l #foo, er2 + mova/b.l @(0x12345678:32,@er2.b),er1 ;017F028912345678 + test_h_gr32 0x12345679, er1 ; 109 + mova/b.l @(0x12345678:32,@(0x1:2,er2).b),er1 ;017F128912345678 + test_h_gr32 0x12345679, er1 ; 114 + mova/b.l @(0x12345678:32,@er2+.b),er1 ;017F828912345678 + test_h_gr32 0x12345679, er1 ; 110 + test_h_gr32 foo+1, er2 + mova/b.l @(0x12345678:32,@-er2.b),er1 ;017FB28912345678 + test_h_gr32 0x12345679, er1 ; 113 + test_h_gr32 foo, er2 + mova/b.l @(0x12345678:32,@+er2.b),er1 ;017F928912345678 + test_h_gr32 0x12345679, er1 ; 112 + test_h_gr32 foo+1, er2 + mova/b.l @(0x12345678:32,@er2-.b),er1 ;017FA28912345678 + test_h_gr32 0x12345679, er1 ; 111 + test_h_gr32 foo, er2 + +t02q: + mov.l #4, er2 + mova/b.l @(0x12345678:32, @(foo:16, er2).b), er1 + test_h_gr32 0x12345688, er1 ; 115 + mova/b.l @(0x12345678:32, @(foo:16, r2L.b).b), er1 + test_h_gr32 0x12345688, er1 ; 117 + mova/b.l @(0x12345678:32, @(foo:16, r2.w).b), er1 + test_h_gr32 0x12345688, er1 ; 118 + mova/b.l @(0x12345678:32, @(foo:16, er2.l).b), er1 + test_h_gr32 0x12345688, er1 ; 119 + + mov.l #4, er2 + mova/b.l @(0x12345678:32, @(foo:32, er2).b), er1 + test_h_gr32 0x12345688, er1 ; 116 + mova/b.l @(0x12345678:32, @(foo:32, r2L.b).b), er1 + test_h_gr32 0x12345688, er1 ; 120 + mova/b.l @(0x12345678:32, @(foo:32, r2.w).b), er1 + test_h_gr32 0x12345688, er1 ; 121 + mova/b.l @(0x12345678:32, @(foo:32, er2.l).b), er1 + test_h_gr32 0x12345688, er1 ; 122 + + mova/b.l @(0x12345678:32,@foo:16.b),er1 + test_h_gr32 0x12345679, er1 ; 123 + mova/b.l @(0x12345678:32,@foo:32.b),er1 + test_h_gr32 0x12345679, er1 ; 124 + +t02r: + mov.l #foo, er2 + mova/b.l @(0x12345678:32,@er2.w),er1 ;015F029912345678 + test_h_gr32 0x12345779, er1 ; 125 + mova/b.l @(0x12345678:32,@(0x2:2,er2).w),er1 ;015F129912345678 + test_h_gr32 0x12345779, er1 ; 130 + mova/b.l @(0x12345678:32,@er2+.w),er1 ;015F829912345678 + test_h_gr32 0x12345779, er1 ; 126 + test_h_gr32 foo+2, er2 + mova/b.l @(0x12345678:32,@-er2.w),er1 ;015FB29912345678 + test_h_gr32 0x12345779, er1 ; 129 + test_h_gr32 foo, er2 + mova/b.l @(0x12345678:32,@+er2.w),er1 ;015F929912345678 + test_h_gr32 0x12345779, er1 ; 128 + test_h_gr32 foo+2, er2 + mova/b.l @(0x12345678:32,@er2-.w),er1 ;015FA29912345678 + test_h_gr32 0x12345779, er1 ; 127 + test_h_gr32 foo, er2 + + mov.l #4, er2 + mova/b.l @(0x12345678:32, @(foo:16, er2).w), er1 + test_h_gr32 0x12346688, er1 ; 131 + shar.l er2 + mova/b.l @(0x12345678:32, @(foo:16, r2L.b).w), er1 + test_h_gr32 0x12346688, er1 ; 133 + mova/b.l @(0x12345678:32, @(foo:16, r2.w).w), er1 + test_h_gr32 0x12346688, er1 ; 134 + mova/b.l @(0x12345678:32, @(foo:16, er2.l).w), er1 + test_h_gr32 0x12346688, er1 ; 135 + + mov.l #4, er2 + mova/b.l @(0x12345678:32, @(foo:32, er2).w), er1 + test_h_gr32 0x12346688, er1 ; 132 + shar.l er2 + mova/b.l @(0x12345678:32, @(foo:32, r2L.b).w), er1 + test_h_gr32 0x12346688, er1 ; 136 + mova/b.l @(0x12345678:32, @(foo:32, r2.w).w), er1 + test_h_gr32 0x12346688, er1 ; 137 + mova/b.l @(0x12345678:32, @(foo:32, er2.l).w), er1 + test_h_gr32 0x12346688, er1 ; 138 + + mova/b.l @(0x12345678:32,@foo:16.w),er1 + test_h_gr32 0x12345779, er1 ; 139 + mova/b.l @(0x12345678:32,@foo:32.w),er1 + test_h_gr32 0x12345779, er1 ; 140 + +t02s: + mov.l #foo, er2 + mova/w.l @(0x12345678:32,@er2.b),er1 ;017F02A912345678 + test_h_gr32 0x1234567a, er1 ; 141 + mova/w.l @(0x12345678:32,@(0x1:2,er2).b),er1 ;017F12A912345678 + test_h_gr32 0x1234567a, er1 ; 146 + mova/w.l @(0x12345678:32,@er2+.b),er1 ;017F82A912345678 + test_h_gr32 0x1234567a, er1 ; 142 + test_h_gr32 foo+1, er2 + mova/w.l @(0x12345678:32,@-er2.b),er1 ;017FB2A912345678 + test_h_gr32 0x1234567a, er1 ; 145 + test_h_gr32 foo, er2 + mova/w.l @(0x12345678:32,@+er2.b),er1 ;017F92A912345678 + test_h_gr32 0x1234567a, er1 ; 144 + test_h_gr32 foo+1, er2 + mova/w.l @(0x12345678:32,@er2-.b),er1 ;017FA2A912345678 + test_h_gr32 0x1234567a, er1 ; 143 + test_h_gr32 foo, er2 + + mov.l #4, er2 + mova/w.l @(0x12345678:32, @(foo:16, er2).b), er1 + test_h_gr32 0x12345698, er1 ; 147 + mova/w.l @(0x12345678:32, @(foo:16, r2L.b).b), er1 + test_h_gr32 0x12345698, er1 ; 149 + mova/w.l @(0x12345678:32, @(foo:16, r2.w).b), er1 + test_h_gr32 0x12345698, er1 ; 150 + mova/w.l @(0x12345678:32, @(foo:16, er2.l).b), er1 + test_h_gr32 0x12345698, er1 ; 151 + + mov.l #4, er2 + mova/w.l @(0x12345678:32, @(foo:32, er2).b), er1 + test_h_gr32 0x12345698, er1 ; 148 + mova/w.l @(0x12345678:32, @(foo:32, r2L.b).b), er1 + test_h_gr32 0x12345698, er1 ; 152 + mova/w.l @(0x12345678:32, @(foo:32, r2.w).b), er1 + test_h_gr32 0x12345698, er1 ; 153 + mova/w.l @(0x12345678:32, @(foo:32, er2.l).b), er1 + test_h_gr32 0x12345698, er1 ; 154 + + mova/w.l @(0x12345678:32,@foo:16.b),er1 + test_h_gr32 0x1234567a, er1 ; 155 + mova/w.l @(0x12345678:32,@foo:32.b),er1 + test_h_gr32 0x1234567a, er1 ; 156 + +t02t: + mov.l #foo, er2 + mova/w.l @(0x12345678:32,@er2.w),er1 ;015F02B912345678 + test_h_gr32 0x1234587a, er1 ; 157 + mova/w.l @(0x12345678:32,@(0x2:2,er2).w),er1 ;015F12B912345678 + test_h_gr32 0x1234587a, er1 ; 162 + mova/w.l @(0x12345678:32,@er2+.w),er1 ;015F82B912345678 + test_h_gr32 0x1234587a, er1 ; 158 + test_h_gr32 foo+2, er2 + mova/w.l @(0x12345678:32,@-er2.w),er1 ;015FB2B912345678 + test_h_gr32 0x1234587a, er1 ; 161 + test_h_gr32 foo, er2 + mova/w.l @(0x12345678:32,@+er2.w),er1 ;015F92B912345678 + test_h_gr32 0x1234587a, er1 ; 160 + test_h_gr32 foo+2, er2 + mova/w.l @(0x12345678:32,@er2-.w),er1 ;015FA2B912345678 + test_h_gr32 0x1234587a, er1 ; 159 + test_h_gr32 foo, er2 + + mov.l #4, er2 + mova/w.l @(0x12345678:32, @(foo:16, er2).w), er1 + test_h_gr32 0x12347698, er1 ; 163 + shar.l er2 + mova/w.l @(0x12345678:32, @(foo:16, r2L.b).w), er1 + test_h_gr32 0x12347698, er1 ; 165 + mova/w.l @(0x12345678:32, @(foo:16, r2.w).w), er1 + test_h_gr32 0x12347698, er1 ; 166 + mova/w.l @(0x12345678:32, @(foo:16, er2.l).w), er1 + test_h_gr32 0x12347698, er1 ; 167 + + mov.l #4, er2 + mova/w.l @(0x12345678:32, @(foo:32, er2).w), er1 + test_h_gr32 0x12347698, er1 ; 164 + shar.l er2 + mova/w.l @(0x12345678:32, @(foo:32, r2L.b).w), er1 + test_h_gr32 0x12347698, er1 ; 168 + mova/w.l @(0x12345678:32, @(foo:32, r2.w).w), er1 + test_h_gr32 0x12347698, er1 ; 169 + mova/w.l @(0x12345678:32, @(foo:32, er2.l).w), er1 + test_h_gr32 0x12347698, er1 ; 170 + + mova/w.l @(0x12345678:32,@foo:16.w),er1 + test_h_gr32 0x1234587a, er1 ; 171 + mova/w.l @(0x12345678:32,@foo:32.w),er1 + test_h_gr32 0x1234587a, er1 ; 172 + +t02u: + mov.l #foo, er2 + mova/l.l @(0x12345678:32,@er2.b),er1 ;017F02C912345678 + test_h_gr32 0x1234567c, er1 ; 173 + mova/l.l @(0x12345678:32,@(0x1:2,er2).b),er1 ;017F12C912345678 + test_h_gr32 0x1234567c, er1 ; 178 + mova/l.l @(0x12345678:32,@er2+.b),er1 ;017F82C912345678 + test_h_gr32 0x1234567c, er1 ; 174 + test_h_gr32 foo+1, er2 + mova/l.l @(0x12345678:32,@-er2.b),er1 ;017FB2C912345678 + test_h_gr32 0x1234567c, er1 ; 177 + test_h_gr32 foo, er2 + mova/l.l @(0x12345678:32,@+er2.b),er1 ;017F92C912345678 + test_h_gr32 0x1234567c, er1 ; 176 + test_h_gr32 foo+1, er2 + mova/l.l @(0x12345678:32,@er2-.b),er1 ;017FA2C912345678 + test_h_gr32 0x1234567c, er1 ; 175 + test_h_gr32 foo, er2 + + mov.l #4, er2 + mova/l.l @(0x12345678:32, @(foo:16, er2).b), er1 + test_h_gr32 0x123456b8, er1 ; 179 + mova/l.l @(0x12345678:32, @(foo:16, r2L.b).b), er1 + test_h_gr32 0x123456b8, er1 ; 181 + mova/l.l @(0x12345678:32, @(foo:16, r2.w).b), er1 + test_h_gr32 0x123456b8, er1 ; 182 + mova/l.l @(0x12345678:32, @(foo:16, er2.l).b), er1 + test_h_gr32 0x123456b8, er1 ; 183 + + mov.l #4, er2 + mova/l.l @(0x12345678:32, @(foo:32, er2).b), er1 + test_h_gr32 0x123456b8, er1 ; 180 + mova/l.l @(0x12345678:32, @(foo:32, r2L.b).b), er1 + test_h_gr32 0x123456b8, er1 ; 184 + mova/l.l @(0x12345678:32, @(foo:32, r2.w).b), er1 + test_h_gr32 0x123456b8, er1 ; 185 + mova/l.l @(0x12345678:32, @(foo:32, er2.l).b), er1 + test_h_gr32 0x123456b8, er1 ; 186 + + mova/l.l @(0x12345678:32,@foo:16.b),er1 + test_h_gr32 0x1234567c, er1 ; 187 + mova/l.l @(0x12345678:32,@foo:32.b),er1 + test_h_gr32 0x1234567c, er1 ; 188 + +t02v: + mov.l #foo, er2 + mova/l.l @(0x12345678:32,@er2.w),er1 ;015F02D912345678 + test_h_gr32 0x12345a7c, er1 ; 189 + mova/l.l @(0x12345678:32,@(0x2:2,er2).w),er1 ;015F12D912345678 + test_h_gr32 0x12345a7c, er1 ; 194 + mova/l.l @(0x12345678:32,@er2+.w),er1 ;015F82D912345678 + test_h_gr32 0x12345a7c, er1 ; 190 + test_h_gr32 foo+2, er2 + mova/l.l @(0x12345678:32,@-er2.w),er1 ;015FB2D912345678 + test_h_gr32 0x12345a7c, er1 ; 193 + test_h_gr32 foo, er2 + mova/l.l @(0x12345678:32,@+er2.w),er1 ;015F92D912345678 + test_h_gr32 0x12345a7c, er1 ; 192 + test_h_gr32 foo+2, er2 + mova/l.l @(0x12345678:32,@er2-.w),er1 ;015FA2D912345678 + test_h_gr32 0x12345a7c, er1 ; 191 + test_h_gr32 foo, er2 + + mov.l #4, er2 + mova/l.l @(0x12345678:32, @(foo:16, er2).w), er1 + test_h_gr32 0x123496b8, er1 ; 195 + shar.l er2 + mova/l.l @(0x12345678:32, @(foo:16, r2L.b).w), er1 + test_h_gr32 0x123496b8, er1 ; 197 + mova/l.l @(0x12345678:32, @(foo:16, r2.w).w), er1 + test_h_gr32 0x123496b8, er1 ; 198 + mova/l.l @(0x12345678:32, @(foo:16, er2.l).w), er1 + test_h_gr32 0x123496b8, er1 ; 199 + + mov.l #4, er2 + mova/l.l @(0x12345678:32, @(foo:32, er2).w), er1 + test_h_gr32 0x123496b8, er1 ; 195 + shar.l er2 + mova/l.l @(0x12345678:32, @(foo:32, r2L.b).w), er1 + test_h_gr32 0x123496b8, er1 ; 197 + mova/l.l @(0x12345678:32, @(foo:32, r2.w).w), er1 + test_h_gr32 0x123496b8, er1 ; 198 + mova/l.l @(0x12345678:32, @(foo:32, er2.l).w), er1 + test_h_gr32 0x123496b8, er1 ; 199 + + mova/l.l @(0x12345678:32,@foo:16.w),er1 + test_h_gr32 0x12345a7c, er1 ; 203 + mova/l.l @(0x12345678:32,@foo:32.w),er1 + test_h_gr32 0x12345a7c, er1 ; 204 + + test_gr_a5a5 0 + test_h_gr32 2, er2 + test_h_gr32 0x01010101, er3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 + pass exit 0 diff --git a/sim/testsuite/sim/h8300/shll.s b/sim/testsuite/sim/h8300/shll.s index fcff565..7fbf14d 100644 --- a/sim/testsuite/sim/h8300/shll.s +++ b/sim/testsuite/sim/h8300/shll.s @@ -90,6 +90,28 @@ shll_b_reg8_4: test_gr_a5a5 5 test_gr_a5a5 6 test_gr_a5a5 7 + +shll_b_reg8_reg8: + set_grs_a5a5 ; Fill all general regs with a fixed pattern + set_ccr_zero + + mov #5, r0h + shll.b r0h, r0l ; shift left logical by register value + + test_carry_clear ; H=0 N=1 Z=0 V=0 C=0 + test_zero_clear + test_ovf_clear + test_neg_set + test_h_gr16 0x05a0 r0 ; 1010 0101 -> 1010 0000 + test_h_gr32 0xa5a505a0 er0 + + test_gr_a5a5 1 ; Make sure other general regs not disturbed + test_gr_a5a5 2 + test_gr_a5a5 3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 .endif .if (sim_cpu) ; Not available in h8300 mode @@ -181,6 +203,28 @@ shll_w_reg16_8: test_gr_a5a5 5 test_gr_a5a5 6 test_gr_a5a5 7 + +shll_w_reg16_reg8: + set_grs_a5a5 ; Fill all general regs with a fixed pattern + set_ccr_zero + + mov #5, r0h + shll.w r0h, r0 ; shift left logical by register value + + test_carry_clear ; H=0 N=1 Z=0 V=0 C=0 + test_zero_clear + test_ovf_clear + test_neg_set + test_h_gr16 0xb4a0 r0 ; 1010 0101 1010 0101 -> 1011 0100 1010 0000 + test_h_gr32 0xa5a5b4a0 er0 + + test_gr_a5a5 1 ; Make sure other general regs not disturbed + test_gr_a5a5 2 + test_gr_a5a5 3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 .endif shll_l_reg32_1: @@ -299,6 +343,29 @@ shll_l_reg32_16: test_gr_a5a5 5 test_gr_a5a5 6 test_gr_a5a5 7 + +shll_l_reg32_reg8: + set_grs_a5a5 ; Fill all general regs with a fixed pattern + set_ccr_zero + + mov #5, r1l + shll.l r1l, er0 ; shift left logical by register value + + test_carry_clear ; H=0 N=1 Z=0 V=0 C=0 + test_zero_clear + test_ovf_clear + test_neg_set + ; 1010 0101 1010 0101 1010 0101 1010 0101 + ; -> 1011 0100 1011 0100 1011 0100 1010 0000 + test_h_gr32 0xb4b4b4a0 er0 + + test_h_gr32 0xa5a5a505 er1 + test_gr_a5a5 2 ; Make sure other general regs not disturbed + test_gr_a5a5 3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 .endif .endif diff --git a/sim/testsuite/sim/h8300/shlr.s b/sim/testsuite/sim/h8300/shlr.s index f7dffc2..4223313 100644 --- a/sim/testsuite/sim/h8300/shlr.s +++ b/sim/testsuite/sim/h8300/shlr.s @@ -691,6 +691,28 @@ shlr_b_reg8_4: test_gr_a5a5 6 test_gr_a5a5 7 +shlr_b_reg8_reg8: + set_grs_a5a5 ; Fill all general regs with a fixed pattern + set_ccr_zero + + mov #5, r0h + shlr.b r0h, r0l ; shift right logical by register value + + test_carry_clear ; H=0 N=0 Z=0 V=0 C=0 + test_zero_clear + test_ovf_clear + test_neg_clear + + test_h_gr16 0x0505 r0 ; 1010 0101 -> 0000 0101 + test_h_gr32 0xa5a50505 er0 + test_gr_a5a5 1 ; Make sure other general regs not disturbed + test_gr_a5a5 2 + test_gr_a5a5 3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 + shlr_b_ind_4: set_grs_a5a5 ; Fill all general regs with a fixed pattern set_ccr_zero @@ -1685,6 +1707,28 @@ shlr_w_reg16_4: test_gr_a5a5 6 test_gr_a5a5 7 +shlr_w_reg16_reg8: + set_grs_a5a5 ; Fill all general regs with a fixed pattern + set_ccr_zero + + mov #5, r1l + shlr.w r1l, r0 ; shift right logical by register value + + test_carry_clear ; H=0 N=0 Z=0 V=0 C=0 + test_zero_clear + test_ovf_clear + test_neg_clear + + test_h_gr16 0x052d r0 ; 1010 0101 1010 0101 -> 0000 0101 0010 1101 + test_h_gr32 0xa5a5052d er0 + test_h_gr32 0xa5a5a505 er1 + test_gr_a5a5 2 ; Make sure other general regs not disturbed + test_gr_a5a5 3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 + shlr_w_ind_4: set_grs_a5a5 ; Fill all general regs with a fixed pattern set_ccr_zero @@ -3029,6 +3073,29 @@ shlr_l_reg32_4: test_gr_a5a5 6 test_gr_a5a5 7 +shlr_l_reg32_reg8: + set_grs_a5a5 ; Fill all general regs with a fixed pattern + set_ccr_zero + + mov #5, r1l + shlr.l r1l, er0 ; shift right logical by value of register + + test_carry_clear ; H=0 N=0 Z=0 V=0 C=0 + test_zero_clear + test_ovf_clear + test_neg_clear + ; 1010 0101 1010 0101 1010 0101 1010 0101 + ; -> 0000 0101 0010 1101 0010 1101 0010 1101 + test_h_gr32 0x052d2d2d er0 + test_h_gr32 0xa5a5a505 er1 + + test_gr_a5a5 2 ; Make sure other general regs not disturbed + test_gr_a5a5 3 + test_gr_a5a5 4 + test_gr_a5a5 5 + test_gr_a5a5 6 + test_gr_a5a5 7 + shlr_l_ind_4: set_grs_a5a5 ; Fill all general regs with a fixed pattern set_ccr_zero -- 2.7.4