diff --git a/lib/IR/DataLayout.cpp b/lib/IR/DataLayout.cpp index cde393777a6..0dcc8427dcd 100644 --- a/lib/IR/DataLayout.cpp +++ b/lib/IR/DataLayout.cpp @@ -312,6 +312,9 @@ void DataLayout::parseSpecifier(StringRef Desc) { PrefAlign = inBytes(getInt(Tok)); } + if (ABIAlign > PrefAlign) + report_fatal_error( + "Preferred alignment cannot be less than the ABI alignment"); setAlignment(AlignType, ABIAlign, PrefAlign, Size); break; diff --git a/test/Assembler/invalid-datalayout14.ll b/test/Assembler/invalid-datalayout14.ll new file mode 100644 index 00000000000..84634b52a14 --- /dev/null +++ b/test/Assembler/invalid-datalayout14.ll @@ -0,0 +1,3 @@ +; RUN: not llvm-as < %s 2>&1 | FileCheck %s +target datalayout = "i64:64:16" +; CHECK: Preferred alignment cannot be less than the ABI alignment