#include "mlir/Dialect/Affine/Analysis/LoopAnalysis.h"
#include "mlir/Dialect/Affine/Analysis/Utils.h"
#include "mlir/Dialect/Affine/LoopFusionUtils.h"
#include "mlir/Dialect/Func/IR/FuncOps.h"
#include "mlir/Pass/Pass.h"
#define PASS_NAME "test-affine-access-analysis"
using namespace mlir;
using namespace mlir::affine;
namespace {
struct TestAccessAnalysis
: public PassWrapper<TestAccessAnalysis, OperationPass<func::FuncOp>> {
MLIR_DEFINE_EXPLICIT_INTERNAL_INLINE_TYPE_ID(TestAccessAnalysis)
StringRef getArgument() const final { return PASS_NAME; }
StringRef getDescription() const final {
return "Tests affine memory access analysis utility";
}
void runOnOperation() override;
};
}
static void
gatherLoadsAndStores(AffineForOp forOp,
SmallVectorImpl<Operation *> &loadAndStoreOps) {
forOp.walk([&](Operation *op) {
if (isa<AffineReadOpInterface, AffineWriteOpInterface>(op))
loadAndStoreOps.push_back(op);
});
}
void TestAccessAnalysis::runOnOperation() {
SmallVector<Operation *> loadStores;
SmallVector<AffineForOp> enclosingOps;
for (auto forOp : getOperation().getOps<AffineForOp>()) {
loadStores.clear();
gatherLoadsAndStores(forOp, loadStores);
for (Operation *memOp : loadStores) {
enclosingOps.clear();
getAffineForIVs(*memOp, &enclosingOps);
for (unsigned d = 0, e = enclosingOps.size(); d < e; d++) {
AffineForOp loop = enclosingOps[d];
int memRefDim;
bool isContiguous, isInvariant;
if (auto read = dyn_cast<AffineReadOpInterface>(memOp)) {
isContiguous =
isContiguousAccess(loop.getInductionVar(), read, &memRefDim);
isInvariant = isInvariantAccess(read, loop);
} else {
auto write = cast<AffineWriteOpInterface>(memOp);
isContiguous =
isContiguousAccess(loop.getInductionVar(), write, &memRefDim);
isInvariant = isInvariantAccess(write, loop);
}
if (isContiguous && memRefDim == 0)
memOp->emitRemark("contiguous along loop ") << d << '\n';
if (isInvariant)
memOp->emitRemark("invariant along loop ") << d << '\n';
}
}
}
}
namespace mlir {
void registerTestAffineAccessAnalysisPass() {
PassRegistration<TestAccessAnalysis>();
}
}