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 | f8d29f228d6f8e2efbff2efe287ee9dcd3ada433 (patch) | |
| tree | c1f0fdf6acfd1b143abe961eb02f88bcae9be414 /llvm/lib/VMCore/IntrinsicInst.cpp | |
| parent | 7b7ace5537784bdf43563377ef2982655c5549e8 (diff) | |
| download | bcm5719-llvm-f8d29f228d6f8e2efbff2efe287ee9dcd3ada433.tar.gz bcm5719-llvm-f8d29f228d6f8e2efbff2efe287ee9dcd3ada433.zip | |
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.
llvm-svn: 47075
Diffstat (limited to 'llvm/lib/VMCore/IntrinsicInst.cpp')
0 files changed, 0 insertions, 0 deletions

