From b715ffa0c805f4d4813f0cda8b17eeb618e1ebf0 Mon Sep 17 00:00:00 2001 From: Timotej Kapus Date: Fri, 8 Nov 2019 12:25:59 +0000 Subject: [optimize-array] Fix hole index in buildMixedSelectExpr buildMixedSelectExpr was using the byte index for holes in the select condition instead of the word based one. This only occured if there was more than 1 hole. --- lib/Expr/ArrayExprOptimizer.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) (limited to 'lib/Expr') diff --git a/lib/Expr/ArrayExprOptimizer.cpp b/lib/Expr/ArrayExprOptimizer.cpp index 8ba0b40d..b55974d0 100644 --- a/lib/Expr/ArrayExprOptimizer.cpp +++ b/lib/Expr/ArrayExprOptimizer.cpp @@ -643,8 +643,7 @@ ref ExprOptimizer::buildMixedSelectExpr( ref temp_idx = MulExpr::create( ConstantExpr::create(holes[i], re->index->getWidth()), ConstantExpr::create(width / 8, re->index->getWidth())); - ref cond = EqExpr::create( - re->index, ConstantExpr::create(holes[i], re->index->getWidth())); + ref cond = EqExpr::create(re->index, temp_idx); ref temp = SelectExpr::create( cond, extendRead(re->updates, temp_idx, width), result); result = temp; -- cgit 1.4.1