]> granicus.if.org Git - llvm/commit
Merging r196046:
authorBill Wendling <isanbard@gmail.com>
Mon, 2 Dec 2013 07:38:06 +0000 (07:38 +0000)
committerBill Wendling <isanbard@gmail.com>
Mon, 2 Dec 2013 07:38:06 +0000 (07:38 +0000)
commit1b26fdbf1f01e90b803cc035b6b932cd95c76830
treec9717538bdb0fd127cbdd8cba12633cb32552fa8
parent3d238de4d54eb0b16afd96a57f49f92b2f7748e0
Merging r196046:
------------------------------------------------------------------------
r196046 | tnorthover | 2013-12-01 06:16:24 -0800 (Sun, 01 Dec 2013) | 8 lines

ARM: fix bug in -Oz stack adjustment folding

Previously, we clobbered callee-saved registers when folding an "add
sp, #N" into a "pop {rD, ...}" instruction. This change checks whether
a register we're going to add to the "pop" could actually be live
outside the function before doing so and should fix the issue.

This should fix PR18081.
------------------------------------------------------------------------

git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_34@196074 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/ARM/ARMBaseInstrInfo.cpp
lib/Target/ARM/ARMBaseRegisterInfo.h
lib/Target/ARM/ARMFrameLowering.cpp
lib/Target/ARM/Thumb1FrameLowering.cpp
test/CodeGen/ARM/fold-stack-adjust.ll