2021-10-26 19:43:42 +00:00
|
|
|
define genCheckpoint
|
2021-10-24 13:14:11 +00:00
|
|
|
# GDB config
|
|
|
|
set pagination off
|
|
|
|
set logging overwrite on
|
|
|
|
set logging redirect on
|
|
|
|
set confirm off
|
|
|
|
|
|
|
|
# Argument Parsing
|
|
|
|
set $tcpPort=$arg0
|
|
|
|
set $instrCount=$arg1
|
2021-10-26 19:43:42 +00:00
|
|
|
set $statePath=$arg2
|
2021-10-24 21:46:56 +00:00
|
|
|
set $ramPath=$arg2
|
|
|
|
set $checkPC=$arg3
|
|
|
|
set $checkPCoccurences=$arg4
|
2021-10-24 13:14:11 +00:00
|
|
|
eval "set $statePath = \"%s/stateGDB.txt\"", $statePath
|
2021-11-06 05:37:05 +00:00
|
|
|
eval "set $ramPath = \"%s/ramGDB.bin\"", $ramPath
|
2021-10-24 13:14:11 +00:00
|
|
|
|
|
|
|
# Connect to QEMU session
|
|
|
|
eval "target extended-remote :%d",$tcpPort
|
|
|
|
|
|
|
|
# QEMU Config
|
|
|
|
maintenance packet Qqemu.PhyMemMode:1
|
|
|
|
|
|
|
|
# Symbol file
|
|
|
|
file ../buildroot-image-output/vmlinux
|
|
|
|
|
|
|
|
# Step over reset vector into actual code
|
|
|
|
stepi 100
|
|
|
|
# Set breakpoint for where to stop
|
|
|
|
b do_idle
|
|
|
|
# Proceed to checkpoint
|
|
|
|
printf "GDB proceeding to checkpoint at %d instrs\n", $instrCount
|
|
|
|
#stepi $instrCount-1000
|
2021-10-26 19:43:42 +00:00
|
|
|
eval "b *0x%s",$checkPC
|
2021-10-24 13:14:11 +00:00
|
|
|
ignore 2 $checkPCoccurences
|
|
|
|
c
|
|
|
|
|
|
|
|
printf "Reached checkpoint at %d instrs\n", $instrCount
|
|
|
|
|
|
|
|
# Log all registers to a file
|
|
|
|
printf "GDB storing state to %s\n", $statePath
|
|
|
|
eval "set logging file %s", $statePath
|
|
|
|
set logging on
|
|
|
|
info all-registers
|
|
|
|
set logging off
|
|
|
|
|
|
|
|
# Log main memory to a file
|
|
|
|
printf "GDB storing RAM to %s\n", $ramPath
|
2021-11-06 05:37:05 +00:00
|
|
|
eval "dump binary memory %s 0x80000000 0xffffffff", $ramPath
|
2021-10-24 13:14:11 +00:00
|
|
|
|
|
|
|
kill
|
|
|
|
q
|
|
|
|
end
|