diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-01-08 22:48:57 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-01-08 22:48:57 +0000 | 
| commit | 18d2b346372804b7eb3b120c4d92a45bc088ace2 (patch) | |
| tree | 4badcd5a9820e9bf7540ceb0c5d7177e87a04b3a | |
| parent | a1c2df7ae606092535a4325d12aeed660cce2192 (diff) | |
| download | bcm5719-llvm-18d2b346372804b7eb3b120c4d92a45bc088ace2.tar.gz bcm5719-llvm-18d2b346372804b7eb3b120c4d92a45bc088ace2.zip  | |
Add support for llvm.setjmp and longjmp.  Only 3 SingleSource/UnitTests fail now.
llvm-svn: 19404
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | 9 | 
1 files changed, 8 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index ac486894dd8..f6d497988fc 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -569,6 +569,7 @@ void SelectionDAGLowering::visitStore(StoreInst &I) {  }  void SelectionDAGLowering::visitCall(CallInst &I) { +  const char *RenameFn = 0;    if (Function *F = I.getCalledFunction())      switch (F->getIntrinsicID()) {      case 0: break;  // Not an intrinsic. @@ -584,6 +585,8 @@ void SelectionDAGLowering::visitCall(CallInst &I) {        // readport, writeport, readio, writeio        assert(0 && "This intrinsic is not implemented yet!");        return; +    case Intrinsic::setjmp:  RenameFn = "setjmp"; break; +    case Intrinsic::longjmp: RenameFn = "longjmp"; break;      case Intrinsic::memcpy:  visitMemCpy(I); return;      case Intrinsic::memset:  visitMemSet(I); return;      case Intrinsic::memmove: visitMemMove(I); return; @@ -594,7 +597,11 @@ void SelectionDAGLowering::visitCall(CallInst &I) {        return;      } -  SDOperand Callee = getValue(I.getOperand(0)); +  SDOperand Callee; +  if (!RenameFn) +    Callee = getValue(I.getOperand(0)); +  else +    Callee = DAG.getExternalSymbol(RenameFn, TLI.getPointerTy());    std::vector<std::pair<SDOperand, const Type*> > Args;    for (unsigned i = 1, e = I.getNumOperands(); i != e; ++i) {  | 

