mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
snapshot
This commit is contained in:
parent
6cef085d7e
commit
5dad9bddd6
@ -57,6 +57,8 @@ const unsigned UnaryOperationCount = JumpIfNotEqual + 1;
|
|||||||
|
|
||||||
enum BinaryOperation {
|
enum BinaryOperation {
|
||||||
Move,
|
Move,
|
||||||
|
MoveLow,
|
||||||
|
MoveHigh,
|
||||||
MoveZ,
|
MoveZ,
|
||||||
Compare,
|
Compare,
|
||||||
Negate,
|
Negate,
|
||||||
@ -365,9 +367,14 @@ class Assembler {
|
|||||||
|
|
||||||
virtual void planDestination
|
virtual void planDestination
|
||||||
(BinaryOperation op,
|
(BinaryOperation op,
|
||||||
unsigned aSize, const uint8_t* aTypeMask, const uint64_t* aRegisterMask,
|
unsigned aSize, uint8_t aTypeMask, uint64_t aRegisterMask,
|
||||||
unsigned bSize, uint8_t* bTypeMask, uint64_t* bRegisterMask) = 0;
|
unsigned bSize, uint8_t* bTypeMask, uint64_t* bRegisterMask) = 0;
|
||||||
|
|
||||||
|
virtual void planMove
|
||||||
|
(uint8_t srcTypeMask, uint64_t srcRegisterMask,
|
||||||
|
uint8_t dstTypeMask, uint64_t dstRegisterMask,
|
||||||
|
uint8_t* tmpTypeMask, uint64_t* tmpRegisterMask) = 0;
|
||||||
|
|
||||||
virtual void planSource
|
virtual void planSource
|
||||||
(TernaryOperation op,
|
(TernaryOperation op,
|
||||||
unsigned aSize, uint8_t* aTypeMask, uint64_t* aRegisterMask,
|
unsigned aSize, uint8_t* aTypeMask, uint64_t* aRegisterMask,
|
||||||
@ -376,8 +383,8 @@ class Assembler {
|
|||||||
|
|
||||||
virtual void planDestination
|
virtual void planDestination
|
||||||
(TernaryOperation op,
|
(TernaryOperation op,
|
||||||
unsigned aSize, const uint8_t* aTypeMask, const uint64_t* aRegisterMask,
|
unsigned aSize, uint8_t aTypeMask, uint64_t aRegisterMask,
|
||||||
unsigned bSize, const uint8_t* bTypeMask, const uint64_t* bRegisterMask,
|
unsigned bSize, uint8_t bTypeMask, uint64_t bRegisterMask,
|
||||||
unsigned cSize, uint8_t* cTypeMask, uint64_t* cRegisterMask) = 0;
|
unsigned cSize, uint8_t* cTypeMask, uint64_t* cRegisterMask) = 0;
|
||||||
|
|
||||||
virtual void acquire() = 0;
|
virtual void acquire() = 0;
|
||||||
|
@ -5361,7 +5361,7 @@ finish(MyThread* t, Allocator* allocator, Context* context)
|
|||||||
::strcmp
|
::strcmp
|
||||||
(reinterpret_cast<const char*>
|
(reinterpret_cast<const char*>
|
||||||
(&byteArrayBody(t, methodName(t, context->method), 0)),
|
(&byteArrayBody(t, methodName(t, context->method), 0)),
|
||||||
"multiplyByFive") == 0)
|
"i2d") == 0)
|
||||||
{
|
{
|
||||||
trap();
|
trap();
|
||||||
}
|
}
|
||||||
|
730
src/compiler.cpp
730
src/compiler.cpp
File diff suppressed because it is too large
Load Diff
130
src/x86.cpp
130
src/x86.cpp
@ -974,27 +974,14 @@ 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
|
void
|
||||||
moveCR(Context* c, unsigned aSize, Assembler::Constant* a,
|
moveCR(Context* c, unsigned aSize, Assembler::Constant* a,
|
||||||
unsigned bSize, Assembler::Register* b)
|
unsigned bSize, Assembler::Register* b)
|
||||||
{
|
{
|
||||||
if(floatReg(b)) {
|
assert(c, not floatReg(b));
|
||||||
sseMoveCR(c, aSize, a, bSize, b);
|
|
||||||
} else {
|
|
||||||
moveCR2(c, aSize, a, bSize, b, 0);
|
moveCR2(c, aSize, a, bSize, b, 0);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
swapRR(Context* c, unsigned aSize UNUSED, Assembler::Register* a,
|
swapRR(Context* c, unsigned aSize UNUSED, Assembler::Register* a,
|
||||||
@ -1093,11 +1080,19 @@ void
|
|||||||
sseMoveMR(Context* c, unsigned aSize, Assembler::Memory* a,
|
sseMoveMR(Context* c, unsigned aSize, Assembler::Memory* a,
|
||||||
unsigned bSize UNUSED, Assembler::Register* b)
|
unsigned bSize UNUSED, Assembler::Register* b)
|
||||||
{
|
{
|
||||||
|
assert(c, aSize == bSize);
|
||||||
|
|
||||||
|
if (BytesPerWord == 4 and aSize == 8) {
|
||||||
|
opcode(c, 0xf3);
|
||||||
|
opcode(c, 0x0f, 0x7e);
|
||||||
|
modrmSibImm(c, b, a);
|
||||||
|
} else {
|
||||||
opcode(c, 0x66);
|
opcode(c, 0x66);
|
||||||
maybeRex(c, aSize, b, a);
|
maybeRex(c, aSize, b, a);
|
||||||
opcode(c, 0x0f, 0x6e);
|
opcode(c, 0x0f, 0x6e);
|
||||||
modrmSibImm(c, b, a);
|
modrmSibImm(c, b, a);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
moveMR(Context* c, unsigned aSize, Assembler::Memory* a,
|
moveMR(Context* c, unsigned aSize, Assembler::Memory* a,
|
||||||
@ -1162,11 +1157,19 @@ void
|
|||||||
sseMoveRM(Context* c, unsigned aSize, Assembler::Register* a,
|
sseMoveRM(Context* c, unsigned aSize, Assembler::Register* a,
|
||||||
UNUSED unsigned bSize, Assembler::Memory* b)
|
UNUSED unsigned bSize, Assembler::Memory* b)
|
||||||
{
|
{
|
||||||
|
assert(c, aSize == bSize);
|
||||||
|
|
||||||
|
if (BytesPerWord == 4 and aSize == 8) {
|
||||||
|
opcode(c, 0x66);
|
||||||
|
opcode(c, 0x0f, 0xd6);
|
||||||
|
modrmSibImm(c, a, b);
|
||||||
|
} else {
|
||||||
opcode(c, 0x66);
|
opcode(c, 0x66);
|
||||||
maybeRex(c, aSize, a, b);
|
maybeRex(c, aSize, a, b);
|
||||||
opcode(c, 0x0f, 0x7e);
|
opcode(c, 0x0f, 0x7e);
|
||||||
modrmSibImm(c, a, b);
|
modrmSibImm(c, a, b);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
moveRM(Context* c, unsigned aSize, Assembler::Register* a,
|
moveRM(Context* c, unsigned aSize, Assembler::Register* a,
|
||||||
@ -2802,7 +2805,8 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
case FloatCompare:
|
case FloatCompare:
|
||||||
assert(&c, supportsSSE());
|
assert(&c, supportsSSE());
|
||||||
*aTypeMask = (1 << RegisterOperand);
|
*aTypeMask = (1 << RegisterOperand);
|
||||||
*aRegisterMask = FloatRegisterMask;
|
*aRegisterMask = (static_cast<uint64_t>(FloatRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Negate:
|
case Negate:
|
||||||
@ -2818,7 +2822,8 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
|
|
||||||
case FloatAbs:
|
case FloatAbs:
|
||||||
*aTypeMask = (1 << RegisterOperand);
|
*aTypeMask = (1 << RegisterOperand);
|
||||||
*aRegisterMask = FloatRegisterMask;
|
*aRegisterMask = (static_cast<uint64_t>(FloatRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FloatNegate:
|
case FloatNegate:
|
||||||
@ -2833,22 +2838,25 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
|
|
||||||
case FloatSqrt:
|
case FloatSqrt:
|
||||||
*aTypeMask = (1 << RegisterOperand) | (1 << MemoryOperand);
|
*aTypeMask = (1 << RegisterOperand) | (1 << MemoryOperand);
|
||||||
*aRegisterMask = FloatRegisterMask;
|
*aRegisterMask = (static_cast<uint64_t>(FloatRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Float2Float:
|
case Float2Float:
|
||||||
if (supportsSSE() and supportsSSE2()) {
|
if (supportsSSE() and supportsSSE2()) {
|
||||||
*aTypeMask = (1 << RegisterOperand) | (1 << MemoryOperand);
|
*aTypeMask = (1 << RegisterOperand) | (1 << MemoryOperand);
|
||||||
*aRegisterMask = FloatRegisterMask;
|
*aRegisterMask = (static_cast<uint64_t>(FloatRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
} else {
|
} else {
|
||||||
*thunk = true;
|
*thunk = true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Float2Int:
|
case Float2Int:
|
||||||
if (supportsSSE()) {
|
if (supportsSSE() and (bSize <= BytesPerWord)) {
|
||||||
*aTypeMask = (1 << RegisterOperand);
|
*aTypeMask = (1 << RegisterOperand);
|
||||||
*aRegisterMask = FloatRegisterMask;
|
*aRegisterMask = (static_cast<uint64_t>(FloatRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
} else {
|
} else {
|
||||||
*thunk = true;
|
*thunk = true;
|
||||||
}
|
}
|
||||||
@ -2890,9 +2898,8 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
}
|
}
|
||||||
|
|
||||||
virtual void planDestination
|
virtual void planDestination
|
||||||
(BinaryOperation op,
|
(BinaryOperation op, unsigned aSize, uint8_t aTypeMask,
|
||||||
unsigned aSize, const uint8_t* aTypeMask UNUSED,
|
uint64_t aRegisterMask, unsigned bSize, uint8_t* bTypeMask,
|
||||||
const uint64_t* aRegisterMask, unsigned bSize, uint8_t* bTypeMask,
|
|
||||||
uint64_t* bRegisterMask)
|
uint64_t* bRegisterMask)
|
||||||
{
|
{
|
||||||
*bTypeMask = ~0;
|
*bTypeMask = ~0;
|
||||||
@ -2907,7 +2914,8 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
|
|
||||||
case FloatCompare:
|
case FloatCompare:
|
||||||
*bTypeMask = (1 << RegisterOperand);
|
*bTypeMask = (1 << RegisterOperand);
|
||||||
*bRegisterMask = FloatRegisterMask;
|
*bRegisterMask = (static_cast<uint64_t>(FloatRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Abs:
|
case Abs:
|
||||||
@ -2917,34 +2925,45 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
|
|
||||||
case FloatAbs:
|
case FloatAbs:
|
||||||
*bTypeMask = (1 << RegisterOperand);
|
*bTypeMask = (1 << RegisterOperand);
|
||||||
*bRegisterMask = *aRegisterMask;
|
*bRegisterMask = aRegisterMask;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Negate:
|
case Negate:
|
||||||
*bTypeMask = (1 << RegisterOperand);
|
*bTypeMask = (1 << RegisterOperand);
|
||||||
*bRegisterMask = *aRegisterMask;
|
*bRegisterMask = aRegisterMask;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FloatNegate:
|
case FloatNegate:
|
||||||
case FloatSqrt:
|
case FloatSqrt:
|
||||||
case Float2Float:
|
case Float2Float:
|
||||||
*bTypeMask = (1 << RegisterOperand);
|
|
||||||
*bRegisterMask = FloatRegisterMask;
|
|
||||||
break;
|
|
||||||
case Int2Float:
|
case Int2Float:
|
||||||
*bTypeMask = (1 << RegisterOperand);
|
*bTypeMask = (1 << RegisterOperand);
|
||||||
*bRegisterMask = FloatRegisterMask;
|
*bRegisterMask = (static_cast<uint64_t>(FloatRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Float2Int:
|
case Float2Int:
|
||||||
*bTypeMask = (1 << RegisterOperand);
|
*bTypeMask = (1 << RegisterOperand);
|
||||||
*bRegisterMask = GeneralRegisterMask
|
|
||||||
| (static_cast<uint64_t>(GeneralRegisterMask) << 32);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Move:
|
case Move:
|
||||||
|
if (aTypeMask & ((1 << MemoryOperand) | 1 << AddressOperand)) {
|
||||||
|
*bTypeMask = (1 << RegisterOperand);
|
||||||
|
*bRegisterMask = GeneralRegisterMask
|
||||||
|
| (static_cast<uint64_t>(GeneralRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
|
} else if (aTypeMask & (1 << RegisterOperand)) {
|
||||||
*bTypeMask = (1 << RegisterOperand) | (1 << MemoryOperand);
|
*bTypeMask = (1 << RegisterOperand) | (1 << MemoryOperand);
|
||||||
|
if (aRegisterMask & FloatRegisterMask) {
|
||||||
|
*bRegisterMask = FloatRegisterMask;
|
||||||
|
} else {
|
||||||
*bRegisterMask = GeneralRegisterMask
|
*bRegisterMask = GeneralRegisterMask
|
||||||
| (static_cast<uint64_t>(GeneralRegisterMask) << 32);
|
| (static_cast<uint64_t>(GeneralRegisterMask) << 32);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
*bTypeMask = (1 << RegisterOperand) | (1 << MemoryOperand);
|
||||||
|
}
|
||||||
|
|
||||||
if (BytesPerWord == 4) {
|
if (BytesPerWord == 4) {
|
||||||
if (aSize == 4 and bSize == 8) {
|
if (aSize == 4 and bSize == 8) {
|
||||||
*bRegisterMask = (static_cast<uint64_t>(1) << (rdx + 32))
|
*bRegisterMask = (static_cast<uint64_t>(1) << (rdx + 32))
|
||||||
@ -2962,6 +2981,41 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
virtual void planMove
|
||||||
|
(uint8_t srcTypeMask, uint64_t srcRegisterMask,
|
||||||
|
uint8_t dstTypeMask, uint64_t dstRegisterMask,
|
||||||
|
uint8_t* tmpTypeMask, uint64_t* tmpRegisterMask)
|
||||||
|
{
|
||||||
|
*tmpTypeMask = srcTypeMask;
|
||||||
|
*tmpRegisterMask = srcRegisterMask;
|
||||||
|
|
||||||
|
if ((dstTypeMask & (1 << MemoryOperand))
|
||||||
|
and (srcTypeMask & ((1 << MemoryOperand) | 1 << AddressOperand)))
|
||||||
|
{
|
||||||
|
// can't move directly from memory to memory
|
||||||
|
*tmpTypeMask = (1 << RegisterOperand);
|
||||||
|
*tmpRegisterMask = GeneralRegisterMask
|
||||||
|
| (static_cast<uint64_t>(GeneralRegisterMask) << 32)
|
||||||
|
| FloatRegisterMask;
|
||||||
|
} else if (dstTypeMask & (1 << RegisterOperand)) {
|
||||||
|
if (srcTypeMask & (1 << RegisterOperand)) {
|
||||||
|
if (((dstRegisterMask & FloatRegisterMask) == 0)
|
||||||
|
xor ((srcRegisterMask & FloatRegisterMask) == 0))
|
||||||
|
{
|
||||||
|
// can't move directly from FPR to GPR or vice-versa
|
||||||
|
*tmpTypeMask = (1 << MemoryOperand);
|
||||||
|
*tmpRegisterMask = 0;
|
||||||
|
}
|
||||||
|
} else if ((dstRegisterMask & FloatRegisterMask)
|
||||||
|
and (srcTypeMask & (1 << ConstantOperand)))
|
||||||
|
{
|
||||||
|
// can't move directly from constant to FPR
|
||||||
|
*tmpTypeMask = (1 << MemoryOperand);
|
||||||
|
*tmpRegisterMask = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
virtual void planSource
|
virtual void planSource
|
||||||
(TernaryOperation op,
|
(TernaryOperation op,
|
||||||
unsigned aSize, uint8_t *aTypeMask, uint64_t *aRegisterMask,
|
unsigned aSize, uint8_t *aTypeMask, uint64_t *aRegisterMask,
|
||||||
@ -3042,14 +3096,12 @@ class MyArchitecture: public Assembler::Architecture {
|
|||||||
}
|
}
|
||||||
|
|
||||||
virtual void planDestination
|
virtual void planDestination
|
||||||
(TernaryOperation op UNUSED,
|
(TernaryOperation, unsigned, uint8_t, uint64_t, unsigned, uint8_t,
|
||||||
unsigned aSize UNUSED, const uint8_t* aTypeMask UNUSED,
|
uint64_t bRegisterMask, unsigned, uint8_t* cTypeMask,
|
||||||
const uint64_t* aRegisterMask UNUSED, unsigned bSize UNUSED,
|
uint64_t* cRegisterMask)
|
||||||
const uint8_t* bTypeMask UNUSED, const uint64_t* bRegisterMask,
|
|
||||||
unsigned cSize UNUSED, uint8_t* cTypeMask, uint64_t* cRegisterMask)
|
|
||||||
{
|
{
|
||||||
*cTypeMask = (1 << RegisterOperand);
|
*cTypeMask = (1 << RegisterOperand);
|
||||||
*cRegisterMask = *bRegisterMask;
|
*cRegisterMask = bRegisterMask;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void acquire() {
|
virtual void acquire() {
|
||||||
|
@ -46,10 +46,10 @@ public class AllFloats {
|
|||||||
expect(divide(5f, 2d) == 5f/2d);
|
expect(divide(5f, 2d) == 5f/2d);
|
||||||
expect(add(5f, 4f) == 5f+4f);
|
expect(add(5f, 4f) == 5f+4f);
|
||||||
expect(add(5d, 4d) == 5f+4d);
|
expect(add(5d, 4d) == 5f+4d);
|
||||||
expect(add(5f, 4f) == 5f+4d);
|
expect(add(5f, 4d) == 5f+4d);
|
||||||
expect(subtract(5f, 4f) == 5f-4f);
|
expect(subtract(5f, 4f) == 5f-4f);
|
||||||
expect(subtract(5d, 4d) == 5f-4d);
|
expect(subtract(5d, 4d) == 5f-4d);
|
||||||
expect(subtract(5f, 4f) == 5f-4d);
|
expect(subtract(5f, 4d) == 5f-4d);
|
||||||
expect(complex(4f, 3f) == (4f-3f)/(4f*3f) + 2f);
|
expect(complex(4f, 3f) == (4f-3f)/(4f*3f) + 2f);
|
||||||
expect(complex(4d, 3d) == (4d-3d)/(4d*3d) + 2d);
|
expect(complex(4d, 3d) == (4d-3d)/(4d*3d) + 2d);
|
||||||
expect(complex(4f, 3d) == (4f-3d)/(4f*3d) + 2f);
|
expect(complex(4f, 3d) == (4f-3d)/(4f*3d) + 2f);
|
||||||
|
Loading…
Reference in New Issue
Block a user