summaryrefslogtreecommitdiff
path: root/tests/cris/check_movsm.s
blob: 7074336e78853ff1d89b908bc32b50cb2337500f (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
# 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"

 .data
x:
 .byte 5,-11
 .word 5,-11
 .word 0

 start
 move.d x,r5

 moveq -1,r3
 movs.b [r5+],r3
 test_move_cc 0 0 0 0
 checkr3 5

 moveq 0,r3
 movs.b [r5],r3
 test_move_cc 1 0 0 0
 addq 1,r5
 checkr3 fffffff5

 moveq -1,r3
 movs.w [r5+],r3
 test_move_cc 0 0 0 0
 checkr3 5

 moveq 0,r3
 movs.w [r5],r3
 test_move_cc 1 0 0 0
 addq 2,r5
 checkr3 fffffff5

 movs.w [r5],r3
 test_move_cc 0 1 0 0
 checkr3 0

 quit