OpenCores
URL https://opencores.org/ocsvn/w11/w11/trunk

Subversion Repositories w11

[/] [w11/] [tags/] [w11a_V0.6/] [tools/] [tbench/] [test_w11a_dstw_word_flow.tcl] - Blame information for rev 24

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 22 wfjm
# $Id: test_w11a_dstw_word_flow.tcl 552 2014-03-02 23:02:00Z mueller $
2 19 wfjm
#
3 22 wfjm
# Copyright 2013-2014 by Walter F.J. Mueller <W.F.J.Mueller@gsi.de>
4 19 wfjm
# License disclaimer see LICENSE_gpl_v2.txt in $RETROBASE directory
5
#
6
# Revision History:
7
# Date         Rev Version  Comment
8 22 wfjm
# 2014-03-01   552   1.0.1  check that unused regs stay 0
9 19 wfjm
# 2013-03-31   502   1.0    Initial version
10
#
11
# Test dstw flow with mov #nnn,... instructions for word access
12
#
13
 
14 22 wfjm
# ----------------------------------------------------------------------------
15 19 wfjm
rlc log "test_w11a_dstw_word_flow: test dstw flow for word with mov #nnn,..."
16
rlc log "  r0,(r0),(r0)+,@(r0)+,-(r0),@-(r0) (mode=0,1,2,3,4,5)"
17 22 wfjm
 
18
# code register pre/post conditions beyond defaults
19
#   r0           -> 0100
20
#   r1   #data1  -> ..same
21
#   r2   #data2  -> #data2+4
22
#   r3   #pdata3 -> #pdata3+4
23
#   r4   #data4e -> #data4e-4
24
#   r5   #pdat5e -> #pdat5e-4
25 19 wfjm
$cpu ldasm -lst lst -sym sym {
26
        . = 1000
27
start:  mov     #100,r0
28
        mov     #110,(r1)
29
        mov     #120,(r2)+
30
        mov     #121,(r2)+
31
        mov     #130,@(r3)+
32
        mov     #131,@(r3)+
33
        mov     #141,-(r4)
34
        mov     #140,-(r4)
35
        mov     #151,@-(r5)
36
        mov     #150,@-(r5)
37
        halt
38
stop:
39 22 wfjm
;
40 19 wfjm
data1:  .word   0
41
data2:  .word   0,0
42
data3:  .word   0,0
43
data4:  .word   0,0
44
data4e:
45
data5:  .word   0,0
46
data5e:
47
pdata3: .word   data3,data3+2
48
pdata5: .word   data5,data5+2
49
pdat5e:
50
}
51
 
52 20 wfjm
rw11::asmrun  $cpu sym [list r1 $sym(data1) \
53 22 wfjm
                             r2 $sym(data2) \
54
                             r3 $sym(pdata3) \
55
                             r4 $sym(data4e) \
56
                             r5 $sym(pdat5e) ]
57 20 wfjm
rw11::asmwait $cpu sym 1.0
58
rw11::asmtreg $cpu [list r0 0100 \
59
                         r1 $sym(data1) \
60
                         r2 [expr {$sym(data2)  + 4}] \
61
                         r3 [expr {$sym(pdata3) + 4}] \
62
                         r4 [expr {$sym(data4e) - 4}] \
63
                         r5 [expr {$sym(pdat5e) - 4}] ]
64
rw11::asmtmem $cpu $sym(data1) {0110 0120 0121 0130 0131 0140 0141 0150 0151}
65 19 wfjm
 
66 22 wfjm
# ----------------------------------------------------------------------------
67
rlc log "  nn(r0),@nn(r0),var,@var,@#var (mode=6,7,67,77,37)"
68 19 wfjm
 
69 22 wfjm
# code register pre/post conditions beyond defaults
70
#   r0   #data0-020  -> ..same
71
#   r1   #pdata0-040 -> ..same
72 19 wfjm
$cpu ldasm -lst lst -sym sym {
73
        . = 1000
74
start:  mov     #200,20(r0)
75
        mov     #210,@40(r1)
76
        mov     #220,data2
77
        mov     #230,@pdata3
78
        mov     #240,@#data4
79
        halt
80
stop:
81 22 wfjm
;
82 19 wfjm
data0:  .word   0
83
data1:  .word   0
84
data2:  .word   0
85
data3:  .word   0
86
data4:  .word   0
87
data4e:
88
pdata1: .word   data1
89
pdata3: .word   data3
90
}
91
 
92 20 wfjm
rw11::asmrun  $cpu sym [list r0 [expr {$sym(data0)-020}] \
93
                             r1 [expr {$sym(pdata1)-040}]  ]
94
rw11::asmwait $cpu sym 1.0
95 22 wfjm
rw11::asmtreg $cpu [list r0 [expr {$sym(data0)-020}] \
96
                         r1 [expr {$sym(pdata1)-040}] \
97
                         r2 0 \
98
                         r3 0 \
99
                         r4 0 \
100
                         r5 0 ]
101 20 wfjm
rw11::asmtmem $cpu $sym(data0) {0200 0210 0220 0230 0240}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.