]> granicus.if.org Git - llvm/commit
Merging r324422:
authorHans Wennborg <hans@hanshq.net>
Wed, 7 Feb 2018 10:01:03 +0000 (10:01 +0000)
committerHans Wennborg <hans@hanshq.net>
Wed, 7 Feb 2018 10:01:03 +0000 (10:01 +0000)
commit5d4f6a8d9baa3cb5bb57e94317aad4a692abab62
tree9c22dadfaaa22f2cd630585f03afbb9b58140076
parentc00e97dc8ce0be0627432e653dd691722a6f7108
Merging r324422:
------------------------------------------------------------------------
r324422 | efriedma | 2018-02-07 00:00:17 +0100 (Wed, 07 Feb 2018) | 16 lines

[LivePhysRegs] Fix handling of return instructions.

See D42509 for the original version of this.

Basically, there are two significant changes to behavior here:

- addLiveOuts always adds all pristine registers (even if a block has
no successors).
- addLiveOuts and addLiveOutsNoPristines always add all callee-saved
registers for return blocks (including conditional return blocks).

I cleaned up the functions a bit to make it clear these properties hold.

Differential Revision: https://reviews.llvm.org/D42655

------------------------------------------------------------------------

git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_60@324466 91177308-0d34-0410-b5e6-96231b3b80d8
lib/CodeGen/LivePhysRegs.cpp
test/CodeGen/ARM/pr25838.ll
test/CodeGen/Thumb/stm-scavenging.ll [new file with mode: 0644]