[LLVMdev] mem2reg optimization
Dan Gohman
gohman at apple.com
Tue Oct 7 15:26:32 PDT 2008
On Oct 7, 2008, at 3:07 PM, David Greene wrote:
> On Tuesday 07 October 2008 16:13, Dan Gohman wrote:
>
>>> No, it's analysis that depend on the orderings of loads and stores
>>> (or any
>>> instruction). I ran across this need in another area.
>>
>> I believe that there are problems, but I'm not seeing what
>> the problem is with an instruction ordering pass to be used
>> by mem2reg. Can you be more specific, or point me to the
>> thread where this was discussed?
>
> Oh, use by mem2reg shouldn't be a problem. But as you say, unless
> it's used
> other places, why make it a separate pass? My point was that the
> other place
> I've found this useful is in an analysis pass and that's problematic
> because
> the ordering won't be updated by PassManager even if the dependent
> analysis
> is. Therefore, the dependent analysis will compute wrong answers.
Ok, thanks for clarifying for me.
>
> Let's not confuse separate issues:
>
> 1. mem2reg needs speedup that ordering can provide. I propose we
> provide that
> within mem2reg itself for now to keep things simple.
>
> 2. Breaking ordering out into a pass is fine as long as only
> transformation
> passes use it. It will not help analysis passes.
>
> 3. PassManager support for analysis passes depending on other
> analysis passes
> is a whole can of worms I don't want to touch right now. :)
Sounds reasonable :-). Thanks!
Dan
More information about the llvm-dev
mailing list