source: trunk/Softwares/Test/Test_011/src/sys/crt0.s

Last change on this file was 101, checked in by rosiere, 16 years ago

1) Add soc test
2) fix bug (Pc management, Decod and execute, Update prediction ...)

  • Property svn:keywords set to Id
File size: 5.3 KB
Line 
1/*
2 * Test_011
3 *
4 * end_ko : infinite_loop
5 * end_ok : Write in R1 the stop address and stop an data
6 *          The store in the destination of an jump
7 * start  : Test l.addi
8 */
9       
10        .file   "crt0.s"
11        /*
12        .section .vector
13        */
14        .section .text
15        .align  4       
16
17/* ---[ 0x0  : Print a error ]------------------------------------------- */
18
19        .org 0x0
20_end_ko        :       
21        l.movhi r1,     hi(_tty)
22        l.ori   r1, r1, lo(_tty)
23        l.sw    4(r1), r1 /* stop address */
24_infinite_loop :       
25        l.j     _infinite_loop
26        l.nop
27
28_end_ok :
29        l.movhi r1,     hi(_tty)
30        l.ori   r1, r1, lo(_tty)
31        l.sw    4(r1), r0 /* stop address */
32
33
34/* ---[ 0x100: RESET exception ]----------------------------------------- */
35        .org 0x100
36        .global _start
37_start:
38        /*
39             A (r1)     B (I)  - D (r3 wait)CY OV (SR = r6, mask SR = r5)
40                                       (r4)                (r7)
41          1) 0x00000000 0x0000 - 0x00000000 0  0
42          2) 0x14011959 0x1959 - 0x140132b2 0  0
43          3) 0xebfee6a7 0xe6a7 - 0xebfecd4e 1  0
44          4) 0xebfee6a7 0x1959 - 0xebff0000 0  0
45          5) 0x14011959 0xe6a7 - 0x14010000 1  0
46          6) 0x87654321 0xabcd - 0x8764eeee 1  0
47          7) 0x7fffffff 0x5432 - 0x80005431 0  1
48          */
49
50        /* Mask to read OV (SR[11]), CY (SR[10]) and not F (SR[9]) */
51        l.movhi r5,     hi(0x00000c00)
52        l.ori   r5, r5, lo(0x00000c00)
53       
54        /**********/
55        /* Test 1 */
56        /**********/
57        l.movhi r1,     hi(0x00000000) /* RA */
58        l.ori   r1, r1, lo(0x00000000)
59        l.movhi r3,     hi(0x00000000) /* RD wait */
60        l.ori   r3, r3, lo(0x00000000)
61        l.movhi r6,     hi(0x00000000) /* SR wait */
62        l.ori   r6, r6, lo(0x00000000)
63       
64        l.addi  r4, r1, 0x0000
65
66        /* Test flag */
67        l.mfspr r7, r0, 17
68        l.and   r7, r7, r5
69
70        l.sfeq  r6, r7
71        l.bnf   _end_ko
72        l.nop
73
74        /* Test result */
75        l.sfeq  r3, r4
76        l.bnf   _end_ko
77        l.nop
78
79        /**********/
80        /* Test 2 */
81        /**********/
82        l.movhi r1,     hi(0x14011959) /* RA */
83        l.ori   r1, r1, lo(0x14011959)
84        l.movhi r3,     hi(0x140132b2) /* RD wait */
85        l.ori   r3, r3, lo(0x140132b2)
86        l.movhi r6,     hi(0x00000000) /* SR wait */
87        l.ori   r6, r6, lo(0x00000000)
88       
89        l.addi  r4, r1, 0x1959
90
91        /* Test flag */
92        l.mfspr r7, r0, 17
93        l.and   r7, r7, r5
94
95        l.sfeq  r6, r7
96        l.bnf   _end_ko
97        l.nop
98
99        /* Test result */
100        l.sfeq  r3, r4
101        l.bnf   _end_ko
102        l.nop
103
104        /**********/
105        /* Test 3 */
106        /**********/
107        l.movhi r1,     hi(0xebfee6a7) /* RA */
108        l.ori   r1, r1, lo(0xebfee6a7)
109        l.movhi r3,     hi(0xebfecd4e) /* RD wait */
110        l.ori   r3, r3, lo(0xebfecd4e)
111        l.movhi r6,     hi(0x00000400) /* SR wait */
112        l.ori   r6, r6, lo(0x00000400)
113       
114        l.addi  r4, r1, 0xe6a7
115
116        /* Test flag */
117        l.mfspr r7, r0, 17
118        l.and   r7, r7, r5
119
120        l.sfeq  r6, r7
121        l.bnf   _end_ko
122        l.nop
123
124        /* Test result */
125        l.sfeq  r3, r4
126        l.bnf   _end_ko
127        l.nop
128
129        /**********/
130        /* Test 4 */
131        /**********/
132        l.movhi r1,     hi(0xebfee6a7) /* RA */
133        l.ori   r1, r1, lo(0xebfee6a7)
134        l.movhi r3,     hi(0xebff0000) /* RD wait */
135        l.ori   r3, r3, lo(0xebff0000)
136        l.movhi r6,     hi(0x00000000) /* SR wait */
137        l.ori   r6, r6, lo(0x00000000)
138       
139        l.addi  r4, r1, 0x1959
140
141        /* Test flag */
142        l.mfspr r7, r0, 17
143        l.and   r7, r7, r5
144
145        l.sfeq  r6, r7
146        l.bnf   _end_ko
147        l.nop
148
149        /* Test result */
150        l.sfeq  r3, r4
151        l.bnf   _end_ko
152        l.nop
153
154        /**********/
155        /* Test 5 */
156        /**********/
157        l.movhi r1,     hi(0x14011959) /* RA */
158        l.ori   r1, r1, lo(0x14011959)
159        l.movhi r3,     hi(0x14010000) /* RD wait */
160        l.ori   r3, r3, lo(0x14010000)
161        l.movhi r6,     hi(0x00000400) /* SR wait */
162        l.ori   r6, r6, lo(0x00000400)
163       
164        l.addi  r4, r1, 0xe6a7
165
166        /* Test flag */
167        l.mfspr r7, r0, 17
168        l.and   r7, r7, r5
169
170        l.sfeq  r6, r7
171        l.bnf   _end_ko
172        l.nop
173
174        /* Test result */
175        l.sfeq  r3, r4
176        l.bnf   _end_ko
177        l.nop
178
179        /**********/
180        /* Test 6 */
181        /**********/
182        l.movhi r1,     hi(0x87654321) /* RA */
183        l.ori   r1, r1, lo(0x87654321)
184        l.movhi r3,     hi(0x8764eeee) /* RD wait */
185        l.ori   r3, r3, lo(0x8764eeee)
186        l.movhi r6,     hi(0x00000400) /* SR wait */
187        l.ori   r6, r6, lo(0x00000400)
188       
189        l.addi  r4, r1, 0xabcd
190
191        /* Test flag */
192        l.mfspr r7, r0, 17
193        l.and   r7, r7, r5
194
195        l.sfeq  r6, r7
196        l.bnf   _end_ko
197        l.nop
198
199        /* Test result */
200        l.sfeq  r3, r4
201        l.bnf   _end_ko
202        l.nop
203
204        /**********/
205        /* Test 7 */
206        /**********/
207        l.movhi r1,     hi(0x7fffffff) /* RA */
208        l.ori   r1, r1, lo(0x7fffffff)
209        l.movhi r3,     hi(0x80005431) /* RD wait */
210        l.ori   r3, r3, lo(0x80005431)
211        l.movhi r6,     hi(0x00000800) /* SR wait */
212        l.ori   r6, r6, lo(0x00000800)
213       
214        l.addi  r4, r1, 0x5432
215
216        /* Test flag */
217        l.mfspr r7, r0, 17
218        l.and   r7, r7, r5
219
220        l.sfeq  r6, r7
221        l.bnf   _end_ko
222        l.nop
223
224        /* Test result */
225        l.sfeq  r3, r4
226        l.bnf   _end_ko
227        l.nop
228
229        /**********/
230        /* End */
231        /**********/
232
233        l.j     _end_ok
234        l.nop
Note: See TracBrowser for help on using the repository browser.