From 53b94fca7da5eeb08bb9b9802367a29c3e811e92 Mon Sep 17 00:00:00 2001 From: "Alon Zakai (kripken)" Date: Mon, 13 Feb 2017 10:44:00 -0800 Subject: fix fuzz testcase, xor maxBits is the max, not the min --- src/passes/OptimizeInstructions.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/passes/OptimizeInstructions.cpp b/src/passes/OptimizeInstructions.cpp index c81119f75..efd9e0037 100644 --- a/src/passes/OptimizeInstructions.cpp +++ b/src/passes/OptimizeInstructions.cpp @@ -179,8 +179,8 @@ static Index getMaxBits(Expression* curr) { case AddInt32: case SubInt32: case MulInt32: case DivSInt32: case DivUInt32: case RemSInt32: case RemUInt32: case RotLInt32: case RotRInt32: return 32; - case AndInt32: case XorInt32: return std::min(getMaxBits(binary->left), getMaxBits(binary->right)); - case OrInt32: return std::max(getMaxBits(binary->left), getMaxBits(binary->right)); + case AndInt32: return std::min(getMaxBits(binary->left), getMaxBits(binary->right)); + case OrInt32: case XorInt32: return std::max(getMaxBits(binary->left), getMaxBits(binary->right)); case ShlInt32: { if (auto* shifts = binary->right->dynCast()) { return std::min(Index(32), getMaxBits(binary->left) + shifts->value.geti32()); -- cgit v1.2.3