8sa1-binutils-gdb/sim/testsuite/msp430/testutils.inc
Mike Frysinger 1368b914e9 sim: testsuite: flatten tree
Now that all port tests live under testsuite/sim/*/, and none live
in testsuite/ directly, flatten the structure by moving all of the
dirs under testsuite/sim/ to testsuite/ directly.

We need to stop passing --tool to dejagnu so that it searches all
dirs and not just ones that start with "sim".  Since we have no
other dirs in this tree, and no plans to add any, should be fine.
2021-01-15 19:18:34 -05:00

101 lines
2.1 KiB
PHP

# 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:
# Note - we cannot just invoke:
#
# write 1, _passmsg, 5
#
# here because _passmsg contains the run-time (VMA) address of
# the pass string (probably 0x500) not the load-time (LMA)
# address (probably 0x804c). Normally using the VMA address
# would be the correct thing to do - *if* there was some start
# up code which copied data from LMA to VMA. But we have no
# start up code, so the data still resides at the LMA
# address. Hence we use __romdatastart instead.
#
# Note - we are cheating because the address that we pass to
# "write" should actually be:
#
# __romdatastart + (_passmsg - __datastart)
#
# but the assembler cannot cope with this expression. So we
# cheat and use the fact that we know that _passmsg is the
# first string in the .data section and so (_passmsg -
# __datastart) evaluates to zero.
write 1, __romdatastart, 5
exit 0
.global __fail
.type __fail, function
__fail:
# Note - see above.
#
# write 1, _failmsg, 5
#
# This time we use the fact that _passmsg is aligned to a
# 16 byte boundary to work out that (_failmsg - __datastart)
# evaluates to 0x10.
write 1, __romdatastart + 0x10, 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