Commit 2cdb96d7 authored by bmeurer@chromium.org's avatar bmeurer@chromium.org

[ia32] Use more efficient encoding when loading integer constants.

R=titzer@chromium.org

Review URL: https://codereview.chromium.org/642053002

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@24494 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 75f665d2
...@@ -249,7 +249,7 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { ...@@ -249,7 +249,7 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) {
__ idiv(i.InputOperand(1)); __ idiv(i.InputOperand(1));
break; break;
case kIA32Udiv: case kIA32Udiv:
__ xor_(edx, edx); __ Move(edx, Immediate(0));
__ div(i.InputOperand(1)); __ div(i.InputOperand(1));
break; break;
case kIA32Not: case kIA32Not:
...@@ -552,7 +552,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr, ...@@ -552,7 +552,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr,
switch (condition) { switch (condition) {
case kUnorderedEqual: case kUnorderedEqual:
__ j(parity_odd, &check, Label::kNear); __ j(parity_odd, &check, Label::kNear);
__ mov(reg, Immediate(0)); __ Move(reg, Immediate(0));
__ jmp(&done, Label::kNear); __ jmp(&done, Label::kNear);
// Fall through. // Fall through.
case kEqual: case kEqual:
...@@ -580,7 +580,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr, ...@@ -580,7 +580,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr,
break; break;
case kUnorderedLessThan: case kUnorderedLessThan:
__ j(parity_odd, &check, Label::kNear); __ j(parity_odd, &check, Label::kNear);
__ mov(reg, Immediate(0)); __ Move(reg, Immediate(0));
__ jmp(&done, Label::kNear); __ jmp(&done, Label::kNear);
// Fall through. // Fall through.
case kUnsignedLessThan: case kUnsignedLessThan:
...@@ -596,7 +596,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr, ...@@ -596,7 +596,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr,
break; break;
case kUnorderedLessThanOrEqual: case kUnorderedLessThanOrEqual:
__ j(parity_odd, &check, Label::kNear); __ j(parity_odd, &check, Label::kNear);
__ mov(reg, Immediate(0)); __ Move(reg, Immediate(0));
__ jmp(&done, Label::kNear); __ jmp(&done, Label::kNear);
// Fall through. // Fall through.
case kUnsignedLessThanOrEqual: case kUnsignedLessThanOrEqual:
...@@ -626,7 +626,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr, ...@@ -626,7 +626,7 @@ void CodeGenerator::AssembleArchBoolean(Instruction* instr,
// Emit a branch to set a register to either 1 or 0. // Emit a branch to set a register to either 1 or 0.
Label set; Label set;
__ j(cc, &set, Label::kNear); __ j(cc, &set, Label::kNear);
__ mov(reg, Immediate(0)); __ Move(reg, Immediate(0));
__ jmp(&done, Label::kNear); __ jmp(&done, Label::kNear);
__ bind(&set); __ bind(&set);
__ mov(reg, Immediate(1)); __ mov(reg, Immediate(1));
...@@ -899,10 +899,10 @@ void CodeGenerator::AssembleMove(InstructionOperand* source, ...@@ -899,10 +899,10 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
} }
} else if (destination->IsRegister()) { } else if (destination->IsRegister()) {
Register dst = g.ToRegister(destination); Register dst = g.ToRegister(destination);
__ mov(dst, g.ToImmediate(source)); __ Move(dst, g.ToImmediate(source));
} else if (destination->IsStackSlot()) { } else if (destination->IsStackSlot()) {
Operand dst = g.ToOperand(destination); Operand dst = g.ToOperand(destination);
__ mov(dst, g.ToImmediate(source)); __ Move(dst, g.ToImmediate(source));
} else if (src_constant.type() == Constant::kFloat32) { } else if (src_constant.type() == Constant::kFloat32) {
// TODO(turbofan): Can we do better here? // TODO(turbofan): Can we do better here?
uint32_t src = bit_cast<uint32_t>(src_constant.ToFloat32()); uint32_t src = bit_cast<uint32_t>(src_constant.ToFloat32());
...@@ -912,7 +912,7 @@ void CodeGenerator::AssembleMove(InstructionOperand* source, ...@@ -912,7 +912,7 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
} else { } else {
DCHECK(destination->IsDoubleStackSlot()); DCHECK(destination->IsDoubleStackSlot());
Operand dst = g.ToOperand(destination); Operand dst = g.ToOperand(destination);
__ mov(dst, Immediate(src)); __ Move(dst, Immediate(src));
} }
} else { } else {
DCHECK_EQ(Constant::kFloat64, src_constant.type()); DCHECK_EQ(Constant::kFloat64, src_constant.type());
...@@ -926,8 +926,8 @@ void CodeGenerator::AssembleMove(InstructionOperand* source, ...@@ -926,8 +926,8 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
DCHECK(destination->IsDoubleStackSlot()); DCHECK(destination->IsDoubleStackSlot());
Operand dst0 = g.ToOperand(destination); Operand dst0 = g.ToOperand(destination);
Operand dst1 = g.HighOperand(destination); Operand dst1 = g.HighOperand(destination);
__ mov(dst0, Immediate(lower)); __ Move(dst0, Immediate(lower));
__ mov(dst1, Immediate(upper)); __ Move(dst1, Immediate(upper));
} }
} }
} else if (source->IsDoubleRegister()) { } else if (source->IsDoubleRegister()) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment