diff options
author | Robert Lytton <robert@xmos.com> | 2013-11-12 10:11:05 +0000 |
---|---|---|
committer | Robert Lytton <robert@xmos.com> | 2013-11-12 10:11:05 +0000 |
commit | c17ea93ed516d5c7d03a8d5c7fc470a0f254b58a (patch) | |
tree | c6625154686be3edcb14d4436377a3a42bcc664c | |
parent | 3cda2d38851d73eec38d38a46462aaa65de4ef8e (diff) | |
download | external_llvm-c17ea93ed516d5c7d03a8d5c7fc470a0f254b58a.zip external_llvm-c17ea93ed516d5c7d03a8d5c7fc470a0f254b58a.tar.gz external_llvm-c17ea93ed516d5c7d03a8d5c7fc470a0f254b58a.tar.bz2 |
XCore target: return error for unsupported alignment
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194463 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/XCore/XCoreFrameLowering.cpp | 4 | ||||
-rw-r--r-- | test/CodeGen/XCore/alignment.ll | 9 |
2 files changed, 13 insertions, 0 deletions
diff --git a/lib/Target/XCore/XCoreFrameLowering.cpp b/lib/Target/XCore/XCoreFrameLowering.cpp index c60259d..d4075e0 100644 --- a/lib/Target/XCore/XCoreFrameLowering.cpp +++ b/lib/Target/XCore/XCoreFrameLowering.cpp @@ -93,6 +93,10 @@ void XCoreFrameLowering::emitPrologue(MachineFunction &MF) const { XCoreFunctionInfo *XFI = MF.getInfo<XCoreFunctionInfo>(); DebugLoc dl = MBBI != MBB.end() ? MBBI->getDebugLoc() : DebugLoc(); + if (MFI->getMaxAlignment() > getStackAlignment()) + report_fatal_error("emitPrologue unsupported alignment: " + + Twine(MFI->getMaxAlignment())); + bool FP = hasFP(MF); const AttributeSet &PAL = MF.getFunction()->getAttributes(); diff --git a/test/CodeGen/XCore/alignment.ll b/test/CodeGen/XCore/alignment.ll new file mode 100644 index 0000000..28bdf3b --- /dev/null +++ b/test/CodeGen/XCore/alignment.ll @@ -0,0 +1,9 @@ +; RUN: not llc < %s -march=xcore 2>&1 | FileCheck %s + +; CHECK: emitPrologue unsupported alignment: 8 +define void @f() nounwind { +entry: + %BadAlignment = alloca i64, align 8 + ret void +} + |