[llvm] [Attributor] New attribute to identify what byte ranges are alive for an allocation (PR #66148)
Johannes Doerfert via llvm-commits
llvm-commits at lists.llvm.org
Mon Sep 18 09:04:21 PDT 2023
================
@@ -12658,6 +12669,268 @@ struct AAAddressSpaceCallSiteArgument final : AAAddressSpaceImpl {
};
} // namespace
+/// ----------- Allocation Info ----------
+namespace {
+struct AAAllocationInfoImpl : public AAAllocationInfo {
+ AAAllocationInfoImpl(const IRPosition &IRP, Attributor &A)
+ : AAAllocationInfo(IRP, A) {}
+
+ std::optional<TypeSize> getAllocatedSize() const override {
+ assert(isValidState() && "the AA is invalid");
+ return AssumedAllocatedSize;
+ }
+
+ bool isaMallocInst(Instruction *I) {
+ CallInst *Call = dyn_cast<CallInst>(I);
+ auto CallName = Call->getCalledFunction()->getName();
+ if (CallName.str() == "malloc")
+ return true;
+
+ return false;
+ };
+
+ ChangeStatus updateImpl(Attributor &A) override {
+
+ Instruction *I = getIRPosition().getCtxI();
+
+ const IRPosition &IRP = getIRPosition();
----------------
jdoerfert wrote:
Look at this code. It is the wrong way around and the empty lines are not really helpful.
https://github.com/llvm/llvm-project/pull/66148
More information about the llvm-commits
mailing list