mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-02 12:06:44 +00:00
b903ddeea7
* 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
1167 lines
51 KiB
Plaintext
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}
|