forked from OSchip/llvm-project
Initial support for recognizing LLVM exception handling intrinsics
llvm-svn: 8102
This commit is contained in:
parent
9c5bfd0f80
commit
ade9410c99
|
@ -17,10 +17,17 @@ namespace LLVMIntrinsic {
|
||||||
enum ID {
|
enum ID {
|
||||||
not_intrinsic = 0, // Must be zero
|
not_intrinsic = 0, // Must be zero
|
||||||
|
|
||||||
|
// Varargs handling intrinsics...
|
||||||
va_start, // Used to represent a va_start call in C
|
va_start, // Used to represent a va_start call in C
|
||||||
va_end, // Used to represent a va_end call in C
|
va_end, // Used to represent a va_end call in C
|
||||||
va_copy, // Used to represent a va_copy call in C
|
va_copy, // Used to represent a va_copy call in C
|
||||||
|
|
||||||
|
// Exception handling intrinsics...
|
||||||
|
exc_throw, // Throw an exception
|
||||||
|
exc_rethrow, // Rethrow a caught exception
|
||||||
|
exc_getcurrent, // Get the current pending exception
|
||||||
|
|
||||||
|
// Setjmp/Longjmp intrinsics...
|
||||||
setjmp, // Used to represent a setjmp call in C
|
setjmp, // Used to represent a setjmp call in C
|
||||||
longjmp, // Used to represent a longjmp call in C
|
longjmp, // Used to represent a longjmp call in C
|
||||||
sigsetjmp, // Used to represent a sigsetjmp call in C
|
sigsetjmp, // Used to represent a sigsetjmp call in C
|
||||||
|
|
|
@ -189,10 +189,16 @@ unsigned Function::getIntrinsicID() const {
|
||||||
|
|
||||||
switch (getName()[5]) {
|
switch (getName()[5]) {
|
||||||
case 'a':
|
case 'a':
|
||||||
for (unsigned i = 0; i < num_alpha_intrinsics; ++i) {
|
if (getName().size() > 11 &&
|
||||||
|
std::string(getName().begin()+4, getName().begin()+11) == ".alpha.")
|
||||||
|
for (unsigned i = 0; i < num_alpha_intrinsics; ++i)
|
||||||
if (getName() == alpha_intrinsics[i].name)
|
if (getName() == alpha_intrinsics[i].name)
|
||||||
return alpha_intrinsics[i].id;
|
return alpha_intrinsics[i].id;
|
||||||
}
|
break;
|
||||||
|
case 'e':
|
||||||
|
if (getName() == "llvm.exc.getcurrent")return LLVMIntrinsic::exc_getcurrent;
|
||||||
|
if (getName() == "llvm.exc.rethrow") return LLVMIntrinsic::exc_getcurrent;
|
||||||
|
if (getName() == "llvm.exc.throw") return LLVMIntrinsic::exc_getcurrent;
|
||||||
break;
|
break;
|
||||||
case 'l':
|
case 'l':
|
||||||
if (getName() == "llvm.longjmp") return LLVMIntrinsic::longjmp;
|
if (getName() == "llvm.longjmp") return LLVMIntrinsic::longjmp;
|
||||||
|
|
|
@ -510,6 +510,8 @@ void Verifier::visitIntrinsicFunctionCall(LLVMIntrinsic::ID ID, CallInst &CI) {
|
||||||
Assert1(IF->isExternal(), "Intrinsic functions should never be defined!", IF);
|
Assert1(IF->isExternal(), "Intrinsic functions should never be defined!", IF);
|
||||||
unsigned NumArgs = 0;
|
unsigned NumArgs = 0;
|
||||||
|
|
||||||
|
// FIXME: this should check the return type of each intrinsic as well, also
|
||||||
|
// arguments!
|
||||||
switch (ID) {
|
switch (ID) {
|
||||||
case LLVMIntrinsic::va_start:
|
case LLVMIntrinsic::va_start:
|
||||||
Assert1(CI.getParent()->getParent()->getFunctionType()->isVarArg(),
|
Assert1(CI.getParent()->getParent()->getFunctionType()->isVarArg(),
|
||||||
|
@ -519,6 +521,11 @@ void Verifier::visitIntrinsicFunctionCall(LLVMIntrinsic::ID ID, CallInst &CI) {
|
||||||
break;
|
break;
|
||||||
case LLVMIntrinsic::va_end: NumArgs = 1; break;
|
case LLVMIntrinsic::va_end: NumArgs = 1; break;
|
||||||
case LLVMIntrinsic::va_copy: NumArgs = 2; break;
|
case LLVMIntrinsic::va_copy: NumArgs = 2; break;
|
||||||
|
|
||||||
|
case LLVMIntrinsic::exc_throw: NumArgs = 1; break;
|
||||||
|
case LLVMIntrinsic::exc_rethrow: NumArgs = 0; break;
|
||||||
|
case LLVMIntrinsic::exc_getcurrent: NumArgs = 0; break;
|
||||||
|
|
||||||
case LLVMIntrinsic::setjmp: NumArgs = 1; break;
|
case LLVMIntrinsic::setjmp: NumArgs = 1; break;
|
||||||
case LLVMIntrinsic::longjmp: NumArgs = 2; break;
|
case LLVMIntrinsic::longjmp: NumArgs = 2; break;
|
||||||
case LLVMIntrinsic::sigsetjmp: NumArgs = 2; break;
|
case LLVMIntrinsic::sigsetjmp: NumArgs = 2; break;
|
||||||
|
|
Loading…
Reference in New Issue