genode/repos/gems/run/tresor_tester.run
Martin Stein b903ddeea7 tresor: fix and test handling of minimal trees
* add testing of trees with minimal and maximal dimensions to tresor_tester.run
* replace tresor_init-local configuration type with simpler and more conformant
  configuration type in tresor/types.h that does also XML-parsing and
  XML-generation of configurations
* raise min degree to 2 because a degree of 1 is not practical und would
  require additional logic
* fix overflow with num_blocks=0 in Superblock_control::Read|Write_vbas
* fix off-by-one bug regarding the number of levels in Vbd_initializer
* improve sanity checks in Tree_configuration constructors
* document level indices in tresor_init/README
* fix size of some arrays in order to be able to handle the maximum number of
  tree levels

Ref #5077
2024-04-12 15:00:46 +02:00

1167 lines
51 KiB
Plaintext

# riscv lacks jitterentropy support currently
if {[get_cmd_switch --autopilot] && [have_board virt_qemu_riscv]} {
puts "Autopilot mode is not supported on this platform."
exit 0
}
set dd [installed_command dd]
proc tresor_image_name { } {
return "tresor_block.img"
}
proc lx_local_tresor_image { } {
return bin/[tresor_image_name]
}
proc lx_autopilot_tresor_image { } {
return /tmp/[tresor_image_name].[exec id -un]
}
proc lx_tresor_image_size_mb { } {
return 400
}
proc benchmark_blk_count { } {
if {[have_board linux]} {
# benchmarks over 50 mebibyte
return 12800
}
if {[have_board virt_qemu_arm_v8a]} {
# benchmarks over 25 mebibyte
return 6400
}
# benchmarks turned off
return 0
}
proc block_io_vfs_ram_mb { } {
if {[benchmark_blk_count] > 0} {
# when benchmarks turned on
set bench_mb [expr (([benchmark_blk_count] * 4096) / 1024 / 1024)]
return [expr 8 * $bench_mb]
}
# when benchmarks turned off
return 10
}
proc jent_avail { } {
if {[have_board pbxa9]} { return 0 }
if {[have_board zynq_qemu]} { return 0 }
return 1
}
append build_components {
core lib/ld init timer
server/vfs lib/vfs lib/libc lib/libcrypto
app/tresor_tester
server/log_terminal
server/report_rom
lib/vfs_tresor_crypto_aes_cbc
lib/vfs_tresor_trust_anchor
lib/vfs_import
}
append_if [jent_avail] build_components { lib/vfs_jitterentropy }
append_if [have_board linux] build_components { server/lx_fs }
append_if [have_board linux] build_components { server/lx_block }
build $build_components
create_boot_directory
append config {
<config verbose="yes">
<parent-provides>
<service name="ROM"/>
<service name="IRQ"/>
<service name="IO_MEM"/>
<service name="IO_PORT"/>
<service name="PD"/>
<service name="RM"/>
<service name="CPU"/>
<service name="LOG"/>
</parent-provides>
<start name="timer" caps="100">
<resource name="RAM" quantum="1M"/>
<provides><service name="Timer"/></provides>
<route>
<service name="PD"> <parent/> </service>
<service name="ROM"> <parent/> </service>
<service name="LOG"> <parent/> </service>
<service name="CPU"> <parent/> </service>
<service name="IO_PORT"> <parent/> </service>
<service name="IO_MEM"> <parent/> </service>
<service name="IRQ"> <parent/> </service>
</route>
</start>
<start name="report_rom" caps="100">
<resource name="RAM" quantum="4M"/>
<provides> <service name="Report"/> <service name="ROM"/> </provides>
<config verbose="yes"/>
<route>
<service name="LOG"> <parent/> </service>
<service name="PD"> <parent/> </service>
<service name="CPU"> <parent/> </service>
<service name="ROM"> <parent/> </service>
</route>
</start>
<start name="log_terminal" caps="100">
<resource name="RAM" quantum="1M"/>
<provides><service name="Terminal"/></provides>
<route>
<service name="LOG"> <parent/> </service>
<service name="PD"> <parent/> </service>
<service name="CPU"> <parent/> </service>
<service name="ROM"> <parent/> </service>
</route>
</start>
}
if {[have_board linux]} {
append config {
<start name="block_io_fs" caps="100" ld="no">
<binary name="lx_fs"/>
<resource name="RAM" quantum="4M"/>
<provides> <service name="File_system"/> </provides>
<config>
<default-policy root="/" writeable="yes"/>
</config>
<route>
<service name="LOG"> <parent/> </service>
<service name="PD"> <parent/> </service>
<service name="CPU"> <parent/> </service>
<service name="ROM"> <parent/> </service>
</route>
</start>
}
} else {
append config {
<start name="block_io_fs" caps="100">
<binary name="vfs"/>
<resource name="RAM" quantum="} [block_io_vfs_ram_mb] {M"/>
<provides><service name="File_system"/></provides>
<config>
<vfs>
<dir name="block_io">
<ram/>
</dir>
<import>
<dir name="block_io">
<inline name="} [tresor_image_name] {"></inline>
</dir>
</import>
</vfs>
<default-policy root="/block_io" writeable="yes"/>
</config>
<route>
<service name="PD"> <parent/> </service>
<service name="ROM"> <parent/> </service>
<service name="LOG"> <parent/> </service>
<service name="CPU"> <parent/> </service>
</route>
</start>
}
}
append config {
<start name="trust_anchor_fs" caps="200">
<binary name="vfs"/>
<resource name="RAM" quantum="10M"/>
<provides><service name="File_system"/></provides>
<config>
<vfs>
<dir name="storage">
<ram/>
</dir>
<dir name="dev"> }
append_if [jent_avail] config {
<jitterentropy name="jitterentropy"/> }
append_if [expr ![jent_avail]] config {
<inline name="jitterentropy">0123456789abcdefghijklmnopqrstuv</inline> }
append config {
<tresor_trust_anchor name="tresor_trust_anchor" storage_dir="/storage"/>
</dir>
</vfs>
<default-policy root="/dev/tresor_trust_anchor" writeable="yes"/>
</config>
<route>
<service name="PD"> <parent/> </service>
<service name="ROM"> <parent/> </service>
<service name="LOG"> <parent/> </service>
<service name="CPU"> <parent/> </service>
</route>
</start>
<start name="test" caps="200">
<binary name="tresor_tester"/>
<resource name="RAM" quantum="10M"/>
<config ld_verbose="yes">
<block-io type="vfs" path="/} [tresor_image_name] {"/>
<crypto path="/crypto"/>
<trust-anchor path="/trust_anchor"/>
<vfs>
<fs buffer_size="1M"/>
<tresor_crypto_aes_cbc name="crypto"/>
<dir name="trust_anchor">
<fs label="trust_anchor"/>
</dir>
</vfs>
<commands>
<log string="Step 1: Initialize Trust Anchor and Tresor device, start Tresor library"/>
<initialize-trust-anchor passphrase="foobar"/>
<initialize>
<virtual-block-device max_lvl="2" degree="8" num_leaves="64" />
<free-tree max_lvl="3" degree="8" num_leaves="100" />
</initialize>
<check/>
<construct/>
<log string="Step 2: test synchronous write, read"/>
<request op="read" vba="1" num_blocks="1" uninitialized_data="yes"/>
<request op="write" vba="1" num_blocks="1" salt="1234"/>
<request op="read" vba="1" num_blocks="1" salt="1234"/>
<request op="write" vba="12" num_blocks="10" />
<request op="read" vba="12" num_blocks="10" />
<request op="write" vba="24" num_blocks="40" />
<request op="read" vba="24" num_blocks="40" />
<log string="Step 3: test synchronous write, read, compare"/>
<request op="write" vba="9" num_blocks="1" salt="4321"/>
<request op="read" vba="9" num_blocks="1" salt="4321"/>
<request op="write" vba="41" num_blocks="3" salt="8765"/>
<request op="read" vba="41" num_blocks="3" salt="8765"/>
<request op="write" vba="9" num_blocks="1" salt="1234"/>
<request op="write" vba="41" num_blocks="19" salt="5678"/>
<request op="read" vba="9" num_blocks="1" salt="1234"/>
<request op="read" vba="41" num_blocks="19" salt="5678"/>
<log string="Step 4: test asynchronous write, read"/>
<request op="write" vba="20" num_blocks="3" />
<request op="write" vba="15" num_blocks="10" />
<request op="read" vba="34" num_blocks="2" />
<request op="read" vba="21" num_blocks="5" />
<request op="write" vba="12" num_blocks="12" />
<request op="read" vba="32" num_blocks="8" />
<request op="write" vba="17" num_blocks="7" />
<request op="write" vba="29" num_blocks="9" />
<request op="read" vba="14" num_blocks="18" />
<log string="Step 5: test asynchronous write, read, compare"/>
<request op="write" vba="20" num_blocks="3" salt="7373"/>
<request op="read" vba="21" num_blocks="1" salt="7373"/>
<request op="write" vba="15" num_blocks="10" salt="1515"/>
<request op="write" vba="15" num_blocks="4" salt="6001"/>
<request op="read" vba="21" num_blocks="3" salt="1515"/>
<request op="read" vba="19" num_blocks="3" salt="1515"/>
<request op="write" vba="17" num_blocks="5" salt="9689"/>
<request op="read" vba="22" num_blocks="3" salt="1515"/>
<request op="read" vba="15" num_blocks="2" salt="6001"/>
<request op="write" vba="11" num_blocks="6" salt="0987"/>
<request op="read" vba="17" num_blocks="5" salt="9689"/>
<request op="write" vba="22" num_blocks="2" salt="6543"/>
<request op="write" vba="25" num_blocks="11" salt="5432"/>
<request op="read" vba="24" num_blocks="1" salt="1515"/>
<request op="write" vba="10" num_blocks="5" salt="4221"/>
<request op="write" vba="21" num_blocks="2" salt="1001"/>
<request op="write" vba="12" num_blocks="10" salt="3366"/>
<request op="write" vba="26" num_blocks="4" salt="7271"/>
<request op="write" vba="15" num_blocks="7" salt="1331"/>
<request op="read" vba="23" num_blocks="1" salt="6543"/>
<request op="read" vba="25" num_blocks="1" salt="5432"/>
<request op="read" vba="28" num_blocks="2" salt="7271"/>
<request op="read" vba="24" num_blocks="1" salt="1515"/>
<request op="read" vba="12" num_blocks="3" salt="3366"/>
<request op="read" vba="19" num_blocks="3" salt="1331"/>
<request op="read" vba="10" num_blocks="2" salt="4221"/>
<log string="Step 6: shut down Tresor library, check Tresor integrity, restart Tresor library"/>
<request op="deinitialize" />
<destruct/>
<check/>
<construct/>
<log string="Step 7: test snapshot management"/>
<request op="write" vba="20" num_blocks="3" salt="7304"/>
<request op="create_snapshot" id="1"/>
<request op="read" vba="21" num_blocks="1" salt="7304"/>
<request op="write" vba="15" num_blocks="10" salt="9612"/>
<request op="write" vba="15" num_blocks="4" salt="6111"/>
<request op="read" vba="21" num_blocks="3" salt="9612"/>
<request op="read" vba="19" num_blocks="3" salt="9612"/>
<request op="write" vba="17" num_blocks="5" salt="5353"/>
<request op="create_snapshot" id="2"/>
<request op="create_snapshot" id="3"/>
<request op="read" vba="22" num_blocks="3" salt="9612"/>
<request op="read" vba="15" num_blocks="2" salt="6111"/>
<request op="write" vba="11" num_blocks="6" salt="5436"/>
<check-snapshots/>
<request op="discard_snapshot" id="1"/>
<request op="discard_snapshot" id="2"/>
<check-snapshots/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<request op="write" vba="20" num_blocks="3" salt="7384"/>
<request op="create_snapshot" id="4"/>
<request op="create_snapshot" id="5"/>
<request op="read" vba="21" num_blocks="1" salt="7384"/>
<request op="write" vba="15" num_blocks="10" salt="9602"/>
<request op="write" vba="15" num_blocks="4" salt="6100"/>
<request op="read" vba="21" num_blocks="3" salt="9602"/>
<request op="read" vba="19" num_blocks="3" salt="9602"/>
<request op="write" vba="17" num_blocks="5" salt="5555"/>
<request op="read" vba="22" num_blocks="3" salt="9602"/>
<request op="read" vba="15" num_blocks="2" salt="6100"/>
<request op="create_snapshot" id="6"/>
<request op="write" vba="11" num_blocks="6" salt="1436"/>
<request op="read" vba="17" num_blocks="5" salt="5555"/>
<request op="write" vba="22" num_blocks="2" salt="7463"/>
<request op="write" vba="25" num_blocks="11" salt="4323"/>
<request op="read" vba="24" num_blocks="1" salt="9602"/>
<request op="write" vba="10" num_blocks="5" salt="3758"/>
<request op="create_snapshot" id="7"/>
<request op="create_snapshot" id="8"/>
<request op="write" vba="21" num_blocks="2" salt="8094"/>
<request op="write" vba="12" num_blocks="10" salt="4455"/>
<request op="write" vba="26" num_blocks="4" salt="7574"/>
<request op="write" vba="15" num_blocks="7" salt="1931"/>
<request op="read" vba="23" num_blocks="1" salt="7463"/>
<request op="read" vba="25" num_blocks="1" salt="4323"/>
<request op="read" vba="28" num_blocks="2" salt="7574"/>
<request op="create_snapshot" id="9"/>
<request op="read" vba="24" num_blocks="1" salt="9602"/>
<request op="read" vba="12" num_blocks="3" salt="4455"/>
<request op="read" vba="19" num_blocks="3" salt="1931"/>
<request op="read" vba="10" num_blocks="2" salt="3758"/>
<check-snapshots/>
<request op="discard_snapshot" id="4"/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<log string="Step 8: reinitialize Tresor device"/>
<request op="deinitialize" />
<destruct/>
<initialize>
<virtual-block-device max_lvl="3" degree="8" num_leaves="100" />
<free-tree max_lvl="3" degree="8" num_leaves="512" />
</initialize>
<construct/>
<log string="Step 9: test synchronous rekeying"/>
<request op="read" vba="30" num_blocks="10" uninitialized_data="yes"/>
<request op="write" vba="0" num_blocks="1" salt="4359"/>
<request op="rekey" sync="yes"/>
<request op="read" vba="0" num_blocks="1" salt="4359"/>
<request op="write" vba="15" num_blocks="7" salt="1742"/>
<request op="write" vba="20" num_blocks="13" salt="8471"/>
<request op="create_snapshot" id="10"/>
<request op="write" vba="33" num_blocks="5" salt="7831"/>
<request op="rekey" sync="yes"/>
<request op="read" vba="17" num_blocks="3" salt="1742"/>
<request op="write" vba="51" num_blocks="8" salt="8384"/>
<request op="read" vba="25" num_blocks="1" salt="8471"/>
<request op="write" vba="30" num_blocks="5" salt="2837"/>
<request op="create_snapshot" id="11"/>
<request op="rekey" sync="yes"/>
<request op="read" vba="35" num_blocks="2" salt="7831"/>
<request op="read" vba="31" num_blocks="4" salt="2837"/>
<request op="read" vba="51" num_blocks="8" salt="8384"/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<log string="Step 10: test asynchronous rekeying"/>
<request op="write" vba="20" num_blocks="3" salt="7384"/>
<request op="rekey" />
<request op="read" vba="21" num_blocks="1" salt="7384"/>
<request op="write" vba="15" num_blocks="10" salt="9602"/>
<request op="write" vba="15" num_blocks="4" salt="6100"/>
<request op="read" vba="21" num_blocks="3" salt="9602"/>
<request op="read" vba="19" num_blocks="3" salt="9602"/>
<request op="write" vba="17" num_blocks="5" salt="5555"/>
<request op="read" vba="22" num_blocks="3" salt="9602"/>
<request op="read" vba="15" num_blocks="2" salt="6100"/>
<request op="write" vba="11" num_blocks="6" salt="1436"/>
<request op="create_snapshot" id="12"/>
<request op="read" vba="17" num_blocks="5" salt="5555"/>
<request op="write" vba="22" num_blocks="2" salt="7463"/>
<request op="rekey" />
<request op="write" vba="25" num_blocks="11" salt="4323"/>
<request op="read" vba="24" num_blocks="1" salt="9602"/>
<request op="write" vba="10" num_blocks="5" salt="3758"/>
<request op="write" vba="21" num_blocks="2" salt="8094"/>
<request op="write" vba="12" num_blocks="10" salt="4455"/>
<request op="write" vba="26" num_blocks="4" salt="7574"/>
<request op="write" vba="15" num_blocks="7" salt="1931"/>
<request op="read" vba="23" num_blocks="1" salt="7463"/>
<request op="read" vba="25" num_blocks="1" salt="4323"/>
<request op="read" vba="28" num_blocks="2" salt="7574"/>
<request op="read" vba="24" num_blocks="1" salt="9602"/>
<request op="read" vba="12" num_blocks="3" salt="4455"/>
<request op="read" vba="19" num_blocks="3" salt="1931"/>
<request op="read" vba="10" num_blocks="2" salt="3758"/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<log string="Step 11: test synchronous free tree extension"/>
<request op="write" vba="20" num_blocks="3" salt="7304"/>
<request op="extend_ft" num_blocks="23" />
<request op="read" vba="21" num_blocks="1" salt="7304"/>
<request op="extend_ft" num_blocks="6" />
<request op="write" vba="15" num_blocks="10" salt="9612"/>
<request op="write" vba="15" num_blocks="4" salt="6111"/>
<request op="extend_ft" num_blocks="10" />
<request op="read" vba="21" num_blocks="3" salt="9612"/>
<request op="read" vba="19" num_blocks="3" salt="9612"/>
<request op="write" vba="17" num_blocks="5" salt="5353"/>
<request op="extend_ft" num_blocks="2" />
<request op="extend_ft" num_blocks="2" />
<request op="extend_ft" num_blocks="2" />
<request op="read" vba="22" num_blocks="3" salt="9612"/>
<request op="extend_ft" num_blocks="1" />
<request op="read" vba="15" num_blocks="2" salt="6111"/>
<request op="write" vba="11" num_blocks="6" salt="5436"/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<log string="Step 12: test asynchronous free tree extension"/>
<request op="write" vba="20" num_blocks="3" salt="3874"/>
<request op="extend_ft" num_blocks="21" />
<request op="extend_ft" num_blocks="17" />
<request op="read" vba="21" num_blocks="1" salt="3874"/>
<request op="write" vba="15" num_blocks="10" salt="6092"/>
<request op="write" vba="15" num_blocks="4" salt="1060"/>
<request op="read" vba="21" num_blocks="3" salt="6092"/>
<request op="read" vba="19" num_blocks="3" salt="6092"/>
<request op="write" vba="17" num_blocks="5" salt="5555"/>
<request op="read" vba="22" num_blocks="3" salt="6092"/>
<request op="read" vba="15" num_blocks="2" salt="1060"/>
<request op="extend_ft" num_blocks="180" />
<request op="write" vba="11" num_blocks="6" salt="4316"/>
<request op="read" vba="17" num_blocks="5" salt="5555"/>
<request op="write" vba="22" num_blocks="2" salt="4673"/>
<request op="write" vba="25" num_blocks="11" salt="3243"/>
<request op="read" vba="24" num_blocks="1" salt="6092"/>
<request op="write" vba="10" num_blocks="5" salt="7538"/>
<request op="extend_ft" num_blocks="3" />
<request op="extend_ft" num_blocks="2" />
<request op="write" vba="21" num_blocks="2" salt="0984"/>
<request op="write" vba="12" num_blocks="10" salt="4545"/>
<request op="write" vba="26" num_blocks="4" salt="5774"/>
<request op="write" vba="15" num_blocks="7" salt="9311"/>
<request op="write" vba="65" num_blocks="7" salt="4583"/>
<request op="read" vba="23" num_blocks="1" salt="4673"/>
<request op="read" vba="25" num_blocks="1" salt="3243"/>
<request op="read" vba="28" num_blocks="2" salt="5774"/>
<request op="extend_ft" num_blocks="11" />
<request op="read" vba="24" num_blocks="1" salt="6092"/>
<request op="read" vba="12" num_blocks="3" salt="4545"/>
<request op="read" vba="19" num_blocks="3" salt="9311"/>
<request op="read" vba="10" num_blocks="2" salt="7538"/>
<request op="read" vba="65" num_blocks="7" salt="4583"/>
<request op="write" vba="60" num_blocks="10" salt="2725"/>
<request op="read" vba="63" num_blocks="7" salt="2725"/>
<request op="read" vba="70" num_blocks="2" salt="4583"/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<log string="Step 13: test synchronous vbd extension"/>
<request op="write" vba="20" num_blocks="3" salt="0473"/>
<request op="extend_vbd" num_blocks="23" />
<request op="read" vba="21" num_blocks="1" salt="0473"/>
<request op="extend_vbd" num_blocks="6" />
<request op="write" vba="15" num_blocks="10" salt="1296"/>
<request op="write" vba="15" num_blocks="4" salt="1161"/>
<request op="extend_vbd" num_blocks="10" />
<request op="read" vba="21" num_blocks="3" salt="1296"/>
<request op="read" vba="19" num_blocks="3" salt="1296"/>
<request op="write" vba="17" num_blocks="5" salt="5353"/>
<request op="extend_vbd" num_blocks="2" />
<request op="extend_vbd" num_blocks="2" />
<request op="extend_vbd" num_blocks="2" />
<request op="read" vba="22" num_blocks="3" salt="1296"/>
<request op="extend_vbd" num_blocks="1" />
<request op="read" vba="15" num_blocks="2" salt="1161"/>
<request op="write" vba="11" num_blocks="6" salt="3654"/>
<request op="write" vba="65" num_blocks="1" salt="5346"/>
<request op="read" vba="65" num_blocks="1" salt="5346"/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<log string="Step 14: test asynchronous vbd extension"/>
<request op="write" vba="20" num_blocks="3" salt="7384"/>
<request op="extend_vbd" num_blocks="21" />
<request op="extend_vbd" num_blocks="17" />
<request op="read" vba="21" num_blocks="1" salt="7384"/>
<request op="write" vba="15" num_blocks="10" salt="9602"/>
<request op="write" vba="15" num_blocks="4" salt="6100"/>
<request op="read" vba="21" num_blocks="3" salt="9602"/>
<request op="read" vba="19" num_blocks="3" salt="9602"/>
<request op="write" vba="17" num_blocks="5" salt="5555"/>
<request op="read" vba="22" num_blocks="3" salt="9602"/>
<request op="read" vba="15" num_blocks="2" salt="6100"/>
<request op="extend_vbd" num_blocks="180" />
<request op="write" vba="11" num_blocks="6" salt="1436"/>
<request op="read" vba="17" num_blocks="5" salt="5555"/>
<request op="write" vba="22" num_blocks="2" salt="7463"/>
<request op="write" vba="25" num_blocks="11" salt="4323"/>
<request op="read" vba="24" num_blocks="1" salt="9602"/>
<request op="write" vba="10" num_blocks="5" salt="3758"/>
<request op="extend_vbd" num_blocks="3" />
<request op="extend_vbd" num_blocks="2" />
<request op="write" vba="21" num_blocks="2" salt="8094"/>
<request op="write" vba="12" num_blocks="10" salt="4455"/>
<request op="write" vba="26" num_blocks="4" salt="7574"/>
<request op="write" vba="15" num_blocks="7" salt="1931"/>
<request op="write" vba="65" num_blocks="7" salt="8453"/>
<request op="read" vba="23" num_blocks="1" salt="7463"/>
<request op="read" vba="25" num_blocks="1" salt="4323"/>
<request op="read" vba="28" num_blocks="2" salt="7574"/>
<request op="extend_vbd" num_blocks="11" />
<request op="read" vba="24" num_blocks="1" salt="9602"/>
<request op="read" vba="12" num_blocks="3" salt="4455"/>
<request op="read" vba="19" num_blocks="3" salt="1931"/>
<request op="read" vba="10" num_blocks="2" salt="3758"/>
<request op="read" vba="65" num_blocks="7" salt="8453"/>
<request op="write" vba="60" num_blocks="10" salt="2275"/>
<request op="read" vba="63" num_blocks="7" salt="2275"/>
<request op="read" vba="70" num_blocks="2" salt="8453"/>
<request op="sync" vba="0" num_blocks="256" />
<check/>
<log string="Step 15: check minimum vbd dimensions"/>
<request op="deinitialize"/>
<destruct/>
<initialize>
<virtual-block-device max_lvl="1" degree="2" num_leaves="1"/>
<free-tree max_lvl="1" degree="2" num_leaves="1"/>
</initialize>
<check/>
<construct/>
<request op="read" vba="0" num_blocks="1" uninitialized="yes"/>
<request op="write" vba="0" num_blocks="1" salt="4321"/>
<request op="read" vba="0" num_blocks="1" salt="4321"/>
<log string="Step 16: check minimum free tree dimensions"/>
<request op="deinitialize"/>
<destruct/>
<initialize>
<virtual-block-device max_lvl="1" degree="2" num_leaves="1"/>
<free-tree max_lvl="2" degree="64" num_leaves="4096"/>
</initialize>
<construct/>
<check/>
<request op="write" vba="0" num_blocks="1" salt="1234"/>
<request op="read" vba="0" num_blocks="1" salt="1234"/>
<request op="rekey" sync="yes"/>
<request op="write" vba="0" num_blocks="1" salt="4321"/>
<request op="read" vba="0" num_blocks="1" salt="4321"/>
<request op="create_snapshot" id="13"/>
<request op="write" vba="0" num_blocks="1" salt="1234"/>
<request op="rekey"/>
<request op="write" vba="0" num_blocks="1" salt="9465"/>
<request op="read" vba="0" num_blocks="1" salt="9465"/>
<request op="extend_vbd" num_blocks="61" sync="yes"/>
<request op="write" vba="0" num_blocks="32" sync="yes" salt="4321"/>
<request op="read" vba="0" num_blocks="32" salt="4321"/>
<check/>
<check-snapshots/>
<log string="Step 17: check maximum tree dimensions"/>
<destruct/>
<initialize>
<virtual-block-device max_lvl="5" degree="64" num_leaves="100000"/>
<free-tree max_lvl="5" degree="64" num_leaves="100000"/>
</initialize>
<construct/>
<check/>
<request op="write" vba="0" num_blocks="1" salt="1234"/>
<request op="write" vba="99999" num_blocks="1" salt="5463"/>
<request op="read" vba="0" num_blocks="1" salt="1234"/>
<request op="extend_vbd" num_blocks="200"/>
<request op="write" vba="0" num_blocks="1" salt="4567"/>
<request op="read" vba="99999" num_blocks="1" salt="5463"/>
<request op="read" vba="0" num_blocks="1" salt="4567"/>
<request op="extend_ft" num_blocks="200"/>
<request op="write" vba="100" num_blocks="100" salt="1384"/>
<request op="write" vba="99990" num_blocks="30" salt="5463"/>
<request op="read" vba="100" num_blocks="100" salt="1384"/>
<request op="read" vba="99990" num_blocks="30" salt="5463"/>
<check/>
<check-snapshots/>
<log string="Step 18: reinitialize Tresor device"/>
<request op="deinitialize" />
<destruct/>
<initialize>
<virtual-block-device max_lvl="3" degree="64" num_leaves="25600" />
<free-tree max_lvl="3" degree="64" num_leaves="25600" />
</initialize>
<construct/>
}
if {[benchmark_blk_count] > 0} {
append config {
<log string="Step 19: do read/write benchmarks"/>
<start-benchmark label="read initial data in one request"/>
<request op="read" vba="0" num_blocks="} [benchmark_blk_count] {" />
<finish-benchmark/>
<start-benchmark label="overwrite initial data in one request"/>
<request op="write" vba="0" num_blocks="} [benchmark_blk_count] {" />
<finish-benchmark/>
<start-benchmark label="overwrite written data in one request"/>
<request op="write" vba="0" num_blocks="} [benchmark_blk_count] {" />
<finish-benchmark/>
<start-benchmark label="read written data in one request"/>
<request op="read" vba="0" num_blocks="} [benchmark_blk_count] {" />
<finish-benchmark/>
<start-benchmark label="read written data randomized"/>
<request op="read" vba="00001" num_blocks="10" />
<request op="read" vba="00028" num_blocks="80" />
<request op="read" vba="24045" num_blocks="50" />
<request op="read" vba="04441" num_blocks="10" />
<request op="read" vba="14240" num_blocks="40" />
<request op="read" vba="00230" num_blocks="80" />
<request op="read" vba="01673" num_blocks="30" />
<request op="read" vba="21609" num_blocks="30" />
<request op="read" vba="12201" num_blocks="10" />
<request op="read" vba="19601" num_blocks="10" />
<request op="read" vba="08901" num_blocks="10" />
<request op="read" vba="00972" num_blocks="20" />
<request op="read" vba="00097" num_blocks="70" />
<request op="read" vba="05593" num_blocks="30" />
<request op="read" vba="15201" num_blocks="10" />
<request op="read" vba="25237" num_blocks="20" />
<request op="read" vba="03537" num_blocks="70" />
<request op="read" vba="15151" num_blocks="10" />
<request op="read" vba="04374" num_blocks="40" />
<request op="read" vba="05350" num_blocks="40" />
<request op="read" vba="00754" num_blocks="40" />
<request op="read" vba="01729" num_blocks="90" />
<request op="read" vba="11246" num_blocks="60" />
<request op="read" vba="13229" num_blocks="90" />
<request op="read" vba="13001" num_blocks="10" />
<request op="read" vba="00120" num_blocks="90" />
<request op="read" vba="20111" num_blocks="10" />
<request op="read" vba="02451" num_blocks="10" />
<request op="read" vba="14734" num_blocks="40" />
<request op="read" vba="00942" num_blocks="20" />
<request op="read" vba="00091" num_blocks="10" />
<request op="read" vba="23011" num_blocks="10" />
<request op="read" vba="20271" num_blocks="50" />
<request op="read" vba="01283" num_blocks="30" />
<request op="read" vba="12823" num_blocks="30" />
<request op="read" vba="00200" num_blocks="50" />
<request op="read" vba="01234" num_blocks="40" />
<request op="read" vba="17490" num_blocks="70" />
<request op="read" vba="19990" num_blocks="20" />
<request op="read" vba="02190" num_blocks="30" />
<request op="read" vba="00421" num_blocks="10" />
<request op="read" vba="11421" num_blocks="10" />
<request op="read" vba="02481" num_blocks="50" />
<request op="read" vba="23471" num_blocks="10" />
<request op="read" vba="21291" num_blocks="40" />
<request op="read" vba="00212" num_blocks="20" />
<request op="read" vba="14402" num_blocks="20" />
<request op="read" vba="01201" num_blocks="10" />
<request op="read" vba="20975" num_blocks="30" />
<request op="read" vba="13777" num_blocks="70" />
<request op="read" vba="00100" num_blocks="10" />
<request op="read" vba="00820" num_blocks="80" />
<request op="read" vba="24540" num_blocks="50" />
<request op="read" vba="04144" num_blocks="10" />
<request op="read" vba="14042" num_blocks="40" />
<request op="read" vba="00032" num_blocks="80" />
<request op="read" vba="01376" num_blocks="30" />
<request op="read" vba="21906" num_blocks="30" />
<request op="read" vba="12102" num_blocks="10" />
<request op="read" vba="19106" num_blocks="10" />
<request op="read" vba="08109" num_blocks="10" />
<request op="read" vba="00279" num_blocks="20" />
<request op="read" vba="00790" num_blocks="70" />
<request op="read" vba="05395" num_blocks="30" />
<request op="read" vba="15102" num_blocks="10" />
<request op="read" vba="25032" num_blocks="20" />
<request op="read" vba="03735" num_blocks="70" />
<request op="read" vba="15151" num_blocks="10" />
<request op="read" vba="04473" num_blocks="40" />
<request op="read" vba="05053" num_blocks="40" />
<request op="read" vba="00457" num_blocks="40" />
<request op="read" vba="01927" num_blocks="90" />
<request op="read" vba="11642" num_blocks="60" />
<request op="read" vba="13922" num_blocks="90" />
<request op="read" vba="13100" num_blocks="10" />
<request op="read" vba="00021" num_blocks="90" />
<request op="read" vba="20111" num_blocks="10" />
<request op="read" vba="02154" num_blocks="10" />
<request op="read" vba="14437" num_blocks="40" />
<request op="read" vba="00249" num_blocks="20" />
<request op="read" vba="00190" num_blocks="10" />
<request op="read" vba="23110" num_blocks="10" />
<request op="read" vba="20172" num_blocks="50" />
<request op="read" vba="01382" num_blocks="30" />
<request op="read" vba="12328" num_blocks="30" />
<request op="read" vba="00002" num_blocks="50" />
<request op="read" vba="01432" num_blocks="40" />
<request op="read" vba="17094" num_blocks="70" />
<request op="read" vba="19099" num_blocks="20" />
<request op="read" vba="02091" num_blocks="30" />
<request op="read" vba="00124" num_blocks="10" />
<request op="read" vba="11124" num_blocks="10" />
<request op="read" vba="02184" num_blocks="50" />
<request op="read" vba="23174" num_blocks="10" />
<request op="read" vba="21192" num_blocks="40" />
<request op="read" vba="00212" num_blocks="20" />
<request op="read" vba="14204" num_blocks="20" />
<request op="read" vba="01102" num_blocks="10" />
<request op="read" vba="20579" num_blocks="30" />
<request op="read" vba="13777" num_blocks="70" />
<request op="read" vba="00010" num_blocks="10" />
<request op="read" vba="02080" num_blocks="80" />
<request op="read" vba="24054" num_blocks="50" />
<request op="read" vba="04414" num_blocks="10" />
<request op="read" vba="14204" num_blocks="40" />
<request op="read" vba="03200" num_blocks="80" />
<request op="read" vba="07631" num_blocks="30" />
<request op="read" vba="20691" num_blocks="30" />
<request op="read" vba="10212" num_blocks="10" />
<request op="read" vba="10619" num_blocks="10" />
<request op="read" vba="00918" num_blocks="10" />
<request op="read" vba="07920" num_blocks="20" />
<request op="read" vba="09070" num_blocks="70" />
<request op="read" vba="09535" num_blocks="30" />
<request op="read" vba="10215" num_blocks="10" />
<request op="read" vba="23275" num_blocks="20" />
<request op="read" vba="03573" num_blocks="70" />
<request op="read" vba="15115" num_blocks="10" />
<request op="read" vba="07344" num_blocks="40" />
<request op="read" vba="05305" num_blocks="40" />
<request op="read" vba="05740" num_blocks="40" />
<request op="read" vba="02791" num_blocks="90" />
<request op="read" vba="14261" num_blocks="60" />
<request op="read" vba="12293" num_blocks="90" />
<request op="read" vba="10013" num_blocks="10" />
<request op="read" vba="02100" num_blocks="90" />
<request op="read" vba="21110" num_blocks="10" />
<request op="read" vba="05412" num_blocks="10" />
<request op="read" vba="13744" num_blocks="40" />
<request op="read" vba="04920" num_blocks="20" />
<request op="read" vba="09010" num_blocks="10" />
<request op="read" vba="21013" num_blocks="10" />
<request op="read" vba="00210" num_blocks="50" />
<request op="read" vba="08231" num_blocks="30" />
<request op="read" vba="12832" num_blocks="30" />
<request op="read" vba="00200" num_blocks="50" />
<request op="read" vba="03241" num_blocks="40" />
<request op="read" vba="19407" num_blocks="70" />
<request op="read" vba="19909" num_blocks="20" />
<request op="read" vba="09102" num_blocks="30" />
<request op="read" vba="02410" num_blocks="10" />
<request op="read" vba="12411" num_blocks="10" />
<request op="read" vba="08412" num_blocks="50" />
<request op="read" vba="22413" num_blocks="10" />
<request op="read" vba="24211" num_blocks="40" />
<request op="read" vba="01220" num_blocks="20" />
<request op="read" vba="10424" num_blocks="20" />
<request op="read" vba="00211" num_blocks="10" />
<request op="read" vba="21950" num_blocks="30" />
<request op="read" vba="17773" num_blocks="70" />
<request op="read" vba="01000" num_blocks="10" />
<request op="read" vba="08002" num_blocks="80" />
<request op="read" vba="25044" num_blocks="50" />
<request op="read" vba="01444" num_blocks="10" />
<request op="read" vba="10244" num_blocks="40" />
<request op="read" vba="00203" num_blocks="80" />
<request op="read" vba="03617" num_blocks="30" />
<request op="read" vba="23610" num_blocks="30" />
<request op="read" vba="11220" num_blocks="10" />
<request op="read" vba="11690" num_blocks="10" />
<request op="read" vba="01980" num_blocks="10" />
<request op="read" vba="02907" num_blocks="20" />
<request op="read" vba="07009" num_blocks="70" />
<request op="read" vba="03559" num_blocks="30" />
<request op="read" vba="11250" num_blocks="10" />
<request op="read" vba="20253" num_blocks="20" />
<request op="read" vba="07533" num_blocks="70" />
<request op="read" vba="11155" num_blocks="10" />
<request op="read" vba="04347" num_blocks="40" />
<request op="read" vba="00355" num_blocks="40" />
<request op="read" vba="04705" num_blocks="40" />
<request op="read" vba="09712" num_blocks="90" />
<request op="read" vba="16214" num_blocks="60" />
<request op="read" vba="19232" num_blocks="90" />
<request op="read" vba="11030" num_blocks="10" />
<request op="read" vba="00102" num_blocks="90" />
<request op="read" vba="21101" num_blocks="10" />
<request op="read" vba="01425" num_blocks="10" />
<request op="read" vba="14743" num_blocks="40" />
<request op="read" vba="02904" num_blocks="20" />
<request op="read" vba="01009" num_blocks="10" />
<request op="read" vba="21031" num_blocks="10" />
<request op="read" vba="25207" num_blocks="50" />
<request op="read" vba="03218" num_blocks="30" />
<request op="read" vba="13822" num_blocks="30" />
<request op="read" vba="00200" num_blocks="50" />
<request op="read" vba="04213" num_blocks="40" />
<request op="read" vba="10479" num_blocks="70" />
<request op="read" vba="10999" num_blocks="20" />
<request op="read" vba="00129" num_blocks="30" />
<request op="read" vba="01402" num_blocks="10" />
<request op="read" vba="11412" num_blocks="10" />
<request op="read" vba="01428" num_blocks="50" />
<request op="read" vba="21437" num_blocks="10" />
<request op="read" vba="24219" num_blocks="40" />
<request op="read" vba="02201" num_blocks="20" />
<request op="read" vba="12440" num_blocks="20" />
<request op="read" vba="01210" num_blocks="10" />
<request op="read" vba="20907" num_blocks="30" />
<request op="read" vba="17737" num_blocks="70" />
<finish-benchmark/>
<start-benchmark label="overwrite written data randomized"/>
<request op="write" vba="00001" num_blocks="10" />
<request op="write" vba="00028" num_blocks="80" />
<request op="write" vba="24045" num_blocks="50" />
<request op="write" vba="04441" num_blocks="10" />
<request op="write" vba="14240" num_blocks="40" />
<request op="write" vba="00230" num_blocks="80" />
<request op="write" vba="01673" num_blocks="30" />
<request op="write" vba="21609" num_blocks="30" />
<request op="write" vba="12201" num_blocks="10" />
<request op="write" vba="19601" num_blocks="10" />
<request op="write" vba="08901" num_blocks="10" />
<request op="write" vba="00972" num_blocks="20" />
<request op="write" vba="00097" num_blocks="70" />
<request op="write" vba="05593" num_blocks="30" />
<request op="write" vba="15201" num_blocks="10" />
<request op="write" vba="25237" num_blocks="20" />
<request op="write" vba="03537" num_blocks="70" />
<request op="write" vba="15151" num_blocks="10" />
<request op="write" vba="04374" num_blocks="40" />
<request op="write" vba="05350" num_blocks="40" />
<request op="write" vba="00754" num_blocks="40" />
<request op="write" vba="01729" num_blocks="90" />
<request op="write" vba="11246" num_blocks="60" />
<request op="write" vba="13229" num_blocks="90" />
<request op="write" vba="13001" num_blocks="10" />
<request op="write" vba="00120" num_blocks="90" />
<request op="write" vba="20111" num_blocks="10" />
<request op="write" vba="02451" num_blocks="10" />
<request op="write" vba="14734" num_blocks="40" />
<request op="write" vba="00942" num_blocks="20" />
<request op="write" vba="00091" num_blocks="10" />
<request op="write" vba="23011" num_blocks="10" />
<request op="write" vba="20271" num_blocks="50" />
<request op="write" vba="01283" num_blocks="30" />
<request op="write" vba="12823" num_blocks="30" />
<request op="write" vba="00200" num_blocks="50" />
<request op="write" vba="01234" num_blocks="40" />
<request op="write" vba="17490" num_blocks="70" />
<request op="write" vba="19990" num_blocks="20" />
<request op="write" vba="02190" num_blocks="30" />
<request op="write" vba="00421" num_blocks="10" />
<request op="write" vba="11421" num_blocks="10" />
<request op="write" vba="02481" num_blocks="50" />
<request op="write" vba="23471" num_blocks="10" />
<request op="write" vba="21291" num_blocks="40" />
<request op="write" vba="00212" num_blocks="20" />
<request op="write" vba="14402" num_blocks="20" />
<request op="write" vba="01201" num_blocks="10" />
<request op="write" vba="20975" num_blocks="30" />
<request op="write" vba="13777" num_blocks="70" />
<request op="write" vba="00100" num_blocks="10" />
<request op="write" vba="00820" num_blocks="80" />
<request op="write" vba="24540" num_blocks="50" />
<request op="write" vba="04144" num_blocks="10" />
<request op="write" vba="14042" num_blocks="40" />
<request op="write" vba="00032" num_blocks="80" />
<request op="write" vba="01376" num_blocks="30" />
<request op="write" vba="21906" num_blocks="30" />
<request op="write" vba="12102" num_blocks="10" />
<request op="write" vba="19106" num_blocks="10" />
<request op="write" vba="08109" num_blocks="10" />
<request op="write" vba="00279" num_blocks="20" />
<request op="write" vba="00790" num_blocks="70" />
<request op="write" vba="05395" num_blocks="30" />
<request op="write" vba="15102" num_blocks="10" />
<request op="write" vba="25032" num_blocks="20" />
<request op="write" vba="03735" num_blocks="70" />
<request op="write" vba="15151" num_blocks="10" />
<request op="write" vba="04473" num_blocks="40" />
<request op="write" vba="05053" num_blocks="40" />
<request op="write" vba="00457" num_blocks="40" />
<request op="write" vba="01927" num_blocks="90" />
<request op="write" vba="11642" num_blocks="60" />
<request op="write" vba="13922" num_blocks="90" />
<request op="write" vba="13100" num_blocks="10" />
<request op="write" vba="00021" num_blocks="90" />
<request op="write" vba="20111" num_blocks="10" />
<request op="write" vba="02154" num_blocks="10" />
<request op="write" vba="14437" num_blocks="40" />
<request op="write" vba="00249" num_blocks="20" />
<request op="write" vba="00190" num_blocks="10" />
<request op="write" vba="23110" num_blocks="10" />
<request op="write" vba="20172" num_blocks="50" />
<request op="write" vba="01382" num_blocks="30" />
<request op="write" vba="12328" num_blocks="30" />
<request op="write" vba="00002" num_blocks="50" />
<request op="write" vba="01432" num_blocks="40" />
<request op="write" vba="17094" num_blocks="70" />
<request op="write" vba="19099" num_blocks="20" />
<request op="write" vba="02091" num_blocks="30" />
<request op="write" vba="00124" num_blocks="10" />
<request op="write" vba="11124" num_blocks="10" />
<request op="write" vba="02184" num_blocks="50" />
<request op="write" vba="23174" num_blocks="10" />
<request op="write" vba="21192" num_blocks="40" />
<request op="write" vba="00212" num_blocks="20" />
<request op="write" vba="14204" num_blocks="20" />
<request op="write" vba="01102" num_blocks="10" />
<request op="write" vba="20579" num_blocks="30" />
<request op="write" vba="13777" num_blocks="70" />
<request op="write" vba="00010" num_blocks="10" />
<request op="write" vba="02080" num_blocks="80" />
<request op="write" vba="24054" num_blocks="50" />
<request op="write" vba="04414" num_blocks="10" />
<request op="write" vba="14204" num_blocks="40" />
<request op="write" vba="03200" num_blocks="80" />
<request op="write" vba="07631" num_blocks="30" />
<request op="write" vba="20691" num_blocks="30" />
<request op="write" vba="10212" num_blocks="10" />
<request op="write" vba="10619" num_blocks="10" />
<request op="write" vba="00918" num_blocks="10" />
<request op="write" vba="07920" num_blocks="20" />
<request op="write" vba="09070" num_blocks="70" />
<request op="write" vba="09535" num_blocks="30" />
<request op="write" vba="10215" num_blocks="10" />
<request op="write" vba="23275" num_blocks="20" />
<request op="write" vba="03573" num_blocks="70" />
<request op="write" vba="15115" num_blocks="10" />
<request op="write" vba="07344" num_blocks="40" />
<request op="write" vba="05305" num_blocks="40" />
<request op="write" vba="05740" num_blocks="40" />
<request op="write" vba="02791" num_blocks="90" />
<request op="write" vba="14261" num_blocks="60" />
<request op="write" vba="12293" num_blocks="90" />
<request op="write" vba="10013" num_blocks="10" />
<request op="write" vba="02100" num_blocks="90" />
<request op="write" vba="21110" num_blocks="10" />
<request op="write" vba="05412" num_blocks="10" />
<request op="write" vba="13744" num_blocks="40" />
<request op="write" vba="04920" num_blocks="20" />
<request op="write" vba="09010" num_blocks="10" />
<request op="write" vba="21013" num_blocks="10" />
<request op="write" vba="00210" num_blocks="50" />
<request op="write" vba="08231" num_blocks="30" />
<request op="write" vba="12832" num_blocks="30" />
<request op="write" vba="00200" num_blocks="50" />
<request op="write" vba="03241" num_blocks="40" />
<request op="write" vba="19407" num_blocks="70" />
<request op="write" vba="19909" num_blocks="20" />
<request op="write" vba="09102" num_blocks="30" />
<request op="write" vba="02410" num_blocks="10" />
<request op="write" vba="12411" num_blocks="10" />
<request op="write" vba="08412" num_blocks="50" />
<request op="write" vba="22413" num_blocks="10" />
<request op="write" vba="24211" num_blocks="40" />
<request op="write" vba="01220" num_blocks="20" />
<request op="write" vba="10424" num_blocks="20" />
<request op="write" vba="00211" num_blocks="10" />
<request op="write" vba="21950" num_blocks="30" />
<request op="write" vba="17773" num_blocks="70" />
<request op="write" vba="01000" num_blocks="10" />
<request op="write" vba="08002" num_blocks="80" />
<request op="write" vba="25044" num_blocks="50" />
<request op="write" vba="01444" num_blocks="10" />
<request op="write" vba="10244" num_blocks="40" />
<request op="write" vba="00203" num_blocks="80" />
<request op="write" vba="03617" num_blocks="30" />
<request op="write" vba="23610" num_blocks="30" />
<request op="write" vba="11220" num_blocks="10" />
<request op="write" vba="11690" num_blocks="10" />
<request op="write" vba="01980" num_blocks="10" />
<request op="write" vba="02907" num_blocks="20" />
<request op="write" vba="07009" num_blocks="70" />
<request op="write" vba="03559" num_blocks="30" />
<request op="write" vba="11250" num_blocks="10" />
<request op="write" vba="20253" num_blocks="20" />
<request op="write" vba="07533" num_blocks="70" />
<request op="write" vba="11155" num_blocks="10" />
<request op="write" vba="04347" num_blocks="40" />
<request op="write" vba="00355" num_blocks="40" />
<request op="write" vba="04705" num_blocks="40" />
<request op="write" vba="09712" num_blocks="90" />
<request op="write" vba="16214" num_blocks="60" />
<request op="write" vba="19232" num_blocks="90" />
<request op="write" vba="11030" num_blocks="10" />
<request op="write" vba="00102" num_blocks="90" />
<request op="write" vba="21101" num_blocks="10" />
<request op="write" vba="01425" num_blocks="10" />
<request op="write" vba="14743" num_blocks="40" />
<request op="write" vba="02904" num_blocks="20" />
<request op="write" vba="01009" num_blocks="10" />
<request op="write" vba="21031" num_blocks="10" />
<request op="write" vba="25207" num_blocks="50" />
<request op="write" vba="03218" num_blocks="30" />
<request op="write" vba="13822" num_blocks="30" />
<request op="write" vba="00200" num_blocks="50" />
<request op="write" vba="04213" num_blocks="40" />
<request op="write" vba="10479" num_blocks="70" />
<request op="write" vba="10999" num_blocks="20" />
<request op="write" vba="00129" num_blocks="30" />
<request op="write" vba="01402" num_blocks="10" />
<request op="write" vba="11412" num_blocks="10" />
<request op="write" vba="01428" num_blocks="50" />
<request op="write" vba="21437" num_blocks="10" />
<request op="write" vba="24219" num_blocks="40" />
<request op="write" vba="02201" num_blocks="20" />
<request op="write" vba="12440" num_blocks="20" />
<request op="write" vba="01210" num_blocks="10" />
<request op="write" vba="20907" num_blocks="30" />
<request op="write" vba="17737" num_blocks="70" />
<finish-benchmark/>
<check/>
}
} else {
append config {
<log string="Step 19: skip because benchmarks are disabled for this platform"/>
}
}
append config {
<log string="Step 20: test check-snapshots command"/>
<request op="create_snapshot" id="15"/>
<request op="write" vba="17737" num_blocks="70" salt="8924"/>
<request op="create_snapshot" id="16"/>
<request op="write" vba="00129" num_blocks="30" salt="9471"/>
<request op="create_snapshot" id="17"/>
<check-snapshots/>
</commands>
</config>
<route>
<service name="File_system" label_last="trust_anchor"> <child name="trust_anchor_fs"/> </service>
<service name="File_system"> <child name="block_io_fs"/> </service>
<service name="Terminal"> <child name="log_terminal"/> </service>
<service name="Timer"> <child name="timer"/> </service>
<service name="LOG"> <parent/> </service>
<service name="PD"> <parent/> </service>
<service name="CPU"> <parent/> </service>
<service name="ROM"> <parent/> </service>
</route>
</start>
</config>
}
install_config $config
if {[have_board linux]} {
exec rm -rf [lx_local_tresor_image]
if { [get_cmd_switch --autopilot] } {
exec rm -rf [lx_autopilot_tresor_image]
catch { exec $dd if=/dev/urandom of=[lx_autopilot_tresor_image] bs=1M count=[lx_tresor_image_size_mb] }
exec ln -sf -T [lx_autopilot_tresor_image] [lx_local_tresor_image]
} else {
catch { exec $dd if=/dev/urandom of=[lx_local_tresor_image] bs=1M count=[lx_tresor_image_size_mb] }
}
}
set boot_modules [build_artifacts]
lappend_if [have_board linux] boot_modules [tresor_image_name]
build_boot_image $boot_modules
append qemu_args " -nographic "
set test_timeout 100
if {[benchmark_blk_count] > 0} {
set test_timeout 300
}
run_genode_until "child \"test\" exited with exit value.*\n" $test_timeout
if {[have_board linux]} {
if { [get_cmd_switch --autopilot] } {
exec rm -rf [lx_local_tresor_image]
exec rm -rf [lx_autopilot_tresor_image]
}
}
grep_output {\[init\] child "test" exited with exit value}
compare_output_to {[init] child "test" exited with exit value 0}