Calling generated code. Woo.
This commit is contained in:
parent
e14d3379cb
commit
9ef2d1baf6
|
@ -120,8 +120,7 @@ int X64Assembler::Assemble(
|
||||||
|
|
||||||
X64Function* fn = new X64Function(symbol_info);
|
X64Function* fn = new X64Function(symbol_info);
|
||||||
fn->set_debug_info(debug_info);
|
fn->set_debug_info(debug_info);
|
||||||
|
fn->Setup(machine_code, code_size);
|
||||||
// TODO(benvanik): set mc
|
|
||||||
|
|
||||||
*out_function = fn;
|
*out_function = fn;
|
||||||
|
|
||||||
|
|
|
@ -20,12 +20,18 @@ using namespace alloy::runtime;
|
||||||
|
|
||||||
|
|
||||||
X64Function::X64Function(FunctionInfo* symbol_info) :
|
X64Function::X64Function(FunctionInfo* symbol_info) :
|
||||||
|
machine_code_(0), code_size_(0),
|
||||||
GuestFunction(symbol_info) {
|
GuestFunction(symbol_info) {
|
||||||
}
|
}
|
||||||
|
|
||||||
X64Function::~X64Function() {
|
X64Function::~X64Function() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void X64Function::Setup(void* machine_code, size_t code_size) {
|
||||||
|
machine_code_ = machine_code;
|
||||||
|
code_size_ = code_size;
|
||||||
|
}
|
||||||
|
|
||||||
int X64Function::AddBreakpointImpl(Breakpoint* breakpoint) {
|
int X64Function::AddBreakpointImpl(Breakpoint* breakpoint) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -35,5 +41,7 @@ int X64Function::RemoveBreakpointImpl(Breakpoint* breakpoint) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int X64Function::CallImpl(ThreadState* thread_state, uint64_t return_address) {
|
int X64Function::CallImpl(ThreadState* thread_state, uint64_t return_address) {
|
||||||
|
typedef void(*call_t)(ThreadState* thread_state, uint64_t return_address);
|
||||||
|
((call_t)machine_code_)(thread_state, return_address);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@ public:
|
||||||
X64Function(runtime::FunctionInfo* symbol_info);
|
X64Function(runtime::FunctionInfo* symbol_info);
|
||||||
virtual ~X64Function();
|
virtual ~X64Function();
|
||||||
|
|
||||||
//void Setup(TranslationContext& ctx);
|
void Setup(void* machine_code, size_t code_size);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual int AddBreakpointImpl(runtime::Breakpoint* breakpoint);
|
virtual int AddBreakpointImpl(runtime::Breakpoint* breakpoint);
|
||||||
|
@ -34,6 +34,8 @@ protected:
|
||||||
uint64_t return_address);
|
uint64_t return_address);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void* machine_code_;
|
||||||
|
size_t code_size_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue