begin merging target assembler multimethod code

This commit is contained in:
Joshua Warner 2013-02-24 22:38:58 -07:00
parent 82eec28856
commit 4d38873096
10 changed files with 80 additions and 65 deletions

View File

@ -21,6 +21,7 @@
#include "encode.h" #include "encode.h"
#include "operations.h" #include "operations.h"
#include "registers.h" #include "registers.h"
#include "../multimethod.h"
#include "alloc-vector.h" #include "alloc-vector.h"
#include <avian/util/abort.h> #include <avian/util/abort.h>
@ -769,7 +770,7 @@ class MyAssembler: public Assembler {
virtual void apply(lir::UnaryOperation op, OperandInfo a) virtual void apply(lir::UnaryOperation op, OperandInfo a)
{ {
arch_->con.unaryOperations[index(&(arch_->con), op, a.type)] arch_->con.unaryOperations[Multimethod::index(op, a.type)]
(&con, a.size, a.operand); (&con, a.size, a.operand);
} }

View File

@ -9,20 +9,17 @@
details. */ details. */
#include "context.h" #include "context.h"
#include "multimethod.h"
#include "operations.h" #include "operations.h"
#include "multimethod.h"
#include "../multimethod.h"
namespace avian { namespace avian {
namespace codegen { namespace codegen {
namespace arm { namespace arm {
using namespace util; using namespace util;
unsigned index(ArchitectureContext*, lir::UnaryOperation operation, lir::OperandType operand)
{
return operation + (lir::UnaryOperationCount * operand);
}
unsigned index(ArchitectureContext*, unsigned index(ArchitectureContext*,
lir::BinaryOperation operation, lir::BinaryOperation operation,
lir::OperandType operand1, lir::OperandType operand1,
@ -66,25 +63,25 @@ void populateTables(ArchitectureContext* con) {
zo[lir::StoreLoadBarrier] = memoryBarrier; zo[lir::StoreLoadBarrier] = memoryBarrier;
zo[lir::Trap] = trap; zo[lir::Trap] = trap;
uo[index(con, lir::LongCall, C)] = CAST1(longCallC); uo[Multimethod::index(lir::LongCall, C)] = CAST1(longCallC);
uo[index(con, lir::AlignedLongCall, C)] = CAST1(longCallC); uo[Multimethod::index(lir::AlignedLongCall, C)] = CAST1(longCallC);
uo[index(con, lir::LongJump, C)] = CAST1(longJumpC); uo[Multimethod::index(lir::LongJump, C)] = CAST1(longJumpC);
uo[index(con, lir::AlignedLongJump, C)] = CAST1(longJumpC); uo[Multimethod::index(lir::AlignedLongJump, C)] = CAST1(longJumpC);
uo[index(con, lir::Jump, R)] = CAST1(jumpR); uo[Multimethod::index(lir::Jump, R)] = CAST1(jumpR);
uo[index(con, lir::Jump, C)] = CAST1(jumpC); uo[Multimethod::index(lir::Jump, C)] = CAST1(jumpC);
uo[index(con, lir::AlignedJump, R)] = CAST1(jumpR); uo[Multimethod::index(lir::AlignedJump, R)] = CAST1(jumpR);
uo[index(con, lir::AlignedJump, C)] = CAST1(jumpC); uo[Multimethod::index(lir::AlignedJump, C)] = CAST1(jumpC);
uo[index(con, lir::Call, C)] = CAST1(callC); uo[Multimethod::index(lir::Call, C)] = CAST1(callC);
uo[index(con, lir::Call, R)] = CAST1(callR); uo[Multimethod::index(lir::Call, R)] = CAST1(callR);
uo[index(con, lir::AlignedCall, C)] = CAST1(callC); uo[Multimethod::index(lir::AlignedCall, C)] = CAST1(callC);
uo[index(con, lir::AlignedCall, R)] = CAST1(callR); uo[Multimethod::index(lir::AlignedCall, R)] = CAST1(callR);
bo[index(con, lir::Move, R, R)] = CAST2(moveRR); bo[index(con, lir::Move, R, R)] = CAST2(moveRR);
bo[index(con, lir::Move, C, R)] = CAST2(moveCR); bo[index(con, lir::Move, C, R)] = CAST2(moveCR);

View File

@ -23,8 +23,6 @@ namespace avian {
namespace codegen { namespace codegen {
namespace arm { namespace arm {
unsigned index(ArchitectureContext*, lir::UnaryOperation operation, lir::OperandType operand);
unsigned index(ArchitectureContext*, unsigned index(ArchitectureContext*,
lir::BinaryOperation operation, lir::BinaryOperation operation,
lir::OperandType operand1, lir::OperandType operand1,

View File

@ -0,0 +1,29 @@
/* Copyright (c) 2008-2012, 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_TARGET_MULTIMETHOD_H
#define AVIAN_CODEGEN_TARGET_MULTIMETHOD_H
namespace avian {
namespace codegen {
class Multimethod {
public:
inline static unsigned index(lir::UnaryOperation operation, lir::OperandType operand) {
return operation + (lir::UnaryOperationCount * operand);
}
};
} // namespace codegen
} // namespace avian
#endif // AVIAN_CODEGEN_TARGET_MULTIMETHOD_H

View File

@ -19,8 +19,9 @@
#include "context.h" #include "context.h"
#include "fixup.h" #include "fixup.h"
#include "block.h" #include "block.h"
#include "multimethod.h"
#include "operations.h" #include "operations.h"
#include "multimethod.h"
#include "../multimethod.h"
using namespace vm; using namespace vm;
using namespace avian::util; using namespace avian::util;
@ -824,7 +825,7 @@ class MyAssembler: public Assembler {
virtual void apply(lir::UnaryOperation op, OperandInfo a) virtual void apply(lir::UnaryOperation op, OperandInfo a)
{ {
arch_->c.unaryOperations[index(&(arch_->c), op, a.type)] arch_->c.unaryOperations[Multimethod::index(op, a.type)]
(&c, a.size, a.operand); (&c, a.size, a.operand);
} }

View File

@ -11,9 +11,10 @@
#include "context.h" #include "context.h"
#include "block.h" #include "block.h"
#include "common.h" #include "common.h"
#include "operations.h" #include "operations.h"
#include "multimethod.h" #include "multimethod.h"
#include "../multimethod.h"
namespace avian { namespace avian {
namespace codegen { namespace codegen {
@ -21,11 +22,6 @@ namespace powerpc {
using namespace util; using namespace util;
unsigned index(ArchitectureContext*, lir::UnaryOperation operation, lir::OperandType operand)
{
return operation + (lir::UnaryOperationCount * operand);
}
unsigned index(ArchitectureContext*, unsigned index(ArchitectureContext*,
lir::BinaryOperation operation, lir::BinaryOperation operation,
lir::OperandType operand1, lir::OperandType operand1,
@ -69,25 +65,25 @@ void populateTables(ArchitectureContext* c) {
zo[lir::StoreLoadBarrier] = memoryBarrier; zo[lir::StoreLoadBarrier] = memoryBarrier;
zo[lir::Trap] = trap; zo[lir::Trap] = trap;
uo[index(c, lir::LongCall, C)] = CAST1(longCallC); uo[Multimethod::index(lir::LongCall, C)] = CAST1(longCallC);
uo[index(c, lir::AlignedLongCall, C)] = CAST1(alignedLongCallC); uo[Multimethod::index(lir::AlignedLongCall, C)] = CAST1(alignedLongCallC);
uo[index(c, lir::LongJump, C)] = CAST1(longJumpC); uo[Multimethod::index(lir::LongJump, C)] = CAST1(longJumpC);
uo[index(c, lir::AlignedLongJump, C)] = CAST1(alignedLongJumpC); uo[Multimethod::index(lir::AlignedLongJump, C)] = CAST1(alignedLongJumpC);
uo[index(c, lir::Jump, R)] = CAST1(jumpR); uo[Multimethod::index(lir::Jump, R)] = CAST1(jumpR);
uo[index(c, lir::Jump, C)] = CAST1(jumpC); uo[Multimethod::index(lir::Jump, C)] = CAST1(jumpC);
uo[index(c, lir::AlignedJump, R)] = CAST1(jumpR); uo[Multimethod::index(lir::AlignedJump, R)] = CAST1(jumpR);
uo[index(c, lir::AlignedJump, C)] = CAST1(jumpC); uo[Multimethod::index(lir::AlignedJump, C)] = CAST1(jumpC);
uo[index(c, lir::Call, C)] = CAST1(callC); uo[Multimethod::index(lir::Call, C)] = CAST1(callC);
uo[index(c, lir::Call, R)] = CAST1(callR); uo[Multimethod::index(lir::Call, R)] = CAST1(callR);
uo[index(c, lir::AlignedCall, C)] = CAST1(callC); uo[Multimethod::index(lir::AlignedCall, C)] = CAST1(callC);
uo[index(c, lir::AlignedCall, R)] = CAST1(callR); uo[Multimethod::index(lir::AlignedCall, R)] = CAST1(callR);
bo[index(c, lir::Move, R, R)] = CAST2(moveRR); bo[index(c, lir::Move, R, R)] = CAST2(moveRR);
bo[index(c, lir::Move, C, R)] = CAST2(moveCR); bo[index(c, lir::Move, C, R)] = CAST2(moveCR);

View File

@ -20,9 +20,6 @@ namespace avian {
namespace codegen { namespace codegen {
namespace powerpc { namespace powerpc {
unsigned index(ArchitectureContext*, lir::UnaryOperation operation, lir::OperandType operand);
unsigned index(ArchitectureContext*, unsigned index(ArchitectureContext*,
lir::BinaryOperation operation, lir::BinaryOperation operation,
lir::OperandType operand1, lir::OperandType operand1,

View File

@ -39,6 +39,7 @@
#include "operations.h" #include "operations.h"
#include "detect.h" #include "detect.h"
#include "multimethod.h" #include "multimethod.h"
#include "../multimethod.h"
#define CAST1(x) reinterpret_cast<UnaryOperationType>(x) #define CAST1(x) reinterpret_cast<UnaryOperationType>(x)
#define CAST2(x) reinterpret_cast<BinaryOperationType>(x) #define CAST2(x) reinterpret_cast<BinaryOperationType>(x)
@ -1043,7 +1044,7 @@ class MyAssembler: public Assembler {
virtual void apply(lir::UnaryOperation op, OperandInfo a) virtual void apply(lir::UnaryOperation op, OperandInfo a)
{ {
arch_->c.unaryOperations[index(&(arch_->c), op, a.type)] arch_->c.unaryOperations[Multimethod::index(op, a.type)]
(&c, a.size, a.operand); (&c, a.size, a.operand);
} }

View File

@ -15,20 +15,17 @@
#include <avian/vm/codegen/lir.h> #include <avian/vm/codegen/lir.h>
#include "context.h" #include "context.h"
#include "multimethod.h"
#include "operations.h" #include "operations.h"
#include "multimethod.h"
#include "../multimethod.h"
namespace avian { namespace avian {
namespace codegen { namespace codegen {
namespace x86 { namespace x86 {
using namespace util; using namespace util;
unsigned index(ArchitectureContext*, lir::UnaryOperation operation, lir::OperandType operand) {
return operation + (lir::UnaryOperationCount * operand);
}
unsigned index(ArchitectureContext*, lir::BinaryOperation operation, unsigned index(ArchitectureContext*, lir::BinaryOperation operation,
lir::OperandType operand1, lir::OperandType operand1,
lir::OperandType operand2) lir::OperandType operand2)
@ -74,25 +71,25 @@ void populateTables(ArchitectureContext* c) {
zo[lir::StoreLoadBarrier] = storeLoadBarrier; zo[lir::StoreLoadBarrier] = storeLoadBarrier;
zo[lir::Trap] = trap; zo[lir::Trap] = trap;
uo[index(c, lir::Call, C)] = CAST1(callC); uo[Multimethod::index(lir::Call, C)] = CAST1(callC);
uo[index(c, lir::Call, R)] = CAST1(callR); uo[Multimethod::index(lir::Call, R)] = CAST1(callR);
uo[index(c, lir::Call, M)] = CAST1(callM); uo[Multimethod::index(lir::Call, M)] = CAST1(callM);
uo[index(c, lir::AlignedCall, C)] = CAST1(alignedCallC); uo[Multimethod::index(lir::AlignedCall, C)] = CAST1(alignedCallC);
uo[index(c, lir::LongCall, C)] = CAST1(longCallC); uo[Multimethod::index(lir::LongCall, C)] = CAST1(longCallC);
uo[index(c, lir::AlignedLongCall, C)] = CAST1(alignedLongCallC); uo[Multimethod::index(lir::AlignedLongCall, C)] = CAST1(alignedLongCallC);
uo[index(c, lir::Jump, R)] = CAST1(jumpR); uo[Multimethod::index(lir::Jump, R)] = CAST1(jumpR);
uo[index(c, lir::Jump, C)] = CAST1(jumpC); uo[Multimethod::index(lir::Jump, C)] = CAST1(jumpC);
uo[index(c, lir::Jump, M)] = CAST1(jumpM); uo[Multimethod::index(lir::Jump, M)] = CAST1(jumpM);
uo[index(c, lir::AlignedJump, C)] = CAST1(alignedJumpC); uo[Multimethod::index(lir::AlignedJump, C)] = CAST1(alignedJumpC);
uo[index(c, lir::LongJump, C)] = CAST1(longJumpC); uo[Multimethod::index(lir::LongJump, C)] = CAST1(longJumpC);
uo[index(c, lir::AlignedLongJump, C)] = CAST1(alignedLongJumpC); uo[Multimethod::index(lir::AlignedLongJump, C)] = CAST1(alignedLongJumpC);
bo[index(c, lir::Negate, R, R)] = CAST2(negateRR); bo[index(c, lir::Negate, R, R)] = CAST2(negateRR);

View File

@ -21,8 +21,6 @@ namespace x86 {
class ArchitectureContext; class ArchitectureContext;
unsigned index(ArchitectureContext*, lir::UnaryOperation operation, lir::OperandType operand);
unsigned index(ArchitectureContext*, lir::BinaryOperation operation, unsigned index(ArchitectureContext*, lir::BinaryOperation operation,
lir::OperandType operand1, lir::OperandType operand1,
lir::OperandType operand2); lir::OperandType operand2);