| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- ;; Bulk instructions
- ;; invalid uses
- (assert_invalid
- (module
- (type $a (array i8))
- (type $b (array (mut i8)))
- (func (export "array.copy-immutable") (param $1 (ref $a)) (param $2 (ref $b))
- (array.copy $a $b (local.get $1) (i32.const 0) (local.get $2) (i32.const 0) (i32.const 0))
- )
- )
- "array is immutable"
- )
- (assert_invalid
- (module
- (type $a (array (mut i8)))
- (type $b (array i16))
- (func (export "array.copy-packed-invalid") (param $1 (ref $a)) (param $2 (ref $b))
- (array.copy $a $b (local.get $1) (i32.const 0) (local.get $2) (i32.const 0) (i32.const 0))
- )
- )
- "array types do not match"
- )
- (assert_invalid
- (module
- (type $a (array (mut i8)))
- (type $b (array (mut (ref $a))))
- (func (export "array.copy-ref-invalid-1") (param $1 (ref $a)) (param $2 (ref $b))
- (array.copy $a $b (local.get $1) (i32.const 0) (local.get $2) (i32.const 0) (i32.const 0))
- )
- )
- "array types do not match"
- )
- (assert_invalid
- (module
- (type $a (array (mut i8)))
- (type $b (array (mut (ref $a))))
- (type $c (array (mut (ref $b))))
- (func (export "array.copy-ref-invalid-1") (param $1 (ref $b)) (param $2 (ref $c))
- (array.copy $b $c (local.get $1) (i32.const 0) (local.get $2) (i32.const 0) (i32.const 0))
- )
- )
- "array types do not match"
- )
- (module
- (type $arr8 (array i8))
- (type $arr8_mut (array (mut i8)))
- (global $g_arr8 (ref $arr8) (array.new $arr8 (i32.const 10) (i32.const 12)))
- (global $g_arr8_mut (mut (ref $arr8_mut)) (array.new_default $arr8_mut (i32.const 12)))
- (data $d1 "abcdefghijkl")
- (func (export "array_get_nth") (param $1 i32) (result i32)
- (array.get_u $arr8_mut (global.get $g_arr8_mut) (local.get $1))
- )
- (func (export "array_copy-null-left")
- (array.copy $arr8_mut $arr8 (ref.null $arr8_mut) (i32.const 0) (global.get $g_arr8) (i32.const 0) (i32.const 0))
- )
- (func (export "array_copy-null-right")
- (array.copy $arr8_mut $arr8 (global.get $g_arr8_mut) (i32.const 0) (ref.null $arr8) (i32.const 0) (i32.const 0))
- )
- (func (export "array_copy") (param $1 i32) (param $2 i32) (param $3 i32)
- (array.copy $arr8_mut $arr8 (global.get $g_arr8_mut) (local.get $1) (global.get $g_arr8) (local.get $2) (local.get $3))
- )
- (func (export "array_copy_overlap_test-1")
- (local $1 (ref $arr8_mut))
- (array.new_data $arr8_mut $d1 (i32.const 0) (i32.const 12))
- (local.set $1)
- (array.copy $arr8_mut $arr8_mut (local.get $1) (i32.const 1) (local.get $1) (i32.const 0) (i32.const 11))
- (global.set $g_arr8_mut (local.get $1))
- )
- (func (export "array_copy_overlap_test-2")
- (local $1 (ref $arr8_mut))
- (array.new_data $arr8_mut $d1 (i32.const 0) (i32.const 12))
- (local.set $1)
- (array.copy $arr8_mut $arr8_mut (local.get $1) (i32.const 0) (local.get $1) (i32.const 1) (i32.const 11))
- (global.set $g_arr8_mut (local.get $1))
- )
- )
- ;; null array argument traps
- (assert_trap (invoke "array_copy-null-left") "null array reference")
- (assert_trap (invoke "array_copy-null-right") "null array reference")
- ;; OOB initial index traps
- (assert_trap (invoke "array_copy" (i32.const 13) (i32.const 0) (i32.const 0)) "out of bounds array access")
- (assert_trap (invoke "array_copy" (i32.const 0) (i32.const 13) (i32.const 0)) "out of bounds array access")
- ;; OOB length traps
- (assert_trap (invoke "array_copy" (i32.const 0) (i32.const 0) (i32.const 13)) "out of bounds array access")
- (assert_trap (invoke "array_copy" (i32.const 0) (i32.const 0) (i32.const 13)) "out of bounds array access")
- ;; start index = array size, len = 0 doesn't trap
- (assert_return (invoke "array_copy" (i32.const 12) (i32.const 0) (i32.const 0)))
- (assert_return (invoke "array_copy" (i32.const 0) (i32.const 12) (i32.const 0)))
- ;; check arrays were not modified
- (assert_return (invoke "array_get_nth" (i32.const 0)) (i32.const 0))
- (assert_return (invoke "array_get_nth" (i32.const 5)) (i32.const 0))
- (assert_return (invoke "array_get_nth" (i32.const 11)) (i32.const 0))
- (assert_trap (invoke "array_get_nth" (i32.const 12)) "out of bounds array access")
- ;; normal case
- (assert_return (invoke "array_copy" (i32.const 0) (i32.const 0) (i32.const 2)))
- (assert_return (invoke "array_get_nth" (i32.const 0)) (i32.const 10))
- (assert_return (invoke "array_get_nth" (i32.const 1)) (i32.const 10))
- (assert_return (invoke "array_get_nth" (i32.const 2)) (i32.const 0))
- ;; test that overlapping array.copy works as if intermediate copy taken
- (assert_return (invoke "array_copy_overlap_test-1"))
- (assert_return (invoke "array_get_nth" (i32.const 0)) (i32.const 97))
- (assert_return (invoke "array_get_nth" (i32.const 1)) (i32.const 97))
- (assert_return (invoke "array_get_nth" (i32.const 2)) (i32.const 98))
- (assert_return (invoke "array_get_nth" (i32.const 5)) (i32.const 101))
- (assert_return (invoke "array_get_nth" (i32.const 10)) (i32.const 106))
- (assert_return (invoke "array_get_nth" (i32.const 11)) (i32.const 107))
- (assert_return (invoke "array_copy_overlap_test-2"))
- (assert_return (invoke "array_get_nth" (i32.const 0)) (i32.const 98))
- (assert_return (invoke "array_get_nth" (i32.const 1)) (i32.const 99))
- (assert_return (invoke "array_get_nth" (i32.const 5)) (i32.const 103))
- (assert_return (invoke "array_get_nth" (i32.const 9)) (i32.const 107))
- (assert_return (invoke "array_get_nth" (i32.const 10)) (i32.const 108))
- (assert_return (invoke "array_get_nth" (i32.const 11)) (i32.const 108))
|