summaryrefslogtreecommitdiff
path: root/lib/Target
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-10-18 05:57:43 +0000
committerChris Lattner <sabre@nondot.org>2003-10-18 05:57:43 +0000
commit4d45bd007d0c3a3a6e5b3876b67fd495acb0db2b (patch)
treecb11e8a60837799547960e7f7b8347a431994934 /lib/Target
parentcda965e28a3411cb9e41f58cddc4c9c1afa0e8a1 (diff)
downloadllvm-4d45bd007d0c3a3a6e5b3876b67fd495acb0db2b.tar.gz
llvm-4d45bd007d0c3a3a6e5b3876b67fd495acb0db2b.tar.bz2
llvm-4d45bd007d0c3a3a6e5b3876b67fd495acb0db2b.tar.xz
Add support for the new varargs intrinsics and instructions
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9226 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target')
-rw-r--r--lib/Target/CBackend/CBackend.cpp37
-rw-r--r--lib/Target/CBackend/Writer.cpp37
2 files changed, 46 insertions, 28 deletions
diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp
index a34f3f7712..00ad0e3bb1 100644
--- a/lib/Target/CBackend/CBackend.cpp
+++ b/lib/Target/CBackend/CBackend.cpp
@@ -90,7 +90,7 @@ namespace {
// emit it inline where it would go.
if (I.getType() == Type::VoidTy || !I.hasOneUse() ||
isa<TerminatorInst>(I) || isa<CallInst>(I) || isa<PHINode>(I) ||
- isa<LoadInst>(I) || isa<VarArgInst>(I))
+ isa<LoadInst>(I) || isa<VAArgInst>(I) || isa<VANextInst>(I))
// Don't inline a load across a store or other bad things!
return false;
@@ -135,7 +135,8 @@ namespace {
void visitLoadInst (LoadInst &I);
void visitStoreInst (StoreInst &I);
void visitGetElementPtrInst(GetElementPtrInst &I);
- void visitVarArgInst(VarArgInst &I);
+ void visitVANextInst(VANextInst &I);
+ void visitVAArgInst (VAArgInst &I);
void visitInstruction(Instruction &I) {
std::cerr << "C Writer does not know about " << I;
@@ -1181,26 +1182,25 @@ void CWriter::visitCallInst(CallInst &I) {
switch (ID) {
default: assert(0 && "Unknown LLVM intrinsic!");
case LLVMIntrinsic::va_start:
- Out << "va_start(*(va_list*)";
- writeOperand(I.getOperand(1));
- Out << ", ";
+ Out << "0; ";
+
+ Out << "va_start(*(va_list*)&" << Mang->getValueName(&I) << ", ";
// Output the last argument to the enclosing function...
writeOperand(&I.getParent()->getParent()->aback());
Out << ")";
return;
case LLVMIntrinsic::va_end:
- Out << "va_end(*(va_list*)";
+ Out << "va_end(*(va_list*)&";
writeOperand(I.getOperand(1));
Out << ")";
return;
case LLVMIntrinsic::va_copy:
- Out << "va_copy(*(va_list*)";
+ Out << "0;";
+ Out << "va_copy(*(va_list*)&" << Mang->getValueName(&I) << ", ";
+ Out << "*(va_list*)&";
writeOperand(I.getOperand(1));
- Out << ", (va_list)";
- writeOperand(I.getOperand(2));
Out << ")";
return;
-
case LLVMIntrinsic::setjmp:
case LLVMIntrinsic::sigsetjmp:
// This intrinsic should never exist in the program, but until we get
@@ -1346,12 +1346,21 @@ void CWriter::visitGetElementPtrInst(GetElementPtrInst &I) {
printIndexingExpression(I.getPointerOperand(), I.idx_begin(), I.idx_end());
}
-void CWriter::visitVarArgInst(VarArgInst &I) {
- Out << "va_arg((va_list)*";
+void CWriter::visitVANextInst(VANextInst &I) {
+ Out << Mang->getValueName(I.getOperand(0));
+ Out << "; va_arg(*(va_list*)&" << Mang->getValueName(&I) << ", ";
+ printType(Out, I.getArgType(), "", /*ignoreName*/false,
+ /*namedContext*/false);
+ Out << ")";
+}
+
+void CWriter::visitVAArgInst(VAArgInst &I) {
+ Out << "0;\n";
+ Out << "{ va_list Tmp; va_copy(Tmp, *(va_list*)&";
writeOperand(I.getOperand(0));
- Out << ", ";
+ Out << ");\n " << Mang->getValueName(&I) << " = va_arg(Tmp, ";
printType(Out, I.getType(), "", /*ignoreName*/false, /*namedContext*/false);
- Out << ")";
+ Out << ");\n va_end(Tmp); }";
}
diff --git a/lib/Target/CBackend/Writer.cpp b/lib/Target/CBackend/Writer.cpp
index a34f3f7712..00ad0e3bb1 100644
--- a/lib/Target/CBackend/Writer.cpp
+++ b/lib/Target/CBackend/Writer.cpp
@@ -90,7 +90,7 @@ namespace {
// emit it inline where it would go.
if (I.getType() == Type::VoidTy || !I.hasOneUse() ||
isa<TerminatorInst>(I) || isa<CallInst>(I) || isa<PHINode>(I) ||
- isa<LoadInst>(I) || isa<VarArgInst>(I))
+ isa<LoadInst>(I) || isa<VAArgInst>(I) || isa<VANextInst>(I))
// Don't inline a load across a store or other bad things!
return false;
@@ -135,7 +135,8 @@ namespace {
void visitLoadInst (LoadInst &I);
void visitStoreInst (StoreInst &I);
void visitGetElementPtrInst(GetElementPtrInst &I);
- void visitVarArgInst(VarArgInst &I);
+ void visitVANextInst(VANextInst &I);
+ void visitVAArgInst (VAArgInst &I);
void visitInstruction(Instruction &I) {
std::cerr << "C Writer does not know about " << I;
@@ -1181,26 +1182,25 @@ void CWriter::visitCallInst(CallInst &I) {
switch (ID) {
default: assert(0 && "Unknown LLVM intrinsic!");
case LLVMIntrinsic::va_start:
- Out << "va_start(*(va_list*)";
- writeOperand(I.getOperand(1));
- Out << ", ";
+ Out << "0; ";
+
+ Out << "va_start(*(va_list*)&" << Mang->getValueName(&I) << ", ";
// Output the last argument to the enclosing function...
writeOperand(&I.getParent()->getParent()->aback());
Out << ")";
return;
case LLVMIntrinsic::va_end:
- Out << "va_end(*(va_list*)";
+ Out << "va_end(*(va_list*)&";
writeOperand(I.getOperand(1));
Out << ")";
return;
case LLVMIntrinsic::va_copy:
- Out << "va_copy(*(va_list*)";
+ Out << "0;";
+ Out << "va_copy(*(va_list*)&" << Mang->getValueName(&I) << ", ";
+ Out << "*(va_list*)&";
writeOperand(I.getOperand(1));
- Out << ", (va_list)";
- writeOperand(I.getOperand(2));
Out << ")";
return;
-
case LLVMIntrinsic::setjmp:
case LLVMIntrinsic::sigsetjmp:
// This intrinsic should never exist in the program, but until we get
@@ -1346,12 +1346,21 @@ void CWriter::visitGetElementPtrInst(GetElementPtrInst &I) {
printIndexingExpression(I.getPointerOperand(), I.idx_begin(), I.idx_end());
}
-void CWriter::visitVarArgInst(VarArgInst &I) {
- Out << "va_arg((va_list)*";
+void CWriter::visitVANextInst(VANextInst &I) {
+ Out << Mang->getValueName(I.getOperand(0));
+ Out << "; va_arg(*(va_list*)&" << Mang->getValueName(&I) << ", ";
+ printType(Out, I.getArgType(), "", /*ignoreName*/false,
+ /*namedContext*/false);
+ Out << ")";
+}
+
+void CWriter::visitVAArgInst(VAArgInst &I) {
+ Out << "0;\n";
+ Out << "{ va_list Tmp; va_copy(Tmp, *(va_list*)&";
writeOperand(I.getOperand(0));
- Out << ", ";
+ Out << ");\n " << Mang->getValueName(&I) << " = va_arg(Tmp, ";
printType(Out, I.getType(), "", /*ignoreName*/false, /*namedContext*/false);
- Out << ")";
+ Out << ");\n va_end(Tmp); }";
}