mirror of
https://github.com/openhwgroup/cvw
synced 2025-01-26 22:44:28 +00:00
61 lines
2.1 KiB
Bash
Executable File
61 lines
2.1 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
source genSettings.sh
|
|
tcpPort=1236
|
|
checkOutDir="$outDir/checkpoint$instrs"
|
|
checkIntermedDir="$checkOutDir/intermediate-outputs"
|
|
|
|
# Parse Commandline Arg
|
|
if [ "$#" -ne 1 ]; then
|
|
echo "genCheckpoint requires 1 argument: <num instrs>" >&2
|
|
exit 1
|
|
fi
|
|
instrs=$1
|
|
if ! [ "$instrs" -eq "$instrs" ] 2> /dev/null
|
|
then
|
|
echo "Error expected integer number of instructions, got $instrs" >&2
|
|
exit 1
|
|
fi
|
|
|
|
read -p "This scripts is going to create a checkpoint at $instrs instrs.
|
|
Is that what you wanted? (y/n) " -n 1 -r
|
|
echo
|
|
if [[ $REPLY =~ ^[Yy]$ ]]
|
|
then
|
|
echo "Creating checkpoint at $instrs instructions!"
|
|
mkdir -p $checkOutDir
|
|
mkdir -p $checkIntermedDir
|
|
|
|
# Identify instruction in trace
|
|
instr=$(sed "${instrs}q;d" "../linux-testvectors/all.txt")
|
|
echo "Found ${instrs}th instr: ${instr}"
|
|
pc=$(echo $instr | cut -d " " -f1)
|
|
asm=$(echo $instr | cut -d " " -f2)
|
|
occurences=$(($(head -$instrs "../linux-testvectors/all.txt" | grep -c "${pc} ${asm}")-1))
|
|
echo "It occurs ${occurences} times before the ${instrs}th instr."
|
|
|
|
# GDB+QEMU
|
|
echo "Starting QEMU with attached GDB script at $(date +%H:%M:%S)"
|
|
($customQemu \
|
|
-M virt \
|
|
-nographic \
|
|
-bios $imageDir/fw_jump.elf -kernel $imageDir/Image -append "root=/dev/vda ro" -initrd $imageDir/rootfs.cpio \
|
|
-singlestep -rtc clock=vm -icount shift=1,align=off,sleep=on,rr=replay,rrfile="$intermedDir/$recordFile" \
|
|
-gdb tcp::$tcpPort -S) \
|
|
& riscv64-unknown-elf-gdb --quiet \
|
|
-x genCheckpoint.gdb -ex "genCheckpoint $tcpPort $instrs \"$checkIntermedDir\" \"$pc\" $occurences"
|
|
echo "Completed GDB script completed at $(date +%H:%M:%S)"
|
|
|
|
# Post-Process GDB outputs
|
|
./parseState.py "$checkOutDir"
|
|
echo "Changing Endianness at $(date +%H:%M:%S)"
|
|
make
|
|
./fixBinMem "$checkIntermedDir/ramGDB.bin" "$checkOutDir/ram.bin"
|
|
echo "Creating truncated trace at $(date +%H:%M:%S)"
|
|
tail -n+$instrs "$outDir/$traceFile" > "$checkOutDir/$traceFile"
|
|
echo "Checkpoint completed at $(date +%H:%M:%S)"
|
|
else
|
|
echo "You can change the number of instructions by editing the \"instrs\" variable in this script."
|
|
echo "Have a nice day!"
|
|
fi
|