summaryrefslogtreecommitdiff
path: root/test/interp/atomic-rmw-or.txt
blob: 88ea9f16979f8deacc3ae52242c0f5c3995a367b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
;;; 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 ;;)