diff --git a/src/compile.cpp b/src/compile.cpp index 954b0c2be6..2beecba6a0 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -5353,7 +5353,7 @@ finish(MyThread* t, Allocator* allocator, Context* context) (&byteArrayBody(t, methodSpec(t, context->method), 0))); // for debugging: - if (//false and + if (false and ::strcmp (reinterpret_cast (&byteArrayBody(t, className(t, methodClass(t, context->method)), 0)), diff --git a/src/compiler.cpp b/src/compiler.cpp index d6be0a7f4b..86b136c0d5 100644 --- a/src/compiler.cpp +++ b/src/compiler.cpp @@ -19,9 +19,9 @@ namespace local { const bool DebugAppend = true; const bool DebugCompile = true; -const bool DebugResources = false; +const bool DebugResources = true; const bool DebugFrame = false; -const bool DebugControl = false; +const bool DebugControl = true; const bool DebugReads = true; const bool DebugSites = true; const bool DebugMoves = false; @@ -1384,11 +1384,15 @@ pickTarget(Context* c, Read* read, bool intersectRead, = (c->availableGeneralRegisterCount > registerReserveCount ? 0 : Target::LowRegisterPenalty); - SiteMask mask; + Value* value = read->value; + + uint32_t registerMask = (value->type == ValueGeneral + ? c->arch->generalRegisterMask() : ~0); + + SiteMask mask(~0, registerMask, AnyFrameIndex); read->intersect(&mask); Target best; - Value* value = read->value; Value* successor = read->successor(); if (successor) { @@ -1418,7 +1422,7 @@ pickTarget(Context* c, Read* read, bool intersectRead, return best; } - { Target mine = pickRegisterTarget(c, value, ~0); + { Target mine = pickRegisterTarget(c, value, registerMask); mine.cost += registerPenalty; @@ -3268,6 +3272,7 @@ grow(Context* c, Value* v) assert(c, v->next == v); Value* next = value(c, v->type); + fprintf(stderr, "grow %p to %p\n", v, next); v->next = next; next->next = v; next->index = 1; @@ -3558,6 +3563,7 @@ getTarget(Context* c, Value* value, Value* result, const SiteMask& resultMask) } } else { SingleRead r(resultMask, 0); + r.value = result; s = pickTargetSite(c, &r, true); v = result; addSite(c, result, s); @@ -3627,6 +3633,14 @@ class CombineEvent: public Event { virtual void compile(Context* c) { assert(c, first->source->type(c) == first->next->source->type(c)); + + if (second->source->type(c) != second->next->source->type(c)) { + fprintf(stderr, "%p %p %d : %p %p %d\n", + second, second->source, second->source->type(c), + second->next, second->next->source, + second->next->source->type(c)); + } + assert(c, second->source->type(c) == second->next->source->type(c)); freezeSource(c, firstSize, first); @@ -3823,13 +3837,12 @@ push(Context* c, unsigned footprint, Value* v, bool reverse) if (footprint > 1) { assert(c, footprint == 2); - if (BytesPerWord == 4 and low->next == v) { - split(c, low); + if (BytesPerWord == 4) { + maybeSplit(c, low); + high = pushWord(c, low->next); + } else { + high = pushWord(c, 0); } - - high = pushWord(c, low->next); - } else if (v) { - high = v->next; } else { high = 0; } @@ -3838,7 +3851,7 @@ push(Context* c, unsigned footprint, Value* v, bool reverse) v = pushWord(c, v); } - if (v) { + if (high) { v->next = high; high->next = v; high->index = 1; @@ -3930,7 +3943,7 @@ storeLocal(Context* c, unsigned footprint, Value* v, unsigned index, bool copy) } if (BytesPerWord == 4) { - assert(c, v->next); + assert(c, v->next != v); high = storeLocal(c, 1, v->next, highIndex, false); } else { @@ -3939,12 +3952,16 @@ storeLocal(Context* c, unsigned footprint, Value* v, unsigned index, bool copy) index = lowIndex; } else { - high = v->next; + high = 0; } v = maybeBuddy(c, v); - v->next = high; - high->index = 1; + + if (high != 0) { + v->next = high; + high->next = v; + high->index = 1; + } Local* local = c->locals + index; local->value = v; @@ -4052,6 +4069,8 @@ class TranslateEvent: public Event { } virtual void compile(Context* c) { + assert(c, value->source->type(c) == value->next->source->type(c)); + uint8_t bTypeMask; uint64_t bRegisterMask; @@ -4215,7 +4234,7 @@ class MemoryEvent: public Event { (c, baseRegister, displacement, indexRegister, scale); Site* low; - if (result->next) { + if (result->next != result) { Site* high = site->copyHigh(c); low = site->copyLow(c); diff --git a/src/x86.cpp b/src/x86.cpp index 4d0a99bd78..5161ee592f 100644 --- a/src/x86.cpp +++ b/src/x86.cpp @@ -974,13 +974,26 @@ sseMoveRR(Context* c, unsigned aSize, Assembler::Register* a, } } +void +sseMoveCR(Context* c, unsigned aSize, Assembler::Constant* a, + unsigned bSize, Assembler::Register* b) +{ + assert(c, aSize <= BytesPerWord); + Assembler::Register tmp(c->client->acquireTemporary(GeneralRegisterMask)); + moveCR2(c, aSize, a, aSize, &tmp, 0); + sseMoveRR(c, aSize, &tmp, bSize, b); + c->client->releaseTemporary(tmp.low); +} + void moveCR(Context* c, unsigned aSize, Assembler::Constant* a, unsigned bSize, Assembler::Register* b) { - assert(c, not floatReg(b)); - - moveCR2(c, aSize, a, bSize, b, 0); + if (floatReg(b)) { + sseMoveCR(c, aSize, a, bSize, b); + } else { + moveCR2(c, aSize, a, bSize, b, 0); + } } void @@ -2995,8 +3008,7 @@ class MyArchitecture: public Assembler::Architecture { // can't move directly from memory to memory *tmpTypeMask = (1 << RegisterOperand); *tmpRegisterMask = GeneralRegisterMask - | (static_cast(GeneralRegisterMask) << 32) - | FloatRegisterMask; + | (static_cast(GeneralRegisterMask) << 32); } else if (dstTypeMask & (1 << RegisterOperand)) { if (srcTypeMask & (1 << RegisterOperand)) { if (((dstRegisterMask & FloatRegisterMask) == 0) @@ -3023,10 +3035,12 @@ class MyArchitecture: public Assembler::Architecture { unsigned, bool* thunk) { *aTypeMask = (1 << RegisterOperand) | (1 << ConstantOperand); - *aRegisterMask = ~static_cast(0); + *aRegisterMask = GeneralRegisterMask + | (static_cast(GeneralRegisterMask) << 32); *bTypeMask = (1 << RegisterOperand); - *bRegisterMask = ~static_cast(0); + *bRegisterMask = GeneralRegisterMask + | (static_cast(GeneralRegisterMask) << 32); *thunk = false;