diff options
author | Alon Zakai <alonzakai@gmail.com> | 2017-10-23 09:48:40 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-23 09:48:40 -0700 |
commit | 83a05025ee883f86cabdf92a9891d6c5ef5afbd4 (patch) | |
tree | 27d3966a4b1797ec14c2896e80aab61c9d76c33e /src/ast/ExpressionAnalyzer.cpp | |
parent | 1005b1267f70a5a7cf7a8774af6c12d813464720 (diff) | |
download | binaryen-83a05025ee883f86cabdf92a9891d6c5ef5afbd4.tar.gz binaryen-83a05025ee883f86cabdf92a9891d6c5ef5afbd4.tar.bz2 binaryen-83a05025ee883f86cabdf92a9891d6c5ef5afbd4.zip |
only look at the |signed| field of loads if it is relevant (#1235)
Diffstat (limited to 'src/ast/ExpressionAnalyzer.cpp')
-rw-r--r-- | src/ast/ExpressionAnalyzer.cpp | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/src/ast/ExpressionAnalyzer.cpp b/src/ast/ExpressionAnalyzer.cpp index 3556fcdd5..d223bf213 100644 --- a/src/ast/ExpressionAnalyzer.cpp +++ b/src/ast/ExpressionAnalyzer.cpp @@ -14,9 +14,9 @@ * limitations under the License. */ -#include "ast_utils.h" #include "support/hash.h" - +#include "ast_utils.h" +#include "ast/load-utils.h" namespace wasm { // Given a stack of expressions, checks if the topmost is used as a result. @@ -208,7 +208,10 @@ bool ExpressionAnalyzer::flexibleEqual(Expression* left, Expression* right, Expr } case Expression::Id::LoadId: { CHECK(Load, bytes); - CHECK(Load, signed_); + if (LoadUtils::isSignRelevant(left->cast<Load>()) && + LoadUtils::isSignRelevant(right->cast<Load>())) { + CHECK(Load, signed_); + } CHECK(Load, offset); CHECK(Load, align); PUSH(Load, ptr); @@ -455,7 +458,9 @@ uint32_t ExpressionAnalyzer::hash(Expression* curr) { } case Expression::Id::LoadId: { HASH(Load, bytes); - HASH(Load, signed_); + if (LoadUtils::isSignRelevant(curr->cast<Load>())) { + HASH(Load, signed_); + } HASH(Load, offset); HASH(Load, align); PUSH(Load, ptr); |