summaryrefslogtreecommitdiff
path: root/download.tcl
blob: 31d4c8266831efcf4e3ad9d9f7afb9360f6262a6 (plain) (blame)
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
#!/usr/bin/env expect

set core 0
set wordsperline 1

if {$::argc > 1} {
    set core [lindex $::argv 0]
    set wordsperline [lindex $::argv 1]
} elseif {$::argc > 0} {
    set core [lindex $::argv 0]
}

spawn nios2-terminal --instance 0
expect -ex "connected to hardware target"

send "@[format %x [expr $core * 32768 / $wordsperline]]\n"

while {[gets stdin line] >= 0} {
    send "$line\n"
    expect -ex "$line"
}

# It's likely we ended with a very large zero-memory operation. We want to see
# two command bytes echoed back to us in order to guarantee that the zero
# operation has completely flushed to memory.
send "?"
expect -ex "?"
send "?"
expect -ex "?"

send "\004"
expect -ex "exiting due to ^D on remote"