mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-18 17:17:10 +00:00
ruby: spaces & indentation
This commit is contained in:
parent
a6b570d033
commit
16f77061d9
|
@ -76,7 +76,6 @@ end
|
||||||
|
|
||||||
# callback for OUT instruction
|
# callback for OUT instruction
|
||||||
HOOK_OUT = Proc.new do |uc, port, size, value, user_data|
|
HOOK_OUT = Proc.new do |uc, port, size, value, user_data|
|
||||||
|
|
||||||
eip = uc.reg_read(UC_X86_REG_EIP)
|
eip = uc.reg_read(UC_X86_REG_EIP)
|
||||||
puts("--- writing to port 0x%x, size: %u, value: 0x%x, address: 0x%x" % [port, size, value, eip])
|
puts("--- writing to port 0x%x, size: %u, value: 0x%x, address: 0x%x" % [port, size, value, eip])
|
||||||
|
|
||||||
|
@ -137,9 +136,8 @@ def test_i386()
|
||||||
tmp = mu.mem_read(ADDRESS, 2)
|
tmp = mu.mem_read(ADDRESS, 2)
|
||||||
print(">>> Read 2 bytes from [0x%x] =" % (ADDRESS))
|
print(">>> Read 2 bytes from [0x%x] =" % (ADDRESS))
|
||||||
tmp.each_byte { |i| print(" 0x%x" % i) }
|
tmp.each_byte { |i| print(" 0x%x" % i) }
|
||||||
|
|
||||||
|
puts
|
||||||
puts
|
|
||||||
|
|
||||||
rescue UcError => e
|
rescue UcError => e
|
||||||
puts("ERROR: %s" % e)
|
puts("ERROR: %s" % e)
|
||||||
|
@ -494,18 +492,18 @@ def test_x86_16()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
test_i386()
|
test_i386()
|
||||||
puts("=" * 20)
|
puts("=" * 20)
|
||||||
test_i386_loop()
|
test_i386_loop()
|
||||||
puts("=" * 20)
|
puts("=" * 20)
|
||||||
test_i386_invalid_mem_read()
|
test_i386_invalid_mem_read()
|
||||||
puts("=" * 20)
|
puts("=" * 20)
|
||||||
test_i386_invalid_mem_write()
|
test_i386_invalid_mem_write()
|
||||||
puts("=" * 20)
|
puts("=" * 20)
|
||||||
test_i386_inout()
|
test_i386_inout()
|
||||||
puts("=" * 20)
|
puts("=" * 20)
|
||||||
test_x86_64()
|
test_x86_64()
|
||||||
puts("=" * 20)
|
puts("=" * 20)
|
||||||
test_x86_64_syscall()
|
test_x86_64_syscall()
|
||||||
puts("=" * 20)
|
puts("=" * 20)
|
||||||
test_x86_16()
|
test_x86_16()
|
||||||
|
|
|
@ -28,7 +28,6 @@ VALUE UcClass = Qnil;
|
||||||
VALUE UcError = Qnil;
|
VALUE UcError = Qnil;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void Init_unicorn() {
|
void Init_unicorn() {
|
||||||
rb_require("unicorn/unicorn_const");
|
rb_require("unicorn/unicorn_const");
|
||||||
UnicornModule = rb_define_module("Unicorn");
|
UnicornModule = rb_define_module("Unicorn");
|
||||||
|
@ -72,7 +71,7 @@ VALUE m_uc_emu_start(int argc, VALUE* argv, VALUE self){
|
||||||
uc_err err;
|
uc_err err;
|
||||||
uc_engine *_uc;
|
uc_engine *_uc;
|
||||||
Data_Get_Struct(rb_iv_get(self,"@uch"), uc_engine, _uc);
|
Data_Get_Struct(rb_iv_get(self,"@uch"), uc_engine, _uc);
|
||||||
|
|
||||||
rb_scan_args(argc, argv, "22",&begin, &until, &timeout, &count);
|
rb_scan_args(argc, argv, "22",&begin, &until, &timeout, &count);
|
||||||
if (NIL_P(timeout))
|
if (NIL_P(timeout))
|
||||||
timeout = INT2NUM(0);
|
timeout = INT2NUM(0);
|
||||||
|
@ -100,7 +99,6 @@ VALUE m_uc_emu_stop(VALUE self){
|
||||||
}
|
}
|
||||||
|
|
||||||
VALUE m_uc_reg_read(VALUE self, VALUE reg_id){
|
VALUE m_uc_reg_read(VALUE self, VALUE reg_id){
|
||||||
|
|
||||||
uc_err err;
|
uc_err err;
|
||||||
int32_t tmp_reg = NUM2INT(reg_id);
|
int32_t tmp_reg = NUM2INT(reg_id);
|
||||||
int64_t reg_value = 0;
|
int64_t reg_value = 0;
|
||||||
|
@ -131,7 +129,6 @@ VALUE m_uc_reg_read(VALUE self, VALUE reg_id){
|
||||||
rb_ary_store(mmr_ary, 3, UINT2NUM(mmr.flags));
|
rb_ary_store(mmr_ary, 3, UINT2NUM(mmr.flags));
|
||||||
return mmr_ary;
|
return mmr_ary;
|
||||||
default:
|
default:
|
||||||
|
|
||||||
err = uc_reg_read(_uc, tmp_reg, ®_value);
|
err = uc_reg_read(_uc, tmp_reg, ®_value);
|
||||||
if (err != UC_ERR_OK) {
|
if (err != UC_ERR_OK) {
|
||||||
rb_raise(UcError, "%s", uc_strerror(err));
|
rb_raise(UcError, "%s", uc_strerror(err));
|
||||||
|
@ -155,7 +152,7 @@ VALUE m_uc_reg_write(VALUE self, VALUE reg_id, VALUE reg_value){
|
||||||
case UC_X86_REG_LDTR:
|
case UC_X86_REG_LDTR:
|
||||||
case UC_X86_REG_TR:
|
case UC_X86_REG_TR:
|
||||||
Check_Type(reg_value, T_ARRAY);
|
Check_Type(reg_value, T_ARRAY);
|
||||||
|
|
||||||
mmr.selector = NUM2USHORT(rb_ary_entry(reg_value,0));
|
mmr.selector = NUM2USHORT(rb_ary_entry(reg_value,0));
|
||||||
mmr.base = NUM2ULL(rb_ary_entry(reg_value,1));
|
mmr.base = NUM2ULL(rb_ary_entry(reg_value,1));
|
||||||
mmr.limit = NUM2UINT(rb_ary_entry(reg_value,2));
|
mmr.limit = NUM2UINT(rb_ary_entry(reg_value,2));
|
||||||
|
@ -220,7 +217,7 @@ VALUE m_uc_mem_map(int argc, VALUE* argv, VALUE self){
|
||||||
|
|
||||||
VALUE m_uc_mem_unmap(VALUE self, VALUE address, VALUE size){
|
VALUE m_uc_mem_unmap(VALUE self, VALUE address, VALUE size){
|
||||||
uc_err err;
|
uc_err err;
|
||||||
uc_engine *_uc;
|
uc_engine *_uc;
|
||||||
_uc = (uc_engine*) NUM2ULL(rb_iv_get(self, "@uch"));
|
_uc = (uc_engine*) NUM2ULL(rb_iv_get(self, "@uch"));
|
||||||
err = uc_mem_unmap(_uc, NUM2ULL(address), NUM2UINT(size));
|
err = uc_mem_unmap(_uc, NUM2ULL(address), NUM2UINT(size));
|
||||||
if (err != UC_ERR_OK) {
|
if (err != UC_ERR_OK) {
|
||||||
|
@ -231,7 +228,7 @@ VALUE m_uc_mem_unmap(VALUE self, VALUE address, VALUE size){
|
||||||
|
|
||||||
VALUE m_uc_mem_protect(VALUE self, VALUE address, VALUE size, VALUE perms){
|
VALUE m_uc_mem_protect(VALUE self, VALUE address, VALUE size, VALUE perms){
|
||||||
uc_err err;
|
uc_err err;
|
||||||
uc_engine *_uc;
|
uc_engine *_uc;
|
||||||
Data_Get_Struct(rb_iv_get(self,"@uch"), uc_engine, _uc);
|
Data_Get_Struct(rb_iv_get(self,"@uch"), uc_engine, _uc);
|
||||||
err = uc_mem_protect(_uc, NUM2ULL(address), NUM2UINT(size), NUM2UINT(perms));
|
err = uc_mem_protect(_uc, NUM2ULL(address), NUM2UINT(size), NUM2UINT(perms));
|
||||||
if (err != UC_ERR_OK) {
|
if (err != UC_ERR_OK) {
|
||||||
|
@ -250,7 +247,6 @@ static void cb_hook_code(uc_engine *uc, uint64_t address, uint32_t size, void *u
|
||||||
ud = rb_ary_entry(passthrough, 1);
|
ud = rb_ary_entry(passthrough, 1);
|
||||||
rUc = rb_ary_entry(passthrough, 2);
|
rUc = rb_ary_entry(passthrough, 2);
|
||||||
rb_funcall(cb, rb_intern("call"), 4, rUc, ULL2NUM(address), UINT2NUM(size), ud);
|
rb_funcall(cb, rb_intern("call"), 4, rUc, ULL2NUM(address), UINT2NUM(size), ud);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cb_hook_mem_access(uc_engine *uc, uint32_t access, uint64_t address, uint32_t size, int64_t value, void *user_data){
|
static void cb_hook_mem_access(uc_engine *uc, uint32_t access, uint64_t address, uint32_t size, int64_t value, void *user_data){
|
||||||
|
@ -264,7 +260,6 @@ static void cb_hook_mem_access(uc_engine *uc, uint32_t access, uint64_t address,
|
||||||
rUc = rb_ary_entry(passthrough, 2);
|
rUc = rb_ary_entry(passthrough, 2);
|
||||||
|
|
||||||
rb_funcall(cb, rb_intern("call"), 6, rUc, UINT2NUM(access), ULL2NUM(address), UINT2NUM(size), LL2NUM(value), ud);
|
rb_funcall(cb, rb_intern("call"), 6, rUc, UINT2NUM(access), ULL2NUM(address), UINT2NUM(size), LL2NUM(value), ud);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool cb_hook_mem_invalid(uc_engine *uc, uint32_t access, uint64_t address, uint32_t size, int64_t value, void *user_data){
|
static bool cb_hook_mem_invalid(uc_engine *uc, uint32_t access, uint64_t address, uint32_t size, int64_t value, void *user_data){
|
||||||
|
@ -289,7 +284,6 @@ static uint32_t cb_hook_insn_in(uc_engine *uc, uint32_t port, int size, void *us
|
||||||
ud = rb_ary_entry(passthrough, 1);
|
ud = rb_ary_entry(passthrough, 1);
|
||||||
rUc = rb_ary_entry(passthrough, 2);
|
rUc = rb_ary_entry(passthrough, 2);
|
||||||
return NUM2UINT(rb_funcall(cb, rb_intern("call"), 4, rUc, UINT2NUM(port), INT2NUM(size), ud));
|
return NUM2UINT(rb_funcall(cb, rb_intern("call"), 4, rUc, UINT2NUM(port), INT2NUM(size), ud));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cb_hook_insn_out(uc_engine *uc, uint32_t port, int size, uint32_t value, void *user_data){
|
static void cb_hook_insn_out(uc_engine *uc, uint32_t port, int size, uint32_t value, void *user_data){
|
||||||
|
@ -302,7 +296,6 @@ static void cb_hook_insn_out(uc_engine *uc, uint32_t port, int size, uint32_t va
|
||||||
ud = rb_ary_entry(passthrough, 1);
|
ud = rb_ary_entry(passthrough, 1);
|
||||||
rUc = rb_ary_entry(passthrough, 2);
|
rUc = rb_ary_entry(passthrough, 2);
|
||||||
rb_funcall(cb, rb_intern("call"), 5, rUc, UINT2NUM(port), INT2NUM(size), UINT2NUM(value), ud);
|
rb_funcall(cb, rb_intern("call"), 5, rUc, UINT2NUM(port), INT2NUM(size), UINT2NUM(value), ud);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cb_hook_insn_syscall(uc_engine *uc, void *user_data){
|
static void cb_hook_insn_syscall(uc_engine *uc, void *user_data){
|
||||||
|
@ -315,7 +308,6 @@ static void cb_hook_insn_syscall(uc_engine *uc, void *user_data){
|
||||||
ud = rb_ary_entry(passthrough, 1);
|
ud = rb_ary_entry(passthrough, 1);
|
||||||
rUc = rb_ary_entry(passthrough, 2);
|
rUc = rb_ary_entry(passthrough, 2);
|
||||||
rb_funcall(cb, rb_intern("call"), 2, rUc, ud);
|
rb_funcall(cb, rb_intern("call"), 2, rUc, ud);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cb_hook_intr(uc_engine *uc, uint64_t address, uint32_t size, int64_t value, void *user_data){
|
static void cb_hook_intr(uc_engine *uc, uint64_t address, uint32_t size, int64_t value, void *user_data){
|
||||||
|
@ -328,10 +320,8 @@ static void cb_hook_intr(uc_engine *uc, uint64_t address, uint32_t size, int64_t
|
||||||
ud = rb_ary_entry(passthrough, 1);
|
ud = rb_ary_entry(passthrough, 1);
|
||||||
rUc = rb_ary_entry(passthrough, 2);
|
rUc = rb_ary_entry(passthrough, 2);
|
||||||
rb_funcall(cb, rb_intern("call"), 5, rUc, ULL2NUM(address), UINT2NUM(size), LL2NUM(value), ud);
|
rb_funcall(cb, rb_intern("call"), 5, rUc, ULL2NUM(address), UINT2NUM(size), LL2NUM(value), ud);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
VALUE m_uc_hook_add(int argc, VALUE* argv, VALUE self){
|
VALUE m_uc_hook_add(int argc, VALUE* argv, VALUE self){
|
||||||
VALUE hook_type;
|
VALUE hook_type;
|
||||||
VALUE callback;
|
VALUE callback;
|
||||||
|
@ -351,12 +341,10 @@ VALUE m_uc_hook_add(int argc, VALUE* argv, VALUE self){
|
||||||
if (NIL_P(arg1))
|
if (NIL_P(arg1))
|
||||||
arg1 = INT2NUM(0);
|
arg1 = INT2NUM(0);
|
||||||
|
|
||||||
|
|
||||||
VALUE passthrough;
|
VALUE passthrough;
|
||||||
uc_hook trace;
|
uc_hook trace;
|
||||||
uc_err err;
|
uc_err err;
|
||||||
|
|
||||||
|
|
||||||
if (rb_class_of(callback) != rb_cProc)
|
if (rb_class_of(callback) != rb_cProc)
|
||||||
rb_raise(UcError, "Expected Proc callback");
|
rb_raise(UcError, "Expected Proc callback");
|
||||||
|
|
||||||
|
@ -367,7 +355,6 @@ VALUE m_uc_hook_add(int argc, VALUE* argv, VALUE self){
|
||||||
|
|
||||||
uint32_t htype = NUM2UINT(hook_type);
|
uint32_t htype = NUM2UINT(hook_type);
|
||||||
if(htype == UC_HOOK_INSN){
|
if(htype == UC_HOOK_INSN){
|
||||||
|
|
||||||
switch(NUM2INT(arg1)){
|
switch(NUM2INT(arg1)){
|
||||||
case UC_X86_INS_IN:
|
case UC_X86_INS_IN:
|
||||||
err = uc_hook_add(_uc, &trace, htype, cb_hook_insn_in,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end), NUM2INT(arg1));
|
err = uc_hook_add(_uc, &trace, htype, cb_hook_insn_in,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end), NUM2INT(arg1));
|
||||||
|
@ -386,7 +373,6 @@ VALUE m_uc_hook_add(int argc, VALUE* argv, VALUE self){
|
||||||
err = uc_hook_add(_uc, &trace, htype, cb_hook_intr,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end));
|
err = uc_hook_add(_uc, &trace, htype, cb_hook_intr,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end));
|
||||||
}
|
}
|
||||||
else if(htype == UC_HOOK_CODE || htype == UC_HOOK_BLOCK){
|
else if(htype == UC_HOOK_CODE || htype == UC_HOOK_BLOCK){
|
||||||
|
|
||||||
err = uc_hook_add(_uc, &trace, htype, cb_hook_code,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end));
|
err = uc_hook_add(_uc, &trace, htype, cb_hook_code,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end));
|
||||||
}
|
}
|
||||||
else if (htype & UC_HOOK_MEM_READ_UNMAPPED
|
else if (htype & UC_HOOK_MEM_READ_UNMAPPED
|
||||||
|
@ -407,8 +393,6 @@ VALUE m_uc_hook_add(int argc, VALUE* argv, VALUE self){
|
||||||
err = uc_hook_add(_uc, &trace, htype, cb_hook_mem_access,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end));
|
err = uc_hook_add(_uc, &trace, htype, cb_hook_mem_access,(void *)passthrough, NUM2ULL(begin), NUM2ULL(end));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (err != UC_ERR_OK) {
|
if (err != UC_ERR_OK) {
|
||||||
rb_raise(UcError, "%s", uc_strerror(err));
|
rb_raise(UcError, "%s", uc_strerror(err));
|
||||||
}
|
}
|
||||||
|
@ -425,7 +409,7 @@ VALUE m_uc_hook_del(VALUE self, VALUE hook){
|
||||||
rb_raise(UcError, "%s", uc_strerror(err));
|
rb_raise(UcError, "%s", uc_strerror(err));
|
||||||
}
|
}
|
||||||
return Qnil;
|
return Qnil;
|
||||||
}
|
}
|
||||||
|
|
||||||
VALUE m_uc_query(VALUE self, VALUE query_mode){
|
VALUE m_uc_query(VALUE self, VALUE query_mode){
|
||||||
int qm = NUM2INT(query_mode);
|
int qm = NUM2INT(query_mode);
|
||||||
|
@ -438,4 +422,4 @@ VALUE m_uc_query(VALUE self, VALUE query_mode){
|
||||||
rb_raise(UcError, "%s", uc_strerror(err));
|
rb_raise(UcError, "%s", uc_strerror(err));
|
||||||
}
|
}
|
||||||
return INT2NUM(result);
|
return INT2NUM(result);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue