Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sync with WebAssembly/spec branch wasm-3.0. #107

Merged
merged 294 commits into from
Jan 15, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
294 commits
Select commit Hold shift + click to select a range
8a1eb2f
Update binary opcodes based on #51
ngzhian Mar 1, 2022
5c175d8
Fix reserved dot products instructions and add bfloat16
ngzhian Mar 4, 2022
fe473a7
Copy "either" result pattern from threads proposal
ngzhian Mar 1, 2022
8da2825
Update instruction names in opcode table based on #42
ngzhian Mar 14, 2022
dafba4f
Add tests for relaxed simd instructions
ngzhian Mar 9, 2022
3f95701
Fixes to test
ngzhian Mar 14, 2022
bfb6b0a
Fix relaxed trunc expected results
ngzhian Mar 14, 2022
9b8c69b
Restrict allowed return values
ngzhian Mar 10, 2022
fbfb92f
Fix typos
ngzhian Mar 10, 2022
c1a56b5
Fix trunc
ngzhian Mar 14, 2022
8413b42
Update trunc description
ngzhian Mar 14, 2022
2e66ec6
Update ImplementationStatus.md
ngzhian Mar 18, 2022
1f29e46
Add dot product to overview
ngzhian Mar 22, 2022
9369de7
Merge remote-tracking branch 'upstream/main' into merge-upstream
ngzhian Mar 28, 2022
1a303a5
Merge pull request #70 from ngzhian/merge-upstream
ngzhian Mar 28, 2022
2d63360
Remove unsigned dot product from overview (#73)
ngzhian May 13, 2022
f80420a
Merge remote-tracking branch 'upstream/main' into merge-upstream
ngzhian Jul 7, 2022
0d63afa
More fixes for merge commits
ngzhian Jul 7, 2022
a3f0037
More merge conflict fixes
ngzhian Jul 7, 2022
c2e53ec
Merge pull request #78 from ngzhian/merge-upstream
ngzhian Jul 7, 2022
1438c0e
Merge remote-tracking branch 'upstream/main' into merge-upstream
ngzhian Aug 4, 2022
d4f766c
Merge pull request #80 from ngzhian/merge-upstream
ngzhian Aug 4, 2022
aff5ae0
Fix ordering for FMA and change FMS to FNMA (fused negative multiply …
ngzhian Aug 4, 2022
e1759af
Merge from upstream spec
ngzhian Sep 12, 2022
26f1b78
Merge pull request #87 from ngzhian/merge-upstream
ngzhian Sep 12, 2022
b58bb2e
Add BFloat16 dot product
ngzhian Sep 12, 2022
0018aeb
Fix fnma instruction name and details
yurydelendik Sep 21, 2022
8cbfd34
Update implementation status with bf16 dot product and fnma
ngzhian Oct 24, 2022
6570724
Fix overview for integer dot products and implementation status
ngzhian Oct 24, 2022
8697e47
Add some relaxed dot product tests
ngzhian Oct 24, 2022
3935fe9
Fix number of lane literals
ngzhian Oct 24, 2022
e35df3a
Fix test results
ngzhian Oct 24, 2022
2dc7f2f
Fix fms -> fnma, add relaxed dot
ngzhian Oct 24, 2022
0f19aec
Rename fma test file
ngzhian Oct 24, 2022
c373433
Fix to instruction names in overview and implementation status
ngzhian Oct 24, 2022
fda767d
Update prototype opcodes
ngzhian Oct 24, 2022
5b727ca
Add link to phase 3 to overview
ngzhian Oct 24, 2022
d0fbbe7
Update Overview.md with implementation status (#30)
sbc100 Oct 24, 2022
56088cf
Merge remote-tracking branch 'upstream/main' into merge
sbc100 Oct 25, 2022
484c78b
Rename relaxed_fma to relaxed_madd (fnma to nmadd)
ngzhian Oct 25, 2022
c199565
Remove bf16 from overview and implementation status
ngzhian Dec 6, 2022
9b886c0
Merge remote-tracking branch 'upstream/main' into merge-upstream
ngzhian Dec 8, 2022
95678a9
Merge pull request #112 from WebAssembly/merge-upstream
ngzhian Dec 8, 2022
22eb1c0
Remove bf16 dot
ngzhian Feb 14, 2023
91a76df
Merge pull request #118 from ngzhian/interp-fix
ngzhian Feb 14, 2023
5f39b1f
Fix names of dot instructions
ngzhian Feb 14, 2023
c7f2df1
Rename relaxed dot in tests
ngzhian Feb 14, 2023
50163d0
Merge pull request #119 from ngzhian/interp-dot-name
ngzhian Feb 14, 2023
d908cd4
Fix expected result type in relaxed dot product tests
ngzhian Feb 14, 2023
e7bb04d
Merge pull request #121 from ngzhian/fix-relaxed-dot-test
ngzhian Feb 14, 2023
961e0db
Check multiple calls to relaxed instructions return same results
ngzhian Feb 15, 2023
e8a9e54
Merge pull request #122 from ngzhian/tests-cmp
ngzhian Feb 15, 2023
e53cbc9
Add expected results for relaxed dot
ngzhian Feb 15, 2023
271b099
Merge pull request #123 from ngzhian/dot-tests
ngzhian Feb 15, 2023
d847308
Fix relaxed nmadd tests (#124)
ngzhian Feb 16, 2023
f443590
Fix relaxed trunc signed (#127)
ngzhian Feb 22, 2023
0bd0984
Merge remote-tracking branch 'upstream/main' into merging-upstream
ngzhian Feb 22, 2023
59f25ed
Merge pull request #128 from ngzhian/merging-upstream
ngzhian Feb 22, 2023
917bd5c
Update int dot tests to allow for saturation of intermediate 16-bit
ngzhian Feb 27, 2023
c423e63
Fix overview for int dot to allow saturation of 16-bit intermediates
ngzhian Feb 27, 2023
a9ad839
Fix typo in relaxed dot test
ngzhian Feb 27, 2023
ae8a9f9
Fix some tests in `i32x4_relaxed_trunc.wast`
alexcrichton Feb 27, 2023
f82b14f
Add a note about the integer value of INT_MAX
alexcrichton Feb 27, 2023
476802d
Implement relaxed instructions using the non-relaxed counterpart (#65)
ngzhian Feb 27, 2023
1bb54a7
Update overview spec of `laneselect` instructions
alexcrichton Feb 27, 2023
24bba96
cherry-pick from upstream: [interpreter] Fix warning flags for OCaml …
sbc100 Feb 28, 2023
786f84d
Spec profiles
rossberg Dec 12, 2022
16f6d1f
Work around MathJax limitations
rossberg Dec 12, 2022
3c78e14
First pass at semantics
ngzhian Oct 12, 2021
70008ac
Changes atop profiles
ngzhian Jan 17, 2023
ab7d0be
Changes to execution and validation
ngzhian Jan 25, 2023
1cf8ca9
Fix to index instructions
ngzhian Jan 25, 2023
52668fa
Fix instruction generation script
ngzhian Jan 25, 2023
83b983d
Add macros
ngzhian Jan 25, 2023
8824d97
Update index of instructions, exec/numerics
ngzhian Jan 25, 2023
2a8208e
Fix binary and text
ngzhian Jan 25, 2023
f8cac7f
Update document/core/exec/numerics.rst
ngzhian Feb 14, 2023
5e08ffc
Update document/core/exec/numerics.rst
ngzhian Feb 14, 2023
c3f3239
Update document/core/exec/numerics.rst
ngzhian Feb 14, 2023
ddcc7ed
Update document/core/exec/numerics.rst
ngzhian Feb 14, 2023
b2fe562
Update document/core/exec/numerics.rst
ngzhian Feb 14, 2023
64bdd02
Update document/core/exec/numerics.rst
ngzhian Feb 14, 2023
caee906
Spell out instruction mnemonic
ngzhian Feb 14, 2023
a1a8a12
Fix text
ngzhian Feb 14, 2023
2c51978
Fix relaxed swizzle lane macro
ngzhian Feb 14, 2023
847b40f
Fix fma det
ngzhian Feb 14, 2023
ce1d31d
Fix mnemonics
ngzhian Feb 14, 2023
a7d4e96
Update changes
ngzhian Feb 14, 2023
824c9fd
Text for relaxed q15muls
ngzhian Feb 15, 2023
61fd687
Typo
ngzhian Feb 15, 2023
70bf915
Fix semantics for dot
ngzhian Feb 27, 2023
4073d27
Update document/core/appendix/changes.rst
ngzhian Mar 2, 2023
753c779
Update document/core/appendix/changes.rst
ngzhian Mar 2, 2023
f59b512
Move changes down
ngzhian Mar 2, 2023
8afc0d1
Add FMA definition
ngzhian Mar 2, 2023
46c9480
Reword fma
ngzhian Mar 2, 2023
a9ef2e4
Remove parens
ngzhian Mar 2, 2023
b00d451
Add entropy.md to discuss fingerprinting, and compat concerns (#83)
dtig Mar 7, 2023
4afd146
Rename entropy.md to Entropy.md
dtig Mar 7, 2023
c4c9dda
Add prose for exec numerics and fma
ngzhian Mar 3, 2023
b90afb8
Merge remote-tracking branch 'upstream/main' into merge-upstream
ngzhian Mar 22, 2023
ba2d5eb
Merge pull request #139 from ngzhian/merge-upstream
ngzhian Mar 22, 2023
44ab5bd
Pull github actions from upstream spec repo (#37)
sbc100 Mar 23, 2023
d456ed8
[test] Test u64 LEB128s that straddle maximum value (#38)
keithw Jun 9, 2023
d1bcd3d
Fix typo in description of limits binary format (#22)
alexcrichton Jun 11, 2023
70f8687
Add more allowed return values for relaxed trunc unsigned
ngzhian Jun 5, 2023
7cfa894
WebAssembly.Memory "index: u32/u64" constructor parameter (#39)
dakenf Aug 4, 2023
d879d67
Document that "either" comes from threads proposal
ngzhian Jun 30, 2023
f7e861c
Fix relaxed laneselect to allow looking at top bit of byte
ngzhian Jun 6, 2023
cd9c447
Add special test case for i16x8.relaxed_laneselect
ngzhian Jun 26, 2023
ca328fc
Changed u32/u64 to i32/i64 (#41)
dakenf Sep 7, 2023
22257c5
Fix relaxed trunc pseudocode in Overview
thibaudmichaud Oct 3, 2023
5d65049
Merge remote-tracking branch 'upstream/main' into merge
sbc100 Oct 25, 2022
3eecdce
Merge remote-tracking branch 'origin/main' into merge
sbc100 Dec 9, 2023
48e69f3
Merge remote-tracking branch 'upstream/main' into merge2
sbc100 Dec 9, 2023
c5804d2
Merge remote-tracking branch 'upstream/main' into HEAD
sbc100 Feb 15, 2024
3165d60
Fix broken build after upstream merge
sbc100 Feb 20, 2024
4347702
[ci] Add --experimental-wasm-memory64 to node flags (#49)
sbc100 Feb 21, 2024
b52270d
Update Overview.md
rossberg Feb 22, 2024
bcf4834
Fix some function lengths in the test suite (#45)
alexcrichton Feb 22, 2024
b54e1cc
Merge remote-tracking branch 'upstream/main' into HEAD
sbc100 Apr 24, 2024
d5969ed
Update overview to include table64 (#52)
sbc100 Apr 24, 2024
debdda8
Merge remote-tracking branch 'upstream/main'
sbc100 Apr 30, 2024
02efcad
Remove tabs from memory64.wast
sbc100 Apr 30, 2024
9ed8215
Merge remote-tracking branch 'upstream/main'
sbc100 Apr 30, 2024
dc4d236
Update interpreter and test suite for table64 (#53)
sbc100 May 1, 2024
5cc08ad
[table64] Fix validation rules for table.fill/copy/size/grow (#54)
sbc100 May 2, 2024
394c31b
Fix validation rules for memory.copy/fill/init (#56)
sbc100 May 2, 2024
04620c2
Fix error in type of memory.init introduced in #56 (#57)
sbc100 May 3, 2024
95dc80e
Update ImplementationStatus.md
dtig May 10, 2024
26816ef
Merge remote-tracking branch 'upstream/main' into HEAD
sbc100 May 10, 2024
b99ab2d
Allow table.copy between tables with different index types (#58)
sbc100 May 24, 2024
415cdaf
Update Overview.md with table64 status. NFC
sbc100 May 28, 2024
6f101d6
Revert parameterization of limits that was added in #13. (#59)
sbc100 May 30, 2024
884edf3
Remove unnecessary inc_address function (#62)
sbc100 Jun 3, 2024
d75e87e
Remove limit64 from parser.mly (#61)
sbc100 Jun 3, 2024
23c6751
Add index constructor argument for WebAssembly.Table (#64)
backes Jun 5, 2024
9edc82d
Fix validation rules for table.set and table.grow in Overview.md (#65)
evicy Jun 10, 2024
56ce0e3
Merge remote-tracking branch 'upstream/wasm-3.0' into main
sbc100 Jun 3, 2024
aae6d05
Tweak Overview.md (#66)
RByers Jun 14, 2024
c7320ac
[spec] Update spec text for memory64 (#50)
sbc100 Jul 1, 2024
4ca510f
Merge remote-tracking branch 'upstream/main'
sbc100 Jul 1, 2024
62da125
Update JS API for memory/table min/max and table.get/set (#70)
sbc100 Jul 2, 2024
e9c9a9b
Add a smoke test for consistent nondeterminism
fitzgen Jul 18, 2024
c3f9359
Merge pull request #156 from fitzgen/test-non-determinism-is-consistent
rossberg Jul 18, 2024
06af2df
Merge remote-tracking branch 'upstream/main'
sbc100 Aug 1, 2024
fddf698
Merge remote-tracking branch 'upstream/wasm-3.0' into wasm-3.0
sbc100 Aug 1, 2024
5a8c4db
Merge remote-tracking branch 'origin/wasm-3.0'
sbc100 Aug 2, 2024
1bf8e0f
Update JS API to handle index types (#75)
bvisness Aug 13, 2024
3f0bd84
Merge remote-tracking branch 'relaxed/main' into wasm-3.0+relaxed
rossberg Sep 3, 2024
04e1cf6
Merge remote-tracking branch 'upstream/wasm-3.0' into main
sbc100 Sep 3, 2024
08d7ccb
Bump actions/download-artifact from 2 to 4.1.7 in /.github/workflows
dependabot[bot] Sep 3, 2024
6e2dfb3
Bump actions/download-artifact from 2 to 4.1.7 in /.github/workflows
dependabot[bot] Sep 3, 2024
6cdb72f
Use consistent upload-artifact
rossberg Sep 4, 2024
3370cfc
Missed one
rossberg Sep 4, 2024
2384c7e
[ci] Bump actions/download-artifact from 2 to 4.1.7 (#559)
rossberg Sep 4, 2024
59174d5
Update ci-spec.yml
rossberg Sep 4, 2024
abcd6d1
[ci] Bump upload/download-artifact to v4 (#118)
rossberg Sep 4, 2024
9d740b0
Minor edits
rossberg Sep 4, 2024
acb599c
Refactor relaxed ops spec
rossberg Sep 4, 2024
940398c
Restrict offsets to index type's range in validation (#79)
bvisness Sep 5, 2024
bc87071
Implementation note
rossberg Sep 6, 2024
d29854b
Fix typing of `array.new` in the index of instructions
fitzgen Sep 19, 2024
671b526
Merge pull request #561 from fitzgen/fix-array-new-typing-in-index
rossberg Sep 19, 2024
87536c8
[versions] Update 3.0 draft
rossberg Sep 21, 2024
4bded37
Fix many miscellaneous spec problems (#77)
bvisness Sep 23, 2024
d8f6d8e
Merge remote-tracking branch 'upstream/wasm-3.0' into HEAD
sbc100 Sep 23, 2024
c61da44
Fix small issues in the JS API (#78)
bvisness Sep 23, 2024
cd8bba6
Update embedding and execution specs for memory64 (#74)
bvisness Sep 23, 2024
615bd1f
wasm-module-builder: Fix left-over use of kWasmStmt (#83)
backes Sep 23, 2024
eb8f31c
Merge branch 'wasm-3.0' into wasm-3.0+relaxed
rossberg Sep 24, 2024
09cc6c6
Adapt changes
rossberg Sep 26, 2024
8dadd74
Eps
rossberg Sep 26, 2024
95acd3e
Merge branch 'wasm-3.0+relaxed' into wasm-3.0
rossberg Sep 26, 2024
60af1b0
[versions] Update 3.0 draft
rossberg Sep 26, 2024
8971797
Expand tests for `array.new_data`
fitzgen Sep 27, 2024
f713000
Remove nullability of local
fitzgen Sep 28, 2024
4c10619
Add a couple more out-of-bounds data segment cases
fitzgen Sep 28, 2024
f846dd1
Add an unualigned data segment access test for `array.new_data`
fitzgen Sep 28, 2024
a765a6d
Merge pull request #562 from fitzgen/test-for-out-of-bounds-array-new…
rossberg Sep 28, 2024
b889c63
Test out-of-bounds element segment indexing for `array.new_elem`
fitzgen Sep 28, 2024
e878982
Merge pull request #563 from fitzgen/array-new-elem-out-of-bounds-tests
rossberg Sep 29, 2024
7995c92
Update IANA media type registration section in Web API
dschuff Sep 28, 2024
31418f6
Update bikeshed_fixup to number the Change History section
dschuff Sep 28, 2024
15eb918
Revert "Update W3C TR build from WD to CRD (#1797)" (#1813)
dschuff Sep 30, 2024
a700617
Add introduction sections to JS API and Web API documents (#1814)
dschuff Sep 30, 2024
e9cbf1a
[spec] Fix typo in relaxed formula
rossberg Oct 1, 2024
d5f5868
Add Changelog sections for JS and Web API documents (#1817)
dschuff Oct 2, 2024
97c2d67
Fix validation errors in changelog (#1819)
dschuff Oct 3, 2024
12bf474
close dl tag to fix web API validation (#1820)
dschuff Oct 3, 2024
f1e8a19
Add a minimal Security and Privacy Considerations section to Web API …
dschuff Oct 3, 2024
8e5f4ee
[spec] Various fixes to SIMD stuff
rossberg Oct 3, 2024
c157e61
Rework IndexValueToU64 to allow more inputs to BigInts (#86)
bvisness Oct 3, 2024
8012c48
Remove redundant runs of bikeshed from the JS/Web Makefiles' tar targets
dschuff Oct 3, 2024
924c1f8
[test] More tests for ill-typed call indirect (#1822)
RaoNikitha Oct 4, 2024
2d480da
Check Echidna publishing results for failure or success (#1821)
dschuff Oct 4, 2024
535bedf
[ci] Use build matrix to run W3C spec builds independently (#1825)
dschuff Oct 6, 2024
c0aeee7
Escape latex newline commands with extra vertical space (#1826)
dschuff Oct 6, 2024
b5c848b
Remove some unneeded bikeshed fixup hacks (#1824)
dschuff Oct 6, 2024
9c69d19
[js-api] Fix up missing preconditions on allocations (#1793)
bvisness Oct 7, 2024
85a7ccb
[ci] Update CI action versions (#1827)
rossberg Oct 7, 2024
1fca55a
[test][js-api] Fix import of table64 and memory64 (#84)
backes Oct 7, 2024
2e89dc5
Fix js-api tests (#87)
backes Oct 7, 2024
2a30893
[interpreter] Fix JS module invocation (#1829)
rossberg Oct 8, 2024
29b1fd4
[interpreter] Proper fix for JS conversion (#1832)
rossberg Oct 8, 2024
aa4ff11
Merge remote-tracking branch 'spec/wasm-3.0'
backes Oct 8, 2024
61e34cc
Fix wasm-module-builder.js (#1831)
thibaudmichaud Oct 9, 2024
76bcf86
Fix a bunch of errors
rossberg Oct 15, 2024
bef38ba
Add missing handlers to eval contexts
rossberg Oct 17, 2024
4056ff9
Rename "index type" to "address type" across the spec (#90)
bvisness Oct 18, 2024
9e107e0
Rename "addressType" to "address" in the JS API (#92)
bvisness Oct 21, 2024
ade7380
Spec test updates (#91)
bvisness Oct 22, 2024
86e22aa
Update JS-test generation after #90 and #92 (#94)
backes Oct 25, 2024
1f803e1
Fix test copy/paste typo (#566)
ejrgilbert Oct 25, 2024
cda4012
[spec] Add elem/data member to moduleinst prose (#1837)
mohanson Oct 29, 2024
37f3cad
[interpreter] Fix subtype condition for result patterns
rossberg Oct 28, 2024
8ce0607
Handle extern refs
rossberg Oct 29, 2024
76654e2
[interpreter] Fix (and sanity-check) JS wrapper modules
rossberg Oct 29, 2024
1e10102
Activate CI for wasm-3.0 branch
rossberg Oct 29, 2024
1795669
Merge remote-tracking branch 'spec/wasm-3.0'
backes Oct 29, 2024
88463e8
Fix direction of subtype check for call_indirect
rossberg Oct 31, 2024
268a03d
[test] generate JS/HTML wrappers for tests in subdirectories (#1808)
ajklein Nov 1, 2024
83eae1b
Correct merge changes
rossberg Nov 6, 2024
837bae3
Various tweaks to memory64 spec
rossberg Nov 6, 2024
3f6b420
Changes entry
rossberg Nov 6, 2024
67ebdcd
Typo
rossberg Nov 6, 2024
5f2f99d
embedding.rst: Fix heading underline. NFC (#1840)
sbc100 Nov 6, 2024
ed1fc53
Update appendix for memory64 (#97)
sbc100 Nov 6, 2024
ace0947
Memory64 spec tweaks and fixes from @rossberg (#98)
sbc100 Nov 6, 2024
906d452
Intepreter and test updates from @rossberg (#99)
sbc100 Nov 6, 2024
d7ba933
Merge remote-tracking branch 'addr64/main' into wasm-3.0+addr64
rossberg Nov 7, 2024
87789ff
Merge branch 'main' into wasm-3.0
rossberg Nov 7, 2024
686d9cf
Merge branch 'wasm-3.0' into wasm-3.0+addr64
rossberg Nov 7, 2024
0d9b985
Update draft PDF
rossberg Nov 7, 2024
d793168
Add back lost text rule
rossberg Nov 7, 2024
d8b7fcd
[interpreter] Remove unnecessary type parameter from limits
rossberg Nov 7, 2024
17fa2a0
Typo
rossberg Nov 7, 2024
224a75c
tree not blob
rossberg Nov 7, 2024
90cbd50
[spec] Remove lingering one-memory validation rule (#1848)
bvisness Nov 13, 2024
d1bf45a
Fix exception allocation
rossberg Nov 22, 2024
efa2158
Test array.new_data and array.new_elem with dropped segments (#1849)
tlively Dec 2, 2024
64f0f3a
Add some tests for invalid subtyping due to non-matching field types …
fitzgen Dec 5, 2024
74654a4
Fix xref typo
rossberg Dec 3, 2024
bc57665
Merge branch 'funcref'
rossberg Dec 9, 2024
a50f1a0
Correct element segment type expansion
rossberg Dec 9, 2024
74d2ec8
Add active elemmode type refinement to changes
rossberg Dec 9, 2024
756060f
Merge branch 'funcref'
rossberg Dec 9, 2024
9d91344
Merge remote-tracking branch 'gc/main' into wasm-3.0
rossberg Dec 9, 2024
62893c2
[spec] Update the definition of `tagtype` and its subtyping (#1862)
f52985 Jan 13, 2025
eb0dbce
Sync with WebAssembly/spec branch wasm-3.0
dhil Jan 15, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 6 additions & 6 deletions .github/workflows/ci-interpreter.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,11 @@ name: CI for interpreter & tests

on:
push:
branches: [ main ]
branches: [ main, wasm-3.0 ]
paths: [ .github/**, interpreter/**, test/** ]

pull_request:
branches: [ main ]
branches: [ main, wasm-3.0 ]
paths: [ .github/**, interpreter/**, test/** ]

# Allows you to run this workflow manually from the Actions tab
Expand All @@ -17,17 +17,17 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout repo
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Setup OCaml
uses: ocaml/setup-ocaml@v2
uses: ocaml/setup-ocaml@v3
with:
ocaml-compiler: 4.14.x
- name: Setup OCaml tools
run: opam install --yes ocamlfind.1.9.5 js_of_ocaml.4.0.0 js_of_ocaml-ppx.4.0.0
- name: Setup Node.js
uses: actions/setup-node@v2
uses: actions/setup-node@v4
with:
node-version: 19.x
node-version: 20.x
- name: Build interpreter
run: cd interpreter && opam exec make
- name: Run tests
Expand Down
18 changes: 9 additions & 9 deletions .github/workflows/ci-spec.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,11 @@ name: CI for specs

on:
push:
branches: [ main ]
branches: [ main, wasm-3.0 ]
paths: [ .github/**, document/** ]

pull_request:
branches: [ main ]
branches: [ main, wasm-3.0 ]
paths: [ .github/**, document/** ]

# Allows you to run this workflow manually from the Actions tab
Expand All @@ -17,11 +17,11 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout repo
uses: actions/checkout@v2
uses: actions/checkout@v4
with:
submodules: "recursive"
- name: Setup Node.js
uses: actions/setup-node@v3
uses: actions/setup-node@v4
with:
node-version: 16
- name: Setup Bikeshed
Expand All @@ -44,7 +44,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout repo
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Setup Bikeshed
run: pip install bikeshed && bikeshed update
- name: Run Bikeshed
Expand All @@ -59,7 +59,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout repo
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Setup Bikeshed
run: pip install bikeshed && bikeshed update
- name: Run Bikeshed
Expand Down Expand Up @@ -128,7 +128,7 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout repo
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Upload artifacts
uses: actions/upload-artifact@v4
with:
Expand All @@ -147,7 +147,7 @@ jobs:
- build-spec-versions
steps:
- name: Checkout repo
uses: actions/checkout@v2
uses: actions/checkout@v4
- name: Create output directory
run: mkdir _output && cp document/index.html _output/index.html
- name: Download core spec artifact
Expand Down Expand Up @@ -187,7 +187,7 @@ jobs:
path: _output/versions
- name: Publish to GitHub Pages
if: github.ref == 'refs/heads/main'
uses: peaceiris/actions-gh-pages@v3
uses: peaceiris/actions-gh-pages@v4
with:
publish_dir: ./_output
github_token: ${{ secrets.GITHUB_TOKEN }}
33 changes: 25 additions & 8 deletions .github/workflows/w3c-publish.yml
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
name: Publish to W3C TR space
name: Validate/Publish to W3C TR space

on:
push:
branches: [ main ]
paths: [ .github/**, document/** ]
pull_request:
paths: [ .github/**, document/** ]

# Allows you to run this workflow manually from the Actions tab, gh CLI tool,
# or REST API. THe w3c-status options correspond to the valid options for
Expand All @@ -23,30 +25,45 @@ on:
- CRD
- CR

env:
YARN_ENABLE_IMMUTABLE_INSTALLS: false
W3C_STATUS: ${{ github.event_name == 'workflow_dispatch' && inputs.w3c-status || 'WD' }}

jobs:
publish-to-w3c-TR:
if: github.repository == 'WebAssembly/spec'
strategy:
fail-fast: false
matrix:
spec: [core, js-api, web-api]
runs-on: ubuntu-latest
steps:
- name: Checkout repo
uses: actions/checkout@v2
uses: actions/checkout@v4
with:
submodules: "recursive"
- name: Setup Node.js
uses: actions/setup-node@v3
uses: actions/setup-node@v4
with:
node-version: 16
- name: Setup Bikeshed
run: pip install bikeshed && bikeshed update
- name: Setup TexLive
if: ${{ matrix.spec == 'core' }}
run: sudo apt-get update -y && sudo apt-get install -y latexmk texlive-latex-recommended texlive-latex-extra texlive-fonts-recommended
- name: Setup Sphinx
if: ${{ matrix.spec == 'core' }}
run: pip install six && pip install sphinx==5.1.0
- name: Publish all specs to their https://www.w3.org/TR/ URLs
run: cd document && make -e WD-echidna-CI
- name: Publish ${{ matrix.spec }} spec to its https://www.w3.org/TR/ URL
if: env.W3C_ECHIDNA_TOKEN_CORE
run: cd document && make -e -C ${{ matrix.spec }} WD-echidna-CI
env:
W3C_STATUS: ${{ github.event_name == 'push' && 'CRD' || inputs.w3c-status }}
W3C_ECHIDNA_TOKEN_CORE: ${{ secrets.W3C_ECHIDNA_TOKEN_CORE }}
W3C_ECHIDNA_TOKEN_JSAPI: ${{ secrets.W3C_ECHIDNA_TOKEN_JSAPI }}
W3C_ECHIDNA_TOKEN_WEBAPI: ${{ secrets.W3C_ECHIDNA_TOKEN_WEBAPI }}
YARN_ENABLE_IMMUTABLE_INSTALLS: false
ECHIDNA_DRYRUN: ${{ !(github.event_name == 'push' && github.repository == 'WebAssembly/spec' && github.ref == 'refs/heads/main') }}
- name: Validate ${{ matrix.spec }} spec with Echidna
if: env.W3C_USERNAME
run: cd document && make -e -C ${{ matrix.spec }} WD-echidna
env:
W3C_USERNAME: ${{ secrets.W3C_USERNAME }}
W3C_PASSWORD: ${{ secrets.W3C_PASSWORD }}
13 changes: 9 additions & 4 deletions document/core/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ NAME = WebAssembly
DECISION_URL = https://github.com/WebAssembly/meetings/blob/main/main/2024/WG-06-12.md
TAR = tar
DEADLINE = $(shell date -d "+30 days" +%Y-%m-%d 2>/dev/null || date -v +30d +%Y-%m-%d)
ECHIDNA_DRYRUN = true

# Internal variables.
PAPEROPT_a4 = -D latex_paper_size=a4
Expand Down Expand Up @@ -196,9 +197,11 @@ WD-echidna: WD-tar
curl 'https://labs.w3.org/echidna/api/request' \
--user '$(W3C_USERNAME):$(W3C_PASSWORD)' \
-F "tar=@$(BUILDDIR)/WD.tar" \
-F "decision=$(DECISION_URL)" | tee $(BUILDDIR)/WD-echidna-id.txt
-F "decision=$(DECISION_URL)" \
-F "dry-run=$(ECHIDNA_DRYRUN)" | tee $(BUILDDIR)/WD-echidna-id.txt
python3 ../util/check-echidna-status.py $(BUILDDIR)
@echo
@echo "Published $(W3C_STATUS). Check its status at https://labs.w3.org/echidna/api/status?id=`cat $(BUILDDIR)/WD-echidna-id.txt`"
@echo "Uploaded $(W3C_STATUS). Check its status at https://labs.w3.org/echidna/api/status?id=`cat $(BUILDDIR)/WD-echidna-id.txt`"

.PHONY: WD-echidna-CI
WD-echidna-CI: WD-tar
Expand All @@ -210,9 +213,11 @@ WD-echidna-CI: WD-tar
curl 'https://labs.w3.org/echidna/api/request' \
-F "tar=@$(BUILDDIR)/WD.tar" \
-F "token=$(W3C_ECHIDNA_TOKEN_CORE)" \
-F "decision=$(DECISION_URL)" | tee $(BUILDDIR)/WD-echidna-id.txt
-F "decision=$(DECISION_URL)" \
-F "dry-run=$(ECHIDNA_DRYRUN)" | tee $(BUILDDIR)/WD-echidna-id.txt
python3 ../util/check-echidna-status.py $(BUILDDIR)
@echo
@echo "Published $(W3C_STATUS). Check its status at https://labs.w3.org/echidna/api/status?id=`cat $(BUILDDIR)/WD-echidna-id.txt`"
@echo "Uploaded $(W3C_STATUS). Check its status at https://labs.w3.org/echidna/api/status?id=`cat $(BUILDDIR)/WD-echidna-id.txt`"

.PHONY: diff
diff: bikeshed
Expand Down
94 changes: 91 additions & 3 deletions document/core/appendix/changes.rst
Original file line number Diff line number Diff line change
Expand Up @@ -308,7 +308,7 @@ Allowed basic numeric computations in constant expressions. [#proposal-extconst]
- |GLOBALGET| for any previously declared immutable :ref:`global <syntax-global>`

.. note::
The :ref:`garbage collection <extension-gc>` added further constant instructions.
The :ref:`garbage collection <extension-gc>` extension added further constant instructions.


.. index:: instruction, function, call
Expand Down Expand Up @@ -389,6 +389,44 @@ Added the ability to use multiple memories per module. [#proposal-multimem]_
* :ref:`Data segments <syntax-elem>` take a :ref:`memory index <syntax-memidx>`


.. index:: address type, number type, table, memory, instruction

64-bit Address Space
....................

Added the ability to declare an :math:`\I64` :ref:`address type <syntax-addrtype>` for :ref:`tables <syntax-tabletype>` and :ref:`memories <syntax-memtype>`. [#proposal-addr64]_

* :ref:`Address types <syntax-addrtype>` denote a subset of the integral :ref:`number types <syntax-numtype>`

* :ref:`Table types <syntax-tabletype>` include an :ref:`address type <syntax-addrtype>`

* :ref:`Memory types <syntax-memtype>` include an :ref:`address type <syntax-addrtype>`

* Operand types of :ref:`table <syntax-instr-table>` and :ref:`memory <syntax-instr-memory>` instructions now depend on the subject's declared address type:

- |TABLEGET|
- |TABLESET|
- |TABLESIZE|
- |TABLEGROW|
- |TABLEFILL|
- |TABLECOPY|
- |TABLEINIT|
- |MEMORYSIZE|
- |MEMORYGROW|
- |MEMORYFILL|
- |MEMORYCOPY|
- |MEMORYINIT|
- :math:`t\K{.load}`
- :math:`t\K{.store}`
- :math:`t\K{.load}\!N\!\K{\_}\sx`
- :math:`t\K{.store}\!N`
- :math:`\K{v128.load}\!N\!\K{x}\!M\!\K{\_}\sx`
- :math:`\K{v128.load}\!N\!\K{\_zero}`
- :math:`\K{v128.load}\!N\!\K{\_splat}`
- :math:`\K{v128.load}\!N\!\K{\_lane}`
- :math:`\K{v128.store}\!N\!\K{\_lane}`


.. index:: reference, reference type, heap type, value type, local, local type, instruction, instruction type, table, function, function type, matching, subtyping

Typeful References
Expand Down Expand Up @@ -424,6 +462,8 @@ Added more precise types for references. [#proposal-typedref]_

* Refined typing of :ref:`local instructions <valid-instr-variable>` and :ref:`instruction sequences <valid-instr-seq>` to track the :ref:`initialization status <syntax-init>` of :ref:`locals <syntax-local>` with non-:ref:`defaultable <valid-defaultable>` type

* Refined decoding of :ref:`active <syntax-elemmode>` :ref:`element segments <binary-elem>` with implicit element type and plain function indices (opcode :math:`0`) to produce :ref:`non-nullable <syntax-nullable>` :ref:`reference type <syntax-reftype>`.

* Extended :ref:`table definitions <syntax-table>` with optional initializer expression


Expand Down Expand Up @@ -518,6 +558,48 @@ Added managed reference types. [#proposal-gc]_
- |EXTERNCONVERTANY|


.. index:: instruction, vector instruction, SIMD

Relaxed Vector Instructions
...........................

Added new *relaxed* vector instructions,
whose behaviour is non-deterministic and implementation-dependent. [#proposal-relaxed]_

* New binary :ref:`vector instruction <syntax-instr-relaxed>`:

- :math:`\K{f}\!N\!\K{x}\!M\!\K{.relaxed\_min}`
- :math:`\K{f}\!N\!\K{x}\!M\!\K{.relaxed\_max}`
- :math:`\K{i16x8.relaxed\_q15mulr\_s}`
- :math:`\K{i16x8.relaxed\_dot\_i8x16\_i7x16\_s}`

* New ternary :ref:`vector instruction <syntax-instr-relaxed>`:

- :math:`\K{f}\!N\!\K{x}\!M\!\K{.relaxed\_madd}`
- :math:`\K{f}\!N\!\K{x}\!M\!\K{.relaxed\_nmadd}`
- :math:`\K{i}\!N\!\K{x}\!M\!\K{.relaxed\_laneselect}`
- :math:`\K{i32x4.relaxed\_dot\_i8x16\_i7x16\_add\_s}`

* New conversion :ref:`vector instructions <syntax-instr-relaxed>`:

- :math:`\K{i32x4.relaxed\_trunc\_f32x4\_}\sx`
- :math:`\K{i32x4.relaxed\_trunc\_f64x2\_}\sx\K{\_zero}`

* New byte reordering :ref:`vector instruction <syntax-instr-relaxed>`:

- :math:`\K{i8x16.relaxed\_swizzle}`


.. index:: determinism, non-determinism, profiles

Profiles
........

Introduced the concept of :ref:`profile <profiles>` for specifying language subsets.

* A new profile defining a :ref:`deterministic <profile-deterministic>` mode of execution.


.. index:: text format, annotation, custom section, identifier, module, type, function, local, structure field

Custom Annotations
Expand All @@ -542,7 +624,7 @@ mirroring the role of custom sections in the binary format. [#proposal-annot]_


.. [#proposal-extconst]
https://github.com/WebAssembly/extended-const/blob/main/proposals/extended-const/
https://github.com/WebAssembly/spec/tree/main/proposals/extended-const/

.. [#proposal-tailcall]
https://github.com/WebAssembly/spec/tree/main/proposals/tail-call/
Expand All @@ -551,13 +633,19 @@ mirroring the role of custom sections in the binary format. [#proposal-annot]_
https://github.com/WebAssembly/spec/tree/main/proposals/exception-handling/

.. [#proposal-multimem]
https://github.com/WebAssembly/multi-memory/blob/main/proposals/multi-memory/
https://github.com/WebAssembly/spec/tree/main/proposals/multi-memory/

.. [#proposal-addr64]
https://github.com/WebAssembly/spec/tree/main/proposals/memory64/

.. [#proposal-typedref]
https://github.com/WebAssembly/spec/tree/main/proposals/function-references/

.. [#proposal-gc]
https://github.com/WebAssembly/spec/tree/main/proposals/gc/

.. [#proposal-relaxed]
https://github.com/WebAssembly/spec/tree/main/proposals/relaxed-simd/

.. [#proposal-annot]
https://github.com/WebAssembly/annotations/tree/main/proposals/annotations/
Loading
Loading