aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/microblaze/testutils.inc
blob: f222be9dccdc3d95b96778325c40c6b008287227 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# MACRO: system_call
# Make a libgloss/Linux system call
	.macro system_call nr:req
	addi r12, r0, \nr;
	brki r14, 8;
	.endm

# MACRO: exit
	.macro exit nr:req
	addi r3, r0, \nr;
	bri 0;
	.endm

# MACRO: pass
# Write 'pass' to stdout and quit
	.macro pass
	write 1, 1f, 5
	exit 0
	.data
	1: .asciz "pass\n"
	.endm

# MACRO: fail
# Write 'fail' to stdout and quit
	.macro fail
	write 1, 1f, 5
	exit 1
	.data
	1: .asciz "fail\n"
	.endm

# MACRO: start
# All assembler tests should start with a call to "start"
	.macro start
	.text
.global _start
_start:
	.endm

# MACRO: write
# Just like the write() C function; uses system calls
	.macro write fd:req, buf:req, count:req
	addi r5, r0, \fd;
	addi r6, r0, \buf;
	addi r7, r0, \count;
	system_call 5
	.endm