From: Brian Gaeke Date: Tue, 13 Apr 2004 18:27:46 +0000 (+0000) Subject: I started working on casts, but I don't have anything compilable yet. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=3d11e8a6d383ad625e0878e1fe21891c3b448ee0;p=oota-llvm.git I started working on casts, but I don't have anything compilable yet. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12903 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/Sparc/InstSelectSimple.cpp b/lib/Target/Sparc/InstSelectSimple.cpp index f8b8a887af0..d75d4d3d4e3 100644 --- a/lib/Target/Sparc/InstSelectSimple.cpp +++ b/lib/Target/Sparc/InstSelectSimple.cpp @@ -62,6 +62,7 @@ namespace { void visitSetCondInst(Instruction &I); void visitCallInst(CallInst &I); void visitReturnInst(ReturnInst &I); + void visitCastInst(CastInst &I); void visitLoadInst(LoadInst &I); void visitStoreInst(StoreInst &I); @@ -282,6 +283,16 @@ bool V8ISel::runOnFunction(Function &Fn) { return true; } +void V8ISel::visitCastInst(CastInst &I) { + unsigned SrcReg = getReg (I.getOperand (0)); + unsigned DestReg = getReg (I.getOperand (0)); + const Type *oldTy = I.getOperand (0)->getType (); + const Type *newTy = I.getType (); + + std::cerr << "Cast instruction not supported: " << I; + abort (); +} + void V8ISel::visitLoadInst(LoadInst &I) { unsigned DestReg = getReg (I); unsigned PtrReg = getReg (I.getOperand (0)); diff --git a/lib/Target/Sparc/SparcV8ISelSimple.cpp b/lib/Target/Sparc/SparcV8ISelSimple.cpp index f8b8a887af0..d75d4d3d4e3 100644 --- a/lib/Target/Sparc/SparcV8ISelSimple.cpp +++ b/lib/Target/Sparc/SparcV8ISelSimple.cpp @@ -62,6 +62,7 @@ namespace { void visitSetCondInst(Instruction &I); void visitCallInst(CallInst &I); void visitReturnInst(ReturnInst &I); + void visitCastInst(CastInst &I); void visitLoadInst(LoadInst &I); void visitStoreInst(StoreInst &I); @@ -282,6 +283,16 @@ bool V8ISel::runOnFunction(Function &Fn) { return true; } +void V8ISel::visitCastInst(CastInst &I) { + unsigned SrcReg = getReg (I.getOperand (0)); + unsigned DestReg = getReg (I.getOperand (0)); + const Type *oldTy = I.getOperand (0)->getType (); + const Type *newTy = I.getType (); + + std::cerr << "Cast instruction not supported: " << I; + abort (); +} + void V8ISel::visitLoadInst(LoadInst &I) { unsigned DestReg = getReg (I); unsigned PtrReg = getReg (I.getOperand (0)); diff --git a/lib/Target/SparcV8/InstSelectSimple.cpp b/lib/Target/SparcV8/InstSelectSimple.cpp index f8b8a887af0..d75d4d3d4e3 100644 --- a/lib/Target/SparcV8/InstSelectSimple.cpp +++ b/lib/Target/SparcV8/InstSelectSimple.cpp @@ -62,6 +62,7 @@ namespace { void visitSetCondInst(Instruction &I); void visitCallInst(CallInst &I); void visitReturnInst(ReturnInst &I); + void visitCastInst(CastInst &I); void visitLoadInst(LoadInst &I); void visitStoreInst(StoreInst &I); @@ -282,6 +283,16 @@ bool V8ISel::runOnFunction(Function &Fn) { return true; } +void V8ISel::visitCastInst(CastInst &I) { + unsigned SrcReg = getReg (I.getOperand (0)); + unsigned DestReg = getReg (I.getOperand (0)); + const Type *oldTy = I.getOperand (0)->getType (); + const Type *newTy = I.getType (); + + std::cerr << "Cast instruction not supported: " << I; + abort (); +} + void V8ISel::visitLoadInst(LoadInst &I) { unsigned DestReg = getReg (I); unsigned PtrReg = getReg (I.getOperand (0)); diff --git a/lib/Target/SparcV8/SparcV8ISelSimple.cpp b/lib/Target/SparcV8/SparcV8ISelSimple.cpp index f8b8a887af0..d75d4d3d4e3 100644 --- a/lib/Target/SparcV8/SparcV8ISelSimple.cpp +++ b/lib/Target/SparcV8/SparcV8ISelSimple.cpp @@ -62,6 +62,7 @@ namespace { void visitSetCondInst(Instruction &I); void visitCallInst(CallInst &I); void visitReturnInst(ReturnInst &I); + void visitCastInst(CastInst &I); void visitLoadInst(LoadInst &I); void visitStoreInst(StoreInst &I); @@ -282,6 +283,16 @@ bool V8ISel::runOnFunction(Function &Fn) { return true; } +void V8ISel::visitCastInst(CastInst &I) { + unsigned SrcReg = getReg (I.getOperand (0)); + unsigned DestReg = getReg (I.getOperand (0)); + const Type *oldTy = I.getOperand (0)->getType (); + const Type *newTy = I.getType (); + + std::cerr << "Cast instruction not supported: " << I; + abort (); +} + void V8ISel::visitLoadInst(LoadInst &I) { unsigned DestReg = getReg (I); unsigned PtrReg = getReg (I.getOperand (0));