From f9145528c8a580b4d963e8eed19691e068ef6b97 Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Tue, 25 Nov 2008 19:22:21 -0700 Subject: [PATCH] do constant-to-memory movq in one instruction on amd64 when possible --- src/x86.cpp | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/src/x86.cpp b/src/x86.cpp index 09984b25de..6855febb34 100644 --- a/src/x86.cpp +++ b/src/x86.cpp @@ -958,13 +958,21 @@ moveCM(Context* c, unsigned aSize UNUSED, Assembler::Constant* a, break; case 8: { - Assembler::Constant ah(shiftMaskPromise(c, a->value, 32, 0xFFFFFFFF)); - Assembler::Constant al(shiftMaskPromise(c, a->value, 0, 0xFFFFFFFF)); + if (BytesPerWord == 8 + and a->value->resolved() + and isInt32(a->value->value())) + { + encode(c, 0xc7, 0, b, true); + c->code.append4(a->value->value()); + } else { + Assembler::Constant ah(shiftMaskPromise(c, a->value, 32, 0xFFFFFFFF)); + Assembler::Constant al(shiftMaskPromise(c, a->value, 0, 0xFFFFFFFF)); - Assembler::Memory bh(b->base, b->offset + 4, b->index, b->scale); + Assembler::Memory bh(b->base, b->offset + 4, b->index, b->scale); - moveCM(c, 4, &al, 4, b); - moveCM(c, 4, &ah, 4, &bh); + moveCM(c, 4, &al, 4, b); + moveCM(c, 4, &ah, 4, &bh); + } } break; default: abort(c);