mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
Add stub method for long shift codegen.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18100 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6f0b77221c
commit
9ffcf9fddd
@ -90,6 +90,9 @@ namespace {
|
|||||||
MachineBasicBlock::iterator IP,
|
MachineBasicBlock::iterator IP,
|
||||||
unsigned DestReg, const char *FuncName,
|
unsigned DestReg, const char *FuncName,
|
||||||
unsigned Op0Reg, unsigned Op1Reg);
|
unsigned Op0Reg, unsigned Op1Reg);
|
||||||
|
void emitShift64 (MachineBasicBlock *MBB, MachineBasicBlock::iterator IP,
|
||||||
|
Instruction &I, unsigned DestReg, unsigned Op0Reg,
|
||||||
|
unsigned Op1Reg);
|
||||||
void visitBinaryOperator(Instruction &I);
|
void visitBinaryOperator(Instruction &I);
|
||||||
void visitShiftInst (ShiftInst &SI) { visitBinaryOperator (SI); }
|
void visitShiftInst (ShiftInst &SI) { visitBinaryOperator (SI); }
|
||||||
void visitSetCondInst(SetCondInst &I);
|
void visitSetCondInst(SetCondInst &I);
|
||||||
@ -1109,6 +1112,20 @@ void V8ISel::emitOp64LibraryCall (MachineBasicBlock *MBB,
|
|||||||
BuildMI (*MBB, IP, V8::ORrr, 2, DestReg+1).addReg (V8::G0).addReg (V8::O1);
|
BuildMI (*MBB, IP, V8::ORrr, 2, DestReg+1).addReg (V8::G0).addReg (V8::O1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void V8ISel::emitShift64 (MachineBasicBlock *MBB,
|
||||||
|
MachineBasicBlock::iterator IP, Instruction &I,
|
||||||
|
unsigned DestReg, unsigned Op0Reg, unsigned Op1Reg) {
|
||||||
|
bool isSigned = I.getType()->isSigned();
|
||||||
|
|
||||||
|
switch (I.getOpcode ()) {
|
||||||
|
case Instruction::Shl:
|
||||||
|
case Instruction::Shr:
|
||||||
|
default:
|
||||||
|
std::cerr << "Sorry, 64-bit shifts are not yet supported:\n" << I;
|
||||||
|
abort ();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void V8ISel::visitBinaryOperator (Instruction &I) {
|
void V8ISel::visitBinaryOperator (Instruction &I) {
|
||||||
unsigned DestReg = getReg (I);
|
unsigned DestReg = getReg (I);
|
||||||
unsigned Op0Reg = getReg (I.getOperand (0));
|
unsigned Op0Reg = getReg (I.getOperand (0));
|
||||||
@ -1168,6 +1185,10 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
FuncName = I.getType ()->isSigned () ? "__rem64" : "__urem64";
|
FuncName = I.getType ()->isSigned () ? "__rem64" : "__urem64";
|
||||||
emitOp64LibraryCall (BB, BB->end (), DestReg, FuncName, Op0Reg, Op1Reg);
|
emitOp64LibraryCall (BB, BB->end (), DestReg, FuncName, Op0Reg, Op1Reg);
|
||||||
return;
|
return;
|
||||||
|
case Instruction::Shl:
|
||||||
|
case Instruction::Shr:
|
||||||
|
emitShift64 (BB, BB->end (), I, DestReg, Op0Reg, Op1Reg);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,6 +90,9 @@ namespace {
|
|||||||
MachineBasicBlock::iterator IP,
|
MachineBasicBlock::iterator IP,
|
||||||
unsigned DestReg, const char *FuncName,
|
unsigned DestReg, const char *FuncName,
|
||||||
unsigned Op0Reg, unsigned Op1Reg);
|
unsigned Op0Reg, unsigned Op1Reg);
|
||||||
|
void emitShift64 (MachineBasicBlock *MBB, MachineBasicBlock::iterator IP,
|
||||||
|
Instruction &I, unsigned DestReg, unsigned Op0Reg,
|
||||||
|
unsigned Op1Reg);
|
||||||
void visitBinaryOperator(Instruction &I);
|
void visitBinaryOperator(Instruction &I);
|
||||||
void visitShiftInst (ShiftInst &SI) { visitBinaryOperator (SI); }
|
void visitShiftInst (ShiftInst &SI) { visitBinaryOperator (SI); }
|
||||||
void visitSetCondInst(SetCondInst &I);
|
void visitSetCondInst(SetCondInst &I);
|
||||||
@ -1109,6 +1112,20 @@ void V8ISel::emitOp64LibraryCall (MachineBasicBlock *MBB,
|
|||||||
BuildMI (*MBB, IP, V8::ORrr, 2, DestReg+1).addReg (V8::G0).addReg (V8::O1);
|
BuildMI (*MBB, IP, V8::ORrr, 2, DestReg+1).addReg (V8::G0).addReg (V8::O1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void V8ISel::emitShift64 (MachineBasicBlock *MBB,
|
||||||
|
MachineBasicBlock::iterator IP, Instruction &I,
|
||||||
|
unsigned DestReg, unsigned Op0Reg, unsigned Op1Reg) {
|
||||||
|
bool isSigned = I.getType()->isSigned();
|
||||||
|
|
||||||
|
switch (I.getOpcode ()) {
|
||||||
|
case Instruction::Shl:
|
||||||
|
case Instruction::Shr:
|
||||||
|
default:
|
||||||
|
std::cerr << "Sorry, 64-bit shifts are not yet supported:\n" << I;
|
||||||
|
abort ();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void V8ISel::visitBinaryOperator (Instruction &I) {
|
void V8ISel::visitBinaryOperator (Instruction &I) {
|
||||||
unsigned DestReg = getReg (I);
|
unsigned DestReg = getReg (I);
|
||||||
unsigned Op0Reg = getReg (I.getOperand (0));
|
unsigned Op0Reg = getReg (I.getOperand (0));
|
||||||
@ -1168,6 +1185,10 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
FuncName = I.getType ()->isSigned () ? "__rem64" : "__urem64";
|
FuncName = I.getType ()->isSigned () ? "__rem64" : "__urem64";
|
||||||
emitOp64LibraryCall (BB, BB->end (), DestReg, FuncName, Op0Reg, Op1Reg);
|
emitOp64LibraryCall (BB, BB->end (), DestReg, FuncName, Op0Reg, Op1Reg);
|
||||||
return;
|
return;
|
||||||
|
case Instruction::Shl:
|
||||||
|
case Instruction::Shr:
|
||||||
|
emitShift64 (BB, BB->end (), I, DestReg, Op0Reg, Op1Reg);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user