;;; 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 ;;)