Duncan Sands d462ba8539 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
2008-02-13 18:01:53 +00:00
..
2007-04-16 17:36:08 +00:00
2007-04-28 06:03:12 +00:00
2007-02-25 21:43:21 +00:00
2007-04-26 21:20:04 +00:00
2007-04-17 23:43:31 +00:00
2008-01-10 00:30:38 +00:00
2007-11-28 18:22:12 +00:00
2007-04-16 17:36:08 +00:00
2007-09-24 15:50:11 +00:00
2008-01-17 19:47:23 +00:00
2008-01-15 22:17:26 +00:00
2007-04-16 03:06:39 +00:00
2007-04-30 05:11:58 +00:00