Skip to content

Commit

Permalink
Merge branch 'main' into CR
Browse files Browse the repository at this point in the history
  • Loading branch information
rossberg committed Jul 10, 2024
2 parents b5a26c7 + d73ac32 commit dc93556
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 21 deletions.
18 changes: 0 additions & 18 deletions .github/workflows/mirror-to-master.yml

This file was deleted.

2 changes: 1 addition & 1 deletion document/core/binary/modules.rst
Original file line number Diff line number Diff line change
Expand Up @@ -360,7 +360,7 @@ It decodes into a vector of :ref:`element segments <syntax-elem>` that represent
.. note::
The initial integer can be interpreted as a bitfield.
Bit 0 indicates a passive or declarative segment,
Bit 0 distinguishes a passive or declarative segment from an active segment,
bit 1 indicates the presence of an explicit table index for an active segment and otherwise distinguishes passive from declarative segments,
bit 2 indicates the use of element type and element :ref:`expressions <binary-expr>` instead of element kind and element indices.

Expand Down
4 changes: 2 additions & 2 deletions document/core/valid/instructions.rst
Original file line number Diff line number Diff line change
Expand Up @@ -1098,7 +1098,7 @@ Memory Instructions
\qquad
C.\CMEMS[0] = \memtype
\qquad
2^{\memarg.\ALIGN} < N/8
2^{\memarg.\ALIGN} \leq N/8
}{
C \vdashinstr \K{v128.}\LOAD{N}\K{\_lane}~\memarg~\laneidx : [\I32~\V128] \to [\V128]
}
Expand All @@ -1122,7 +1122,7 @@ Memory Instructions
\qquad
C.\CMEMS[0] = \memtype
\qquad
2^{\memarg.\ALIGN} < N/8
2^{\memarg.\ALIGN} \leq N/8
}{
C \vdashinstr \K{v128.}\STORE{N}\K{\_lane}~\memarg~\laneidx : [\I32~\V128] \to []
}
Expand Down
25 changes: 25 additions & 0 deletions test/core/memory.wast
Original file line number Diff line number Diff line change
Expand Up @@ -240,3 +240,28 @@
"(import \"\" \"\" (memory $foo 1))"
"(import \"\" \"\" (memory $foo 1))")
"duplicate memory")

;; Test that exporting random globals does not change a memory's semantics.

(module
(memory (export "memory") 1 1)

;; These should not change the behavior of memory accesses.
(global (export "__data_end") i32 (i32.const 10000))
(global (export "__stack_top") i32 (i32.const 10000))
(global (export "__heap_base") i32 (i32.const 10000))

(func (export "load") (param i32) (result i32)
(i32.load8_u (local.get 0))
)
)

;; None of these memory accesses should trap.
(assert_return (invoke "load" (i32.const 0)) (i32.const 0))
(assert_return (invoke "load" (i32.const 10000)) (i32.const 0))
(assert_return (invoke "load" (i32.const 20000)) (i32.const 0))
(assert_return (invoke "load" (i32.const 30000)) (i32.const 0))
(assert_return (invoke "load" (i32.const 40000)) (i32.const 0))
(assert_return (invoke "load" (i32.const 50000)) (i32.const 0))
(assert_return (invoke "load" (i32.const 60000)) (i32.const 0))
(assert_return (invoke "load" (i32.const 65535)) (i32.const 0))

0 comments on commit dc93556

Please sign in to comment.