Add support for call instructions (0-ary only for now).


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12629 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Target/Sparc/InstSelectSimple.cpp b/lib/Target/Sparc/InstSelectSimple.cpp
index 890e55d..05a1920 100644
--- a/lib/Target/Sparc/InstSelectSimple.cpp
+++ b/lib/Target/Sparc/InstSelectSimple.cpp
@@ -58,7 +58,8 @@
     }
 
 	void visitBinaryOperator(BinaryOperator &I);
-    void visitReturnInst(ReturnInst &RI);
+	void visitCallInst(CallInst &I);
+	void visitReturnInst(ReturnInst &RI);
 
     void visitInstruction(Instruction &I) {
       std::cerr << "Unhandled instruction: " << I;
@@ -226,6 +227,11 @@
   return true;
 }
 
+void V8ISel::visitCallInst(CallInst &I) {
+  assert (I.getNumOperands () == 1 && "Can't handle call args yet");
+  BuildMI (BB, V8::CALL, 1).addPCDisp (I.getOperand (0));
+  BuildMI (BB, V8::NOP, 0); // NOP in delay slot
+}
 
 void V8ISel::visitReturnInst(ReturnInst &I) {
   if (I.getNumOperands () == 1) {