mirror of
https://github.com/openhwgroup/cvw
synced 2025-02-11 06:05:49 +00:00
new trace generation method
This commit is contained in:
parent
4e194b2576
commit
356993df7c
34
linux/testvector-generation/genRecording.sh
Executable file
34
linux/testvector-generation/genRecording.sh
Executable file
@ -0,0 +1,34 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
imageDir=$RISCV/buildroot/output/images
|
||||||
|
tvDir=$RISCV/linux-testvectors
|
||||||
|
recordFile="$tvDir/all.qemu"
|
||||||
|
|
||||||
|
read -p "Warning: running this script will overwrite $recordFile
|
||||||
|
Would you like to proceed? (y/n) " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ $REPLY =~ ^[Yy]$ ]]
|
||||||
|
then
|
||||||
|
# Create Output Directory
|
||||||
|
echo "Elevating permissions to create $recordFile"
|
||||||
|
sudo mkdir -p $tvDir
|
||||||
|
sudo chown cad $tvDir
|
||||||
|
sudo touch $recordFile
|
||||||
|
sudo chmod a+rw $recordFile
|
||||||
|
|
||||||
|
# Compile Devicetree from Source
|
||||||
|
dtc -I dts -O dtb ../devicetree/wally-virt.dts > ../devicetree/wally-virt.dtb
|
||||||
|
|
||||||
|
# QEMU Simulation
|
||||||
|
echo "Launching QEMU!"
|
||||||
|
qemu-system-riscv64 \
|
||||||
|
-M virt -dtb ../devicetree/wally-virt.dtb \
|
||||||
|
-nographic \
|
||||||
|
-bios $imageDir/fw_jump.elf -kernel $imageDir/Image -append "root=/dev/vda ro" -initrd $imageDir/rootfs.cpio \
|
||||||
|
-singlestep -rtc clock=vm -icount shift=0,align=off,sleep=on,rr=record,rrfile=$recordFile
|
||||||
|
|
||||||
|
# Cleanup
|
||||||
|
echo "Elevating permissions to restrict write access to $recordFile"
|
||||||
|
sudo chown cad $recordFile
|
||||||
|
sudo chmod o-w $recordFile
|
||||||
|
fi
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
define genTrace
|
|
||||||
# Arguments
|
|
||||||
set $tcpPort=$arg0
|
|
||||||
set $vmlinux=$arg1
|
|
||||||
|
|
||||||
# GDB config
|
|
||||||
set pagination off
|
|
||||||
set logging overwrite on
|
|
||||||
set logging redirect on
|
|
||||||
set confirm off
|
|
||||||
|
|
||||||
# Connect to QEMU session
|
|
||||||
eval "target extended-remote :%d",$tcpPort
|
|
||||||
|
|
||||||
# Symbol Files
|
|
||||||
eval "file %s",$vmlinux
|
|
||||||
|
|
||||||
# Run until Linux login prompt
|
|
||||||
b do_idle
|
|
||||||
ignore 1 2
|
|
||||||
c
|
|
||||||
|
|
||||||
kill
|
|
||||||
q
|
|
||||||
end
|
|
@ -1,13 +1,12 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
tcpPort=1234
|
tcpPort=1234
|
||||||
imageDir=$RISCV/buildroot/output/images
|
imageDir=$RISCV/buildroot/output/images
|
||||||
outDir=$RISCV/linux-testvectors
|
tvDir=$RISCV/linux-testvectors
|
||||||
recordFile="$outDir/all.qemu"
|
recordFile="$tvDir/all.qemu"
|
||||||
traceFile="$outDir/all.txt"
|
traceFile="$tvDir/all.txt"
|
||||||
interruptsFile="$outDir/interrupts.txt"
|
interruptsFile="$tvDir/interrupts.txt"
|
||||||
|
|
||||||
read -p "Warning: running this script will overwrite the contents of:
|
read -p "Warning: running this script will overwrite the contents of:
|
||||||
* $recordFile
|
|
||||||
* $traceFile
|
* $traceFile
|
||||||
* $interruptsFile
|
* $interruptsFile
|
||||||
Would you like to proceed? (y/n) " -n 1 -r
|
Would you like to proceed? (y/n) " -n 1 -r
|
||||||
@ -15,12 +14,11 @@ echo
|
|||||||
if [[ $REPLY =~ ^[Yy]$ ]]
|
if [[ $REPLY =~ ^[Yy]$ ]]
|
||||||
then
|
then
|
||||||
# Create Output Directory
|
# Create Output Directory
|
||||||
sudo mkdir -p $outDir
|
echo "Elevating permissions to create $traceFile, $interruptsFile"
|
||||||
sudo chown cad $outDir
|
sudo mkdir -p $tvDir
|
||||||
sudo touch $recordFile
|
sudo chown cad $tvDir
|
||||||
sudo touch $traceFile
|
sudo touch $traceFile
|
||||||
sudo touch $interruptsFile
|
sudo touch $interruptsFile
|
||||||
sudo chmod a+rw $recordFile
|
|
||||||
sudo chmod a+rw $traceFile
|
sudo chmod a+rw $traceFile
|
||||||
sudo chmod a+rw $interruptsFile
|
sudo chmod a+rw $interruptsFile
|
||||||
|
|
||||||
@ -28,21 +26,19 @@ then
|
|||||||
dtc -I dts -O dtb ../devicetree/wally-virt.dts > ../devicetree/wally-virt.dtb
|
dtc -I dts -O dtb ../devicetree/wally-virt.dts > ../devicetree/wally-virt.dtb
|
||||||
|
|
||||||
# QEMU Simulation
|
# QEMU Simulation
|
||||||
|
echo "Launching QEMU in replay mode!"
|
||||||
(qemu-system-riscv64 \
|
(qemu-system-riscv64 \
|
||||||
-M virt -dtb ../devicetree/wally-virt.dtb \
|
-M virt -dtb ../devicetree/wally-virt.dtb \
|
||||||
-nographic -serial /dev/null \
|
-nographic \
|
||||||
-bios $imageDir/fw_jump.elf -kernel $imageDir/Image -append "root=/dev/vda ro" -initrd $imageDir/rootfs.cpio \
|
-bios $imageDir/fw_jump.elf -kernel $imageDir/Image -append "root=/dev/vda ro" -initrd $imageDir/rootfs.cpio \
|
||||||
-singlestep -rtc clock=vm -icount shift=0,align=off,sleep=on,rr=record,rrfile=$recordFile \
|
-singlestep -rtc clock=vm -icount shift=0,align=off,sleep=on,rr=replay,rrfile=$recordFile \
|
||||||
-d nochain,cpu,in_asm,int \
|
-d nochain,cpu,in_asm,int \
|
||||||
-gdb tcp::$tcpPort -S \
|
2>&1 >/dev/null | ./parseQemuToGDB.py | ./parseGDBtoTrace.py $interruptsFile | ./remove_dup.awk > $traceFile)
|
||||||
2>&1 >/dev/null | ./parseQemuToGDB.py | ./parseGDBtoTrace.py $interruptsFile | ./remove_dup.awk > $traceFile) \
|
|
||||||
& riscv64-unknown-elf-gdb -quiet -x genTrace.gdb -ex "genTrace $tcpPort \"$imageDir/vmlinux\""
|
|
||||||
|
|
||||||
# Cleanup
|
# Cleanup
|
||||||
sudo chown cad $recordFile
|
echo "Elevating permissions to restrict write access to $traceFile, $interruptsFile"
|
||||||
sudo chown cad $traceFile
|
sudo chown cad $traceFile
|
||||||
sudo chown cad $interruptsFile
|
sudo chown cad $interruptsFile
|
||||||
sudo chmod o-w $recordFile
|
|
||||||
sudo chmod o-w $traceFile
|
sudo chmod o-w $traceFile
|
||||||
sudo chmod o-w $interruptsFile
|
sudo chmod o-w $interruptsFile
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user