summaryrefslogtreecommitdiff
path: root/tests/cris/check_movsr.s
blob: d1889a7a1b7085cbee75682054d5d4df6cf8744d (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
# mach: crisv3 crisv8 crisv10 crisv32
# output: 5\nfffffff5\n5\nfffffff5\n0\n

; Movs between registers.  Check that sign-extension is performed and the
; full register is set.

 .include "testutils.inc"
 start
 moveq -1,r5
 moveq 5,r4
 move.b r4,r5
 moveq -1,r3
 movs.b r5,r3
 test_move_cc 0 0 0 0
 checkr3 5

 moveq 0,r5
 moveq -11,r4
 move.b r4,r5
 moveq 0,r3
 movs.b r5,r3
 test_move_cc 1 0 0 0
 checkr3 fffffff5

 moveq -1,r5
 moveq 5,r4
 move.w r4,r5
 moveq -1,r3
 movs.w r5,r3
 test_move_cc 0 0 0 0
 checkr3 5

 moveq 0,r5
 moveq -11,r4
 move.w r4,r5
 moveq 0,r3
 movs.w r5,r3
 test_move_cc 1 0 0 0
 checkr3 fffffff5

 moveq 0,r5
 movs.b r5,r3
 test_move_cc 0 1 0 0
 checkr3 0

 quit