I tried to make 5 separate patches, but as they are constructive, they
had information from the last one. So I will post one by one as it gets
on the tree.
1. We had a function isUsedInTerminator that tested if a comparator was
used in the terminator of its parent BasicBlock. This is wrong because a
comparator can be created in a BasicBlock and used in the terminator of
other BasicBlock, and can be used in more than one.
Patch attached
Andre Tavares wrote:> I did a bunch of modifications on SSI. Most of them to make it faster,
> and a few inconsistencies I found. I will list what I did.
>
> 1. We had a function isUsedInTerminator that tested if a comparator
> was used in the terminator of its parent BasicBlock. This is wrong
> because a comparator can be created in a BasicBlock and used in the
> terminator of other BasicBlock, and can be used in more than one.
>
> 2. There was that list of all variables converted to SSI. I decided to
> remove it as you guys didn't like to have list holding memory. Now
> insertSigma tests if a sigma is already there before it inserts any.
>
> 3. InsertSSIphi had the test if (DF_BB == DF->end()) twice, one with
> break and the other with continue. I kept the continue, which is the
> correct one.
>
> 4. I changed the order in which we rename variables, and now fixphis
> will only need to get the case where a predecessor of a phi is
> missing, it will not have to change value for any phi anymore, because
> I insert the right information on the first time.
>
> 5. SSI is not pruned anymore. To have it pruned we needed to test if
> a PHI or SIGMA dominated any use of the original variable. This costs
> time, and a pruned SSI is not under SSI rules. This was not a problem
> for ABCD, but could be for any other optimization that used it. So all
> PHIS and SIGMAS related to branch instructions are inserted. Those
> other optimization passes can remove them later if necessary.
>
> Regards,
>
> ------------------------------------------------------------------------
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
--
Andre Tavares
Master Student in Computer Science - UFMG - Brasil
http://dcc.ufmg.br/~andrelct
-------------- next part --------------
A non-text attachment was scrubbed...
Name: ssi1.patch
Type: text/x-diff
Size: 3546 bytes
Desc: not available
URL:
<http://lists.llvm.org/pipermail/llvm-dev/attachments/20090901/8ee25868/attachment.patch>