mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 23:31:37 +00:00
Add intrinsics for the llvm.sig(set|long)jmp functions
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7949 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f5a6ab9ff9
commit
8169cf810c
@ -23,6 +23,8 @@ namespace LLVMIntrinsic {
|
||||
|
||||
setjmp, // Used to represent a setjmp call in C
|
||||
longjmp, // Used to represent a longjmp call in C
|
||||
sigsetjmp, // Used to represent a sigsetjmp call in C
|
||||
siglongjmp, // Used to represent a siglongjmp call in C
|
||||
|
||||
//===------------------------------------------------------------------===//
|
||||
// This section defines intrinsic functions used to represent Alpha
|
||||
|
@ -198,7 +198,9 @@ unsigned Function::getIntrinsicID() const {
|
||||
if (getName() == "llvm.longjmp") return LLVMIntrinsic::longjmp;
|
||||
break;
|
||||
case 's':
|
||||
if (getName() == "llvm.setjmp") return LLVMIntrinsic::setjmp;
|
||||
if (getName() == "llvm.setjmp") return LLVMIntrinsic::setjmp;
|
||||
if (getName() == "llvm.sigsetjmp") return LLVMIntrinsic::sigsetjmp;
|
||||
if (getName() == "llvm.siglongjmp") return LLVMIntrinsic::siglongjmp;
|
||||
break;
|
||||
case 'v':
|
||||
if (getName() == "llvm.va_copy") return LLVMIntrinsic::va_copy;
|
||||
|
@ -517,10 +517,12 @@ void Verifier::visitIntrinsicFunctionCall(LLVMIntrinsic::ID ID, CallInst &CI) {
|
||||
" args!", &CI);
|
||||
NumArgs = 1;
|
||||
break;
|
||||
case LLVMIntrinsic::va_end: NumArgs = 1; break;
|
||||
case LLVMIntrinsic::va_copy: NumArgs = 2; break;
|
||||
case LLVMIntrinsic::setjmp: NumArgs = 1; break;
|
||||
case LLVMIntrinsic::longjmp: NumArgs = 2; break;
|
||||
case LLVMIntrinsic::va_end: NumArgs = 1; break;
|
||||
case LLVMIntrinsic::va_copy: NumArgs = 2; break;
|
||||
case LLVMIntrinsic::setjmp: NumArgs = 1; break;
|
||||
case LLVMIntrinsic::longjmp: NumArgs = 2; break;
|
||||
case LLVMIntrinsic::sigsetjmp: NumArgs = 2; break;
|
||||
case LLVMIntrinsic::siglongjmp: NumArgs = 2; break;
|
||||
|
||||
case LLVMIntrinsic::alpha_ctlz: NumArgs = 1; break;
|
||||
case LLVMIntrinsic::alpha_cttz: NumArgs = 1; break;
|
||||
|
Loading…
x
Reference in New Issue
Block a user