diff --git a/include/avian/codegen/architecture.h b/include/avian/codegen/architecture.h index b1cd7e8013..3533f5ed26 100644 --- a/include/avian/codegen/architecture.h +++ b/include/avian/codegen/architecture.h @@ -32,14 +32,28 @@ class RegisterFile; class OperandMask { public: uint8_t typeMask; - uint64_t registerMask; + uint64_t lowRegisterMask; + uint64_t highRegisterMask; - OperandMask(uint8_t typeMask, uint64_t registerMask) - : typeMask(typeMask), registerMask(registerMask) + OperandMask(uint8_t typeMask, + uint64_t lowRegisterMask, + uint64_t highRegisterMask) + : typeMask(typeMask), + lowRegisterMask(lowRegisterMask), + highRegisterMask(highRegisterMask) { } - OperandMask() : typeMask(~0), registerMask(~static_cast(0)) + // TEMPORARY! + OperandMask(uint8_t typeMask, + uint64_t registerMask) + : typeMask(typeMask), + lowRegisterMask(registerMask), + highRegisterMask(registerMask >> 32) + { + } + + OperandMask() : typeMask(~0), lowRegisterMask(~static_cast(0)), highRegisterMask(~static_cast(0)) { } }; diff --git a/src/codegen/compiler.cpp b/src/codegen/compiler.cpp index fbb64bf923..eabe367586 100644 --- a/src/codegen/compiler.cpp +++ b/src/codegen/compiler.cpp @@ -874,14 +874,14 @@ void maybeMove(Context* c, c->arch->planSource(op, dstSize, src, dstSize, &thunk); if (isGeneralValue(srcValue)) { - src.registerMask &= c->regFile->generalRegisters.mask; + src.lowRegisterMask &= c->regFile->generalRegisters.mask; } assertT(c, thunk == 0); assertT(c, dstMask.typeMask & src.typeMask & (1 << lir::RegisterOperand)); Site* tmpTarget - = freeRegisterSite(c, dstMask.registerMask & src.registerMask); + = freeRegisterSite(c, dstMask.registerMask & src.lowRegisterMask); srcValue->source->freeze(c, srcValue); diff --git a/src/codegen/compiler/event.cpp b/src/codegen/compiler/event.cpp index 7bb0257f3f..9668897547 100644 --- a/src/codegen/compiler/event.cpp +++ b/src/codegen/compiler/event.cpp @@ -445,7 +445,7 @@ class CallEvent : public Event { this->addRead( c, address, - SiteMask(op.typeMask, registerMask & op.registerMask, AnyFrameIndex)); + SiteMask(op.typeMask, registerMask & op.lowRegisterMask, AnyFrameIndex)); } Stack* stack = stackBefore; diff --git a/src/codegen/compiler/site.h b/src/codegen/compiler/site.h index 3f93d1f5dd..648c0942b8 100644 --- a/src/codegen/compiler/site.h +++ b/src/codegen/compiler/site.h @@ -48,12 +48,12 @@ class SiteMask { static SiteMask lowPart(const OperandMask& mask) { - return SiteMask(mask.typeMask, mask.registerMask, AnyFrameIndex); + return SiteMask(mask.typeMask, mask.lowRegisterMask, AnyFrameIndex); } static SiteMask highPart(const OperandMask& mask) { - return SiteMask(mask.typeMask, mask.registerMask >> 32, AnyFrameIndex); + return SiteMask(mask.typeMask, mask.lowRegisterMask >> 32, AnyFrameIndex); } uint8_t typeMask; diff --git a/src/codegen/target/arm/assembler.cpp b/src/codegen/target/arm/assembler.cpp index 7de408deba..c080bdad90 100644 --- a/src/codegen/target/arm/assembler.cpp +++ b/src/codegen/target/arm/assembler.cpp @@ -402,7 +402,7 @@ class MyArchitecture : public Architecture { bool* thunk) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::ConstantOperand); - aMask.registerMask = ~static_cast(0); + aMask.lowRegisterMask = ~static_cast(0); *thunk = false; } @@ -414,12 +414,12 @@ class MyArchitecture : public Architecture { { *thunk = false; aMask.typeMask = ~0; - aMask.registerMask = GPR_MASK64; + aMask.lowRegisterMask = GPR_MASK64; switch (op) { case lir::Negate: aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = GPR_MASK64; + aMask.lowRegisterMask = GPR_MASK64; break; case lir::Absolute: @@ -432,7 +432,7 @@ class MyArchitecture : public Architecture { case lir::Float2Float: if (vfpSupported()) { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = FPR_MASK64; + aMask.lowRegisterMask = FPR_MASK64; } else { *thunk = true; } @@ -445,7 +445,7 @@ class MyArchitecture : public Architecture { // cases properly. if (false && vfpSupported() && bSize == 4) { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = FPR_MASK64; + aMask.lowRegisterMask = FPR_MASK64; } else { *thunk = true; } @@ -454,7 +454,7 @@ class MyArchitecture : public Architecture { case lir::Int2Float: if (vfpSupported() && aSize == 4) { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = GPR_MASK64; + aMask.lowRegisterMask = GPR_MASK64; } else { *thunk = true; } @@ -472,12 +472,12 @@ class MyArchitecture : public Architecture { OperandMask& bMask) { bMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); - bMask.registerMask = GPR_MASK64; + bMask.lowRegisterMask = GPR_MASK64; switch (op) { case lir::Negate: bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = GPR_MASK64; + bMask.lowRegisterMask = GPR_MASK64; break; case lir::FloatAbsolute: @@ -486,12 +486,12 @@ class MyArchitecture : public Architecture { case lir::Float2Float: case lir::Int2Float: bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = FPR_MASK64; + bMask.lowRegisterMask = FPR_MASK64; break; case lir::Float2Int: bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = GPR_MASK64; + bMask.lowRegisterMask = GPR_MASK64; break; case lir::Move: @@ -511,21 +511,21 @@ class MyArchitecture : public Architecture { const OperandMask& dstMask) { srcMask.typeMask = ~0; - srcMask.registerMask = ~static_cast(0); + srcMask.lowRegisterMask = ~static_cast(0); tmpMask.typeMask = 0; - tmpMask.registerMask = 0; + tmpMask.lowRegisterMask = 0; if (dstMask.typeMask & (1 << lir::MemoryOperand)) { // can't move directly from memory or constant to memory srcMask.typeMask = 1 << lir::RegisterOperand; tmpMask.typeMask = 1 << lir::RegisterOperand; - tmpMask.registerMask = GPR_MASK64; + tmpMask.lowRegisterMask = GPR_MASK64; } else if (vfpSupported() && dstMask.typeMask & 1 << lir::RegisterOperand - && dstMask.registerMask & FPR_MASK) { + && dstMask.lowRegisterMask & FPR_MASK) { srcMask.typeMask = tmpMask.typeMask = 1 << lir::RegisterOperand | 1 << lir::MemoryOperand; - tmpMask.registerMask = ~static_cast(0); + tmpMask.lowRegisterMask = ~static_cast(0); } } @@ -538,10 +538,10 @@ class MyArchitecture : public Architecture { bool* thunk) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::ConstantOperand); - aMask.registerMask = GPR_MASK64; + aMask.lowRegisterMask = GPR_MASK64; bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = GPR_MASK64; + bMask.lowRegisterMask = GPR_MASK64; *thunk = false; @@ -573,7 +573,7 @@ class MyArchitecture : public Architecture { case lir::FloatDivide: if (vfpSupported()) { aMask.typeMask = bMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = bMask.registerMask = FPR_MASK64; + aMask.lowRegisterMask = bMask.lowRegisterMask = FPR_MASK64; } else { *thunk = true; } @@ -591,7 +591,7 @@ class MyArchitecture : public Architecture { case lir::JumpIfFloatGreaterOrEqualOrUnordered: if (vfpSupported()) { aMask.typeMask = bMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = bMask.registerMask = FPR_MASK64; + aMask.lowRegisterMask = bMask.lowRegisterMask = FPR_MASK64; } else { *thunk = true; } @@ -612,10 +612,10 @@ class MyArchitecture : public Architecture { { if (isBranch(op)) { cMask.typeMask = (1 << lir::ConstantOperand); - cMask.registerMask = 0; + cMask.lowRegisterMask = 0; } else { cMask.typeMask = (1 << lir::RegisterOperand); - cMask.registerMask = bMask.registerMask; + cMask.lowRegisterMask = bMask.lowRegisterMask; } } diff --git a/src/codegen/target/x86/assembler.cpp b/src/codegen/target/x86/assembler.cpp index e9ada91b2e..1b88e15bbe 100644 --- a/src/codegen/target/x86/assembler.cpp +++ b/src/codegen/target/x86/assembler.cpp @@ -512,7 +512,7 @@ class MyArchitecture : public Architecture { unsigned bSize, bool* thunk) { - aMask.registerMask = GeneralRegisterMask + aMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); *thunk = false; @@ -520,14 +520,14 @@ class MyArchitecture : public Architecture { switch (op) { case lir::Negate: aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = (static_cast(1) << (rdx + 32)) + aMask.lowRegisterMask = (static_cast(1) << (rdx + 32)) | (static_cast(1) << rax); break; case lir::Absolute: if (aSize <= TargetBytesPerWord) { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = (static_cast(1) << rax); + aMask.lowRegisterMask = (static_cast(1) << rax); } else { *thunk = true; } @@ -536,7 +536,7 @@ class MyArchitecture : public Architecture { case lir::FloatAbsolute: if (useSSE(&c)) { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = (static_cast(FloatRegisterMask) << 32) + aMask.lowRegisterMask = (static_cast(FloatRegisterMask) << 32) | FloatRegisterMask; } else { *thunk = true; @@ -547,7 +547,7 @@ class MyArchitecture : public Architecture { // floatNegateRR does not support doubles if (useSSE(&c) and aSize == 4 and bSize == 4) { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = FloatRegisterMask; + aMask.lowRegisterMask = FloatRegisterMask; } else { *thunk = true; } @@ -557,7 +557,7 @@ class MyArchitecture : public Architecture { if (useSSE(&c)) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); - aMask.registerMask = (static_cast(FloatRegisterMask) << 32) + aMask.lowRegisterMask = (static_cast(FloatRegisterMask) << 32) | FloatRegisterMask; } else { *thunk = true; @@ -568,7 +568,7 @@ class MyArchitecture : public Architecture { if (useSSE(&c)) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); - aMask.registerMask = (static_cast(FloatRegisterMask) << 32) + aMask.lowRegisterMask = (static_cast(FloatRegisterMask) << 32) | FloatRegisterMask; } else { *thunk = true; @@ -583,7 +583,7 @@ class MyArchitecture : public Architecture { if (false and useSSE(&c) and bSize <= TargetBytesPerWord) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); - aMask.registerMask = (static_cast(FloatRegisterMask) << 32) + aMask.lowRegisterMask = (static_cast(FloatRegisterMask) << 32) | FloatRegisterMask; } else { *thunk = true; @@ -594,7 +594,7 @@ class MyArchitecture : public Architecture { if (useSSE(&c) and aSize <= TargetBytesPerWord) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); - aMask.registerMask + aMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); } else { @@ -604,7 +604,7 @@ class MyArchitecture : public Architecture { case lir::Move: aMask.typeMask = ~0; - aMask.registerMask = ~static_cast(0); + aMask.lowRegisterMask = ~static_cast(0); if (TargetBytesPerWord == 4) { if (aSize == 4 and bSize == 8) { @@ -612,13 +612,13 @@ class MyArchitecture : public Architecture { | (1 << lir::MemoryOperand); const uint32_t mask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx)); - aMask.registerMask = (static_cast(mask) << 32) | mask; + aMask.lowRegisterMask = (static_cast(mask) << 32) | mask; } else if (aSize == 1 or bSize == 1) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); const uint32_t mask = (1 << rax) | (1 << rcx) | (1 << rdx) | (1 << rbx); - aMask.registerMask = (static_cast(mask) << 32) | mask; + aMask.lowRegisterMask = (static_cast(mask) << 32) | mask; } } break; @@ -635,23 +635,23 @@ class MyArchitecture : public Architecture { OperandMask& bMask) { bMask.typeMask = ~0; - bMask.registerMask = GeneralRegisterMask + bMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); switch (op) { case lir::Absolute: bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = (static_cast(1) << rax); + bMask.lowRegisterMask = (static_cast(1) << rax); break; case lir::FloatAbsolute: bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = aMask.registerMask; + bMask.lowRegisterMask = aMask.lowRegisterMask; break; case lir::Negate: bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = aMask.registerMask; + bMask.lowRegisterMask = aMask.lowRegisterMask; break; case lir::FloatNegate: @@ -659,7 +659,7 @@ class MyArchitecture : public Architecture { case lir::Float2Float: case lir::Int2Float: bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = (static_cast(FloatRegisterMask) << 32) + bMask.lowRegisterMask = (static_cast(FloatRegisterMask) << 32) | FloatRegisterMask; break; @@ -671,16 +671,16 @@ class MyArchitecture : public Architecture { if (aMask.typeMask & ((1 << lir::MemoryOperand) | 1 << lir::AddressOperand)) { bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = GeneralRegisterMask + bMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32) | FloatRegisterMask; } else if (aMask.typeMask & (1 << lir::RegisterOperand)) { bMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); - if (aMask.registerMask & FloatRegisterMask) { - bMask.registerMask = FloatRegisterMask; + if (aMask.lowRegisterMask & FloatRegisterMask) { + bMask.lowRegisterMask = FloatRegisterMask; } else { - bMask.registerMask + bMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); } @@ -691,12 +691,12 @@ class MyArchitecture : public Architecture { if (TargetBytesPerWord == 4) { if (aSize == 4 and bSize == 8) { - bMask.registerMask = (static_cast(1) << (rdx + 32)) + bMask.lowRegisterMask = (static_cast(1) << (rdx + 32)) | (static_cast(1) << rax); } else if (aSize == 1 or bSize == 1) { const uint32_t mask = (1 << rax) | (1 << rcx) | (1 << rdx) | (1 << rbx); - bMask.registerMask = (static_cast(mask) << 32) | mask; + bMask.lowRegisterMask = (static_cast(mask) << 32) | mask; } } break; @@ -712,36 +712,36 @@ class MyArchitecture : public Architecture { const OperandMask& dstMask) { srcMask.typeMask = ~0; - srcMask.registerMask = ~static_cast(0); + srcMask.lowRegisterMask = ~static_cast(0); tmpMask.typeMask = 0; - tmpMask.registerMask = 0; + tmpMask.lowRegisterMask = 0; if (dstMask.typeMask & (1 << lir::MemoryOperand)) { // can't move directly from memory to memory srcMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::ConstantOperand); tmpMask.typeMask = 1 << lir::RegisterOperand; - tmpMask.registerMask + tmpMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); } else if (dstMask.typeMask & (1 << lir::RegisterOperand)) { if (size > TargetBytesPerWord) { // can't move directly from FPR to GPR or vice-versa for // values larger than the GPR size - if (dstMask.registerMask & FloatRegisterMask) { - srcMask.registerMask + if (dstMask.lowRegisterMask & FloatRegisterMask) { + srcMask.lowRegisterMask = FloatRegisterMask | (static_cast(FloatRegisterMask) << 32); tmpMask.typeMask = 1 << lir::MemoryOperand; - } else if (dstMask.registerMask & GeneralRegisterMask) { - srcMask.registerMask + } else if (dstMask.lowRegisterMask & GeneralRegisterMask) { + srcMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); tmpMask.typeMask = 1 << lir::MemoryOperand; } } - if (dstMask.registerMask & FloatRegisterMask) { + if (dstMask.lowRegisterMask & FloatRegisterMask) { // can't move directly from constant to FPR srcMask.typeMask &= ~(1 << lir::ConstantOperand); if (size > TargetBytesPerWord) { @@ -749,7 +749,7 @@ class MyArchitecture : public Architecture { } else { tmpMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::MemoryOperand); - tmpMask.registerMask + tmpMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); } @@ -766,11 +766,11 @@ class MyArchitecture : public Architecture { bool* thunk) { aMask.typeMask = (1 << lir::RegisterOperand) | (1 << lir::ConstantOperand); - aMask.registerMask = GeneralRegisterMask + aMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); bMask.typeMask = (1 << lir::RegisterOperand); - bMask.registerMask = GeneralRegisterMask + bMask.lowRegisterMask = GeneralRegisterMask | (static_cast(GeneralRegisterMask) << 32); *thunk = false; @@ -787,8 +787,8 @@ class MyArchitecture : public Architecture { const uint64_t mask = (static_cast(FloatRegisterMask) << 32) | FloatRegisterMask; - aMask.registerMask = mask; - bMask.registerMask = mask; + aMask.lowRegisterMask = mask; + bMask.lowRegisterMask = mask; } else { *thunk = true; } @@ -801,11 +801,11 @@ class MyArchitecture : public Architecture { case lir::Multiply: if (TargetBytesPerWord == 4 and aSize == 8) { const uint32_t mask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx)); - aMask.registerMask = (static_cast(mask) << 32) | mask; - bMask.registerMask = (static_cast(1) << (rdx + 32)) | mask; + aMask.lowRegisterMask = (static_cast(mask) << 32) | mask; + bMask.lowRegisterMask = (static_cast(1) << (rdx + 32)) | mask; } else { - aMask.registerMask = GeneralRegisterMask; - bMask.registerMask = GeneralRegisterMask; + aMask.lowRegisterMask = GeneralRegisterMask; + bMask.lowRegisterMask = GeneralRegisterMask; } break; @@ -814,8 +814,8 @@ class MyArchitecture : public Architecture { *thunk = true; } else { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx)); - bMask.registerMask = 1 << rax; + aMask.lowRegisterMask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx)); + bMask.lowRegisterMask = 1 << rax; } break; @@ -824,8 +824,8 @@ class MyArchitecture : public Architecture { *thunk = true; } else { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx)); - bMask.registerMask = 1 << rax; + aMask.lowRegisterMask = GeneralRegisterMask & ~((1 << rax) | (1 << rdx)); + bMask.lowRegisterMask = 1 << rax; } break; @@ -834,13 +834,13 @@ class MyArchitecture : public Architecture { case lir::UnsignedShiftRight: { if (TargetBytesPerWord == 4 and bSize == 8) { const uint32_t mask = GeneralRegisterMask & ~(1 << rcx); - aMask.registerMask = (static_cast(mask) << 32) | mask; - bMask.registerMask = (static_cast(mask) << 32) | mask; + aMask.lowRegisterMask = (static_cast(mask) << 32) | mask; + bMask.lowRegisterMask = (static_cast(mask) << 32) | mask; } else { - aMask.registerMask = (static_cast(GeneralRegisterMask) << 32) + aMask.lowRegisterMask = (static_cast(GeneralRegisterMask) << 32) | (static_cast(1) << rcx); const uint32_t mask = GeneralRegisterMask & ~(1 << rcx); - bMask.registerMask = (static_cast(mask) << 32) | mask; + bMask.lowRegisterMask = (static_cast(mask) << 32) | mask; } } break; @@ -856,10 +856,10 @@ class MyArchitecture : public Architecture { case lir::JumpIfFloatGreaterOrEqualOrUnordered: if (useSSE(&c)) { aMask.typeMask = (1 << lir::RegisterOperand); - aMask.registerMask = (static_cast(FloatRegisterMask) << 32) + aMask.lowRegisterMask = (static_cast(FloatRegisterMask) << 32) | FloatRegisterMask; bMask.typeMask = aMask.typeMask; - bMask.registerMask = aMask.registerMask; + bMask.lowRegisterMask = aMask.lowRegisterMask; } else { *thunk = true; } @@ -880,10 +880,10 @@ class MyArchitecture : public Architecture { { if (isBranch(op)) { cMask.typeMask = (1 << lir::ConstantOperand); - cMask.registerMask = 0; + cMask.lowRegisterMask = 0; } else { cMask.typeMask = (1 << lir::RegisterOperand); - cMask.registerMask = bMask.registerMask; + cMask.lowRegisterMask = bMask.lowRegisterMask; } } diff --git a/unittest/codegen/assembler-test.cpp b/unittest/codegen/assembler-test.cpp index f463b0c5b4..bffbe6daf6 100644 --- a/unittest/codegen/assembler-test.cpp +++ b/unittest/codegen/assembler-test.cpp @@ -79,6 +79,6 @@ TEST(ArchitecturePlan) (lir::UnaryOperation)op, vm::TargetBytesPerWord, mask, &thunk); assertFalse(thunk); assertNotEqual(static_cast(0), mask.typeMask); - assertNotEqual(static_cast(0), mask.registerMask); + assertNotEqual(static_cast(0), mask.lowRegisterMask); } }