blob: 3a3c19d7fd9f709a0b04b04debb944dffcf2cdcf [file] [log] [blame] [edit]
;; RUN: wasm-split %s --instrument --in-memory -all -S -o - | filecheck %s
;; Check that the output round trips and validates as well
;; RUN: wasm-split %s --instrument --in-memory -all -g -o %t.wasm
;; RUN: wasm-opt -all %t.wasm -S -o -
(module
(import "env" "foo" (func $foo))
(export "bar" (func $bar))
(memory $0 1 1)
(func $bar
(call $foo)
)
(func $baz (param i32) (result i32)
(local.get 0)
)
)
;; Check that a memory has been added
;; CHECK: (memory $0 1 1)
;; And the profiling function exported
;; CHECK: (export "__write_profile" (func $__write_profile))
;; Check that the function instrumentation is correct
;; CHECK: (func $bar
;; CHECK-NEXT: (i32.atomic.store8
;; CHECK-NEXT: (i32.const 0)
;; CHECK-NEXT: (i32.const 1)
;; CHECK-NEXT: )
;; CHECK-NEXT: (call $foo)
;; CHECK-NEXT: )
;; CHECK-NEXT: (func $baz (param $0 i32) (result i32)
;; CHECK-NEXT: (i32.atomic.store8 offset=1
;; CHECK-NEXT: (i32.const 0)
;; CHECK-NEXT: (i32.const 1)
;; CHECK-NEXT: )
;; CHECK-NEXT: (local.get $0)
;; CHECK-NEXT: )
;; Check that the profiling function is correct.
;; CHECK: (func $__write_profile (param $addr i32) (param $size i32) (result i32)
;; CHECK-NEXT: (local $funcIdx i32)
;; CHECK-NEXT: (if
;; CHECK-NEXT: (i32.ge_u
;; CHECK-NEXT: (local.get $size)
;; CHECK-NEXT: (i32.const 16)
;; CHECK-NEXT: )
;; CHECK-NEXT: (block
;; CHECK-NEXT: (i64.store align=1
;; CHECK-NEXT: (local.get $addr)
;; CHECK-NEXT: (i64.const {{.*}})
;; CHECK-NEXT: )
;; CHECK-NEXT: (block $outer
;; CHECK-NEXT: (loop $l
;; CHECK-NEXT: (br_if $outer
;; CHECK-NEXT: (i32.eq
;; CHECK-NEXT: (local.get $funcIdx)
;; CHECK-NEXT: (i32.const 2)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (i32.store offset=8
;; CHECK-NEXT: (i32.add
;; CHECK-NEXT: (local.get $addr)
;; CHECK-NEXT: (i32.mul
;; CHECK-NEXT: (local.get $funcIdx)
;; CHECK-NEXT: (i32.const 4)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (i32.atomic.load8_u
;; CHECK-NEXT: (local.get $funcIdx)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (local.set $funcIdx
;; CHECK-NEXT: (i32.add
;; CHECK-NEXT: (local.get $funcIdx)
;; CHECK-NEXT: (i32.const 1)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (br $l)
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: )
;; CHECK-NEXT: (i32.const 16)
;; CHECK-NEXT: )