From b66a8549fd9eaef6f6d6423889b5aa664422dfee Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 14:38:05 -0700 Subject: [PATCH 1/9] Remove boilerplate code (jump* methods in Compiler) --- include/avian/vm/codegen/compiler.h | 33 +----- include/avian/vm/codegen/lir.h | 4 + src/codegen/compiler.cpp | 163 +--------------------------- src/codegen/compiler/value.h | 7 ++ src/compile.cpp | 71 ++++++------ 5 files changed, 53 insertions(+), 225 deletions(-) diff --git a/include/avian/vm/codegen/compiler.h b/include/avian/vm/codegen/compiler.h index e9feb85d53..8691530cc7 100644 --- a/include/avian/vm/codegen/compiler.h +++ b/include/avian/vm/codegen/compiler.h @@ -124,39 +124,8 @@ class Compiler { virtual Operand* loadz(unsigned size, unsigned srcSelectSize, Operand* src, unsigned dstSize) = 0; - virtual void jumpIfEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfNotEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfLess - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfGreater - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfLessOrEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfGreaterOrEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatNotEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatLess - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatGreater - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatLessOrEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatGreaterOrEqual - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatLessOrUnordered - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatGreaterOrUnordered - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatLessOrEqualOrUnordered - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; - virtual void jumpIfFloatGreaterOrEqualOrUnordered - (unsigned size, Operand* a, Operand* b, Operand* address) = 0; + virtual void condJump(lir::TernaryOperation type, unsigned size, Operand* a, Operand* b, Operand* address) = 0; virtual void jmp(Operand* address) = 0; virtual void exit(Operand* address) = 0; diff --git a/include/avian/vm/codegen/lir.h b/include/avian/vm/codegen/lir.h index 530f72eeab..51bc103b65 100644 --- a/include/avian/vm/codegen/lir.h +++ b/include/avian/vm/codegen/lir.h @@ -108,6 +108,10 @@ inline bool isFloatBranch(lir::TernaryOperation op) { return op > JumpIfNotEqual; } +inline bool isGeneralBranch(lir::TernaryOperation op) { + return isBranch(op) && !isFloatBranch(op); +} + class Operand { }; class Constant: public Operand { diff --git a/src/codegen/compiler.cpp b/src/codegen/compiler.cpp index cf2bca6f03..818f02afe1 100644 --- a/src/codegen/compiler.cpp +++ b/src/codegen/compiler.cpp @@ -2592,170 +2592,17 @@ class MyCompiler: public Compiler { return dst; } - virtual void jumpIfEqual(unsigned size, Operand* a, Operand* b, + virtual void condJump(lir::TernaryOperation type, unsigned size, Operand* a, Operand* b, Operand* address) { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); + assert(&c, + (isGeneralBranch(type) and isGeneralValue(a) and isGeneralValue(b)) + or (isFloatBranch(type) and isFloatValue(a) and isFloatValue(b))); - appendBranch(&c, lir::JumpIfEqual, size, static_cast(a), + appendBranch(&c, type, size, static_cast(a), static_cast(b), static_cast(address)); } - virtual void jumpIfNotEqual(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - - appendBranch(&c, lir::JumpIfNotEqual, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfLess(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - - appendBranch(&c, lir::JumpIfLess, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfGreater(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - - appendBranch(&c, lir::JumpIfGreater, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfLessOrEqual(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - - appendBranch(&c, lir::JumpIfLessOrEqual, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfGreaterOrEqual(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - - appendBranch(&c, lir::JumpIfGreaterOrEqual, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatEqual(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatEqual, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatNotEqual(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatNotEqual, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatLess(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatLess, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatGreater(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatGreater, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatLessOrEqual(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatLessOrEqual, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatGreaterOrEqual(unsigned size, Operand* a, Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatGreaterOrEqual, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatLessOrUnordered(unsigned size, Operand* a, - Operand* b, Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatLessOrUnordered, size, static_cast(a), - static_cast(b), static_cast(address)); - } - - virtual void jumpIfFloatGreaterOrUnordered(unsigned size, Operand* a, - Operand* b, Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatGreaterOrUnordered, size, - static_cast(a), static_cast(b), - static_cast(address)); - } - - virtual void jumpIfFloatLessOrEqualOrUnordered(unsigned size, Operand* a, - Operand* b, Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatLessOrEqualOrUnordered, size, - static_cast(a), static_cast(b), - static_cast(address)); - } - - virtual void jumpIfFloatGreaterOrEqualOrUnordered(unsigned size, Operand* a, - Operand* b, - Operand* address) - { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - - appendBranch(&c, lir::JumpIfFloatGreaterOrEqualOrUnordered, size, - static_cast(a), static_cast(b), - static_cast(address)); - } - virtual void jmp(Operand* address) { appendJump(&c, lir::Jump, static_cast(address)); } diff --git a/src/codegen/compiler/value.h b/src/codegen/compiler/value.h index 6c702bf13f..e9ff43f19b 100644 --- a/src/codegen/compiler/value.h +++ b/src/codegen/compiler/value.h @@ -67,6 +67,13 @@ class Value: public Compiler::Operand { }; +inline bool isGeneralValue(Compiler::Operand* a) { + return static_cast(a)->type == lir::ValueGeneral; +} + +inline bool isFloatValue(Compiler::Operand* a) { + return static_cast(a)->type == lir::ValueFloat; +} Value* value(Context* c, lir::ValueType type, Site* site = 0, Site* target = 0); diff --git a/src/compile.cpp b/src/compile.cpp index 6cce909980..9301276088 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -19,6 +19,7 @@ #include #include #include +#include #include #include @@ -40,7 +41,7 @@ vmJumpAndInvoke(void* thread, void* function, void* stack, unsigned argumentFootprint, uintptr_t* arguments, unsigned frameSize); -using avian::codegen::Compiler; +using namespace avian::codegen; namespace { @@ -3833,27 +3834,27 @@ integerBranch(MyThread* t, Frame* frame, object code, unsigned& ip, switch (instruction) { case ifeq: - c->jumpIfEqual(size, a, b, target); + c->condJump(lir::JumpIfEqual, size, a, b, target); break; case ifne: - c->jumpIfNotEqual(size, a, b, target); + c->condJump(lir::JumpIfNotEqual, size, a, b, target); break; case ifgt: - c->jumpIfGreater(size, a, b, target); + c->condJump(lir::JumpIfGreater, size, a, b, target); break; case ifge: - c->jumpIfGreaterOrEqual(size, a, b, target); + c->condJump(lir::JumpIfGreaterOrEqual, size, a, b, target); break; case iflt: - c->jumpIfLess(size, a, b, target); + c->condJump(lir::JumpIfLess, size, a, b, target); break; case ifle: - c->jumpIfLessOrEqual(size, a, b, target); + c->condJump(lir::JumpIfLessOrEqual, size, a, b, target); break; default: @@ -3884,42 +3885,42 @@ floatBranch(MyThread* t, Frame* frame, object code, unsigned& ip, switch (instruction) { case ifeq: - c->jumpIfFloatEqual(size, a, b, target); + c->condJump(lir::JumpIfFloatEqual, size, a, b, target); break; case ifne: - c->jumpIfFloatNotEqual(size, a, b, target); + c->condJump(lir::JumpIfFloatNotEqual, size, a, b, target); break; case ifgt: if (lessIfUnordered) { - c->jumpIfFloatGreater(size, a, b, target); + c->condJump(lir::JumpIfFloatGreater, size, a, b, target); } else { - c->jumpIfFloatGreaterOrUnordered(size, a, b, target); + c->condJump(lir::JumpIfFloatGreaterOrUnordered, size, a, b, target); } break; case ifge: if (lessIfUnordered) { - c->jumpIfFloatGreaterOrEqual(size, a, b, target); + c->condJump(lir::JumpIfFloatGreaterOrEqual, size, a, b, target); } else { - c->jumpIfFloatGreaterOrEqualOrUnordered(size, a, b, target); + c->condJump(lir::JumpIfFloatGreaterOrEqualOrUnordered, size, a, b, target); } break; case iflt: if (lessIfUnordered) { - c->jumpIfFloatLessOrUnordered(size, a, b, target); + c->condJump(lir::JumpIfFloatLessOrUnordered, size, a, b, target); } else { - c->jumpIfFloatLess(size, a, b, target); + c->condJump(lir::JumpIfFloatLess, size, a, b, target); } break; case ifle: if (lessIfUnordered) { - c->jumpIfFloatLessOrEqualOrUnordered(size, a, b, target); + c->condJump(lir::JumpIfFloatLessOrEqualOrUnordered, size, a, b, target); } else { - c->jumpIfFloatLessOrEqual(size, a, b, target); + c->condJump(lir::JumpIfFloatLessOrEqual, size, a, b, target); } break; @@ -5081,9 +5082,9 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* target = frame->machineIp(newIp); if (instruction == if_acmpeq) { - c->jumpIfEqual(TargetBytesPerWord, a, b, target); + c->condJump(lir::JumpIfEqual, TargetBytesPerWord, a, b, target); } else { - c->jumpIfNotEqual(TargetBytesPerWord, a, b, target); + c->condJump(lir::JumpIfNotEqual, TargetBytesPerWord, a, b, target); } } goto branch; @@ -5107,22 +5108,22 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, switch (instruction) { case if_icmpeq: - c->jumpIfEqual(4, a, b, target); + c->condJump(lir::JumpIfEqual, 4, a, b, target); break; case if_icmpne: - c->jumpIfNotEqual(4, a, b, target); + c->condJump(lir::JumpIfNotEqual, 4, a, b, target); break; case if_icmpgt: - c->jumpIfGreater(4, a, b, target); + c->condJump(lir::JumpIfGreater, 4, a, b, target); break; case if_icmpge: - c->jumpIfGreaterOrEqual(4, a, b, target); + c->condJump(lir::JumpIfGreaterOrEqual, 4, a, b, target); break; case if_icmplt: - c->jumpIfLess(4, a, b, target); + c->condJump(lir::JumpIfLess, 4, a, b, target); break; case if_icmple: - c->jumpIfLessOrEqual(4, a, b, target); + c->condJump(lir::JumpIfLessOrEqual, 4, a, b, target); break; default: abort(t); @@ -5150,22 +5151,22 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, switch (instruction) { case ifeq: - c->jumpIfEqual(4, a, b, target); + c->condJump(lir::JumpIfEqual, 4, a, b, target); break; case ifne: - c->jumpIfNotEqual(4, a, b, target); + c->condJump(lir::JumpIfNotEqual, 4, a, b, target); break; case ifgt: - c->jumpIfGreater(4, a, b, target); + c->condJump(lir::JumpIfGreater, 4, a, b, target); break; case ifge: - c->jumpIfGreaterOrEqual(4, a, b, target); + c->condJump(lir::JumpIfGreaterOrEqual, 4, a, b, target); break; case iflt: - c->jumpIfLess(4, a, b, target); + c->condJump(lir::JumpIfLess, 4, a, b, target); break; case ifle: - c->jumpIfLessOrEqual(4, a, b, target); + c->condJump(lir::JumpIfLessOrEqual, 4, a, b, target); break; default: abort(t); @@ -5187,9 +5188,9 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* target = frame->machineIp(newIp); if (instruction == ifnull) { - c->jumpIfEqual(TargetBytesPerWord, a, b, target); + c->condJump(lir::JumpIfEqual, TargetBytesPerWord, a, b, target); } else { - c->jumpIfNotEqual(TargetBytesPerWord, a, b, target); + c->condJump(lir::JumpIfNotEqual, TargetBytesPerWord, a, b, target); } } goto branch; @@ -6303,7 +6304,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* key = frame->popInt(); - c->jumpIfLess(4, c->constant(bottom, Compiler::IntegerType), key, + c->condJump(lir::JumpIfLess, 4, c->constant(bottom, Compiler::IntegerType), key, frame->machineIp(defaultIp)); c->save(1, key); @@ -6390,7 +6391,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, c->restoreState(s->state); - c->jumpIfGreater(4, c->constant(s->top, Compiler::IntegerType), s->key, + c->condJump(lir::JumpIfGreater, 4, c->constant(s->top, Compiler::IntegerType), s->key, frame->machineIp(s->defaultIp)); c->save(1, s->key); From d5c1a094ca116f8f54eca7a3ce24575b9def298c Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 15:11:30 -0700 Subject: [PATCH 2/9] Remove boilerplate code (general binaryOp methods in Compiler) --- include/avian/vm/codegen/compiler.h | 15 ++--- include/avian/vm/codegen/lir.h | 8 +++ src/codegen/compiler.cpp | 96 +++-------------------------- src/compile.cpp | 82 ++++++++++++------------ 4 files changed, 60 insertions(+), 141 deletions(-) diff --git a/include/avian/vm/codegen/compiler.h b/include/avian/vm/codegen/compiler.h index 8691530cc7..ab55c0b52d 100644 --- a/include/avian/vm/codegen/compiler.h +++ b/include/avian/vm/codegen/compiler.h @@ -129,22 +129,15 @@ class Compiler { virtual void jmp(Operand* address) = 0; virtual void exit(Operand* address) = 0; - virtual Operand* add(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* sub(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* mul(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* div(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* rem(unsigned size, Operand* a, Operand* b) = 0; + + virtual Operand* binaryOp(lir::TernaryOperation type, unsigned size, Operand* a, Operand* b) = 0; + virtual Operand* fadd(unsigned size, Operand* a, Operand* b) = 0; virtual Operand* fsub(unsigned size, Operand* a, Operand* b) = 0; virtual Operand* fmul(unsigned size, Operand* a, Operand* b) = 0; virtual Operand* fdiv(unsigned size, Operand* a, Operand* b) = 0; virtual Operand* frem(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* shl(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* shr(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* ushr(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* and_(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* or_(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* xor_(unsigned size, Operand* a, Operand* b) = 0; + virtual Operand* neg(unsigned size, Operand* a) = 0; virtual Operand* fneg(unsigned size, Operand* a) = 0; virtual Operand* abs(unsigned size, Operand* a) = 0; diff --git a/include/avian/vm/codegen/lir.h b/include/avian/vm/codegen/lir.h index 51bc103b65..18816b272b 100644 --- a/include/avian/vm/codegen/lir.h +++ b/include/avian/vm/codegen/lir.h @@ -112,6 +112,14 @@ inline bool isGeneralBranch(lir::TernaryOperation op) { return isBranch(op) && !isFloatBranch(op); } +inline bool isGeneralBinaryOp(lir::TernaryOperation op) { + return op < FloatAdd; +} + +inline bool isFloatBinaryOp(lir::TernaryOperation op) { + return op > FloatAdd && op <= FloatMin; +} + class Operand { }; class Constant: public Operand { diff --git a/src/codegen/compiler.cpp b/src/codegen/compiler.cpp index 818f02afe1..327d7d27ac 100644 --- a/src/codegen/compiler.cpp +++ b/src/codegen/compiler.cpp @@ -2611,47 +2611,14 @@ class MyCompiler: public Compiler { appendJump(&c, lir::Jump, static_cast(address), true); } - virtual Operand* add(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::Add, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } + virtual Operand* binaryOp(lir::TernaryOperation type, unsigned size, Operand* a, Operand* b) { + assert(&c, + (isGeneralBinaryOp(type) and isGeneralValue(a) and isGeneralValue(b)) + or (isFloatBinaryOp(type) and isFloatValue(a) and isFloatValue(b))); - virtual Operand* sub(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::Subtract, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* mul(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::Multiply, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* div(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::Divide, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* rem(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral - and static_cast(b)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::Remainder, size, static_cast(a), + Value* result = value(&c, static_cast(a)->type); + + appendCombine(&c, type, size, static_cast(a), size, static_cast(b), size, result); return result; } @@ -2704,55 +2671,6 @@ class MyCompiler: public Compiler { return result; } - virtual Operand* shl(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::ShiftLeft, TargetBytesPerWord, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* shr(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::ShiftRight, TargetBytesPerWord, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* ushr(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine - (&c, lir::UnsignedShiftRight, TargetBytesPerWord, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* and_(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::And, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* or_(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::Or, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* xor_(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendCombine(&c, lir::Xor, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - virtual Operand* neg(unsigned size, Operand* a) { assert(&c, static_cast(a)->type == lir::ValueGeneral); Value* result = value(&c, lir::ValueGeneral); diff --git a/src/compile.cpp b/src/compile.cpp index 9301276088..95c5f73e64 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -1408,8 +1408,8 @@ class Frame { object pointer = makePointer(t, p); bc->constants = makeTriple(t, o, pointer, bc->constants); - return c->add - (TargetBytesPerWord, c->memory + return c->binaryOp(lir::Add, + TargetBytesPerWord, c->memory (c->register_(t->arch->thread()), Compiler::AddressType, TARGET_THREAD_HEAPIMAGE), c->promiseConstant (p, Compiler::AddressType)); @@ -1638,8 +1638,8 @@ class Frame { Value absoluteAddressOperand(avian::codegen::Promise* p) { return context->bootContext - ? c->add - (TargetBytesPerWord, c->memory + ? c->binaryOp(lir::Add, + TargetBytesPerWord, c->memory (c->register_(t->arch->thread()), Compiler::AddressType, TARGET_THREAD_CODEIMAGE), c->promiseConstant (new(&context->zone) @@ -4380,10 +4380,10 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, 0, Compiler::VoidType, 4, c->register_(t->arch->thread()), array, - c->add - (4, c->constant(TargetArrayBody, Compiler::IntegerType), - c->shl - (4, c->constant(log(TargetBytesPerWord), Compiler::IntegerType), + c->binaryOp(lir::Add, + 4, c->constant(TargetArrayBody, Compiler::IntegerType), + c->binaryOp(lir::ShiftLeft, + 4, c->constant(log(TargetBytesPerWord), Compiler::IntegerType), index)), value); } break; @@ -5018,13 +5018,13 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case iadd: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->add(4, a, b)); + frame->pushInt(c->binaryOp(lir::Add, 4, a, b)); } break; case iand: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->and_(4, a, b)); + frame->pushInt(c->binaryOp(lir::And, 4, a, b)); } break; case iconst_m1: @@ -5064,7 +5064,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->trace(0, 0); } - frame->pushInt(c->div(4, a, b)); + frame->pushInt(c->binaryOp(lir::Divide, 4, a, b)); } break; case if_acmpeq: @@ -5200,8 +5200,8 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, storeLocal (context, 1, - c->add - (4, c->constant(count, Compiler::IntegerType), + c->binaryOp(lir::Add, + 4, c->constant(count, Compiler::IntegerType), loadLocal(context, 1, index)), index); } break; @@ -5234,7 +5234,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case imul: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->mul(4, a, b)); + frame->pushInt(c->binaryOp(lir::Multiply, 4, a, b)); } break; case ineg: { @@ -5422,8 +5422,8 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* result = c->stackCall (c->memory - (c->and_ - (TargetBytesPerWord, c->constant + (c->binaryOp(lir::And, + TargetBytesPerWord, c->constant (TargetPointerMask, Compiler::IntegerType), c->memory(instance, Compiler::ObjectType, 0, 0, 1)), Compiler::ObjectType, offset, 0, 1), @@ -5470,7 +5470,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case ior: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->or_(4, a, b)); + frame->pushInt(c->binaryOp(lir::Or, 4, a, b)); } break; case irem: { @@ -5482,7 +5482,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->trace(0, 0); } - frame->pushInt(c->rem(4, a, b)); + frame->pushInt(c->binaryOp(lir::Remainder, 4, a, b)); } break; case ireturn: @@ -5494,13 +5494,13 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case ishl: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->shl(4, a, b)); + frame->pushInt(c->binaryOp(lir::ShiftLeft, 4, a, b)); } break; case ishr: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->shr(4, a, b)); + frame->pushInt(c->binaryOp(lir::ShiftRight, 4, a, b)); } break; case istore: @@ -5531,19 +5531,19 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case isub: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->sub(4, a, b)); + frame->pushInt(c->binaryOp(lir::Subtract, 4, a, b)); } break; case iushr: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->ushr(4, a, b)); + frame->pushInt(c->binaryOp(lir::UnsignedShiftRight, 4, a, b)); } break; case ixor: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->xor_(4, a, b)); + frame->pushInt(c->binaryOp(lir::Xor, 4, a, b)); } break; case jsr: @@ -5587,13 +5587,13 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case ladd: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->add(8, a, b)); + frame->pushLong(c->binaryOp(lir::Add, 8, a, b)); } break; case land: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->and_(8, a, b)); + frame->pushLong(c->binaryOp(lir::And, 8, a, b)); } break; case lcmp: { @@ -5705,7 +5705,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->trace(0, 0); } - frame->pushLong(c->div(8, a, b)); + frame->pushLong(c->binaryOp(lir::Divide, 8, a, b)); } break; case lload: @@ -5736,7 +5736,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case lmul: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->mul(8, a, b)); + frame->pushLong(c->binaryOp(lir::Multiply, 8, a, b)); } break; case lneg: @@ -5786,8 +5786,8 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, c->constant(pairCount, Compiler::IntegerType), default_); c->jmp - (context->bootContext ? c->add - (TargetBytesPerWord, c->memory + (context->bootContext ? c->binaryOp(lir::Add, + TargetBytesPerWord, c->memory (c->register_(t->arch->thread()), Compiler::AddressType, TARGET_THREAD_CODEIMAGE), address) : address); @@ -5806,7 +5806,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case lor: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->or_(8, a, b)); + frame->pushLong(c->binaryOp(lir::Or, 8, a, b)); } break; case lrem: { @@ -5818,7 +5818,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->trace(0, 0); } - frame->pushLong(c->rem(8, a, b)); + frame->pushLong(c->binaryOp(lir::Remainder, 8, a, b)); } break; case lreturn: @@ -5830,13 +5830,13 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case lshl: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->shl(8, a, b)); + frame->pushLong(c->binaryOp(lir::ShiftLeft, 8, a, b)); } break; case lshr: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->shr(8, a, b)); + frame->pushLong(c->binaryOp(lir::ShiftRight, 8, a, b)); } break; case lstore: @@ -5867,19 +5867,19 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case lsub: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->sub(8, a, b)); + frame->pushLong(c->binaryOp(lir::Subtract, 8, a, b)); } break; case lushr: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->ushr(8, a, b)); + frame->pushLong(c->binaryOp(lir::UnsignedShiftRight, 8, a, b)); } break; case lxor: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->xor_(8, a, b)); + frame->pushLong(c->binaryOp(lir::Xor, 8, a, b)); } break; case monitorenter: { @@ -6332,8 +6332,8 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, storeLocal (context, 1, - c->add - (4, c->constant(count, Compiler::IntegerType), + c->binaryOp(lir::Add, + 4, c->constant(count, Compiler::IntegerType), loadLocal(context, 1, index)), index); } break; @@ -6409,7 +6409,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* normalizedKey = (s->bottom - ? c->sub(4, c->constant(s->bottom, Compiler::IntegerType), s->key) + ? c->binaryOp(lir::Subtract, 4, c->constant(s->bottom, Compiler::IntegerType), s->key) : s->key); Compiler::Operand* entry = c->memory @@ -6419,8 +6419,8 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, c->jmp (c->load (TargetBytesPerWord, TargetBytesPerWord, context->bootContext - ? c->add - (TargetBytesPerWord, c->memory + ? c->binaryOp(lir::Add, + TargetBytesPerWord, c->memory (c->register_(t->arch->thread()), Compiler::AddressType, TARGET_THREAD_CODEIMAGE), entry) : entry, From 07d0f1172fe401d8f642b7c97facb4952d3647cc Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 15:22:38 -0700 Subject: [PATCH 3/9] Remove boilerplate code (float binaryOp methods in Compiler) --- include/avian/vm/codegen/compiler.h | 6 ---- include/avian/vm/codegen/lir.h | 2 +- src/codegen/compiler.cpp | 48 ----------------------------- src/compile.cpp | 20 ++++++------ 4 files changed, 11 insertions(+), 65 deletions(-) diff --git a/include/avian/vm/codegen/compiler.h b/include/avian/vm/codegen/compiler.h index ab55c0b52d..271661d19a 100644 --- a/include/avian/vm/codegen/compiler.h +++ b/include/avian/vm/codegen/compiler.h @@ -132,12 +132,6 @@ class Compiler { virtual Operand* binaryOp(lir::TernaryOperation type, unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* fadd(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* fsub(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* fmul(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* fdiv(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* frem(unsigned size, Operand* a, Operand* b) = 0; - virtual Operand* neg(unsigned size, Operand* a) = 0; virtual Operand* fneg(unsigned size, Operand* a) = 0; virtual Operand* abs(unsigned size, Operand* a) = 0; diff --git a/include/avian/vm/codegen/lir.h b/include/avian/vm/codegen/lir.h index 18816b272b..3b6b835c3e 100644 --- a/include/avian/vm/codegen/lir.h +++ b/include/avian/vm/codegen/lir.h @@ -117,7 +117,7 @@ inline bool isGeneralBinaryOp(lir::TernaryOperation op) { } inline bool isFloatBinaryOp(lir::TernaryOperation op) { - return op > FloatAdd && op <= FloatMin; + return op >= FloatAdd && op <= FloatMin; } class Operand { }; diff --git a/src/codegen/compiler.cpp b/src/codegen/compiler.cpp index 327d7d27ac..2e698f753f 100644 --- a/src/codegen/compiler.cpp +++ b/src/codegen/compiler.cpp @@ -2623,54 +2623,6 @@ class MyCompiler: public Compiler { return result; } - virtual Operand* fadd(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - static_cast(a)->type = static_cast(b)->type = lir::ValueFloat; - appendCombine(&c, lir::FloatAdd, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* fsub(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - static_cast(a)->type = static_cast(b)->type = lir::ValueFloat; - appendCombine(&c, lir::FloatSubtract, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* fmul(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - static_cast(a)->type = static_cast(b)->type = lir::ValueFloat; - appendCombine(&c, lir::FloatMultiply, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* fdiv(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - appendCombine(&c, lir::FloatDivide, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - - virtual Operand* frem(unsigned size, Operand* a, Operand* b) { - assert(&c, static_cast(a)->type == lir::ValueFloat - and static_cast(b)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - appendCombine(&c, lir::FloatRemainder, size, static_cast(a), - size, static_cast(b), size, result); - return result; - } - virtual Operand* neg(unsigned size, Operand* a) { assert(&c, static_cast(a)->type == lir::ValueGeneral); Value* result = value(&c, lir::ValueGeneral); diff --git a/src/compile.cpp b/src/compile.cpp index 95c5f73e64..eea2526db6 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -4589,7 +4589,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->fadd(8, a, b)); + frame->pushLong(c->binaryOp(lir::FloatAdd, 8, a, b)); } break; case dcmpg: { @@ -4638,14 +4638,14 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->fdiv(8, a, b)); + frame->pushLong(c->binaryOp(lir::FloatDivide, 8, a, b)); } break; case dmul: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->fmul(8, a, b)); + frame->pushLong(c->binaryOp(lir::FloatMultiply, 8, a, b)); } break; case dneg: { @@ -4656,14 +4656,14 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->frem(8, a, b)); + frame->pushLong(c->binaryOp(lir::FloatRemainder, 8, a, b)); } break; case dsub: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->fsub(8, a, b)); + frame->pushLong(c->binaryOp(lir::FloatSubtract, 8, a, b)); } break; case dup: @@ -4706,7 +4706,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->fadd(4, a, b)); + frame->pushInt(c->binaryOp(lir::FloatAdd, 4, a, b)); } break; case fcmpg: { @@ -4755,14 +4755,14 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->fdiv(4, a, b)); + frame->pushInt(c->binaryOp(lir::FloatDivide, 4, a, b)); } break; case fmul: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->fmul(4, a, b)); + frame->pushInt(c->binaryOp(lir::FloatMultiply, 4, a, b)); } break; case fneg: { @@ -4773,14 +4773,14 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->frem(4, a, b)); + frame->pushInt(c->binaryOp(lir::FloatRemainder, 4, a, b)); } break; case fsub: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->fsub(4, a, b)); + frame->pushInt(c->binaryOp(lir::FloatSubtract, 4, a, b)); } break; case getfield: From bd7b66a8981bcf721ec62202b012b2cf43041252 Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 16:43:15 -0700 Subject: [PATCH 4/9] Remove boilerplate code (unaryOp methods in Compiler) --- include/avian/vm/codegen/compiler.h | 6 +---- include/avian/vm/codegen/lir.h | 9 ++++++- src/codegen/compiler.cpp | 39 ++++------------------------- src/compile.cpp | 16 ++++++------ 4 files changed, 22 insertions(+), 48 deletions(-) diff --git a/include/avian/vm/codegen/compiler.h b/include/avian/vm/codegen/compiler.h index 271661d19a..fd95a803ab 100644 --- a/include/avian/vm/codegen/compiler.h +++ b/include/avian/vm/codegen/compiler.h @@ -131,12 +131,8 @@ class Compiler { virtual void exit(Operand* address) = 0; virtual Operand* binaryOp(lir::TernaryOperation type, unsigned size, Operand* a, Operand* b) = 0; + virtual Operand* unaryOp(lir::BinaryOperation type, unsigned size, Operand* a) = 0; - virtual Operand* neg(unsigned size, Operand* a) = 0; - virtual Operand* fneg(unsigned size, Operand* a) = 0; - virtual Operand* abs(unsigned size, Operand* a) = 0; - virtual Operand* fabs(unsigned size, Operand* a) = 0; - virtual Operand* fsqrt(unsigned size, Operand* a) = 0; virtual Operand* f2f(unsigned aSize, unsigned resSize, Operand* a) = 0; virtual Operand* f2i(unsigned aSize, unsigned resSize, Operand* a) = 0; virtual Operand* i2f(unsigned aSize, unsigned resSize, Operand* a) = 0; diff --git a/include/avian/vm/codegen/lir.h b/include/avian/vm/codegen/lir.h index 3b6b835c3e..bb493cc387 100644 --- a/include/avian/vm/codegen/lir.h +++ b/include/avian/vm/codegen/lir.h @@ -99,7 +99,6 @@ const unsigned OperandTypeCount = MemoryOperand + 1; const int NoRegister = -1; - inline bool isBranch(lir::TernaryOperation op) { return op > FloatMin; } @@ -120,6 +119,14 @@ inline bool isFloatBinaryOp(lir::TernaryOperation op) { return op >= FloatAdd && op <= FloatMin; } +inline bool isGeneralUnaryOp(lir::BinaryOperation op) { + return op == Negate || op == Absolute; +} + +inline bool isFloatUnaryOp(lir::BinaryOperation op) { + return op == FloatNegate || op == FloatSquareRoot || op == FloatAbsolute; +} + class Operand { }; class Constant: public Operand { diff --git a/src/codegen/compiler.cpp b/src/codegen/compiler.cpp index 2e698f753f..1c612a87d1 100644 --- a/src/codegen/compiler.cpp +++ b/src/codegen/compiler.cpp @@ -2623,40 +2623,11 @@ class MyCompiler: public Compiler { return result; } - virtual Operand* neg(unsigned size, Operand* a) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendTranslate(&c, lir::Negate, size, static_cast(a), size, result); - return result; - } - - virtual Operand* fneg(unsigned size, Operand* a) { - assert(&c, static_cast(a)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - appendTranslate(&c, lir::FloatNegate, size, static_cast(a), size, result); - return result; - } - - virtual Operand* abs(unsigned size, Operand* a) { - assert(&c, static_cast(a)->type == lir::ValueGeneral); - Value* result = value(&c, lir::ValueGeneral); - appendTranslate(&c, lir::Absolute, size, static_cast(a), size, result); - return result; - } - - virtual Operand* fabs(unsigned size, Operand* a) { - assert(&c, static_cast(a)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - appendTranslate - (&c, lir::FloatAbsolute, size, static_cast(a), size, result); - return result; - } - - virtual Operand* fsqrt(unsigned size, Operand* a) { - assert(&c, static_cast(a)->type == lir::ValueFloat); - Value* result = value(&c, lir::ValueFloat); - appendTranslate - (&c, lir::FloatSquareRoot, size, static_cast(a), size, result); + virtual Operand* unaryOp(lir::BinaryOperation type, unsigned size, Operand* a) { + assert(&c, (isGeneralUnaryOp(type) and isGeneralValue(a))or( + isFloatUnaryOp(type) and isFloatValue(a))); + Value* result = value(&c, static_cast(a)->type); + appendTranslate(&c, type, size, static_cast(a), size, result); return result; } diff --git a/src/compile.cpp b/src/compile.cpp index eea2526db6..f3f7f93d5c 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -3954,17 +3954,17 @@ intrinsic(MyThread* t, Frame* frame, object target) if (MATCH(methodName(t, target), "sqrt") and MATCH(methodSpec(t, target), "(D)D")) { - frame->pushLong(c->fsqrt(8, frame->popLong())); + frame->pushLong(c->unaryOp(lir::FloatSquareRoot, 8, frame->popLong())); return true; } else if (MATCH(methodName(t, target), "abs")) { if (MATCH(methodSpec(t, target), "(I)I")) { - frame->pushInt(c->abs(4, frame->popInt())); + frame->pushInt(c->unaryOp(lir::Absolute, 4, frame->popInt())); return true; } else if (MATCH(methodSpec(t, target), "(J)J")) { - frame->pushLong(c->abs(8, frame->popLong())); + frame->pushLong(c->unaryOp(lir::Absolute, 8, frame->popLong())); return true; } else if (MATCH(methodSpec(t, target), "(F)F")) { - frame->pushInt(c->fabs(4, frame->popInt())); + frame->pushInt(c->unaryOp(lir::FloatAbsolute, 4, frame->popInt())); return true; } } @@ -4649,7 +4649,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, } break; case dneg: { - frame->pushLong(c->fneg(8, frame->popLong())); + frame->pushLong(c->unaryOp(lir::FloatNegate, 8, frame->popLong())); } break; case vm::drem: { @@ -4766,7 +4766,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, } break; case fneg: { - frame->pushInt(c->fneg(4, frame->popInt())); + frame->pushInt(c->unaryOp(lir::FloatNegate, 4, frame->popInt())); } break; case vm::frem: { @@ -5238,7 +5238,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, } break; case ineg: { - frame->pushInt(c->neg(4, frame->popInt())); + frame->pushInt(c->unaryOp(lir::Negate, 4, frame->popInt())); } break; case instanceof: { @@ -5740,7 +5740,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, } break; case lneg: - frame->pushLong(c->neg(8, frame->popLong())); + frame->pushLong(c->unaryOp(lir::Negate, 8, frame->popLong())); break; case lookupswitch: { From eab36b3a23dbbd6dbbff62370ac69aa9009f2c86 Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 16:51:20 -0700 Subject: [PATCH 5/9] Remove boilerplate code (nullaryOp methods in Compiler) --- include/avian/vm/codegen/compiler.h | 7 +------ src/codegen/compiler.cpp | 16 ++-------------- src/compile.cpp | 10 +++++----- 3 files changed, 8 insertions(+), 25 deletions(-) diff --git a/include/avian/vm/codegen/compiler.h b/include/avian/vm/codegen/compiler.h index fd95a803ab..25de4024f3 100644 --- a/include/avian/vm/codegen/compiler.h +++ b/include/avian/vm/codegen/compiler.h @@ -132,17 +132,12 @@ class Compiler { virtual Operand* binaryOp(lir::TernaryOperation type, unsigned size, Operand* a, Operand* b) = 0; virtual Operand* unaryOp(lir::BinaryOperation type, unsigned size, Operand* a) = 0; + virtual void nullaryOp(lir::Operation type) = 0; virtual Operand* f2f(unsigned aSize, unsigned resSize, Operand* a) = 0; virtual Operand* f2i(unsigned aSize, unsigned resSize, Operand* a) = 0; virtual Operand* i2f(unsigned aSize, unsigned resSize, Operand* a) = 0; - virtual void trap() = 0; - - virtual void loadBarrier() = 0; - virtual void storeStoreBarrier() = 0; - virtual void storeLoadBarrier() = 0; - virtual void compile(uintptr_t stackOverflowHandler, unsigned stackLimitOffset) = 0; virtual unsigned resolve(uint8_t* dst) = 0; diff --git a/src/codegen/compiler.cpp b/src/codegen/compiler.cpp index 1c612a87d1..07a0890951 100644 --- a/src/codegen/compiler.cpp +++ b/src/codegen/compiler.cpp @@ -2655,20 +2655,8 @@ class MyCompiler: public Compiler { return result; } - virtual void trap() { - appendOperation(&c, lir::Trap); - } - - virtual void loadBarrier() { - appendOperation(&c, lir::LoadBarrier); - } - - virtual void storeStoreBarrier() { - appendOperation(&c, lir::StoreStoreBarrier); - } - - virtual void storeLoadBarrier() { - appendOperation(&c, lir::StoreLoadBarrier); + virtual void nullaryOp(lir::Operation type) { + appendOperation(&c, type); } virtual void compile(uintptr_t stackOverflowHandler, diff --git a/src/compile.cpp b/src/compile.cpp index f3f7f93d5c..d1907898be 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -4530,7 +4530,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, 2, c->register_(t->arch->thread()), target); if (ip == codeLength(t, code)) { - c->trap(); + c->nullaryOp(lir::Trap); } } goto next; @@ -4926,7 +4926,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, c->register_(t->arch->thread()), frame->append(field)); } else { - c->loadBarrier(); + c->nullaryOp(lir::LoadBarrier); } } } else { @@ -6057,7 +6057,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, 0, frame->trace(0, 0), 0, Compiler::VoidType, 2, c->register_(t->arch->thread()), frame->append(field)); } else { - c->storeStoreBarrier(); + c->nullaryOp(lir::StoreStoreBarrier); } } @@ -6156,7 +6156,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, 0, frame->trace(0, 0), 0, Compiler::VoidType, 2, c->register_(t->arch->thread()), frame->append(field)); } else { - c->storeLoadBarrier(); + c->nullaryOp(lir::StoreLoadBarrier); } } } else { @@ -6254,7 +6254,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, case return_: if (needsReturnBarrier(t, context->method)) { - c->storeStoreBarrier(); + c->nullaryOp(lir::StoreStoreBarrier); } handleExit(t, frame); From ac984775a5e7adee29ec50812d0e7e2f30883782 Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 22:03:42 -0700 Subject: [PATCH 6/9] Remove redundancy in compiling arithmetic operations --- src/compile.cpp | 239 +++++++++++++++++------------------------------- 1 file changed, 83 insertions(+), 156 deletions(-) diff --git a/src/compile.cpp b/src/compile.cpp index d1907898be..c99214bfd2 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -4196,6 +4196,56 @@ class SwitchState { unsigned index; }; +lir::TernaryOperation toCompilerBinaryOp(MyThread* t, unsigned instruction) +{ + switch (instruction) { + case iadd: + case ladd: + return lir::Add; + case ior: + case lor: + return lir::Or; + case ishl: + case lshl: + return lir::ShiftLeft; + case ishr: + case lshr: + return lir::ShiftRight; + case iushr: + case lushr: + return lir::UnsignedShiftRight; + case fadd: + case dadd: + return lir::FloatAdd; + case fsub: + case dsub: + return lir::FloatSubtract; + case fmul: + case dmul: + return lir::FloatMultiply; + case fdiv: + case ddiv: + return lir::FloatDivide; + case frem: + case vm::drem: + return lir::FloatRemainder; + case iand: + case land: + return lir::And; + case isub: + case lsub: + return lir::Subtract; + case ixor: + case lxor: + return lir::Xor; + case imul: + case lmul: + return lir::Multiply; + default: + abort(t); + } +} + void compile(MyThread* t, Frame* initialFrame, unsigned initialIp, int exceptionHandlerStart = -1) @@ -4585,11 +4635,15 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->pushLong(c->f2i(8, 8, frame->popLong())); } break; - case dadd: { + case dadd: + case dsub: + case dmul: + case ddiv: + case vm::drem: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::FloatAdd, 8, a, b)); + frame->pushLong(c->binaryOp(toCompilerBinaryOp(t, instruction), 8, a, b)); } break; case dcmpg: { @@ -4634,38 +4688,10 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->pushLong(c->constant(doubleToBits(1.0), Compiler::FloatType)); break; - case ddiv: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - - frame->pushLong(c->binaryOp(lir::FloatDivide, 8, a, b)); - } break; - - case dmul: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - - frame->pushLong(c->binaryOp(lir::FloatMultiply, 8, a, b)); - } break; - case dneg: { frame->pushLong(c->unaryOp(lir::FloatNegate, 8, frame->popLong())); } break; - case vm::drem: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - - frame->pushLong(c->binaryOp(lir::FloatRemainder, 8, a, b)); - } break; - - case dsub: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - - frame->pushLong(c->binaryOp(lir::FloatSubtract, 8, a, b)); - } break; - case dup: frame->dup(); break; @@ -4702,11 +4728,15 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->pushLong(c->f2i(4, 8, frame->popInt())); } break; - case fadd: { + case fadd: + case fsub: + case fmul: + case fdiv: + case frem: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::FloatAdd, 4, a, b)); + frame->pushInt(c->binaryOp(toCompilerBinaryOp(t, instruction), 4, a, b)); } break; case fcmpg: { @@ -4751,38 +4781,10 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->pushInt(c->constant(floatToBits(2.0), Compiler::FloatType)); break; - case fdiv: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - - frame->pushInt(c->binaryOp(lir::FloatDivide, 4, a, b)); - } break; - - case fmul: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - - frame->pushInt(c->binaryOp(lir::FloatMultiply, 4, a, b)); - } break; - case fneg: { frame->pushInt(c->unaryOp(lir::FloatNegate, 4, frame->popInt())); } break; - case vm::frem: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - - frame->pushInt(c->binaryOp(lir::FloatRemainder, 4, a, b)); - } break; - - case fsub: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - - frame->pushInt(c->binaryOp(lir::FloatSubtract, 4, a, b)); - } break; - case getfield: case getstatic: { uint16_t index = codeReadInt16(t, code, ip); @@ -5015,16 +5017,18 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, (c->load(TargetBytesPerWord, 2, frame->popInt(), TargetBytesPerWord)); } break; - case iadd: { + case iadd: + case iand: + case ior: + case ishl: + case ishr: + case iushr: + case isub: + case ixor: + case imul: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::Add, 4, a, b)); - } break; - - case iand: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::And, 4, a, b)); + frame->pushInt(c->binaryOp(toCompilerBinaryOp(t, instruction), 4, a, b)); } break; case iconst_m1: @@ -5231,12 +5235,6 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->loadInt(3); break; - case imul: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::Multiply, 4, a, b)); - } break; - case ineg: { frame->pushInt(c->unaryOp(lir::Negate, 4, frame->popInt())); } break; @@ -5467,12 +5465,6 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, } } break; - case ior: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::Or, 4, a, b)); - } break; - case irem: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popInt(); @@ -5491,18 +5483,6 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, c->return_(4, frame->popInt()); } goto next; - case ishl: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::ShiftLeft, 4, a, b)); - } break; - - case ishr: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::ShiftRight, 4, a, b)); - } break; - case istore: case fstore: frame->storeInt(codeBody(t, code, ip++)); @@ -5528,24 +5508,6 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->storeInt(3); break; - case isub: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::Subtract, 4, a, b)); - } break; - - case iushr: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::UnsignedShiftRight, 4, a, b)); - } break; - - case ixor: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popInt(); - frame->pushInt(c->binaryOp(lir::Xor, 4, a, b)); - } break; - case jsr: case jsr_w: { uint32_t thisIp; @@ -5584,16 +5546,15 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->pushInt(c->load(8, 8, frame->popLong(), TargetBytesPerWord)); break; - case ladd: { + case ladd: + case land: + case lor: + case lsub: + case lxor: + case lmul: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::Add, 8, a, b)); - } break; - - case land: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::And, 8, a, b)); + frame->pushLong(c->binaryOp(toCompilerBinaryOp(t, instruction), 8, a, b)); } break; case lcmp: { @@ -5733,12 +5694,6 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->loadLong(3); break; - case lmul: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::Multiply, 8, a, b)); - } break; - case lneg: frame->pushLong(c->unaryOp(lir::Negate, 8, frame->popLong())); break; @@ -5803,12 +5758,6 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, } } break; - case lor: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::Or, 8, a, b)); - } break; - case lrem: { Compiler::Operand* a = frame->popLong(); Compiler::Operand* b = frame->popLong(); @@ -5827,16 +5776,12 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, c->return_(8, frame->popLong()); } goto next; - case lshl: { + case lshl: + case lshr: + case lushr: { Compiler::Operand* a = frame->popInt(); Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::ShiftLeft, 8, a, b)); - } break; - - case lshr: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::ShiftRight, 8, a, b)); + frame->pushLong(c->binaryOp(toCompilerBinaryOp(t, instruction), 8, a, b)); } break; case lstore: @@ -5864,24 +5809,6 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, frame->storeLong(3); break; - case lsub: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::Subtract, 8, a, b)); - } break; - - case lushr: { - Compiler::Operand* a = frame->popInt(); - Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::UnsignedShiftRight, 8, a, b)); - } break; - - case lxor: { - Compiler::Operand* a = frame->popLong(); - Compiler::Operand* b = frame->popLong(); - frame->pushLong(c->binaryOp(lir::Xor, 8, a, b)); - } break; - case monitorenter: { Compiler::Operand* target = frame->popObject(); c->call From b3d6f5d94db82f2aa9ce8605d20cf7accf589151 Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 22:20:18 -0700 Subject: [PATCH 7/9] Remove redundancy in compiling jump operations --- src/compile.cpp | 180 +++++++++++++++++++++--------------------------- 1 file changed, 77 insertions(+), 103 deletions(-) diff --git a/src/compile.cpp b/src/compile.cpp index c99214bfd2..ed0afb2b9f 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -3815,6 +3815,35 @@ isReferenceTailCall(MyThread* t, object code, unsigned ip, object caller, c, referenceName(t, calleeReference), referenceSpec(t, calleeReference)); } +lir::TernaryOperation toCompilerJumpOp(MyThread* t, unsigned instruction) { + switch(instruction) { + case ifeq: + case if_icmpeq: + case if_acmpeq: + case ifnull: + return lir::JumpIfEqual; + case ifne: + case if_icmpne: + case if_acmpne: + case ifnonnull: + return lir::JumpIfNotEqual; + case ifgt: + case if_icmpgt: + return lir::JumpIfGreater; + case ifge: + case if_icmpge: + return lir::JumpIfGreaterOrEqual; + case iflt: + case if_icmplt: + return lir::JumpIfLess; + case ifle: + case if_icmple: + return lir::JumpIfLessOrEqual; + default: + abort(t); + } +} + bool integerBranch(MyThread* t, Frame* frame, object code, unsigned& ip, unsigned size, Compiler::Operand* a, Compiler::Operand* b, @@ -3834,27 +3863,12 @@ integerBranch(MyThread* t, Frame* frame, object code, unsigned& ip, switch (instruction) { case ifeq: - c->condJump(lir::JumpIfEqual, size, a, b, target); - break; - case ifne: - c->condJump(lir::JumpIfNotEqual, size, a, b, target); - break; - case ifgt: - c->condJump(lir::JumpIfGreater, size, a, b, target); - break; - case ifge: - c->condJump(lir::JumpIfGreaterOrEqual, size, a, b, target); - break; - case iflt: - c->condJump(lir::JumpIfLess, size, a, b, target); - break; - case ifle: - c->condJump(lir::JumpIfLessOrEqual, size, a, b, target); + c->condJump(toCompilerJumpOp(t, instruction), size, a, b, target); break; default: @@ -3866,6 +3880,44 @@ integerBranch(MyThread* t, Frame* frame, object code, unsigned& ip, return true; } +lir::TernaryOperation toCompilerFloatJumpOp(MyThread* t, + unsigned instruction, + bool lessIfUnordered) +{ + switch(instruction) { + case ifeq: + return lir::JumpIfFloatEqual; + case ifne: + return lir::JumpIfFloatNotEqual; + case ifgt: + if (lessIfUnordered) { + return lir::JumpIfFloatGreater; + } else { + return lir::JumpIfFloatGreaterOrUnordered; + } + case ifge: + if (lessIfUnordered) { + return lir::JumpIfFloatGreaterOrEqual; + } else { + return lir::JumpIfFloatGreaterOrEqualOrUnordered; + } + case iflt: + if (lessIfUnordered) { + return lir::JumpIfFloatLessOrUnordered; + } else { + return lir::JumpIfFloatLess; + } + case ifle: + if (lessIfUnordered) { + return lir::JumpIfFloatLessOrEqualOrUnordered; + } else { + return lir::JumpIfFloatLessOrEqual; + } + default: + abort(t); + } +} + bool floatBranch(MyThread* t, Frame* frame, object code, unsigned& ip, unsigned size, bool lessIfUnordered, Compiler::Operand* a, @@ -3885,44 +3937,16 @@ floatBranch(MyThread* t, Frame* frame, object code, unsigned& ip, switch (instruction) { case ifeq: - c->condJump(lir::JumpIfFloatEqual, size, a, b, target); - break; - case ifne: - c->condJump(lir::JumpIfFloatNotEqual, size, a, b, target); - break; - case ifgt: - if (lessIfUnordered) { - c->condJump(lir::JumpIfFloatGreater, size, a, b, target); - } else { - c->condJump(lir::JumpIfFloatGreaterOrUnordered, size, a, b, target); - } - break; - case ifge: - if (lessIfUnordered) { - c->condJump(lir::JumpIfFloatGreaterOrEqual, size, a, b, target); - } else { - c->condJump(lir::JumpIfFloatGreaterOrEqualOrUnordered, size, a, b, target); - } - break; - case iflt: - if (lessIfUnordered) { - c->condJump(lir::JumpIfFloatLessOrUnordered, size, a, b, target); - } else { - c->condJump(lir::JumpIfFloatLess, size, a, b, target); - } - break; - case ifle: - if (lessIfUnordered) { - c->condJump(lir::JumpIfFloatLessOrEqualOrUnordered, size, a, b, target); - } else { - c->condJump(lir::JumpIfFloatLessOrEqual, size, a, b, target); - } - break; + c->condJump(toCompilerFloatJumpOp(t, instruction, lessIfUnordered), + size, + a, + b, + target); default: ip -= 3; @@ -5085,11 +5109,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* b = frame->popObject(); Compiler::Operand* target = frame->machineIp(newIp); - if (instruction == if_acmpeq) { - c->condJump(lir::JumpIfEqual, TargetBytesPerWord, a, b, target); - } else { - c->condJump(lir::JumpIfNotEqual, TargetBytesPerWord, a, b, target); - } + c->condJump(toCompilerJumpOp(t, instruction), TargetBytesPerWord, a, b, target); } goto branch; case if_icmpeq: @@ -5110,28 +5130,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* b = frame->popInt(); Compiler::Operand* target = frame->machineIp(newIp); - switch (instruction) { - case if_icmpeq: - c->condJump(lir::JumpIfEqual, 4, a, b, target); - break; - case if_icmpne: - c->condJump(lir::JumpIfNotEqual, 4, a, b, target); - break; - case if_icmpgt: - c->condJump(lir::JumpIfGreater, 4, a, b, target); - break; - case if_icmpge: - c->condJump(lir::JumpIfGreaterOrEqual, 4, a, b, target); - break; - case if_icmplt: - c->condJump(lir::JumpIfLess, 4, a, b, target); - break; - case if_icmple: - c->condJump(lir::JumpIfLessOrEqual, 4, a, b, target); - break; - default: - abort(t); - } + c->condJump(toCompilerJumpOp(t, instruction), 4, a, b, target); } goto branch; case ifeq: @@ -5153,28 +5152,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* a = c->constant(0, Compiler::IntegerType); Compiler::Operand* b = frame->popInt(); - switch (instruction) { - case ifeq: - c->condJump(lir::JumpIfEqual, 4, a, b, target); - break; - case ifne: - c->condJump(lir::JumpIfNotEqual, 4, a, b, target); - break; - case ifgt: - c->condJump(lir::JumpIfGreater, 4, a, b, target); - break; - case ifge: - c->condJump(lir::JumpIfGreaterOrEqual, 4, a, b, target); - break; - case iflt: - c->condJump(lir::JumpIfLess, 4, a, b, target); - break; - case ifle: - c->condJump(lir::JumpIfLessOrEqual, 4, a, b, target); - break; - default: - abort(t); - } + c->condJump(toCompilerJumpOp(t, instruction), 4, a, b, target); } goto branch; case ifnull: @@ -5191,11 +5169,7 @@ compile(MyThread* t, Frame* initialFrame, unsigned initialIp, Compiler::Operand* b = frame->popObject(); Compiler::Operand* target = frame->machineIp(newIp); - if (instruction == ifnull) { - c->condJump(lir::JumpIfEqual, TargetBytesPerWord, a, b, target); - } else { - c->condJump(lir::JumpIfNotEqual, TargetBytesPerWord, a, b, target); - } + c->condJump(toCompilerJumpOp(t, instruction), TargetBytesPerWord, a, b, target); } goto branch; case iinc: { From f1c6b973731f5c63bc54ca9c598bcabefcadae48 Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 22:25:23 -0700 Subject: [PATCH 8/9] Reformat a few extra-long lines --- src/compile.cpp | 91 ++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 71 insertions(+), 20 deletions(-) diff --git a/src/compile.cpp b/src/compile.cpp index ed0afb2b9f..2cc9cb7eda 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -8740,7 +8740,12 @@ template int checkConstant(MyThread* t, size_t expected, T C::* field, const char* name) { size_t actual = reinterpret_cast(&(t->*field)) - reinterpret_cast(t); if(expected != actual) { - fprintf(stderr, "constant mismatch (%s): \n\tconstant says: %d\n\tc++ compiler says: %d\n", name, (unsigned) expected, (unsigned) actual); + fprintf(stderr, + "constant mismatch (%s): \n\tconstant says: %d\n\tc++ compiler " + "says: %d\n", + name, + (unsigned)expected, + (unsigned)actual); return 1; } return 0; @@ -8824,21 +8829,59 @@ class MyProcessor: public Processor { #if TARGET_BYTES_PER_WORD == BYTES_PER_WORD - int mismatches = - checkConstant(t, TARGET_THREAD_EXCEPTION, &Thread::exception, "TARGET_THREAD_EXCEPTION") + - checkConstant(t, TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT, &MyThread::exceptionStackAdjustment, "TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT") + - checkConstant(t, TARGET_THREAD_EXCEPTIONOFFSET, &MyThread::exceptionOffset, "TARGET_THREAD_EXCEPTIONOFFSET") + - checkConstant(t, TARGET_THREAD_EXCEPTIONHANDLER, &MyThread::exceptionHandler, "TARGET_THREAD_EXCEPTIONHANDLER") + - checkConstant(t, TARGET_THREAD_IP, &MyThread::ip, "TARGET_THREAD_IP") + - checkConstant(t, TARGET_THREAD_STACK, &MyThread::stack, "TARGET_THREAD_STACK") + - checkConstant(t, TARGET_THREAD_NEWSTACK, &MyThread::newStack, "TARGET_THREAD_NEWSTACK") + - checkConstant(t, TARGET_THREAD_TAILADDRESS, &MyThread::tailAddress, "TARGET_THREAD_TAILADDRESS") + - checkConstant(t, TARGET_THREAD_VIRTUALCALLTARGET, &MyThread::virtualCallTarget, "TARGET_THREAD_VIRTUALCALLTARGET") + - checkConstant(t, TARGET_THREAD_VIRTUALCALLINDEX, &MyThread::virtualCallIndex, "TARGET_THREAD_VIRTUALCALLINDEX") + - checkConstant(t, TARGET_THREAD_HEAPIMAGE, &MyThread::heapImage, "TARGET_THREAD_HEAPIMAGE") + - checkConstant(t, TARGET_THREAD_CODEIMAGE, &MyThread::codeImage, "TARGET_THREAD_CODEIMAGE") + - checkConstant(t, TARGET_THREAD_THUNKTABLE, &MyThread::thunkTable, "TARGET_THREAD_THUNKTABLE") + - checkConstant(t, TARGET_THREAD_STACKLIMIT, &MyThread::stackLimit, "TARGET_THREAD_STACKLIMIT"); + int mismatches + = checkConstant(t, + TARGET_THREAD_EXCEPTION, + &Thread::exception, + "TARGET_THREAD_EXCEPTION") + + checkConstant(t, + TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT, + &MyThread::exceptionStackAdjustment, + "TARGET_THREAD_EXCEPTIONSTACKADJUSTMENT") + + checkConstant(t, + TARGET_THREAD_EXCEPTIONOFFSET, + &MyThread::exceptionOffset, + "TARGET_THREAD_EXCEPTIONOFFSET") + + checkConstant(t, + TARGET_THREAD_EXCEPTIONHANDLER, + &MyThread::exceptionHandler, + "TARGET_THREAD_EXCEPTIONHANDLER") + + checkConstant( + t, TARGET_THREAD_IP, &MyThread::ip, "TARGET_THREAD_IP") + + checkConstant( + t, TARGET_THREAD_STACK, &MyThread::stack, "TARGET_THREAD_STACK") + + checkConstant(t, + TARGET_THREAD_NEWSTACK, + &MyThread::newStack, + "TARGET_THREAD_NEWSTACK") + + checkConstant(t, + TARGET_THREAD_TAILADDRESS, + &MyThread::tailAddress, + "TARGET_THREAD_TAILADDRESS") + + checkConstant(t, + TARGET_THREAD_VIRTUALCALLTARGET, + &MyThread::virtualCallTarget, + "TARGET_THREAD_VIRTUALCALLTARGET") + + checkConstant(t, + TARGET_THREAD_VIRTUALCALLINDEX, + &MyThread::virtualCallIndex, + "TARGET_THREAD_VIRTUALCALLINDEX") + + checkConstant(t, + TARGET_THREAD_HEAPIMAGE, + &MyThread::heapImage, + "TARGET_THREAD_HEAPIMAGE") + + checkConstant(t, + TARGET_THREAD_CODEIMAGE, + &MyThread::codeImage,, + "TARGET_THREAD_CODEIMAGE") + + checkConstant(t, + TARGET_THREAD_THUNKTABLE, + &MyThread::thunkTable, + "TARGET_THREAD_THUNKTABLE") + + checkConstant(t, + TARGET_THREAD_STACKLIMIT, + &MyThread::stackLimit, + "TARGET_THREAD_STACKLIMIT"); if(mismatches > 0) { fprintf(stderr, "%d constant mismatches\n", mismatches); @@ -9252,7 +9295,9 @@ class MyProcessor: public Processor { } virtual void addCompilationHandler(CompilationHandler* handler) { - compilationHandlers = new(allocator->allocate(sizeof(CompilationHandlerList))) CompilationHandlerList(compilationHandlers, handler); + compilationHandlers + = new (allocator->allocate(sizeof(CompilationHandlerList))) + CompilationHandlerList(compilationHandlers, handler); } virtual void compileMethod(Thread* vmt, Zone* zone, object* constants, @@ -9454,11 +9499,16 @@ logCompile(MyThread* t, const void* code, unsigned size, const char* class_, class_, name, spec); } - size_t nameLength = stringOrNullSize(class_) + stringOrNullSize(name) + stringOrNullSize(spec) + 2; + size_t nameLength = stringOrNullSize(class_) + stringOrNullSize(name) + + stringOrNullSize(spec) + 2; THREAD_RUNTIME_ARRAY(t, char, completeName, nameLength); - sprintf(RUNTIME_ARRAY_BODY(completeName), "%s.%s%s", stringOrNull(class_), stringOrNull(name), stringOrNull(spec)); + sprintf(RUNTIME_ARRAY_BODY(completeName), + "%s.%s%s", + stringOrNull(class_), + stringOrNull(name), + stringOrNull(spec)); MyProcessor* p = static_cast(t->m->processor); for(CompilationHandlerList* h = p->compilationHandlers; h; h = h->next) { @@ -9789,7 +9839,8 @@ fixupHeap(MyThread* t UNUSED, uintptr_t* map, unsigned size, uintptr_t* heap) if (number) { *p = reinterpret_cast(heap + (number - 1)) | mark; - // fprintf(stderr, "fixup %d: %d 0x%x\n", index, static_cast(number), static_cast(*p)); + // fprintf(stderr, "fixup %d: %d 0x%x\n", index, + // static_cast(number), static_cast(*p)); } else { *p = mark; } From fa65c67fbfd70f85a3d41e4246a7ae36df5516ca Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Wed, 18 Dec 2013 22:46:58 -0700 Subject: [PATCH 9/9] Extract independent runtime thunks into their own file --- include/avian/vm/codegen/runtime.h | 54 ++++++ makefile | 1 + src/codegen/runtime.cpp | 282 +++++++++++++++++++++++++++ src/compile.cpp | 297 +---------------------------- 4 files changed, 346 insertions(+), 288 deletions(-) create mode 100644 include/avian/vm/codegen/runtime.h create mode 100644 src/codegen/runtime.cpp diff --git a/include/avian/vm/codegen/runtime.h b/include/avian/vm/codegen/runtime.h new file mode 100644 index 0000000000..1142fab3c7 --- /dev/null +++ b/include/avian/vm/codegen/runtime.h @@ -0,0 +1,54 @@ +/* Copyright (c) 2008-2013, Avian Contributors + + Permission to use, copy, modify, and/or distribute this software + for any purpose with or without fee is hereby granted, provided + that the above copyright notice and this permission notice appear + in all copies. + + There is NO WARRANTY for this software. See license.txt for + details. */ + +#ifndef AVIAN_CODEGEN_RUNTIME_H +#define AVIAN_CODEGEN_RUNTIME_H + +namespace avian { +namespace codegen { +namespace runtime { + +int64_t compareDoublesG(uint64_t bi, uint64_t ai); +int64_t compareDoublesL(uint64_t bi, uint64_t ai); +int64_t compareFloatsG(uint32_t bi, uint32_t ai); +int64_t compareFloatsL(uint32_t bi, uint32_t ai); +int64_t compareLongs(uint64_t b, uint64_t a); +uint64_t addDouble(uint64_t b, uint64_t a); +uint64_t subtractDouble(uint64_t b, uint64_t a); +uint64_t multiplyDouble(uint64_t b, uint64_t a); +uint64_t divideDouble(uint64_t b, uint64_t a); +uint64_t moduloDouble(uint64_t b, uint64_t a); +uint64_t negateDouble(uint64_t a); +uint64_t squareRootDouble(uint64_t a); +uint64_t doubleToFloat(int64_t a); +int64_t doubleToInt(int64_t a); +int64_t doubleToLong(int64_t a); +uint64_t addFloat(uint32_t b, uint32_t a); +uint64_t subtractFloat(uint32_t b, uint32_t a); +uint64_t multiplyFloat(uint32_t b, uint32_t a); +uint64_t divideFloat(uint32_t b, uint32_t a); +uint64_t moduloFloat(uint32_t b, uint32_t a); +uint64_t negateFloat(uint32_t a); +uint64_t absoluteFloat(uint32_t a); +int64_t absoluteLong(int64_t a); +int64_t absoluteInt(int32_t a); +uint64_t floatToDouble(int32_t a); +int64_t floatToInt(int32_t a); +int64_t floatToLong(int32_t a); +uint64_t intToDouble(int32_t a); +uint64_t intToFloat(int32_t a); +uint64_t longToDouble(int64_t a); +uint64_t longToFloat(int64_t a); + +} // namespace runtime +} // namespace codegen +} // namespace avian + +#endif // AVIAN_CODEGEN_RUNTIME_H diff --git a/makefile b/makefile index fc3495cef9..9f8f63749d 100755 --- a/makefile +++ b/makefile @@ -1131,6 +1131,7 @@ compiler-sources = \ $(src)/codegen/compiler.cpp \ $(wildcard $(src)/codegen/compiler/*.cpp) \ $(src)/codegen/registers.cpp \ + $(src)/codegen/runtime.cpp \ $(src)/codegen/targets.cpp x86-assembler-sources = $(wildcard $(src)/codegen/target/x86/*.cpp) diff --git a/src/codegen/runtime.cpp b/src/codegen/runtime.cpp new file mode 100644 index 0000000000..d18874ecc1 --- /dev/null +++ b/src/codegen/runtime.cpp @@ -0,0 +1,282 @@ +/* Copyright (c) 2008-2013, Avian Contributors + + Permission to use, copy, modify, and/or distribute this software + for any purpose with or without fee is hereby granted, provided + that the above copyright notice and this permission notice appear + in all copies. + + There is NO WARRANTY for this software. See license.txt for + details. */ + +#include + +namespace avian { +namespace codegen { +namespace runtime { + +static bool isNaN(double v) +{ + return fpclassify(v) == FP_NAN; +} + +static bool isNaN(float v) +{ + return fpclassify(v) == FP_NAN; +} + +int64_t compareDoublesG(uint64_t bi, uint64_t ai) +{ + double a = vm::bitsToDouble(ai); + double b = vm::bitsToDouble(bi); + + if (isNaN(a) or isNaN(b)) { + return 1; + } else if (a < b) { + return -1; + } else if (a > b) { + return 1; + } else if (a == b) { + return 0; + } else { + return 1; + } +} + +int64_t compareDoublesL(uint64_t bi, uint64_t ai) +{ + double a = vm::bitsToDouble(ai); + double b = vm::bitsToDouble(bi); + + if (isNaN(a) or isNaN(b)) { + return -1; + } else if (a < b) { + return -1; + } else if (a > b) { + return 1; + } else if (a == b) { + return 0; + } else { + return -1; + } +} + +int64_t compareFloatsG(uint32_t bi, uint32_t ai) +{ + float a = vm::bitsToFloat(ai); + float b = vm::bitsToFloat(bi); + + if (isNaN(a) or isNaN(b)) { + return 1; + } + if (a < b) { + return -1; + } else if (a > b) { + return 1; + } else if (a == b) { + return 0; + } else { + return 1; + } +} + +int64_t compareFloatsL(uint32_t bi, uint32_t ai) +{ + float a = vm::bitsToFloat(ai); + float b = vm::bitsToFloat(bi); + + if (isNaN(a) or isNaN(b)) { + return -1; + } + if (a < b) { + return -1; + } else if (a > b) { + return 1; + } else if (a == b) { + return 0; + } else { + return -1; + } +} + +int64_t compareLongs(uint64_t b, uint64_t a) +{ + if (a < b) { + return -1; + } else if (a > b) { + return 1; + } else { + return 0; + } +} + +uint64_t addDouble(uint64_t b, uint64_t a) +{ + return vm::doubleToBits(vm::bitsToDouble(a) + vm::bitsToDouble(b)); +} + +uint64_t subtractDouble(uint64_t b, uint64_t a) +{ + return vm::doubleToBits(vm::bitsToDouble(a) - vm::bitsToDouble(b)); +} + +uint64_t multiplyDouble(uint64_t b, uint64_t a) +{ + return vm::doubleToBits(vm::bitsToDouble(a) * vm::bitsToDouble(b)); +} + +uint64_t divideDouble(uint64_t b, uint64_t a) +{ + return vm::doubleToBits(vm::bitsToDouble(a) / vm::bitsToDouble(b)); +} + +uint64_t moduloDouble(uint64_t b, uint64_t a) +{ + return vm::doubleToBits(fmod(vm::bitsToDouble(a), vm::bitsToDouble(b))); +} + +uint64_t negateDouble(uint64_t a) +{ + return vm::doubleToBits(-vm::bitsToDouble(a)); +} + +uint64_t squareRootDouble(uint64_t a) +{ + return vm::doubleToBits(sqrt(vm::bitsToDouble(a))); +} + +uint64_t doubleToFloat(int64_t a) +{ + return vm::floatToBits(static_cast(vm::bitsToDouble(a))); +} + +int64_t doubleToInt(int64_t a) +{ + double f = vm::bitsToDouble(a); + switch (fpclassify(f)) { + case FP_NAN: + return 0; + case FP_INFINITE: + return signbit(f) ? INT32_MIN : INT32_MAX; + default: + return f >= INT32_MAX + ? INT32_MAX + : (f <= INT32_MIN ? INT32_MIN : static_cast(f)); + } +} + +int64_t doubleToLong(int64_t a) +{ + double f = vm::bitsToDouble(a); + switch (fpclassify(f)) { + case FP_NAN: + return 0; + case FP_INFINITE: + return signbit(f) ? INT64_MIN : INT64_MAX; + default: + return f >= INT64_MAX + ? INT64_MAX + : (f <= INT64_MIN ? INT64_MIN : static_cast(f)); + } +} + +uint64_t addFloat(uint32_t b, uint32_t a) +{ + return vm::floatToBits(vm::bitsToFloat(a) + vm::bitsToFloat(b)); +} + +uint64_t subtractFloat(uint32_t b, uint32_t a) +{ + return vm::floatToBits(vm::bitsToFloat(a) - vm::bitsToFloat(b)); +} + +uint64_t multiplyFloat(uint32_t b, uint32_t a) +{ + return vm::floatToBits(vm::bitsToFloat(a) * vm::bitsToFloat(b)); +} + +uint64_t divideFloat(uint32_t b, uint32_t a) +{ + return vm::floatToBits(vm::bitsToFloat(a) / vm::bitsToFloat(b)); +} + +uint64_t moduloFloat(uint32_t b, uint32_t a) +{ + return vm::floatToBits(fmod(vm::bitsToFloat(a), vm::bitsToFloat(b))); +} + +uint64_t negateFloat(uint32_t a) +{ + return vm::floatToBits(-vm::bitsToFloat(a)); +} + +uint64_t absoluteFloat(uint32_t a) +{ + return vm::floatToBits(fabsf(vm::bitsToFloat(a))); +} + +int64_t absoluteLong(int64_t a) +{ + return a > 0 ? a : -a; +} + +int64_t absoluteInt(int32_t a) +{ + return a > 0 ? a : -a; +} + +uint64_t floatToDouble(int32_t a) +{ + return vm::doubleToBits(static_cast(vm::bitsToFloat(a))); +} + +int64_t floatToInt(int32_t a) +{ + float f = vm::bitsToFloat(a); + switch (fpclassify(f)) { + case FP_NAN: + return 0; + case FP_INFINITE: + return signbit(f) ? INT32_MIN : INT32_MAX; + default: + return f >= INT32_MAX + ? INT32_MAX + : (f <= INT32_MIN ? INT32_MIN : static_cast(f)); + } +} + +int64_t floatToLong(int32_t a) +{ + float f = vm::bitsToFloat(a); + switch (fpclassify(f)) { + case FP_NAN: + return 0; + case FP_INFINITE: + return signbit(f) ? INT64_MIN : INT64_MAX; + default: + return static_cast(f); + } +} + +uint64_t intToDouble(int32_t a) +{ + return vm::doubleToBits(static_cast(a)); +} + +uint64_t intToFloat(int32_t a) +{ + return vm::floatToBits(static_cast(a)); +} + +uint64_t longToDouble(int64_t a) +{ + return vm::doubleToBits(static_cast(a)); +} + +uint64_t longToFloat(int64_t a) +{ + return vm::floatToBits(static_cast(a)); +} + +} // namespace runtime +} // namespace codegen +} // namespace avian diff --git a/src/compile.cpp b/src/compile.cpp index 2cc9cb7eda..cfa1aef6c4 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -20,6 +20,7 @@ #include #include #include +#include #include #include @@ -2460,232 +2461,6 @@ getJClassFromReference(MyThread* t, object pair) referenceName(t, pairSecond(t, pair))))); } -bool -isNaN(double v) -{ - return fpclassify(v) == FP_NAN; -} - -bool -isNaN(float v) -{ - return fpclassify(v) == FP_NAN; -} - -int64_t -compareDoublesG(uint64_t bi, uint64_t ai) -{ - double a = bitsToDouble(ai); - double b = bitsToDouble(bi); - - if (isNaN(a) or isNaN(b)) { - return 1; - } else if (a < b) { - return -1; - } else if (a > b) { - return 1; - } else if (a == b) { - return 0; - } else { - return 1; - } -} - -int64_t -compareDoublesL(uint64_t bi, uint64_t ai) -{ - double a = bitsToDouble(ai); - double b = bitsToDouble(bi); - - if (isNaN(a) or isNaN(b)) { - return -1; - } else if (a < b) { - return -1; - } else if (a > b) { - return 1; - } else if (a == b) { - return 0; - } else { - return -1; - } -} - -int64_t -compareFloatsG(uint32_t bi, uint32_t ai) -{ - float a = bitsToFloat(ai); - float b = bitsToFloat(bi); - - if (isNaN(a) or isNaN(b)) { - return 1; - } if (a < b) { - return -1; - } else if (a > b) { - return 1; - } else if (a == b) { - return 0; - } else { - return 1; - } -} - -int64_t -compareFloatsL(uint32_t bi, uint32_t ai) -{ - float a = bitsToFloat(ai); - float b = bitsToFloat(bi); - - if (isNaN(a) or isNaN(b)) { - return -1; - } if (a < b) { - return -1; - } else if (a > b) { - return 1; - } else if (a == b) { - return 0; - } else { - return -1; - } -} - -int64_t -compareLongs(uint64_t b, uint64_t a) -{ - if (a < b) { - return -1; - } else if (a > b) { - return 1; - } else { - return 0; - } -} - -uint64_t -addDouble(uint64_t b, uint64_t a) -{ - return doubleToBits(bitsToDouble(a) + bitsToDouble(b)); -} - -uint64_t -subtractDouble(uint64_t b, uint64_t a) -{ - return doubleToBits(bitsToDouble(a) - bitsToDouble(b)); -} - -uint64_t -multiplyDouble(uint64_t b, uint64_t a) -{ - return doubleToBits(bitsToDouble(a) * bitsToDouble(b)); -} - -uint64_t -divideDouble(uint64_t b, uint64_t a) -{ - return doubleToBits(bitsToDouble(a) / bitsToDouble(b)); -} - -uint64_t -moduloDouble(uint64_t b, uint64_t a) -{ - return doubleToBits(fmod(bitsToDouble(a), bitsToDouble(b))); -} - -uint64_t -negateDouble(uint64_t a) -{ - return doubleToBits(- bitsToDouble(a)); -} - -uint64_t -squareRootDouble(uint64_t a) -{ - return doubleToBits(sqrt(bitsToDouble(a))); -} - -uint64_t -doubleToFloat(int64_t a) -{ - return floatToBits(static_cast(bitsToDouble(a))); -} - -int64_t -doubleToInt(int64_t a) -{ - double f = bitsToDouble(a); - switch (fpclassify(f)) { - case FP_NAN: return 0; - case FP_INFINITE: return signbit(f) ? INT32_MIN : INT32_MAX; - default: return f >= INT32_MAX ? INT32_MAX - : (f <= INT32_MIN ? INT32_MIN : static_cast(f)); - } -} - -int64_t -doubleToLong(int64_t a) -{ - double f = bitsToDouble(a); - switch (fpclassify(f)) { - case FP_NAN: return 0; - case FP_INFINITE: return signbit(f) ? INT64_MIN : INT64_MAX; - default: return f >= INT64_MAX ? INT64_MAX - : (f <= INT64_MIN ? INT64_MIN : static_cast(f)); - } -} - -uint64_t -addFloat(uint32_t b, uint32_t a) -{ - return floatToBits(bitsToFloat(a) + bitsToFloat(b)); -} - -uint64_t -subtractFloat(uint32_t b, uint32_t a) -{ - return floatToBits(bitsToFloat(a) - bitsToFloat(b)); -} - -uint64_t -multiplyFloat(uint32_t b, uint32_t a) -{ - return floatToBits(bitsToFloat(a) * bitsToFloat(b)); -} - -uint64_t -divideFloat(uint32_t b, uint32_t a) -{ - return floatToBits(bitsToFloat(a) / bitsToFloat(b)); -} - -uint64_t -moduloFloat(uint32_t b, uint32_t a) -{ - return floatToBits(fmod(bitsToFloat(a), bitsToFloat(b))); -} - -uint64_t -negateFloat(uint32_t a) -{ - return floatToBits(- bitsToFloat(a)); -} - -uint64_t -absoluteFloat(uint32_t a) -{ - return floatToBits(fabsf(bitsToFloat(a))); -} - -int64_t -absoluteLong(int64_t a) -{ - return a > 0 ? a : -a; -} - -int64_t -absoluteInt(int32_t a) -{ - return a > 0 ? a : -a; -} - unsigned traceSize(Thread* t) { @@ -2722,8 +2497,7 @@ throwArithmetic(MyThread* t) } } -int64_t -divideLong(MyThread* t, int64_t b, int64_t a) +int64_t divideLong(MyThread* t, int64_t b, int64_t a) { if (LIKELY(b)) { return a / b; @@ -2732,8 +2506,7 @@ divideLong(MyThread* t, int64_t b, int64_t a) } } -int64_t -divideInt(MyThread* t, int32_t b, int32_t a) +int64_t divideInt(MyThread* t, int32_t b, int32_t a) { if (LIKELY(b)) { return a / b; @@ -2742,8 +2515,7 @@ divideInt(MyThread* t, int32_t b, int32_t a) } } -int64_t -moduloLong(MyThread* t, int64_t b, int64_t a) +int64_t moduloLong(MyThread* t, int64_t b, int64_t a) { if (LIKELY(b)) { return a % b; @@ -2752,8 +2524,7 @@ moduloLong(MyThread* t, int64_t b, int64_t a) } } -int64_t -moduloInt(MyThread* t, int32_t b, int32_t a) +int64_t moduloInt(MyThread* t, int32_t b, int32_t a) { if (LIKELY(b)) { return a % b; @@ -2762,59 +2533,6 @@ moduloInt(MyThread* t, int32_t b, int32_t a) } } -uint64_t -floatToDouble(int32_t a) -{ - return doubleToBits(static_cast(bitsToFloat(a))); -} - -int64_t -floatToInt(int32_t a) -{ - float f = bitsToFloat(a); - switch (fpclassify(f)) { - case FP_NAN: return 0; - case FP_INFINITE: return signbit(f) ? INT32_MIN : INT32_MAX; - default: return f >= INT32_MAX ? INT32_MAX - : (f <= INT32_MIN ? INT32_MIN : static_cast(f)); - } -} - -int64_t -floatToLong(int32_t a) -{ - float f = bitsToFloat(a); - switch (fpclassify(f)) { - case FP_NAN: return 0; - case FP_INFINITE: return signbit(f) ? INT64_MIN : INT64_MAX; - default: return static_cast(f); - } -} - -uint64_t -intToDouble(int32_t a) -{ - return doubleToBits(static_cast(a)); -} - -uint64_t -intToFloat(int32_t a) -{ - return floatToBits(static_cast(a)); -} - -uint64_t -longToDouble(int64_t a) -{ - return doubleToBits(static_cast(a)); -} - -uint64_t -longToFloat(int64_t a) -{ - return floatToBits(static_cast(a)); -} - uint64_t makeBlankObjectArray(MyThread* t, object class_, int32_t length) { @@ -8803,6 +8521,9 @@ class MyProcessor: public Processor { thunkTable[throwArrayIndexOutOfBoundsIndex] = voidPointer (throwArrayIndexOutOfBounds); thunkTable[throwStackOverflowIndex] = voidPointer(throwStackOverflow); + + using namespace avian::codegen::runtime; + #define THUNK(s) thunkTable[s##Index] = voidPointer(s); #include "thunks.cpp" #undef THUNK @@ -8872,7 +8593,7 @@ class MyProcessor: public Processor { "TARGET_THREAD_HEAPIMAGE") + checkConstant(t, TARGET_THREAD_CODEIMAGE, - &MyThread::codeImage,, + &MyThread::codeImage, "TARGET_THREAD_CODEIMAGE") + checkConstant(t, TARGET_THREAD_THUNKTABLE,