Skip to content

Commit

Permalink
util: Add disk flashing utility
Browse files Browse the repository at this point in the history
  • Loading branch information
paulsc96 committed Jul 6, 2024
1 parent de83a83 commit 11777b5
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 1 deletion.
17 changes: 17 additions & 0 deletions util/flash_disk.gdb
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
target extended-remote localhost:3333

# Load flashing program
load sw/boot/flash.spm.elf

# Load disk image to DRAM
eval "restore %s binary 0x80000000", $img

# Write flash parameters to scratch regs
set *0x03000000=$target
set *0x03000004=0x80000000
set *0x03000008=$offs
set *0x0300000c=$len

# Launch payload and quit after return
continue
quit
28 changes: 28 additions & 0 deletions util/flash_disk.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
#! /usr/bin/env bash

# Arguments:
# $1: target board
# $2: target disk
# $3: (optional): disk image
# $4: (optional): copy length
# $5: (optional): copy offset

Check failure on line 9 in util/flash_disk.sh

View workflow job for this annotation

GitHub Actions / lint-license

FAILED: First comment ended before licence notice

Check failure on line 9 in util/flash_disk.sh

View workflow job for this annotation

GitHub Actions / lint-license

FAILED: First comment ended before licence notice
set -e
set +x

# Determine the image name and size
img=${3:-sw/boot/linux.${1}.gpt.bin}
# Ensure the image exists and determine rounded-up size
len=${4:-$(stat -c%s ${img})}
len=$((len/512+1))

# Run OpenOCD and GDB
openocd -f util/openocd.${1}.tcl &
sleep 2
riscv64-unknown-elf-gdb --batch \
-ex "set \$target = ${2:-1}" \
-ex "set \$img = \"${img}\"" \
-ex "set \$len = ${len}" \
-ex "set \$offs = ${5:-0}" \
-ex "source util/flash_disk.gdb"
wait
8 changes: 7 additions & 1 deletion util/openocd.common.tcl
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,16 @@ riscv set_command_timeout_sec 120

riscv set_prefer_sba off

# Exit when debugger detaches
$_TARGETNAME configure -event gdb-detach {
echo "GDB detached; ending debugging session."
shutdown
}

# Try enabling address translation (only works for newer versions)
if { [catch {riscv set_enable_virtual on} ] } {
echo "Warning: This version of OpenOCD does not support address translation. To debug on virtual addresses, please update to the latest version." }

init
halt
echo "Ready for Remote Connections"
echo "Ready for Remote Connections."

0 comments on commit 11777b5

Please sign in to comment.