Modified the code so that it generates (0) for setjmp() and abort() for

longjmp() (and does not include setjmp.h).
This is to fix some problems on Sparc while non-local jumps are still
unimplemented.

llvm-svn: 7449
This commit is contained in:
John Criswell 2003-07-31 15:11:08 +00:00
parent aab262210c
commit 6e264f078a
1 changed files with 18 additions and 0 deletions

View File

@ -570,7 +570,9 @@ void CWriter::printModule(Module *M) {
// get declaration for alloca
Out << "/* Provide Declarations */\n";
Out << "#include <stdarg.h>\n";
#ifdef HAVE_JUMP
Out << "#include <setjmp.h>\n";
#endif
generateCompilerSpecificCode(Out);
// Provide a definition for `bool' if not compiling with a C++ compiler.
@ -1123,16 +1125,32 @@ void CWriter::visitCallInst(CallInst &I) {
return;
case LLVMIntrinsic::setjmp:
#ifdef HAVE_JUMP
Out << "setjmp(*(jmp_buf*)";
writeOperand(I.getOperand(1));
Out << ")";
#else
//
// For right now, we don't really support non-local jumps. So
// make setjmp() always evaluate to zero for now.
//
Out << "(0)";
#endif
return;
case LLVMIntrinsic::longjmp:
#ifdef HAVE_JUMP
Out << "longjmp(*(jmp_buf*)";
writeOperand(I.getOperand(1));
Out << ", ";
writeOperand(I.getOperand(2));
Out << ")";
#else
//
// For right now, we don't really support non-local jumps. So
// make longjmp() abort the program.
//
Out << "abort()";
#endif
return;
}
}