[llvm-commits] [llvm] r94763 - /llvm/trunk/lib/Transforms/Utils/PromoteMemoryToRegister.cpp
Devang Patel
devang.patel at gmail.com
Fri Jan 29 11:33:56 PST 2010
Hi Victor,
On Fri, Jan 29, 2010 at 12:01 AM, Victor Hernandez <vhernandez at apple.com> wrote:
> Author: hernande
> Date: Thu Jan 28 18:01:35 2010
> New Revision: 94763
>
> URL: http://llvm.org/viewvc/llvm-project?rev=94763&view=rev
> Log:
> mem2reg erases the dbg.declare intrinsics that it converts to dbg.val intrinsics
>
> Modified:
> llvm/trunk/lib/Transforms/Utils/PromoteMemoryToRegister.cpp
>
> Modified: llvm/trunk/lib/Transforms/Utils/PromoteMemoryToRegister.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Utils/PromoteMemoryToRegister.cpp?rev=94763&r1=94762&r2=94763&view=diff
>
> ==============================================================================
> --- llvm/trunk/lib/Transforms/Utils/PromoteMemoryToRegister.cpp (original)
> +++ llvm/trunk/lib/Transforms/Utils/PromoteMemoryToRegister.cpp Thu Jan 28 18:01:35 2010
> @@ -373,9 +373,11 @@
>
> // Finally, after the scan, check to see if the store is all that is left.
> if (Info.UsingBlocks.empty()) {
> - // Record debuginfo for the store before removing it.
> - if (DbgDeclareInst *DDI = Info.DbgDeclare)
> + // Record debuginfo for the store and remove the declaration's debuginfo.
> + if (DbgDeclareInst *DDI = Info.DbgDeclare) {
> ConvertDebugDeclareToDebugValue(DDI, Info.OnlyStore);
> + DDI->eraseFromParent();
> + }
Why not erase DDI in ConvertDebugDeclareToDebugValue() itself ?
-
Devang
> // Remove the (now dead) store and alloca.
> Info.OnlyStore->eraseFromParent();
> LBI.deleteValue(Info.OnlyStore);
> @@ -418,6 +420,10 @@
> // The alloca has been processed, move on.
> RemoveFromAllocasList(AllocaNum);
>
> + // The alloca's debuginfo can be removed as well.
> + if (DbgDeclareInst *DDI = Info.DbgDeclare)
> + DDI->eraseFromParent();
> +
> ++NumLocalPromoted;
> continue;
> }
> @@ -493,7 +499,11 @@
> A->eraseFromParent();
> }
>
> -
> + // Remove alloca's dbg.declare instrinsics from the function.
> + for (unsigned i = 0, e = AllocaDbgDeclares.size(); i != e; ++i)
> + if (DbgDeclareInst *DDI = AllocaDbgDeclares[i])
> + DDI->eraseFromParent();
> +
> // Loop over all of the PHI nodes and see if there are any that we can get
> // rid of because they merge all of the same incoming values. This can
> // happen due to undef values coming into the PHI nodes. This process is
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
>
--
-
Devang
More information about the llvm-commits
mailing list