summaryrefslogtreecommitdiffstats
path: root/test/CodeGen/Thumb
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2010-07-02 20:16:09 +0000
committerDale Johannesen <dalej@apple.com>2010-07-02 20:16:09 +0000
commitf1e309eb4862459a76445942ba4dafc433b6f317 (patch)
tree9ffe14cb16d9826246eabf37e3a126065183256f /test/CodeGen/Thumb
parent6bae55017c49e59746a65cef2513f031bbcebfce (diff)
downloadexternal_llvm-f1e309eb4862459a76445942ba4dafc433b6f317.zip
external_llvm-f1e309eb4862459a76445942ba4dafc433b6f317.tar.gz
external_llvm-f1e309eb4862459a76445942ba4dafc433b6f317.tar.bz2
Propagate the AlignStack bit in InlineAsm's to the
PrologEpilog code, and use it to determine whether the asm forces stack alignment or not. gcc consistently does not do this for GCC-style asms; Apple gcc inconsistently sometimes does it for asm blocks. There is no convenient place to put a bit in either the SDNode or the MachineInstr form, so I've added an extra operand to each; unlovely, but it does allow for expansion for more bits, should we need it. PR 5125. Some existing testcases are affected. The operand lists of the SDNode and MachineInstr forms are indexed with awesome mnemonics, like "2"; I may fix this someday, but not now. I'm not making it any worse. If anyone is inspired I think you can find all the right places from this patch. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@107506 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/Thumb')
-rw-r--r--test/CodeGen/Thumb/push.ll2
1 files changed, 1 insertions, 1 deletions
diff --git a/test/CodeGen/Thumb/push.ll b/test/CodeGen/Thumb/push.ll
index fd05ef4..94ef8e9 100644
--- a/test/CodeGen/Thumb/push.ll
+++ b/test/CodeGen/Thumb/push.ll
@@ -5,6 +5,6 @@ define void @t() nounwind {
; CHECK: t:
; CHECK: push {r7}
entry:
- call void asm sideeffect ".long 0xe7ffdefe", ""() nounwind
+ call void asm sideeffect alignstack ".long 0xe7ffdefe", ""() nounwind
ret void
}