mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 23:31:37 +00:00
Make sure SP is always aligned on a 2 byte boundary
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@193320 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5e1d0d39db
commit
cb8c3d1e49
@ -27,8 +27,8 @@ protected:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
explicit MSP430FrameLowering(const MSP430Subtarget &sti)
|
explicit MSP430FrameLowering(const MSP430Subtarget &sti)
|
||||||
: TargetFrameLowering(TargetFrameLowering::StackGrowsDown, 2, -2), STI(sti) {
|
: TargetFrameLowering(TargetFrameLowering::StackGrowsDown, 2, -2, 2),
|
||||||
}
|
STI(sti) {}
|
||||||
|
|
||||||
/// emitProlog/emitEpilog - These methods insert prolog and epilog code into
|
/// emitProlog/emitEpilog - These methods insert prolog and epilog code into
|
||||||
/// the function.
|
/// the function.
|
||||||
|
17
test/CodeGen/MSP430/transient-stack-alignment.ll
Normal file
17
test/CodeGen/MSP430/transient-stack-alignment.ll
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
; RUN: llc < %s | FileCheck %s
|
||||||
|
|
||||||
|
target datalayout = "e-p:16:16:16-i8:8:8-i16:16:16-i32:16:32-n8:16-a0:16:16"
|
||||||
|
target triple = "msp430---elf"
|
||||||
|
|
||||||
|
define void @test() #0 {
|
||||||
|
; CHECK-LABEL: test:
|
||||||
|
; CHECK: sub.w #2, r1
|
||||||
|
%1 = alloca i8, align 1
|
||||||
|
; CHECK-NEXT: mov.b #0, 1(r1)
|
||||||
|
store i8 0, i8* %1, align 1
|
||||||
|
; CHECK-NEXT: add.w #2, r1
|
||||||
|
; CHECK-NEXT: ret
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
|
attributes #0 = { nounwind "no-frame-pointer-elim"="false" }
|
Loading…
x
Reference in New Issue
Block a user