summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-11-21 22:32:23 +0000
committerChris Lattner <sabre@nondot.org>2003-11-21 22:32:23 +0000
commit3ae303cc8c8d58d7e4d97515c23e1aead6ede13a (patch)
tree70c867e5b7febf17ccf10f2b0519a8b4007c9f0a /llvm
parentbc2d3308fef3d4e67e7703148fae6ceb86d57fbf (diff)
downloadbcm5719-llvm-3ae303cc8c8d58d7e4d97515c23e1aead6ede13a.tar.gz
bcm5719-llvm-3ae303cc8c8d58d7e4d97515c23e1aead6ede13a.zip
Check return types of functions
llvm-svn: 10146
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/AsmParser/llvmAsmParser.y3
-rw-r--r--llvm/lib/VMCore/Function.cpp3
-rw-r--r--llvm/lib/VMCore/Verifier.cpp3
3 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/AsmParser/llvmAsmParser.y b/llvm/lib/AsmParser/llvmAsmParser.y
index 8e4450138e8..ca2924bb498 100644
--- a/llvm/lib/AsmParser/llvmAsmParser.y
+++ b/llvm/lib/AsmParser/llvmAsmParser.y
@@ -1395,6 +1395,9 @@ FunctionHeaderH : TypesV Name '(' ArgList ')' {
UnEscapeLexed($2);
std::string FunctionName($2);
+ if (!(*$1)->isFirstClassType() && *$1 != Type::VoidTy)
+ ThrowException("LLVM functions cannot return aggregate types!");
+
std::vector<const Type*> ParamTypeList;
if ($4) { // If there are arguments...
for (std::vector<std::pair<PATypeHolder*,char*> >::iterator I = $4->begin();
diff --git a/llvm/lib/VMCore/Function.cpp b/llvm/lib/VMCore/Function.cpp
index 9a4ac6711cc..b5586721e85 100644
--- a/llvm/lib/VMCore/Function.cpp
+++ b/llvm/lib/VMCore/Function.cpp
@@ -95,6 +95,9 @@ Function::Function(const FunctionType *Ty, LinkageTypes Linkage,
ArgumentList.setParent(this);
SymTab = new SymbolTable();
+ assert((getReturnType()->isFirstClassType() ||getReturnType() == Type::VoidTy)
+ && "LLVM functions cannot return aggregate values!");
+
// Create the arguments vector, all arguments start out unnamed.
for (unsigned i = 0, e = Ty->getNumParams(); i != e; ++i) {
assert(Ty->getParamType(i) != Type::VoidTy &&
diff --git a/llvm/lib/VMCore/Verifier.cpp b/llvm/lib/VMCore/Verifier.cpp
index 1d441d1dd5e..98288f41427 100644
--- a/llvm/lib/VMCore/Verifier.cpp
+++ b/llvm/lib/VMCore/Verifier.cpp
@@ -241,6 +241,9 @@ void Verifier::visitFunction(Function &F) {
Assert2(FT->getNumParams() == NumArgs,
"# formal arguments must match # of arguments for function type!",
&F, FT);
+ Assert1(F.getReturnType()->isFirstClassType() ||
+ F.getReturnType() == Type::VoidTy,
+ "Functions cannot return aggregate values!", &F);
// Check that the argument values match the function type for this function...
unsigned i = 0;
OpenPOWER on IntegriCloud