Propagate the AlignStack bit in InlineAsm's to the
authorDale Johannesen <dalej@apple.com>
Fri, 2 Jul 2010 20:16:09 +0000 (20:16 +0000)
committerDale Johannesen <dalej@apple.com>
Fri, 2 Jul 2010 20:16:09 +0000 (20:16 +0000)
commitf1e309eb4862459a76445942ba4dafc433b6f317
tree9ffe14cb16d9826246eabf37e3a126065183256f
parent6bae55017c49e59746a65cef2513f031bbcebfce
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
12 files changed:
include/llvm/InlineAsm.h
lib/CodeGen/AsmPrinter/AsmPrinterInlineAsm.cpp
lib/CodeGen/MachineInstr.cpp
lib/CodeGen/PrologEpilogInserter.cpp
lib/CodeGen/SelectionDAG/InstrEmitter.cpp
lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
test/CodeGen/Thumb/push.ll
test/CodeGen/X86/2009-04-20-LinearScanOpt.ll
test/CodeGen/X86/2010-07-02-asm-alignstack.ll [new file with mode: 0644]
test/CodeGen/X86/inline-asm-tied.ll
test/CodeGen/X86/iv-users-in-other-loops.ll