Commit e4630047e161ac1b23bfd37b2c52785fce49400a
1 parent
73e14b62
Simple test for mips/mipsel, based on a test by Alexander Voropay.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2246 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
2 changed files
with
71 additions
and
0 deletions
tests/Makefile
... | ... | @@ -82,6 +82,13 @@ hello-arm: hello-arm.o |
82 | 82 | hello-arm.o: hello-arm.c |
83 | 83 | arm-linux-gcc -Wall -g -O2 -c -o $@ $< |
84 | 84 | |
85 | +# MIPS test | |
86 | +hello-mips: hello-mips.c | |
87 | + mips-linux-gnu-gcc -nostdlib -static -mno-abicalls -fno-PIC -mabi=32 -Wall -Wextra -g -O2 -o $@ $< | |
88 | + | |
89 | +hello-mipsel: hello-mips.c | |
90 | + mipsel-linux-gnu-gcc -nostdlib -static -mno-abicalls -fno-PIC -mabi=32 -Wall -Wextra -g -O2 -o $@ $< | |
91 | + | |
85 | 92 | # XXX: find a way to compile easily a test for each arch |
86 | 93 | test2: |
87 | 94 | @for arch in i386 arm armeb sparc ppc mips mipsel; do \ | ... | ... |
tests/hello-mips.c
0 → 100644
1 | +/* | |
2 | +* MIPS o32 Linux syscall example | |
3 | +* | |
4 | +* http://www.linux-mips.org/wiki/RISC/os | |
5 | +* http://www.linux-mips.org/wiki/MIPSABIHistory | |
6 | +* http://www.linux.com/howtos/Assembly-HOWTO/mips.shtml | |
7 | +* | |
8 | +* mipsel-linux-gcc -nostdlib -mno-abicalls -fno-PIC -mabi=32 \ | |
9 | +* -O2 -static -o hello-mips hello-mips.c | |
10 | +* | |
11 | +*/ | |
12 | +#define __NR_SYSCALL_BASE 4000 | |
13 | +#define __NR_exit (__NR_SYSCALL_BASE+ 1) | |
14 | +#define __NR_write (__NR_SYSCALL_BASE+ 4) | |
15 | + | |
16 | +static inline void exit1(int status) | |
17 | +{ | |
18 | + register unsigned long __a0 asm("$4") = (unsigned long) status; | |
19 | + | |
20 | + __asm__ __volatile__ ( | |
21 | + " .set push \n" | |
22 | + " .set noreorder \n" | |
23 | + " li $2, %0 \n" | |
24 | + " syscall \n" | |
25 | + " .set pop " | |
26 | + : | |
27 | + : "i" (__NR_exit), "r" (__a0) | |
28 | + : "$2", "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24", | |
29 | + "memory"); | |
30 | +} | |
31 | + | |
32 | +static inline int write(int fd, const char *buf, int len) | |
33 | +{ | |
34 | + register unsigned long __a0 asm("$4") = (unsigned long) fd; | |
35 | + register unsigned long __a1 asm("$5") = (unsigned long) buf; | |
36 | + register unsigned long __a2 asm("$6") = (unsigned long) len; | |
37 | + register unsigned long __a3 asm("$7"); | |
38 | + unsigned long __v0; | |
39 | + | |
40 | + __asm__ __volatile__ ( | |
41 | + " .set push \n" | |
42 | + " .set noreorder \n" | |
43 | + " li $2, %2 \n" | |
44 | + " syscall \n" | |
45 | + " move %0, $2 \n" | |
46 | + " .set pop " | |
47 | + : "=r" (__v0), "=r" (__a3) | |
48 | + : "i" (__NR_write), "r" (__a0), "r" (__a1), "r" (__a2) | |
49 | + : "$2", "$8", "$9", "$10", "$11", "$12", "$13", "$14", "$15", "$24", | |
50 | + "memory"); | |
51 | + | |
52 | +/* if (__a3 == 0) */ | |
53 | + return (int) __v0; | |
54 | +/* | |
55 | + errno = __v0; | |
56 | + return -1; | |
57 | + */ | |
58 | +} | |
59 | + | |
60 | +void __start(void) | |
61 | +{ | |
62 | + write (1, "Hello, World!\n", 14); | |
63 | + exit1 (42); | |
64 | +} | ... | ... |