For ISD::RET, if # of operands >= 2, try selection the real data dep. operand

first before the chain.
e.g.
int X;

int foo(int x)
{
  x += X + 37;
  return x;
}

If chain operand is selected first, we would generate:
	movl X, %eax
	movl 4(%esp), %ecx
	leal 37(%ecx,%eax), %eax

rather than
	movl $37, %eax
	addl 4(%esp), %eax
	addl X, %eax

which does not require %ecx. (Due to ADD32rm not matching.)


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24673 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Evan Cheng 2005-12-12 20:32:18 +00:00
parent 110f2243fc
commit cbd6ed4d6b

View File

@ -356,15 +356,22 @@ SDOperand X86DAGToDAGISel::Select(SDOperand Op) {
break; break;
case ISD::RET: { case ISD::RET: {
SDOperand Chain = Select(N->getOperand(0)); // Token chain. SDOperand Chain = N->getOperand(0); // Token chain.
switch (N->getNumOperands()) { unsigned NumOps = N->getNumOperands();
// Note: A bit of a hack / optimization... Try to delay chain selection
// as much as possible. So it's more likely it has already been selected
// for a real use.
switch (NumOps) {
default: default:
assert(0 && "Unknown return instruction!"); assert(0 && "Unknown return instruction!");
case 3: case 3:
Chain = Select(Chain);
assert(0 && "Not yet handled return instruction!"); assert(0 && "Not yet handled return instruction!");
break; break;
case 2: { case 2: {
SDOperand Val = Select(N->getOperand(1)); SDOperand Val = Select(N->getOperand(1));
Chain = Select(Chain);
switch (N->getOperand(1).getValueType()) { switch (N->getOperand(1).getValueType()) {
default: default:
assert(0 && "All other types should have been promoted!!"); assert(0 && "All other types should have been promoted!!");
@ -378,6 +385,7 @@ SDOperand X86DAGToDAGISel::Select(SDOperand Op) {
} }
} }
case 1: case 1:
Chain = Select(Chain);
break; break;
} }
if (X86Lowering.getBytesToPopOnReturn() == 0) if (X86Lowering.getBytesToPopOnReturn() == 0)