From 90c50cad1983c5e29107a78382dead0fe2a9562c Mon Sep 17 00:00:00 2001 From: Tyker Date: Mon, 15 Jun 2020 10:57:17 +0200 Subject: [AssumeBundles] add cannonicalisation to the assume builder Summary: this reduces significantly the number of assumes generated without aftecting too much the information that is preserved. this improves the compile-time cost of enable-knowledge-retention significantly. Reviewers: jdoerfert, sstefan1 Reviewed By: jdoerfert Subscribers: hiraditya, asbirlea, llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D79650 --- llvm/lib/IR/Value.cpp | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'llvm/lib/IR/Value.cpp') diff --git a/llvm/lib/IR/Value.cpp b/llvm/lib/IR/Value.cpp index 70d4012..78c12f4 100644 --- a/llvm/lib/IR/Value.cpp +++ b/llvm/lib/IR/Value.cpp @@ -516,7 +516,9 @@ enum PointerStripKind { }; template -static const Value *stripPointerCastsAndOffsets(const Value *V) { +static const Value *stripPointerCastsAndOffsets( + const Value *V, + function_ref Func = [](const Value *) {}) { if (!V->getType()->isPointerTy()) return V; @@ -526,6 +528,7 @@ static const Value *stripPointerCastsAndOffsets(const Value *V) { Visited.insert(V); do { + Func(V); if (auto *GEP = dyn_cast(V)) { switch (StripKind) { case PSK_ZeroIndices: @@ -667,8 +670,9 @@ const Value *Value::stripAndAccumulateConstantOffsets( return V; } -const Value *Value::stripInBoundsOffsets() const { - return stripPointerCastsAndOffsets(this); +const Value * +Value::stripInBoundsOffsets(function_ref Func) const { + return stripPointerCastsAndOffsets(this, Func); } uint64_t Value::getPointerDereferenceableBytes(const DataLayout &DL, -- cgit v1.1