Hi Tobias,<br>If the PHI node at exit block of region R has multiple inputs from the R,<br>I split the exit block into 2. <br>The first block contains all PHI nodes whose input are all from the region. <br>The second is the new exit node.<br>
<br>All branches (outside R) to the old exit now point the new exit.<br>All regions whose exit is the old exit are also updated with the new exit node.<br><br>It works like a charm.<br>Thanks.<br>Vu<br><div class="gmail_quote">
On Wed, Jan 26, 2011 at 7:26 PM, Tobias Grosser <span dir="ltr"><<a href="mailto:grosser@fim.uni-passau.de">grosser@fim.uni-passau.de</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
<div><div></div><div class="h5">On 01/26/2011 07:50 PM, Vu Le wrote:<br>
<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
I guess I didn't have a clear question.<br>
<br>
Suppose we have BB1 and BB2 both point to BB3.<br>
BB1 has variable x. BB2 also as variable x.<br>
BB3 will have PHINode for x with 2 value from BB1 and BB2.<br>
BB1 BB2<br>
\ /<br>
BB3<br>
<br>
Now if BB1 and BB2 is extracted into a function<br>
(using ExtractCodeRegion), they will be replaced by<br>
a basic block called codeRepl (which has a call to the extracted<br>
function).<br>
codeRepl<br>
|<br>
BB3<br>
<br>
The problem is that the PHINode in BB3 still has 2 values x,<br>
both from codeRepl. That's wrong because BB3 has only 1 successors,<br>
which is codeRepl. In fact, there is NO way to update PhiNode,<br>
because all the x are from ONE node, codeRepl.<br>
So the function ExtractCodeRegion doesn't work in this example.<br>
<br>
My solution for this is before extracting BB1 and BB2, I split the PHINode<br>
in BB3 into another basic block<br>
BB1 BB2<br>
\ /<br>
PhiBB<br>
|<br>
BB<br>
And extract BB1, BB2 and PhiBB.<br>
If you have any ideas or if you think this will not work, please let me<br>
know.<br>
Thanks.<br>
Vu<br>
</blockquote>
<br></div></div>
Hi Vu,<br>
<br>
I believe this is the right approach. If I am right and you work on the RegionInfo pass I believe what you want is only to extract so called simpleRegions that have just a single entry and exit edge.<br>
<br>
Have a look at the email from Andreas Simbuerger two weeks ago:<br>
<br>
[llvm-commits] [PATCH] Add SeSeRegionInfo transform pass<br>
<br>
This should contain the functions needed to transform a refined region into a simple region. Either we get this patch committed and you could just use this pass or we add the corresponding functions to RegionInfo and you translate just the regions that you finally will extract.<br>
<br>
Cheers<br>
Tobi<br>
</blockquote></div><br>