Do not fold away subreg_to_reg if the source register has a sub-register index. That...
authorEvan Cheng <evan.cheng@apple.com>
Mon, 23 Mar 2009 07:19:58 +0000 (07:19 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Mon, 23 Mar 2009 07:19:58 +0000 (07:19 +0000)
commit7d6d4b360fb8c1895b57eeb1284e792f953ea7ee
tree418af119ada84a281c17a9346f9183361e6fdec1
parenta8bd27ff666a0c5f7248f01670f0f53887359086
Do not fold away subreg_to_reg if the source register has a sub-register index. That means the source register is taking a sub-register of a larger register. e.g. On x86
%RAX<def> = ...
%RAX<def> = SUBREG_TO_REG 0, %EAX:3<kill>, 3
The first def is defining RAX, not EAX so the top bits were not zero-extended.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67511 91177308-0d34-0410-b5e6-96231b3b80d8
lib/CodeGen/LowerSubregs.cpp
test/CodeGen/X86/subreg-to-reg-2.ll [new file with mode: 0644]