summaryrefslogtreecommitdiff
path: root/test/lit/exec
diff options
context:
space:
mode:
Diffstat (limited to 'test/lit/exec')
-rw-r--r--test/lit/exec/memory-copy.wat267
-rw-r--r--test/lit/exec/memory-fill.wat184
2 files changed, 451 insertions, 0 deletions
diff --git a/test/lit/exec/memory-copy.wat b/test/lit/exec/memory-copy.wat
new file mode 100644
index 000000000..793f94656
--- /dev/null
+++ b/test/lit/exec/memory-copy.wat
@@ -0,0 +1,267 @@
+;; NOTE: Assertions have been generated by update_lit_checks.py --output=fuzz-exec and should not be edited.
+
+;; RUN: wasm-opt %s --enable-bulk-memory --memory-copy-fill-lowering --fuzz-exec -q -o /dev/null 2>&1 | filecheck %s
+
+;; Tests derived from bulk-memory.wast spec tests
+
+;; memory.copy
+(module
+ (import "fuzzing-support" "log-i32" (func $log-i32 (param i32)))
+ (memory 1 1)
+ (data (i32.const 0) "\aa\bb\cc\dd")
+
+ (func $assert_load (param i32 i32)
+ (if (i32.ne (local.get 1) (i32.load8_u (local.get 0)))
+ (then (unreachable)))
+ )
+
+ (func $print_memory
+ (local $i i32)
+ (local.set 0 (i32.const 9))
+ (loop $loop
+ (call $log-i32 (local.get 0))
+ (call $log-i32 (i32.load8_u (local.get 0)))
+ (local.set 0 (i32.add (local.get 0) (i32.const 1)))
+ (br_if $loop (i32.ne (local.get 0) (i32.const 17)))
+ )
+ )
+
+ ;; non-overlapping copy
+ ;; CHECK: [fuzz-exec] calling test1
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ (func $test1 (export "test1")
+ (call $print_memory)
+ (memory.copy (i32.const 10) (i32.const 0) (i32.const 4))
+ (call $print_memory)
+ (call $assert_load (i32.const 9) (i32.const 0))
+ (call $assert_load (i32.const 10) (i32.const 0xaa))
+ (call $assert_load (i32.const 11) (i32.const 0xbb))
+ (call $assert_load (i32.const 12) (i32.const 0xcc))
+ (call $assert_load (i32.const 13) (i32.const 0xdd))
+ (call $assert_load (i32.const 14) (i32.const 0))
+ )
+ ;; Overlap, src > dst
+ ;; CHECK: [fuzz-exec] calling test2
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ (func $test2 (export "test2")
+ (memory.copy (i32.const 8) (i32.const 10) (i32.const 4))
+ (call $print_memory)
+ (call $assert_load (i32.const 8) (i32.const 0xaa))
+ (call $assert_load (i32.const 9) (i32.const 0xbb))
+ (call $assert_load (i32.const 10) (i32.const 0xcc))
+ (call $assert_load (i32.const 11) (i32.const 0xdd))
+ (call $assert_load (i32.const 12) (i32.const 0xcc))
+ (call $assert_load (i32.const 13) (i32.const 0xdd))
+ )
+ ;; Overlap, src < dst
+ ;; CHECK: [fuzz-exec] calling test3
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ (func $test3 (export "test3")
+ (memory.copy (i32.const 10) (i32.const 7) (i32.const 6))
+ (call $print_memory)
+ (call $assert_load (i32.const 10) (i32.const 0x0))
+ (call $assert_load (i32.const 11) (i32.const 0xaa))
+ (call $assert_load (i32.const 12) (i32.const 0xbb))
+ (call $assert_load (i32.const 13) (i32.const 0xcc))
+ (call $assert_load (i32.const 14) (i32.const 0xdd))
+ (call $assert_load (i32.const 15) (i32.const 0xcc))
+ (call $assert_load (i32.const 16) (i32.const 0))
+ )
+ ;; Overlap src < dst but size is OOB (but the address does not overflow)
+ ;; CHECK: [fuzz-exec] calling test4a
+ ;; CHECK-NEXT: [trap out of bounds segment access in memory.copy]
+ (func $test4a (export "test4a")
+ (memory.copy (i32.const 13) (i32.const 11) (i32.const 0x10000))
+ (call $print_memory) ;; not reached.
+ )
+ ;; CHECK: [fuzz-exec] calling test4b
+ (func $test4b (export "test4b")
+ (call $assert_load (i32.const 10) (i32.const 0x0))
+ (call $assert_load (i32.const 11) (i32.const 0xaa))
+ (call $assert_load (i32.const 12) (i32.const 0xbb))
+ (call $assert_load (i32.const 13) (i32.const 0xcc))
+ (call $assert_load (i32.const 14) (i32.const 0xdd))
+ (call $assert_load (i32.const 15) (i32.const 0xcc))
+ (call $assert_load (i32.const 16) (i32.const 0))
+ )
+ ;; Copy ending at memory limit is ok
+ ;; CHECK: [fuzz-exec] calling test5
+ (func $test5 (export "test5")
+ (memory.copy (i32.const 0xff00) (i32.const 0) (i32.const 0x100))
+ (memory.copy (i32.const 0xfe00) (i32.const 0xff00) (i32.const 0x100))
+ )
+ ;; Succeed when copying 0 bytes at the end of the region
+ ;; CHECK: [fuzz-exec] calling test6
+ (func $test6 (export "test6")
+ (memory.copy (i32.const 0x10000) (i32.const 0) (i32.const 0))
+ (memory.copy (i32.const 0x0) (i32.const 0x10000) (i32.const 0))
+ )
+ ;; copying 0 bytes outside of the limit is not allowed.
+ ;; CHECK: [fuzz-exec] calling test7
+ ;; CHECK-NEXT: [trap out of bounds segment access in memory.copy]
+ (func $test7 (export "test7")
+ (memory.copy (i32.const 0x10001) (i32.const 0) (i32.const 0x0))
+ )
+ ;; CHECK: [fuzz-exec] calling test8
+ ;; CHECK-NEXT: [trap out of bounds segment access in memory.copy]
+ (func $test8 (export "test8")
+ (memory.copy (i32.const 0x0) (i32.const 0x10001) (i32.const 0))
+ )
+)
+
+
+
+;; CHECK: [fuzz-exec] calling test1
+;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+
+;; CHECK: [fuzz-exec] calling test2
+;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+
+;; CHECK: [fuzz-exec] calling test3
+;; CHECK-NEXT: [LoggingExternalInterface logging 9]
+;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+;; CHECK-NEXT: [LoggingExternalInterface logging 10]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 11]
+;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+;; CHECK-NEXT: [LoggingExternalInterface logging 12]
+;; CHECK-NEXT: [LoggingExternalInterface logging 187]
+;; CHECK-NEXT: [LoggingExternalInterface logging 13]
+;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+;; CHECK-NEXT: [LoggingExternalInterface logging 14]
+;; CHECK-NEXT: [LoggingExternalInterface logging 221]
+;; CHECK-NEXT: [LoggingExternalInterface logging 15]
+;; CHECK-NEXT: [LoggingExternalInterface logging 204]
+;; CHECK-NEXT: [LoggingExternalInterface logging 16]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+
+;; CHECK: [fuzz-exec] calling test4a
+;; CHECK-NEXT: [trap unreachable]
+
+;; CHECK: [fuzz-exec] calling test4b
+
+;; CHECK: [fuzz-exec] calling test5
+
+;; CHECK: [fuzz-exec] calling test6
+
+;; CHECK: [fuzz-exec] calling test7
+;; CHECK-NEXT: [trap unreachable]
+
+;; CHECK: [fuzz-exec] calling test8
+;; CHECK-NEXT: [trap unreachable]
+;; CHECK-NEXT: [fuzz-exec] comparing test1
+;; CHECK-NEXT: [fuzz-exec] comparing test2
+;; CHECK-NEXT: [fuzz-exec] comparing test3
+;; CHECK-NEXT: [fuzz-exec] comparing test4a
+;; CHECK-NEXT: [fuzz-exec] comparing test4b
+;; CHECK-NEXT: [fuzz-exec] comparing test5
+;; CHECK-NEXT: [fuzz-exec] comparing test6
+;; CHECK-NEXT: [fuzz-exec] comparing test7
+;; CHECK-NEXT: [fuzz-exec] comparing test8
diff --git a/test/lit/exec/memory-fill.wat b/test/lit/exec/memory-fill.wat
new file mode 100644
index 000000000..dc9aead6d
--- /dev/null
+++ b/test/lit/exec/memory-fill.wat
@@ -0,0 +1,184 @@
+;; NOTE: Assertions have been generated by update_lit_checks.py --output=fuzz-exec and should not be edited.
+
+;; RUN: wasm-opt %s --enable-bulk-memory --memory-copy-fill-lowering --fuzz-exec -q -o /dev/null 2>&1 | filecheck %s
+
+;; Tests derived from bulk-memory.wast spec tests
+
+;; memory.fill
+(module
+ (import "fuzzing-support" "log-i32" (func $log-i32 (param i32)))
+ (memory 1)
+
+
+ (func $assert_load (param i32 i32)
+ (if (i32.ne (local.get 1) (i32.load8_u (local.get 0)))
+ (then (unreachable)))
+ )
+
+ (func $print_memory (param i32 i32)
+ (loop $loop
+ (call $log-i32 (local.get 0))
+ (call $log-i32 (i32.load8_u (local.get 0)))
+ (local.set 0 (i32.add (local.get 0) (i32.const 1)))
+ (br_if $loop (i32.ne (local.get 0) (local.get 1)))
+ )
+ )
+ ;; basic fill test
+ ;; CHECK: [fuzz-exec] calling test1
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 255]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 255]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 255]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ (func $test1 (export "test1")
+ (call $print_memory (i32.const 0) (i32.const 5))
+ (memory.fill (i32.const 1) (i32.const 0xff) (i32.const 3))
+ (call $print_memory (i32.const 0) (i32.const 5))
+ (call $assert_load (i32.const 0) (i32.const 0))
+ (call $assert_load (i32.const 1) (i32.const 0xff))
+ (call $assert_load (i32.const 2) (i32.const 0xff))
+ (call $assert_load (i32.const 3) (i32.const 0xff))
+ (call $assert_load (i32.const 4) (i32.const 0x0))
+ )
+ ;; Fill value is stored as a byte
+ ;; CHECK: [fuzz-exec] calling test2
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+ (func $test2 (export "test2")
+ (memory.fill (i32.const 0) (i32.const 0xbbaa) (i32.const 2))
+ (call $print_memory (i32.const 0) (i32.const 2))
+ (call $assert_load (i32.const 0) (i32.const 0xaa))
+ (call $assert_load (i32.const 1) (i32.const 0xaa))
+ )
+ ;; Fill all of memory
+ ;; CHECK: [fuzz-exec] calling test3
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 5]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ (func $test3 (export "test3")
+ (memory.fill (i32.const 0) (i32.const 0) (i32.const 0x10000))
+ ;; let's not print all of memory; just beyond what we filled before
+ (call $print_memory (i32.const 0) (i32.const 6))
+ )
+ ;; Succeed when writing 0 bytes at the end of the region
+ ;; CHECK: [fuzz-exec] calling test4
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 5]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 6]
+ ;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+ (func $test4 (export "test4")
+ (memory.fill (i32.const 0x10000) (i32.const 0) (i32.const 0))
+ ;; let's not print all of memory; just beyond what we filled before
+ (call $print_memory (i32.const 0) (i32.const 7))
+ )
+ ;; Writing 0 bytes outside of memory is not allowed
+ ;; CHECK: [fuzz-exec] calling test5
+ ;; CHECK-NEXT: [trap out of bounds memory access in memory.fill]
+ (func $test5 (export "test5")
+ (memory.fill (i32.const 0x10001) (i32.const 0) (i32.const 0))
+ ;; should not be reached
+ (call $print_memory (i32.const 0) (i32.const 6))
+ )
+ ;; again we do not test negative/overflowing addresses as the spec test does.
+)
+;; CHECK: [fuzz-exec] calling test1
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+;; CHECK-NEXT: [LoggingExternalInterface logging 255]
+;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+;; CHECK-NEXT: [LoggingExternalInterface logging 255]
+;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+;; CHECK-NEXT: [LoggingExternalInterface logging 255]
+;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+
+;; CHECK: [fuzz-exec] calling test2
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+;; CHECK-NEXT: [LoggingExternalInterface logging 170]
+
+;; CHECK: [fuzz-exec] calling test3
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 5]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+
+;; CHECK: [fuzz-exec] calling test4
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 1]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 2]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 3]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 4]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 5]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+;; CHECK-NEXT: [LoggingExternalInterface logging 6]
+;; CHECK-NEXT: [LoggingExternalInterface logging 0]
+
+;; CHECK: [fuzz-exec] calling test5
+;; CHECK-NEXT: [trap unreachable]
+;; CHECK-NEXT: [fuzz-exec] comparing test1
+;; CHECK-NEXT: [fuzz-exec] comparing test2
+;; CHECK-NEXT: [fuzz-exec] comparing test3
+;; CHECK-NEXT: [fuzz-exec] comparing test4
+;; CHECK-NEXT: [fuzz-exec] comparing test5