diff options
| author | Duncan Sands <baldrick@free.fr> | 2008-02-13 18:01:53 +0000 | 
|---|---|---|
| committer | Duncan Sands <baldrick@free.fr> | 2008-02-13 18:01:53 +0000 | 
| commit | 146d5af37804de3c482dde4e88e453622cb4039e (patch) | |
| tree | 7c160428925fb88c8e140a63491831477f3d02e2 /lib/ExecutionEngine | |
| parent | 76bb530d9d98b307adc35f9d63301ddedc2075b6 (diff) | |
| download | external_llvm-146d5af37804de3c482dde4e88e453622cb4039e.zip external_llvm-146d5af37804de3c482dde4e88e453622cb4039e.tar.gz external_llvm-146d5af37804de3c482dde4e88e453622cb4039e.tar.bz2 | |
Teach LegalizeTypes how to expand and promote CTLZ,
CTTZ and CTPOP.  The expansion code differs from
that in LegalizeDAG in that it chooses to take the
CTLZ/CTTZ count from the Hi/Lo part depending on
whether the Hi/Lo value is zero, not on whether
CTLZ/CTTZ of Hi/Lo returned 32 (or whatever the
width of the type is) for it.  I made this change
because the optimizers may well know that Hi/Lo
is zero and exploit it.  The promotion code for
CTTZ also differs from that in LegalizeDAG: it
uses an "or" to get the right result when the
original value is zero, rather than using a compare
and select.  This also means the value doesn't
need to be zero extended.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47075 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine')
0 files changed, 0 insertions, 0 deletions
