summaryrefslogtreecommitdiff
path: root/src/ast/ExpressionAnalyzer.cpp
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2017-10-23 09:48:40 -0700
committerGitHub <noreply@github.com>2017-10-23 09:48:40 -0700
commit83a05025ee883f86cabdf92a9891d6c5ef5afbd4 (patch)
tree27d3966a4b1797ec14c2896e80aab61c9d76c33e /src/ast/ExpressionAnalyzer.cpp
parent1005b1267f70a5a7cf7a8774af6c12d813464720 (diff)
downloadbinaryen-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.cpp13
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);