summaryrefslogtreecommitdiffstats
path: root/llvm/lib/VMCore/IntrinsicInst.cpp
diff options
context:
space:
mode:
authorDuncan Sands <baldrick@free.fr>2008-02-13 18:01:53 +0000
committerDuncan Sands <baldrick@free.fr>2008-02-13 18:01:53 +0000
commitf8d29f228d6f8e2efbff2efe287ee9dcd3ada433 (patch)
treec1f0fdf6acfd1b143abe961eb02f88bcae9be414 /llvm/lib/VMCore/IntrinsicInst.cpp
parent7b7ace5537784bdf43563377ef2982655c5549e8 (diff)
downloadbcm5719-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
OpenPOWER on IntegriCloud