summaryrefslogtreecommitdiff
path: root/sim/testsuite/sim/cris/asm/movsm.ms
blob: 59973d1f35262374f9fed03e2c0962a651f29658 (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
 dumpr3

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

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

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

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

 quit