2022-03-01 01:45:09 +00:00
|
|
|
#!/bin/bash
|
2024-07-27 00:20:56 +00:00
|
|
|
set -e
|
2022-03-01 01:45:09 +00:00
|
|
|
tcpPort=1235
|
2023-11-21 19:46:37 +00:00
|
|
|
tvDir=$RISCV/linux-testvectors
|
2022-03-01 01:45:09 +00:00
|
|
|
rawRamFile="$tvDir/ramGDB.bin"
|
|
|
|
ramFile="$tvDir/ram.bin"
|
|
|
|
rawBootmemFile="$tvDir/bootmemGDB.bin"
|
|
|
|
bootmemFile="$tvDir/bootmem.bin"
|
|
|
|
rawUntrimmedBootmemFile="$tvDir/untrimmedBootmemFileGDB.bin"
|
|
|
|
|
2024-07-23 09:00:11 +00:00
|
|
|
if ! mkdir -p "$tvDir"; then
|
|
|
|
echo "Error: unable to create linux testvector directory $tvDir!">&2
|
|
|
|
echo "Please try running as sudo.">&2
|
2023-11-22 13:25:09 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2024-07-23 09:00:11 +00:00
|
|
|
if ! test -w "$tvDir"; then
|
|
|
|
echo "Using sudo to gain access to $tvDir"
|
|
|
|
if ! sudo chmod -R a+rw "$tvDir"; then
|
|
|
|
echo "Error: insuffcient write privileges for linux testvector directory $tvDir !">&2
|
|
|
|
echo "Please chmod it. For example:">&2
|
|
|
|
echo " sudo chmod -R a+rw $tvDir">&2
|
|
|
|
exit 1
|
|
|
|
fi
|
2023-11-22 13:25:09 +00:00
|
|
|
fi
|
2024-07-24 07:22:28 +00:00
|
|
|
|
2023-11-22 13:25:09 +00:00
|
|
|
echo "Launching QEMU in replay mode!"
|
2025-01-21 03:16:55 +00:00
|
|
|
./qemuBoot.sh --gdb $tcpPort &
|
|
|
|
riscv64-unknown-elf-gdb -batch \
|
|
|
|
-ex "target remote :$tcpPort" \
|
|
|
|
-ex "maintenance packet Qqemu.PhyMemMode:1" \
|
|
|
|
-ex "printf \"Creating $rawBootmemFile\n\"" \
|
|
|
|
-ex "dump binary memory $rawBootmemFile 0x1000 0x1fff" \
|
|
|
|
-ex "printf \"Creating $rawRamFile\n\"" \
|
|
|
|
-ex "dump binary memory $rawRamFile 0x80000000 0x8fffffff" \
|
|
|
|
-ex "kill" \
|
2022-03-01 01:45:09 +00:00
|
|
|
|
2023-11-22 13:25:09 +00:00
|
|
|
echo "Changing Endianness"
|
2024-11-10 01:32:43 +00:00
|
|
|
# Extend files to 8 byte multiple
|
|
|
|
truncate -s %8 "$rawRamFile"
|
|
|
|
truncate -s %8 "$rawBootmemFile"
|
|
|
|
# Reverse bytes
|
2024-11-10 01:01:34 +00:00
|
|
|
objcopy --reverse-bytes=8 -F binary "$rawRamFile" "$ramFile"
|
|
|
|
objcopy --reverse-bytes=8 -F binary "$rawBootmemFile" "$bootmemFile"
|
2023-11-22 13:25:09 +00:00
|
|
|
rm -f "$rawRamFile" "$rawBootmemFile" "$rawUntrimmedBootmemFile"
|
|
|
|
|
|
|
|
echo "genInitMem.sh completed!"
|