| ;;; TOOL: run-interp |
| ;;; ARGS*: --enable-threads |
| (module |
| (memory 1 1 shared) |
| |
| ;; i32 |
| |
| (func (export "i32.atomic.rmw8.and_u-result") (result i32) |
| i32.const 0 i32.const 1000000 i32.store |
| i32.const 0 i32.const 64 i32.atomic.rmw8.and_u) |
| |
| (func (export "i32.atomic.rmw8.and_u-memory") (result i32) |
| i32.const 0 i32.const 1000000 i32.store |
| i32.const 0 i32.const 64 i32.atomic.rmw8.and_u drop |
| i32.const 0 i32.load8_u) |
| |
| (func (export "i32.atomic.rmw16.and_u-result") (result i32) |
| i32.const 0 i32.const 1000000 i32.store |
| i32.const 0 i32.const 64 i32.atomic.rmw16.and_u) |
| |
| (func (export "i32.atomic.rmw16.and_u-memory") (result i32) |
| i32.const 0 i32.const 1000000 i32.store |
| i32.const 0 i32.const 64 i32.atomic.rmw16.and_u drop |
| i32.const 0 i32.load16_u) |
| |
| (func (export "i32.atomic.rmw.and-result") (result i32) |
| i32.const 0 i32.const 1000000 i32.store |
| i32.const 0 i32.const 64 i32.atomic.rmw.and) |
| |
| (func (export "i32.atomic.rmw.and-memory") (result i32) |
| i32.const 0 i32.const 1000000 i32.store |
| i32.const 0 i32.const 64 i32.atomic.rmw.and drop |
| i32.const 0 i32.load) |
| |
| |
| ;; i64 |
| |
| (func (export "i64.atomic.rmw8.and_u-result") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 64 i64.atomic.rmw8.and_u) |
| |
| (func (export "i64.atomic.rmw8.and_u-memory") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 64 i64.atomic.rmw8.and_u drop |
| i32.const 0 i64.load8_u) |
| |
| (func (export "i64.atomic.rmw16.and_u-result") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 1024 i64.atomic.rmw16.and_u) |
| |
| (func (export "i64.atomic.rmw16.and_u-memory") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 1024 i64.atomic.rmw16.and_u drop |
| i32.const 0 i64.load16_u) |
| |
| (func (export "i64.atomic.rmw32.and_u-result") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 1024 i64.atomic.rmw32.and_u) |
| |
| (func (export "i64.atomic.rmw32.and_u-memory") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 1024 i64.atomic.rmw32.and_u drop |
| i32.const 0 i64.load32_u) |
| |
| (func (export "i64.atomic.rmw.and-result") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 1024 i64.atomic.rmw.and) |
| |
| (func (export "i64.atomic.rmw.and-memory") (result i64) |
| i32.const 0 i64.const 10000000000 i64.store |
| i32.const 0 i64.const 1024 i64.atomic.rmw.and drop |
| i32.const 0 i64.load) |
| |
| |
| ;; Test bad alignment |
| |
| (func (export "bad_align-i32.atomic.rmw16.and_u") |
| i32.const 1 i32.const 0 i32.atomic.rmw16.and_u drop) |
| (func (export "bad_align-i32.atomic.rmw.and") |
| i32.const 2 i32.const 0 i32.atomic.rmw.and drop) |
| |
| (func (export "bad_align-i64.atomic.rmw16.and_u") |
| i32.const 1 i64.const 0 i64.atomic.rmw16.and_u drop) |
| (func (export "bad_align-i64.atomic.rmw32.and_u") |
| i32.const 2 i64.const 0 i64.atomic.rmw32.and_u drop) |
| (func (export "bad_align-i64.atomic.rmw.and") |
| i32.const 4 i64.const 0 i64.atomic.rmw.and drop) |
| |
| ) |
| (;; STDOUT ;;; |
| i32.atomic.rmw8.and_u-result() => i32:64 |
| i32.atomic.rmw8.and_u-memory() => i32:64 |
| i32.atomic.rmw16.and_u-result() => i32:16960 |
| i32.atomic.rmw16.and_u-memory() => i32:64 |
| i32.atomic.rmw.and-result() => i32:1000000 |
| i32.atomic.rmw.and-memory() => i32:64 |
| i64.atomic.rmw8.and_u-result() => i64:0 |
| i64.atomic.rmw8.and_u-memory() => i64:0 |
| i64.atomic.rmw16.and_u-result() => i64:58368 |
| i64.atomic.rmw16.and_u-memory() => i64:1024 |
| i64.atomic.rmw32.and_u-result() => i64:1410065408 |
| i64.atomic.rmw32.and_u-memory() => i64:1024 |
| i64.atomic.rmw.and-result() => i64:10000000000 |
| i64.atomic.rmw.and-memory() => i64:1024 |
| bad_align-i32.atomic.rmw16.and_u() => error: invalid atomic access at 1+0 |
| bad_align-i32.atomic.rmw.and() => error: invalid atomic access at 2+0 |
| bad_align-i64.atomic.rmw16.and_u() => error: invalid atomic access at 1+0 |
| bad_align-i64.atomic.rmw32.and_u() => error: invalid atomic access at 2+0 |
| bad_align-i64.atomic.rmw.and() => error: invalid atomic access at 4+0 |
| ;;; STDOUT ;;) |