mirror of
https://github.com/corda/corda.git
synced 2025-01-21 03:55:00 +00:00
use ir::Type in place of Compiler::OperandType
This commit is contained in:
parent
d8914a9646
commit
704c05f818
@ -40,14 +40,6 @@ class Compiler {
|
||||
static const unsigned TailJump = 1 << 2;
|
||||
static const unsigned LongJumpOrCall = 1 << 3;
|
||||
|
||||
enum OperandType {
|
||||
ObjectType,
|
||||
AddressType,
|
||||
IntegerType,
|
||||
FloatType,
|
||||
VoidType
|
||||
};
|
||||
|
||||
class Operand { };
|
||||
class State { };
|
||||
class Subroutine { };
|
||||
@ -71,11 +63,11 @@ class Compiler {
|
||||
virtual Promise* poolAppend(intptr_t value) = 0;
|
||||
virtual Promise* poolAppendPromise(Promise* value) = 0;
|
||||
|
||||
virtual Operand* constant(int64_t value, OperandType type) = 0;
|
||||
virtual Operand* promiseConstant(Promise* value, OperandType type) = 0;
|
||||
virtual Operand* constant(int64_t value, ir::Type type) = 0;
|
||||
virtual Operand* promiseConstant(Promise* value, ir::Type type) = 0;
|
||||
virtual Operand* address(Promise* address) = 0;
|
||||
virtual Operand* memory(Operand* base,
|
||||
OperandType type,
|
||||
ir::Type type,
|
||||
int displacement = 0,
|
||||
Operand* index = 0,
|
||||
unsigned scale = 1) = 0;
|
||||
@ -94,7 +86,7 @@ class Compiler {
|
||||
unsigned flags,
|
||||
TraceHandler* traceHandler,
|
||||
unsigned resultSize,
|
||||
OperandType resultType,
|
||||
ir::Type resultType,
|
||||
unsigned argumentCount,
|
||||
...) = 0;
|
||||
|
||||
@ -102,7 +94,7 @@ class Compiler {
|
||||
unsigned flags,
|
||||
TraceHandler* traceHandler,
|
||||
unsigned resultSize,
|
||||
OperandType resultType,
|
||||
ir::Type resultType,
|
||||
unsigned argumentFootprint) = 0;
|
||||
|
||||
virtual void return_(ir::Type type, Operand* value) = 0;
|
||||
|
@ -30,6 +30,10 @@ class Type {
|
||||
// (double/long on 32-bit systems)
|
||||
// TODO: remove when possible
|
||||
Half,
|
||||
|
||||
// Represents the lack of a return value
|
||||
// TODO: remove when possible
|
||||
Void
|
||||
};
|
||||
|
||||
private:
|
||||
@ -91,6 +95,10 @@ class Types {
|
||||
// A 8-byte floating point type
|
||||
Type f8;
|
||||
|
||||
// A type representing the lack of a return value
|
||||
// TODO: remove when possible
|
||||
Type void_;
|
||||
|
||||
Types(unsigned bytesPerWord)
|
||||
: object(Type::Object, bytesPerWord),
|
||||
address(Type::Integer, bytesPerWord),
|
||||
@ -99,7 +107,8 @@ class Types {
|
||||
i4(Type::Integer, 4),
|
||||
i8(Type::Integer, 8),
|
||||
f4(Type::Float, 4),
|
||||
f8(Type::Float, 8)
|
||||
f8(Type::Float, 8),
|
||||
void_(Type::Void, 0)
|
||||
{
|
||||
}
|
||||
};
|
||||
|
@ -186,22 +186,6 @@ addBuddy(Value* original, Value* buddy)
|
||||
}
|
||||
}
|
||||
|
||||
lir::ValueType
|
||||
valueType(Context* c, Compiler::OperandType type)
|
||||
{
|
||||
switch (type) {
|
||||
case Compiler::ObjectType:
|
||||
case Compiler::AddressType:
|
||||
case Compiler::IntegerType:
|
||||
case Compiler::VoidType:
|
||||
return lir::ValueGeneral;
|
||||
case Compiler::FloatType:
|
||||
return lir::ValueFloat;
|
||||
default:
|
||||
abort(c);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
move(Context* c, Value* value, Site* src, Site* dst);
|
||||
|
||||
@ -2121,6 +2105,8 @@ unsigned typeFootprint(Context* c, ir::Type type)
|
||||
case ir::Type::Address:
|
||||
case ir::Type::Half:
|
||||
return 1;
|
||||
case ir::Type::Void:
|
||||
return 0;
|
||||
default:
|
||||
abort(c);
|
||||
}
|
||||
@ -2306,13 +2292,14 @@ class MyCompiler: public Compiler {
|
||||
return p;
|
||||
}
|
||||
|
||||
virtual Operand* constant(int64_t value, Compiler::OperandType type) {
|
||||
virtual Operand* constant(int64_t value, ir::Type type)
|
||||
{
|
||||
return promiseConstant(resolvedPromise(&c, value), type);
|
||||
}
|
||||
|
||||
virtual Operand* promiseConstant(Promise* value, Compiler::OperandType type) {
|
||||
return compiler::value
|
||||
(&c, valueType(&c, type), compiler::constantSite(&c, value));
|
||||
virtual Operand* promiseConstant(Promise* value, ir::Type type)
|
||||
{
|
||||
return compiler::value(&c, type, compiler::constantSite(&c, value));
|
||||
}
|
||||
|
||||
virtual Operand* address(Promise* address) {
|
||||
@ -2320,12 +2307,12 @@ class MyCompiler: public Compiler {
|
||||
}
|
||||
|
||||
virtual Operand* memory(Operand* base,
|
||||
OperandType type,
|
||||
ir::Type type,
|
||||
int displacement = 0,
|
||||
Operand* index = 0,
|
||||
unsigned scale = 1)
|
||||
{
|
||||
Value* result = value(&c, valueType(&c, type));
|
||||
Value* result = value(&c, type);
|
||||
|
||||
appendMemory(&c, static_cast<Value*>(base), displacement,
|
||||
static_cast<Value*>(index), scale, result);
|
||||
@ -2441,7 +2428,7 @@ class MyCompiler: public Compiler {
|
||||
unsigned flags,
|
||||
TraceHandler* traceHandler,
|
||||
unsigned resultSize,
|
||||
OperandType resultType,
|
||||
ir::Type resultType,
|
||||
unsigned argumentCount,
|
||||
...)
|
||||
{
|
||||
@ -2479,7 +2466,7 @@ class MyCompiler: public Compiler {
|
||||
(&c, RUNTIME_ARRAY_BODY(arguments)[i], argumentStack);
|
||||
}
|
||||
|
||||
Value* result = value(&c, valueType(&c, resultType));
|
||||
Value* result = value(&c, resultType);
|
||||
appendCall(&c, static_cast<Value*>(address), flags, traceHandler, result,
|
||||
resultSize, argumentStack, index, 0);
|
||||
|
||||
@ -2490,10 +2477,10 @@ class MyCompiler: public Compiler {
|
||||
unsigned flags,
|
||||
TraceHandler* traceHandler,
|
||||
unsigned resultSize,
|
||||
OperandType resultType,
|
||||
ir::Type resultType,
|
||||
unsigned argumentFootprint)
|
||||
{
|
||||
Value* result = value(&c, valueType(&c, resultType));
|
||||
Value* result = value(&c, resultType);
|
||||
appendCall(&c, static_cast<Value*>(address), flags, traceHandler, result,
|
||||
resultSize, c.stack, 0, argumentFootprint);
|
||||
return result;
|
||||
|
1373
src/compile.cpp
1373
src/compile.cpp
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user