diff options
author | Alon Zakai <alonzakai@gmail.com> | 2017-09-11 10:22:41 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-09-11 10:22:41 -0700 |
commit | 13bccf058972660d7d59e68c08c0278c1554a19b (patch) | |
tree | 57a5c0827243516a927ad2181bb4f361557141c7 /src/ast/ExpressionAnalyzer.cpp | |
parent | 9fafcef2c3dfe18b119b11fa527514835a4371ce (diff) | |
download | binaryen-13bccf058972660d7d59e68c08c0278c1554a19b.tar.gz binaryen-13bccf058972660d7d59e68c08c0278c1554a19b.tar.bz2 binaryen-13bccf058972660d7d59e68c08c0278c1554a19b.zip |
asm2wasm atomics (#1171)
* translate asm.js atomics into wasm atomics
* fix wasm-builder atomic load emitting, the alignment is the loaded size, not the output size
* don't require code for each node type in vaccuum, for non-mentioned nodes, assume we can't optimize them out
* support atomics in hashing, comparing, and copying
Diffstat (limited to 'src/ast/ExpressionAnalyzer.cpp')
-rw-r--r-- | src/ast/ExpressionAnalyzer.cpp | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/src/ast/ExpressionAnalyzer.cpp b/src/ast/ExpressionAnalyzer.cpp index 421206706..b8e2ae34c 100644 --- a/src/ast/ExpressionAnalyzer.cpp +++ b/src/ast/ExpressionAnalyzer.cpp @@ -223,6 +223,34 @@ bool ExpressionAnalyzer::flexibleEqual(Expression* left, Expression* right, Expr PUSH(Store, value); break; } + case Expression::Id::AtomicCmpxchgId: { + CHECK(AtomicCmpxchg, bytes); + CHECK(AtomicCmpxchg, offset); + PUSH(AtomicCmpxchg, ptr); + PUSH(AtomicCmpxchg, expected); + PUSH(AtomicCmpxchg, replacement); + break; + } + case Expression::Id::AtomicRMWId: { + CHECK(AtomicRMW, op); + CHECK(AtomicRMW, bytes); + CHECK(AtomicRMW, offset); + PUSH(AtomicRMW, ptr); + PUSH(AtomicRMW, value); + break; + } + case Expression::Id::AtomicWaitId: { + CHECK(AtomicWait, expectedType); + PUSH(AtomicWait, ptr); + PUSH(AtomicWait, expected); + PUSH(AtomicWait, timeout); + break; + } + case Expression::Id::AtomicWakeId: { + PUSH(AtomicWake, ptr); + PUSH(AtomicWake, wakeCount); + break; + } case Expression::Id::ConstId: { CHECK(Const, value); break; @@ -440,6 +468,34 @@ uint32_t ExpressionAnalyzer::hash(Expression* curr) { PUSH(Store, value); break; } + case Expression::Id::AtomicCmpxchgId: { + HASH(AtomicCmpxchg, bytes); + HASH(AtomicCmpxchg, offset); + PUSH(AtomicCmpxchg, ptr); + PUSH(AtomicCmpxchg, expected); + PUSH(AtomicCmpxchg, replacement); + break; + } + case Expression::Id::AtomicRMWId: { + HASH(AtomicRMW, op); + HASH(AtomicRMW, bytes); + HASH(AtomicRMW, offset); + PUSH(AtomicRMW, ptr); + PUSH(AtomicRMW, value); + break; + } + case Expression::Id::AtomicWaitId: { + HASH(AtomicWait, expectedType); + PUSH(AtomicWait, ptr); + PUSH(AtomicWait, expected); + PUSH(AtomicWait, timeout); + break; + } + case Expression::Id::AtomicWakeId: { + PUSH(AtomicWake, ptr); + PUSH(AtomicWake, wakeCount); + break; + } case Expression::Id::ConstId: { HASH(Const, value.type); HASH64(Const, value.getBits()); |