From 28a7dfa33d979e5ff3ed2d975c71b08d611fe6b6 Mon Sep 17 00:00:00 2001 From: Vincent Zhao Date: Fri, 28 Aug 2020 00:27:36 +0530 Subject: [PATCH] [MLIR] Fixed missing constraint append when adding an AffineIfOp domain The prior diff that introduced `addAffineIfOpDomain` missed appending constraints from the ifOp domain. This revision fixes this problem. Differential Revision: https://reviews.llvm.org/D86421 --- mlir/lib/Analysis/AffineStructures.cpp | 5 ++++- mlir/test/Transforms/memref-dependence-check.mlir | 10 +++++----- 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/mlir/lib/Analysis/AffineStructures.cpp b/mlir/lib/Analysis/AffineStructures.cpp index b712b2cef45e..546dfa4ba7db 100644 --- a/mlir/lib/Analysis/AffineStructures.cpp +++ b/mlir/lib/Analysis/AffineStructures.cpp @@ -731,8 +731,11 @@ void FlatAffineConstraints::addAffineIfOpDomain(AffineIfOp ifOp) { SmallVector operands = ifOp.getOperands(); cst.setIdValues(0, cst.getNumDimAndSymbolIds(), operands); - // Merge the constraints from ifOp to the current domain. + // Merge the constraints from ifOp to the current domain. We need first merge + // and align the IDs from both constraints, and then append the constraints + // from the ifOp into the current one. mergeAndAlignIdsWithOther(0, &cst); + append(cst); } // Searches for a constraint with a non-zero coefficient at 'colIdx' in diff --git a/mlir/test/Transforms/memref-dependence-check.mlir b/mlir/test/Transforms/memref-dependence-check.mlir index fc1c72cf1664..fbe0a149e9f4 100644 --- a/mlir/test/Transforms/memref-dependence-check.mlir +++ b/mlir/test/Transforms/memref-dependence-check.mlir @@ -9,15 +9,15 @@ func @store_may_execute_before_load() { %m = alloc() : memref<10xf32> %cf7 = constant 7.0 : f32 %c0 = constant 4 : index - // There is a dependence from store 0 to load 1 at depth 1 because the - // ancestor IfOp of the store, dominates the ancestor ForSmt of the load, - // and thus the store "may" conditionally execute before the load. + // There is no dependence from store 0 to load 1 at depth if we take into account + // the constraint introduced by the following `affine.if`, which indicates that + // the store 0 will never be executed. affine.if #set0(%c0) { affine.for %i0 = 0 to 10 { affine.store %cf7, %m[%i0] : memref<10xf32> // expected-remark@above {{dependence from 0 to 0 at depth 1 = false}} // expected-remark@above {{dependence from 0 to 0 at depth 2 = false}} - // expected-remark@above {{dependence from 0 to 1 at depth 1 = true}} + // expected-remark@above {{dependence from 0 to 1 at depth 1 = false}} } } affine.for %i1 = 0 to 10 { @@ -1044,7 +1044,7 @@ func @test_interleaved_affine_for_if() { %N = dim %0, %c0 : memref<101xf32> %cf7 = constant 7.0 : f32 - affine.for %i0 = 0 to 100 { + affine.for %i0 = 0 to 101 { affine.if #set1(%i0)[%N] { %1 = affine.load %0[%i0] : memref<101xf32> // expected-remark@above {{dependence from 0 to 0 at depth 1 = false}}