2009-03-15 18:02:36 +00:00
|
|
|
/* Copyright (c) 2008-2009, Avian Contributors
|
2008-02-19 18:06:52 +00:00
|
|
|
|
|
|
|
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. */
|
|
|
|
|
2007-11-20 16:21:17 +00:00
|
|
|
#ifndef COMPILER_H
|
|
|
|
#define COMPILER_H
|
|
|
|
|
2007-11-21 22:15:33 +00:00
|
|
|
#include "system.h"
|
2007-12-31 22:40:56 +00:00
|
|
|
#include "zone.h"
|
2008-02-11 17:21:41 +00:00
|
|
|
#include "assembler.h"
|
2007-11-21 22:15:33 +00:00
|
|
|
|
2007-11-20 16:21:17 +00:00
|
|
|
namespace vm {
|
|
|
|
|
2009-04-27 01:53:42 +00:00
|
|
|
class TraceHandler {
|
|
|
|
public:
|
|
|
|
virtual void handleTrace(Promise* address, unsigned argumentIndex) = 0;
|
|
|
|
};
|
|
|
|
|
2007-11-20 16:21:17 +00:00
|
|
|
class Compiler {
|
|
|
|
public:
|
2008-05-31 22:14:27 +00:00
|
|
|
class Client {
|
|
|
|
public:
|
2009-08-06 16:17:48 +00:00
|
|
|
virtual intptr_t getThunk(UnaryOperation op, unsigned size) = 0;
|
2009-08-06 14:48:15 +00:00
|
|
|
virtual intptr_t getThunk(BinaryOperation op, unsigned size, unsigned resultSize) = 0;
|
|
|
|
virtual intptr_t getThunk(TernaryOperation op, unsigned size, unsigned resultSize) = 0;
|
2008-05-31 22:14:27 +00:00
|
|
|
};
|
|
|
|
|
2008-02-11 17:21:41 +00:00
|
|
|
static const unsigned Aligned = 1 << 0;
|
|
|
|
static const unsigned NoReturn = 1 << 1;
|
2009-04-22 01:39:25 +00:00
|
|
|
static const unsigned TailJump = 1 << 2;
|
2007-12-30 22:24:48 +00:00
|
|
|
|
2008-02-11 17:21:41 +00:00
|
|
|
class Operand { };
|
2008-09-13 21:09:26 +00:00
|
|
|
class State { };
|
2008-11-14 00:59:21 +00:00
|
|
|
class Subroutine { };
|
2007-12-30 22:24:48 +00:00
|
|
|
|
2008-09-13 21:09:26 +00:00
|
|
|
virtual State* saveState() = 0;
|
|
|
|
virtual void restoreState(State* state) = 0;
|
2008-02-11 17:21:41 +00:00
|
|
|
|
2008-11-14 00:59:21 +00:00
|
|
|
virtual Subroutine* startSubroutine() = 0;
|
|
|
|
virtual void endSubroutine(Subroutine* subroutine) = 0;
|
2009-07-20 14:26:01 +00:00
|
|
|
virtual void linkSubroutine(Subroutine* subroutine) = 0;
|
2008-11-14 00:59:21 +00:00
|
|
|
|
2008-05-19 04:31:52 +00:00
|
|
|
virtual void init(unsigned logicalCodeSize, unsigned parameterFootprint,
|
2008-09-28 19:00:52 +00:00
|
|
|
unsigned localFootprint, unsigned alignedFrameSize) = 0;
|
2008-02-11 17:21:41 +00:00
|
|
|
|
|
|
|
virtual void visitLogicalIp(unsigned logicalIp) = 0;
|
|
|
|
virtual void startLogicalIp(unsigned logicalIp) = 0;
|
|
|
|
|
2007-12-16 00:24:15 +00:00
|
|
|
virtual Promise* machineIp(unsigned logicalIp) = 0;
|
2007-11-26 23:15:53 +00:00
|
|
|
|
2008-02-11 17:21:41 +00:00
|
|
|
virtual Promise* poolAppend(intptr_t value) = 0;
|
|
|
|
virtual Promise* poolAppendPromise(Promise* value) = 0;
|
2007-11-21 22:15:33 +00:00
|
|
|
|
2009-08-10 19:20:23 +00:00
|
|
|
virtual Operand* constant(int64_t value, unsigned code) = 0;
|
|
|
|
virtual Operand* promiseConstant(Promise* value, unsigned code) = 0;
|
2008-02-11 17:21:41 +00:00
|
|
|
virtual Operand* address(Promise* address) = 0;
|
2007-12-30 22:24:48 +00:00
|
|
|
virtual Operand* memory(Operand* base,
|
2009-08-10 19:20:23 +00:00
|
|
|
unsigned code,
|
2007-12-30 22:24:48 +00:00
|
|
|
int displacement = 0,
|
|
|
|
Operand* index = 0,
|
2008-04-09 19:08:13 +00:00
|
|
|
unsigned scale = 1) = 0;
|
2007-12-16 00:24:15 +00:00
|
|
|
|
2009-04-07 00:34:12 +00:00
|
|
|
virtual Operand* register_(int number) = 0;
|
2007-11-21 22:15:33 +00:00
|
|
|
|
2008-11-02 22:25:51 +00:00
|
|
|
virtual void push(unsigned footprint) = 0;
|
|
|
|
virtual void push(unsigned footprint, Operand* value) = 0;
|
2008-11-07 00:39:38 +00:00
|
|
|
virtual void save(unsigned footprint, Operand* value) = 0;
|
2008-11-02 22:25:51 +00:00
|
|
|
virtual Operand* pop(unsigned footprint) = 0;
|
2008-07-05 20:21:13 +00:00
|
|
|
virtual void pushed() = 0;
|
2009-01-30 01:36:19 +00:00
|
|
|
virtual void popped(unsigned footprint) = 0;
|
2009-05-15 02:08:01 +00:00
|
|
|
virtual unsigned topOfStack() = 0;
|
2008-11-02 22:25:51 +00:00
|
|
|
virtual Operand* peek(unsigned footprint, unsigned index) = 0;
|
2008-02-11 17:21:41 +00:00
|
|
|
|
|
|
|
virtual Operand* call(Operand* address,
|
|
|
|
unsigned flags,
|
|
|
|
TraceHandler* traceHandler,
|
|
|
|
unsigned resultSize,
|
2009-08-10 19:20:23 +00:00
|
|
|
unsigned resultCode,
|
2008-02-11 17:21:41 +00:00
|
|
|
unsigned argumentCount,
|
|
|
|
...) = 0;
|
2008-02-12 02:06:12 +00:00
|
|
|
|
2008-07-05 20:21:13 +00:00
|
|
|
virtual Operand* stackCall(Operand* address,
|
|
|
|
unsigned flags,
|
|
|
|
TraceHandler* traceHandler,
|
|
|
|
unsigned resultSize,
|
2009-08-10 19:20:23 +00:00
|
|
|
unsigned resultCode,
|
2008-07-05 20:21:13 +00:00
|
|
|
unsigned argumentFootprint) = 0;
|
|
|
|
|
2008-02-12 02:06:12 +00:00
|
|
|
virtual void return_(unsigned size, Operand* value) = 0;
|
|
|
|
|
2009-08-10 19:20:23 +00:00
|
|
|
virtual void initLocal(unsigned size, unsigned index, unsigned code) = 0;
|
2008-09-25 00:48:32 +00:00
|
|
|
virtual void initLocalsFromLogicalIp(unsigned logicalIp) = 0;
|
2008-11-02 22:25:51 +00:00
|
|
|
virtual void storeLocal(unsigned footprint, Operand* src,
|
|
|
|
unsigned index) = 0;
|
|
|
|
virtual Operand* loadLocal(unsigned footprint, unsigned index) = 0;
|
2008-11-25 17:34:48 +00:00
|
|
|
virtual void saveLocals() = 0;
|
2008-05-19 04:31:52 +00:00
|
|
|
|
2008-05-31 22:14:27 +00:00
|
|
|
virtual void checkBounds(Operand* object, unsigned lengthOffset,
|
|
|
|
Operand* index, intptr_t handler) = 0;
|
|
|
|
|
2009-02-28 23:17:24 +00:00
|
|
|
virtual void store(unsigned srcSize, Operand* src, unsigned dstSize,
|
|
|
|
Operand* dst) = 0;
|
2009-03-06 17:56:11 +00:00
|
|
|
virtual Operand* load(unsigned srcSize, unsigned srcSelectSize, Operand* src,
|
|
|
|
unsigned dstSize) = 0;
|
|
|
|
virtual Operand* loadz(unsigned size, unsigned srcSelectSize, Operand* src,
|
|
|
|
unsigned dstSize) = 0;
|
2008-06-12 16:56:48 +00:00
|
|
|
virtual Operand* lcmp(Operand* a, Operand* b) = 0;
|
2008-02-12 02:06:12 +00:00
|
|
|
virtual void cmp(unsigned size, Operand* a, Operand* b) = 0;
|
2009-08-06 14:48:15 +00:00
|
|
|
virtual void fcmp(unsigned size, Operand* a, Operand* b) = 0;
|
2008-02-11 17:21:41 +00:00
|
|
|
virtual void jl(Operand* address) = 0;
|
|
|
|
virtual void jg(Operand* address) = 0;
|
|
|
|
virtual void jle(Operand* address) = 0;
|
|
|
|
virtual void jge(Operand* address) = 0;
|
|
|
|
virtual void je(Operand* address) = 0;
|
|
|
|
virtual void jne(Operand* address) = 0;
|
2009-08-10 19:20:23 +00:00
|
|
|
virtual void fjl(Operand* address) = 0;
|
|
|
|
virtual void fjg(Operand* address) = 0;
|
|
|
|
virtual void fjle(Operand* address) = 0;
|
|
|
|
virtual void fjge(Operand* address) = 0;
|
|
|
|
virtual void fje(Operand* address) = 0;
|
|
|
|
virtual void fjne(Operand* address) = 0;
|
|
|
|
virtual void fjuo(Operand* address) = 0;
|
2008-02-11 17:21:41 +00:00
|
|
|
virtual void jmp(Operand* address) = 0;
|
2009-04-26 02:54:36 +00:00
|
|
|
virtual void exit(Operand* address) = 0;
|
2008-02-12 02:06:12 +00:00
|
|
|
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;
|
2009-08-06 14:48:15 +00:00
|
|
|
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;
|
2008-02-12 02:06:12 +00:00
|
|
|
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;
|
2009-08-06 14:48:15 +00:00
|
|
|
virtual Operand* fneg(unsigned size, Operand* a) = 0;
|
2009-08-10 19:20:23 +00:00
|
|
|
virtual Operand* operation(BinaryOperation op, unsigned aSize, unsigned resSize, unsigned resCode, Operand* a) = 0;
|
|
|
|
virtual Operand* operation(TernaryOperation op, unsigned aSize, unsigned bSize, unsigned resSize, unsigned resCode, Operand* a, Operand* b) = 0;
|
2009-08-06 14:48:15 +00:00
|
|
|
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;
|
2008-02-11 17:21:41 +00:00
|
|
|
|
2009-03-03 03:18:15 +00:00
|
|
|
virtual void loadBarrier() = 0;
|
|
|
|
virtual void storeStoreBarrier() = 0;
|
|
|
|
virtual void storeLoadBarrier() = 0;
|
|
|
|
|
2008-02-11 17:21:41 +00:00
|
|
|
virtual unsigned compile() = 0;
|
2007-12-11 23:52:28 +00:00
|
|
|
virtual unsigned poolSize() = 0;
|
2008-02-11 17:21:41 +00:00
|
|
|
virtual void writeTo(uint8_t* dst) = 0;
|
2007-11-26 23:15:53 +00:00
|
|
|
|
2007-11-21 22:15:33 +00:00
|
|
|
virtual void dispose() = 0;
|
2007-11-20 16:21:17 +00:00
|
|
|
};
|
|
|
|
|
2007-11-21 22:15:33 +00:00
|
|
|
Compiler*
|
2008-05-06 21:13:02 +00:00
|
|
|
makeCompiler(System* system, Assembler* assembler, Zone* zone,
|
2008-05-31 22:14:27 +00:00
|
|
|
Compiler::Client* client);
|
2007-11-21 22:15:33 +00:00
|
|
|
|
2007-11-20 16:21:17 +00:00
|
|
|
} // namespace vm
|
|
|
|
|
|
|
|
#endif//COMPILER_H
|