mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-07 14:28:44 +00:00
30b8f4efc8
The CBE repository contained a lot of Genode-specific code despite the fact that the CBE core logic is not bound to Genode in any way. Therefore the Genode-specific CBE code is moved to the 'gems' repository to form part of Genode mainline. The remaining CBE code becomes a port in Genode instead of being invoked as sub-repository. The commit combines the following work steps: * add all files removed from CBE repository * add CBE port files * make all CBE libs and targets build again * make all CBE run scripts succeed again * make all CBE recipes build again * make CBE autopilot succeed again * let CBE autopilot use 'libsparcrypto' contrib dir and Genode build dir instead of '.ci' dir in CBE contrib dir (remove '.ci' dir from CBE repo) * let CBE autopilot always check for all ports * make CBE autopilot directly executable * fix license headers in all Genode CBE files * remove unused VFS replay component * remove unused CBE test * remove unused external crypto * remove unused files in run dir * remove unused external trust anchor * add cbe_tester test to autopilot list * get rid of directories 'include/cbe_*' and 'include/utils' Fixes #3937
253 lines
5.7 KiB
Bash
253 lines
5.7 KiB
Bash
#!/bin/bash
|
|
|
|
echo "--- Automated CBE testing ---"
|
|
|
|
produce_pattern() {
|
|
local pattern="$1"
|
|
local size="$2"
|
|
[ "$pattern" = "" ] && exit 1
|
|
|
|
local tmp_file="/tmp/pattern.tmp"
|
|
local N=1041
|
|
# prints numbers until N and uses pattern as delimiter and
|
|
# generates about 4 KiB of data with a 1 byte pattern
|
|
seq -s "$pattern" $N > $tmp_file
|
|
dd if=$tmp_file count=1 bs=$size 2>/dev/null
|
|
}
|
|
|
|
test_write_1() {
|
|
local data_file="$1"
|
|
local offset=$2
|
|
|
|
local pattern_file="/tmp/pattern"
|
|
dd bs=4096 count=1 if=$pattern_file of=$data_file seek=$offset 2>/dev/null || exit 1
|
|
}
|
|
|
|
test_read_compare_1() {
|
|
local data_file="$1"
|
|
local offset=$2
|
|
|
|
local pattern_file="/tmp/pattern"
|
|
rm $pattern_file.out 2>/dev/null
|
|
|
|
dd bs=4096 count=1 if=$data_file of=$pattern_file.out skip=$offset 2>/dev/null || exit 1
|
|
local sha1=$(sha1sum $pattern_file)
|
|
local sha1_sum=${sha1:0:40}
|
|
|
|
local sha1out=$(sha1sum $pattern_file.out)
|
|
local sha1out_sum=${sha1out:0:40}
|
|
|
|
if [ "$sha1_sum" != "$sha1out_sum" ]; then
|
|
echo "mismatch for block $offset:"
|
|
echo " expected: $sha1_sum"
|
|
echo -n " "
|
|
dd if=$pattern_file bs=32 count=1 2>/dev/null; echo
|
|
echo " got: $sha1out_sum"
|
|
echo -n " "
|
|
dd if=$pattern_file.out bs=32 count=1 2>/dev/null; echo
|
|
return 1
|
|
fi
|
|
}
|
|
|
|
test_create_snapshot() {
|
|
local cbe_dir="$1"
|
|
|
|
echo "Create snapshot"
|
|
echo true > $cbe_dir/control/create_snapshot
|
|
}
|
|
|
|
test_list_snapshots() {
|
|
local cbe_dir="$1"
|
|
|
|
echo "List content of '$cbe_dir'"
|
|
ls -l $cbe_dir/snapshots
|
|
}
|
|
|
|
test_discard_snapshot() {
|
|
local cbe_dir="$1"
|
|
local snap_id=$2
|
|
|
|
echo "Discard snapshot with id: $snap_id"
|
|
echo $snap_id > $cbe_dir/control/discard_snapshot
|
|
}
|
|
|
|
test_rekey() {
|
|
local cbe_dir="$1"
|
|
|
|
echo "Start rekeying"
|
|
echo on > $cbe_dir/control/rekey
|
|
echo "Reykeying started"
|
|
}
|
|
|
|
test_vbd_extension() {
|
|
local cbe_dir="$1"
|
|
local nr_of_phys_blocks="$2"
|
|
|
|
echo "Start extending VBD"
|
|
echo tree=vbd, blocks=$nr_of_phys_blocks > $cbe_dir/control/extend
|
|
echo "VBD extension started"
|
|
}
|
|
|
|
test_ft_extension() {
|
|
local cbe_dir="$1"
|
|
local nr_of_phys_blocks="$2"
|
|
|
|
echo "Start extending FT"
|
|
echo tree=ft, blocks=$nr_of_phys_blocks > $cbe_dir/control/extend
|
|
echo "FT extension started"
|
|
}
|
|
|
|
test_rekey_state() {
|
|
local cbe_dir="$1"
|
|
local state="$(< $cbe_dir/control/rekey)"
|
|
|
|
echo "Rekeying state: $state"
|
|
}
|
|
|
|
test_rekey_state() {
|
|
local cbe_dir="$1"
|
|
local state="$(< $cbe_dir/control/rekey)"
|
|
|
|
echo "Rekeying state: $state"
|
|
}
|
|
|
|
wait_for_rekeying() {
|
|
local cbe_dir="$1"
|
|
|
|
echo "Wait for rekeying to finish..."
|
|
while : ; do
|
|
local file_content="$(< $cbe_dir/control/rekey)"
|
|
local state="${file_content:0:4}"
|
|
if [ "$state" = "idle" ]; then
|
|
local result="${file_content:5}"
|
|
echo "Reykeying done: $result"
|
|
break;
|
|
fi
|
|
sleep 2
|
|
done
|
|
}
|
|
|
|
wait_for_vbd_extension() {
|
|
local cbe_dir="$1"
|
|
|
|
echo "Wait for VBD extension to finish..."
|
|
while : ; do
|
|
local file_content="$(< $cbe_dir/control/extend)"
|
|
local state="${file_content:0:4}"
|
|
if [ "$state" = "idle" ]; then
|
|
local result="${file_content:5}"
|
|
echo "VBD extension done: $result"
|
|
break;
|
|
fi
|
|
sleep 2
|
|
done
|
|
}
|
|
|
|
wait_for_ft_extension() {
|
|
local cbe_dir="$1"
|
|
|
|
echo "Wait for FT extension to finish..."
|
|
while : ; do
|
|
local file_content="$(< $cbe_dir/control/extend)"
|
|
local state="${file_content:0:4}"
|
|
if [ "$state" = "idle" ]; then
|
|
local result="${file_content:5}"
|
|
echo "VBD extension done: $result"
|
|
break;
|
|
fi
|
|
sleep 2
|
|
done
|
|
}
|
|
|
|
main() {
|
|
local cbe_dir="/dev/cbe"
|
|
local data_file="$cbe_dir/current/data"
|
|
|
|
ls -l $cbe_dir
|
|
|
|
for i in $(seq 3); do
|
|
|
|
echo "--> Run $i:"
|
|
|
|
local pattern_file="/tmp/pattern"
|
|
produce_pattern "$i" "4096" > $pattern_file
|
|
|
|
test_write_1 "$data_file" "419"
|
|
test_write_1 "$data_file" "63"
|
|
test_write_1 "$data_file" "333"
|
|
|
|
test_vbd_extension "$cbe_dir" "1000"
|
|
test_read_compare_1 "$data_file" "63"
|
|
test_write_1 "$data_file" "175"
|
|
test_read_compare_1 "$data_file" "419"
|
|
test_write_1 "$data_file" "91"
|
|
test_read_compare_1 "$data_file" "175"
|
|
test_read_compare_1 "$data_file" "91"
|
|
test_read_compare_1 "$data_file" "333"
|
|
wait_for_vbd_extension "$cbe_dir"
|
|
|
|
test_write_1 "$data_file" "32"
|
|
test_write_1 "$data_file" "77"
|
|
test_write_1 "$data_file" "199"
|
|
|
|
test_ft_extension "$cbe_dir" "1000"
|
|
test_read_compare_1 "$data_file" "32"
|
|
test_write_1 "$data_file" "211"
|
|
test_read_compare_1 "$data_file" "77"
|
|
test_write_1 "$data_file" "278"
|
|
test_read_compare_1 "$data_file" "199"
|
|
test_read_compare_1 "$data_file" "278"
|
|
test_read_compare_1 "$data_file" "211"
|
|
wait_for_ft_extension "$cbe_dir"
|
|
|
|
test_write_1 "$data_file" "0"
|
|
test_write_1 "$data_file" "8"
|
|
test_write_1 "$data_file" "16"
|
|
test_write_1 "$data_file" "490"
|
|
test_write_1 "$data_file" "468"
|
|
|
|
test_read_compare_1 "$data_file" "0"
|
|
test_read_compare_1 "$data_file" "8"
|
|
test_read_compare_1 "$data_file" "16"
|
|
test_read_compare_1 "$data_file" "490"
|
|
|
|
test_rekey "$cbe_dir"
|
|
test_write_1 "$data_file" "0"
|
|
test_rekey_state "$cbe_dir"
|
|
test_read_compare_1 "$data_file" "490"
|
|
test_rekey_state "$cbe_dir"
|
|
test_write_1 "$data_file" "16"
|
|
test_rekey_state "$cbe_dir"
|
|
test_read_compare_1 "$data_file" "468"
|
|
test_rekey_state "$cbe_dir"
|
|
test_read_compare_1 "$data_file" "8"
|
|
test_rekey_state "$cbe_dir"
|
|
test_read_compare_1 "$data_file" "16"
|
|
test_rekey_state "$cbe_dir"
|
|
test_read_compare_1 "$data_file" "0"
|
|
test_write_1 "$data_file" "300"
|
|
test_write_1 "$data_file" "240"
|
|
test_write_1 "$data_file" "201"
|
|
test_write_1 "$data_file" "328"
|
|
wait_for_rekeying "$cbe_dir"
|
|
|
|
echo "--> Run $i done"
|
|
|
|
done
|
|
|
|
echo "--> Read/Compare test"
|
|
test_read_compare_1 "$data_file" "0"
|
|
test_read_compare_1 "$data_file" "490"
|
|
test_read_compare_1 "$data_file" "468"
|
|
test_read_compare_1 "$data_file" "8"
|
|
test_read_compare_1 "$data_file" "16"
|
|
echo "--> Read/Compare test done"
|
|
|
|
echo "--- Automated CBE testing finished, shell is yours ---"
|
|
}
|
|
|
|
main "$@"
|
|
|
|
# just drop into shell
|
|
# exit 0
|