mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-27 14:34:58 +00:00
Avoid emitting an extra copy on each 32-bit operation
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12743 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
88ddd4a07d
commit
0d538bbec2
@ -161,6 +161,12 @@ static TypeClass getClass (const Type *T) {
|
|||||||
return cByte;
|
return cByte;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
static TypeClass getClassB(const Type *T) {
|
||||||
|
if (T == Type::BoolTy) return cByte;
|
||||||
|
return getClass(T);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// copyConstantToRegister - Output the instructions required to put the
|
/// copyConstantToRegister - Output the instructions required to put the
|
||||||
/// specified constant into the specified register.
|
/// specified constant into the specified register.
|
||||||
@ -280,9 +286,8 @@ void V8ISel::visitReturnInst(ReturnInst &I) {
|
|||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else if (I.getNumOperands () != 1) {
|
|
||||||
visitInstruction (I);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Just emit a 'retl' instruction to return.
|
// Just emit a 'retl' instruction to return.
|
||||||
BuildMI(BB, V8::RETL, 0);
|
BuildMI(BB, V8::RETL, 0);
|
||||||
return;
|
return;
|
||||||
@ -293,7 +298,9 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
unsigned Op0Reg = getReg (I.getOperand (0));
|
unsigned Op0Reg = getReg (I.getOperand (0));
|
||||||
unsigned Op1Reg = getReg (I.getOperand (1));
|
unsigned Op1Reg = getReg (I.getOperand (1));
|
||||||
|
|
||||||
unsigned ResultReg = makeAnotherReg (I.getType ());
|
unsigned ResultReg = DestReg;
|
||||||
|
if (getClassB(I.getType()) != cInt)
|
||||||
|
ResultReg = makeAnotherReg (I.getType ());
|
||||||
unsigned OpCase = ~0;
|
unsigned OpCase = ~0;
|
||||||
|
|
||||||
// FIXME: support long, ulong, fp.
|
// FIXME: support long, ulong, fp.
|
||||||
@ -368,7 +375,7 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case cInt:
|
case cInt:
|
||||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg (V8::G0).addReg (ResultReg);
|
// Nothing todo here.
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
|
@ -161,6 +161,12 @@ static TypeClass getClass (const Type *T) {
|
|||||||
return cByte;
|
return cByte;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
static TypeClass getClassB(const Type *T) {
|
||||||
|
if (T == Type::BoolTy) return cByte;
|
||||||
|
return getClass(T);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// copyConstantToRegister - Output the instructions required to put the
|
/// copyConstantToRegister - Output the instructions required to put the
|
||||||
/// specified constant into the specified register.
|
/// specified constant into the specified register.
|
||||||
@ -280,9 +286,8 @@ void V8ISel::visitReturnInst(ReturnInst &I) {
|
|||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else if (I.getNumOperands () != 1) {
|
|
||||||
visitInstruction (I);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Just emit a 'retl' instruction to return.
|
// Just emit a 'retl' instruction to return.
|
||||||
BuildMI(BB, V8::RETL, 0);
|
BuildMI(BB, V8::RETL, 0);
|
||||||
return;
|
return;
|
||||||
@ -293,7 +298,9 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
unsigned Op0Reg = getReg (I.getOperand (0));
|
unsigned Op0Reg = getReg (I.getOperand (0));
|
||||||
unsigned Op1Reg = getReg (I.getOperand (1));
|
unsigned Op1Reg = getReg (I.getOperand (1));
|
||||||
|
|
||||||
unsigned ResultReg = makeAnotherReg (I.getType ());
|
unsigned ResultReg = DestReg;
|
||||||
|
if (getClassB(I.getType()) != cInt)
|
||||||
|
ResultReg = makeAnotherReg (I.getType ());
|
||||||
unsigned OpCase = ~0;
|
unsigned OpCase = ~0;
|
||||||
|
|
||||||
// FIXME: support long, ulong, fp.
|
// FIXME: support long, ulong, fp.
|
||||||
@ -368,7 +375,7 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case cInt:
|
case cInt:
|
||||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg (V8::G0).addReg (ResultReg);
|
// Nothing todo here.
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
|
@ -161,6 +161,12 @@ static TypeClass getClass (const Type *T) {
|
|||||||
return cByte;
|
return cByte;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
static TypeClass getClassB(const Type *T) {
|
||||||
|
if (T == Type::BoolTy) return cByte;
|
||||||
|
return getClass(T);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// copyConstantToRegister - Output the instructions required to put the
|
/// copyConstantToRegister - Output the instructions required to put the
|
||||||
/// specified constant into the specified register.
|
/// specified constant into the specified register.
|
||||||
@ -280,9 +286,8 @@ void V8ISel::visitReturnInst(ReturnInst &I) {
|
|||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else if (I.getNumOperands () != 1) {
|
|
||||||
visitInstruction (I);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Just emit a 'retl' instruction to return.
|
// Just emit a 'retl' instruction to return.
|
||||||
BuildMI(BB, V8::RETL, 0);
|
BuildMI(BB, V8::RETL, 0);
|
||||||
return;
|
return;
|
||||||
@ -293,7 +298,9 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
unsigned Op0Reg = getReg (I.getOperand (0));
|
unsigned Op0Reg = getReg (I.getOperand (0));
|
||||||
unsigned Op1Reg = getReg (I.getOperand (1));
|
unsigned Op1Reg = getReg (I.getOperand (1));
|
||||||
|
|
||||||
unsigned ResultReg = makeAnotherReg (I.getType ());
|
unsigned ResultReg = DestReg;
|
||||||
|
if (getClassB(I.getType()) != cInt)
|
||||||
|
ResultReg = makeAnotherReg (I.getType ());
|
||||||
unsigned OpCase = ~0;
|
unsigned OpCase = ~0;
|
||||||
|
|
||||||
// FIXME: support long, ulong, fp.
|
// FIXME: support long, ulong, fp.
|
||||||
@ -368,7 +375,7 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case cInt:
|
case cInt:
|
||||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg (V8::G0).addReg (ResultReg);
|
// Nothing todo here.
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
|
@ -161,6 +161,12 @@ static TypeClass getClass (const Type *T) {
|
|||||||
return cByte;
|
return cByte;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
static TypeClass getClassB(const Type *T) {
|
||||||
|
if (T == Type::BoolTy) return cByte;
|
||||||
|
return getClass(T);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// copyConstantToRegister - Output the instructions required to put the
|
/// copyConstantToRegister - Output the instructions required to put the
|
||||||
/// specified constant into the specified register.
|
/// specified constant into the specified register.
|
||||||
@ -280,9 +286,8 @@ void V8ISel::visitReturnInst(ReturnInst &I) {
|
|||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else if (I.getNumOperands () != 1) {
|
|
||||||
visitInstruction (I);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Just emit a 'retl' instruction to return.
|
// Just emit a 'retl' instruction to return.
|
||||||
BuildMI(BB, V8::RETL, 0);
|
BuildMI(BB, V8::RETL, 0);
|
||||||
return;
|
return;
|
||||||
@ -293,7 +298,9 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
unsigned Op0Reg = getReg (I.getOperand (0));
|
unsigned Op0Reg = getReg (I.getOperand (0));
|
||||||
unsigned Op1Reg = getReg (I.getOperand (1));
|
unsigned Op1Reg = getReg (I.getOperand (1));
|
||||||
|
|
||||||
unsigned ResultReg = makeAnotherReg (I.getType ());
|
unsigned ResultReg = DestReg;
|
||||||
|
if (getClassB(I.getType()) != cInt)
|
||||||
|
ResultReg = makeAnotherReg (I.getType ());
|
||||||
unsigned OpCase = ~0;
|
unsigned OpCase = ~0;
|
||||||
|
|
||||||
// FIXME: support long, ulong, fp.
|
// FIXME: support long, ulong, fp.
|
||||||
@ -368,7 +375,7 @@ void V8ISel::visitBinaryOperator (Instruction &I) {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case cInt:
|
case cInt:
|
||||||
BuildMI (BB, V8::ORrr, 2, DestReg).addReg (V8::G0).addReg (ResultReg);
|
// Nothing todo here.
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
visitInstruction (I);
|
visitInstruction (I);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user