Commit f7aa8cc7 authored by ahaas's avatar ahaas Committed by Commit bot

[x64] Load int32 constants with movl instead of movq to avoid sign extension.

R=bmeurer@chromium.org

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

Cr-Commit-Position: refs/heads/master@{#35352}
parent d1ec440f
...@@ -2077,10 +2077,16 @@ void CodeGenerator::AssembleMove(InstructionOperand* source, ...@@ -2077,10 +2077,16 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
Register dst = destination->IsRegister() ? g.ToRegister(destination) Register dst = destination->IsRegister() ? g.ToRegister(destination)
: kScratchRegister; : kScratchRegister;
switch (src.type()) { switch (src.type()) {
case Constant::kInt32: case Constant::kInt32: {
// TODO(dcarney): don't need scratch in this case. // TODO(dcarney): don't need scratch in this case.
__ Set(dst, src.ToInt32()); int32_t value = src.ToInt32();
if (value == 0) {
__ xorl(dst, dst);
} else {
__ movl(dst, Immediate(value));
}
break; break;
}
case Constant::kInt64: case Constant::kInt64:
__ Set(dst, src.ToInt64()); __ Set(dst, src.ToInt64());
break; break;
......
...@@ -1774,7 +1774,6 @@ TEST(RunInt32SubP) { ...@@ -1774,7 +1774,6 @@ TEST(RunInt32SubP) {
} }
} }
TEST(RunInt32SubImm) { TEST(RunInt32SubImm) {
{ {
FOR_UINT32_INPUTS(i) { FOR_UINT32_INPUTS(i) {
...@@ -1798,6 +1797,11 @@ TEST(RunInt32SubImm) { ...@@ -1798,6 +1797,11 @@ TEST(RunInt32SubImm) {
} }
} }
TEST(RunInt32SubImm2) {
BufferedRawMachineAssemblerTester<int32_t> r;
r.Return(r.Int32Sub(r.Int32Constant(-1), r.Int32Constant(0)));
CHECK_EQ(-1, r.Call());
}
TEST(RunInt32SubAndWord32SarP) { TEST(RunInt32SubAndWord32SarP) {
{ {
......
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