diff options
author | Tim Northover <tnorthover@apple.com> | 2013-05-30 12:30:50 +0000 |
---|---|---|
committer | Tim Northover <tnorthover@apple.com> | 2013-05-30 12:30:50 +0000 |
commit | d01fb9e212d989ff14e84a332c5b18f8a23d4b35 (patch) | |
tree | b0cc82ff6b1b77bd30280de05446e8611721862e /docs | |
parent | d5c52f1d760cd2f6f347733a02bf666fc1d50662 (diff) | |
download | llvm-d01fb9e212d989ff14e84a332c5b18f8a23d4b35.tar.gz llvm-d01fb9e212d989ff14e84a332c5b18f8a23d4b35.tar.bz2 llvm-d01fb9e212d989ff14e84a332c5b18f8a23d4b35.tar.xz |
Fix rematerialization into physical registers.
r182872 introduced a bug in how the register-coalescer's rematerialization
handled defining a physical register. It relied on the output of the
coalescer's setRegisters method to determine whether the replacement
instruction needed an implicit-def. However, this value isn't necessarily the
same as the CopyMI's actual destination register which is what the rest of the
basic-block expects us to be defining.
The commit changes the rematerializer to use the actual register attached to
CopyMI in its decision.
This will be tested soon by an X86 patch which moves everything to using
MOV32r0 instead of other sizes.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@182925 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'docs')
0 files changed, 0 insertions, 0 deletions