diff options
author | Davide Italiano <davide@freebsd.org> | 2017-05-21 20:30:27 +0000 |
---|---|---|
committer | Davide Italiano <davide@freebsd.org> | 2017-05-21 20:30:27 +0000 |
commit | 21a49dcdf19e9df75015d2618400e9fde2e579fc (patch) | |
tree | d06ec7d98363ba7e5b965cd08d5b2c256db49368 /llvm/lib/Transforms/Utils/DemoteRegToStack.cpp | |
parent | a3f75469311c68b3d0d4b79df6cac5941c6a9202 (diff) | |
download | bcm5719-llvm-21a49dcdf19e9df75015d2618400e9fde2e579fc.tar.gz bcm5719-llvm-21a49dcdf19e9df75015d2618400e9fde2e579fc.zip |
[InstCombine] Take in account the size in sext->lshr->trunc patterns.
Otherwise we end up miscompiling, transforming:
define i8 @tinky() {
%sext = sext i1 1 to i16
%hibit = lshr i16 %sext, 15
%tr = trunc i16 %hibit to i8
ret i8 %tr
}
into:
%sext = sext i1 1 to i8
ret i8 %sext
and the first get folded to ret i8 1, while the second gets folded
to ret i8 -1.
Eventually we should get rid of this transform entirely, but for now,
this at least fixes a know correctness bug.
Differential Revision: https://reviews.llvm.org/D33338
llvm-svn: 303513
Diffstat (limited to 'llvm/lib/Transforms/Utils/DemoteRegToStack.cpp')
0 files changed, 0 insertions, 0 deletions