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