sim: msp430: start a test framework
authorMike Frysinger <vapier@gentoo.org>
Sat, 8 Mar 2014 05:21:13 +0000 (00:21 -0500)
committerMike Frysinger <vapier@gentoo.org>
Tue, 11 Mar 2014 03:59:59 +0000 (23:59 -0400)
The current sim lacks any sort of tests.  Start a basic framework and
add a simple one to test the add insn.

sim/ChangeLog
sim/configure
sim/configure.tgt
sim/testsuite/ChangeLog
sim/testsuite/configure
sim/testsuite/sim/msp430/ChangeLog [new file with mode: 0644]
sim/testsuite/sim/msp430/add.s [new file with mode: 0644]
sim/testsuite/sim/msp430/allinsn.exp [new file with mode: 0644]
sim/testsuite/sim/msp430/testutils.inc [new file with mode: 0644]

index 71d9db9..32feec8 100644 (file)
@@ -1,3 +1,8 @@
+2014-03-10  Mike Frysinger  <vapier@gentoo.org>
+
+       * configure.tgt (msp430*-*-*): Set sim_testsuite to yes.
+       * configure: Regenerate.
+
 2014-01-06  Tom Tromey  <tromey@redhat.com>
 
        * common/cgen-trace.c: Don't use old VA_* macros.
index ab98231..36d356e 100755 (executable)
@@ -3775,6 +3775,7 @@ subdirs="$subdirs arm"
   subdirs="$subdirs msp430"
 
 
+       sim_testsuite=yes
        ;;
    rl78-*-*)
 
index 39f92b6..d112e72 100644 (file)
@@ -88,6 +88,7 @@ case "${target}" in
        ;;
    msp430*-*-*)
        SIM_ARCH(msp430)
+       sim_testsuite=yes
        ;;
    rl78-*-*)
        SIM_ARCH(rl78)
index 86aa1ce..be7ad56 100644 (file)
@@ -1,3 +1,7 @@
+2014-03-10  Mike Frysinger  <vapier@gentoo.org>
+
+       * configure: Regenerate.
+
 2014-03-04  Mike Frysinger  <vapier@gentoo.org>
 
        * common/bits-gen.c (main): Change to new style prototype.
index af18624..f90bd47 100755 (executable)
@@ -1895,6 +1895,7 @@ case "${target}" in
        ;;
    msp430*-*-*)
        sim_arch=msp430
+       sim_testsuite=yes
        ;;
    rl78-*-*)
        sim_arch=rl78
diff --git a/sim/testsuite/sim/msp430/ChangeLog b/sim/testsuite/sim/msp430/ChangeLog
new file mode 100644 (file)
index 0000000..d26efad
--- /dev/null
@@ -0,0 +1,3 @@
+2014-03-10  Mike Frysinger  <vapier@gentoo.org>
+
+       * add.s, allinsn.exp, testutils.inc: New files.
diff --git a/sim/testsuite/sim/msp430/add.s b/sim/testsuite/sim/msp430/add.s
new file mode 100644 (file)
index 0000000..76247ed
--- /dev/null
@@ -0,0 +1,20 @@
+# check that basic add insn works.
+# mach: msp430
+
+.include "testutils.inc"
+
+       start
+
+       mov #10, r4
+       add #23, r4
+       cmp #33, r4
+       jne 1f
+
+       cmp #32, r4
+       jlo 1f
+
+       cmp #34, r4
+       jhs 1f
+
+       pass
+1:     fail
diff --git a/sim/testsuite/sim/msp430/allinsn.exp b/sim/testsuite/sim/msp430/allinsn.exp
new file mode 100644 (file)
index 0000000..affa8ae
--- /dev/null
@@ -0,0 +1,15 @@
+# msp430 simulator testsuite
+
+if [istarget msp430-*] {
+    # all machines
+    set all_machs "msp430"
+
+    foreach src [lsort [glob -nocomplain $srcdir/$subdir/*.s]] {
+       # If we're only testing specific files and this isn't one of them,
+       # skip it.
+       if ![runtest_file_p $runtests $src] {
+           continue
+       }
+       run_sim_test $src $all_machs
+    }
+}
diff --git a/sim/testsuite/sim/msp430/testutils.inc b/sim/testsuite/sim/msp430/testutils.inc
new file mode 100644 (file)
index 0000000..6c540b1
--- /dev/null
@@ -0,0 +1,70 @@
+# MACRO: start
+# All assembler tests should start with a call to "start"
+       .macro start
+       .text
+
+       # Skip over these inlined funcs.
+       jmp __start;
+
+       .global __pass
+       .type __pass, function
+__pass:
+       write 1, _passmsg, 5
+       exit 0
+
+       .global __fail
+       .type __fail, function
+__fail:
+       write 1, _failmsg, 5
+       exit 1
+
+       .data
+_passmsg:
+       .ascii "pass\n"
+       .align 4
+
+_failmsg:
+       .ascii "fail\n"
+       .align 4
+
+       .text
+       .global __start
+       .type __start, function
+__start:
+       .endm
+
+# MACRO: system_call
+# Make a libgloss/Linux system call
+       .macro system_call nr:req
+       call #(0x180|\nr);
+       .endm
+
+# MACRO: exit
+# Quit the current test
+       .macro exit rc:req
+       mov #\rc, r12
+       system_call 1
+       .endm
+
+# MACRO: pass
+# Write 'pass' to stdout via syscalls and quit;
+# meant for non-OS operating environments
+       .macro pass
+       jmp __pass;
+       .endm
+
+# MACRO: fail
+# Write 'fail' to stdout via syscalls and quit;
+# meant for non-OS operating environments
+       .macro fail
+       jmp __fail;
+       .endm
+
+# MACRO: write
+# Just like the write() C function; uses system calls
+       .macro write fd:req, buf:req, count:req
+       mov #\fd, r12;
+       mov #\buf, r13;
+       mov #\count, r14;
+       system_call 5
+       .endm