Format code
This commit is contained in:
@@ -529,26 +529,36 @@ static void test_arm64_pc_wrap(void)
|
||||
OK(uc_close(uc));
|
||||
}
|
||||
|
||||
static void
|
||||
test_arm64_mem_prot_regress_hook_mem(uc_engine *uc, uc_mem_type type,
|
||||
uint64_t address, int size, int64_t value, void *user_data)
|
||||
static void test_arm64_mem_prot_regress_hook_mem(uc_engine *uc,
|
||||
uc_mem_type type,
|
||||
uint64_t address, int size,
|
||||
int64_t value, void *user_data)
|
||||
{
|
||||
// fprintf(stderr, "%s %p %d\n", (type == UC_MEM_WRITE) ? "UC_MEM_WRITE" : "UC_MEM_READ", (void *)address, size);
|
||||
// fprintf(stderr, "%s %p %d\n", (type == UC_MEM_WRITE) ? "UC_MEM_WRITE" :
|
||||
// "UC_MEM_READ", (void *)address, size);
|
||||
}
|
||||
|
||||
static bool
|
||||
test_arm64_mem_prot_regress_hook_prot(uc_engine *uc, uc_mem_type type,
|
||||
uint64_t address, int size, int64_t value, void *user_data)
|
||||
static bool test_arm64_mem_prot_regress_hook_prot(uc_engine *uc,
|
||||
uc_mem_type type,
|
||||
uint64_t address, int size,
|
||||
int64_t value,
|
||||
void *user_data)
|
||||
{
|
||||
// fprintf(stderr, "%s %p %d\n", (type == UC_MEM_WRITE_PROT) ? "UC_MEM_WRITE_PROT" : ((type == UC_MEM_FETCH_PROT) ? "UC_MEM_FETCH_PROT" : "UC_MEM_READ_PROT"), (void *)address, size);
|
||||
// fprintf(stderr, "%s %p %d\n", (type == UC_MEM_WRITE_PROT) ?
|
||||
// "UC_MEM_WRITE_PROT" : ((type == UC_MEM_FETCH_PROT) ? "UC_MEM_FETCH_PROT"
|
||||
// : "UC_MEM_READ_PROT"), (void *)address, size);
|
||||
return false;
|
||||
}
|
||||
|
||||
static bool
|
||||
test_arm64_mem_prot_regress_hook_unm(uc_engine *uc, uc_mem_type type,
|
||||
uint64_t address, int size, int64_t value, void *user_data)
|
||||
static bool test_arm64_mem_prot_regress_hook_unm(uc_engine *uc,
|
||||
uc_mem_type type,
|
||||
uint64_t address, int size,
|
||||
int64_t value, void *user_data)
|
||||
{
|
||||
// fprintf(stderr, "%s %p %d\n", (type == UC_MEM_WRITE_UNMAPPED) ? "UC_MEM_WRITE_UNMAPPED" : ((type == UC_MEM_FETCH_UNMAPPED) ? "UC_MEM_FETCH_UNMAPPED" : "UC_MEM_READ_UNMAPPED"), (void *)address, size);
|
||||
// fprintf(stderr, "%s %p %d\n", (type == UC_MEM_WRITE_UNMAPPED) ?
|
||||
// "UC_MEM_WRITE_UNMAPPED" : ((type == UC_MEM_FETCH_UNMAPPED) ?
|
||||
// "UC_MEM_FETCH_UNMAPPED" : "UC_MEM_READ_UNMAPPED"), (void *)address,
|
||||
// size);
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -562,17 +572,24 @@ static void test_arm64_mem_prot_regress(void)
|
||||
uc_engine *uc;
|
||||
OK(uc_open(UC_ARCH_ARM64, UC_MODE_ARM, &uc));
|
||||
|
||||
OK(uc_mem_map(uc, 0, 0x4000, UC_PROT_READ|UC_PROT_EXEC));
|
||||
OK(uc_mem_map(uc, 0x4000, 0xC000, UC_PROT_READ|UC_PROT_WRITE));
|
||||
OK(uc_mem_map(uc, 0, 0x4000, UC_PROT_READ | UC_PROT_EXEC));
|
||||
OK(uc_mem_map(uc, 0x4000, 0xC000, UC_PROT_READ | UC_PROT_WRITE));
|
||||
OK(uc_mem_write(uc, 0, code, sizeof(code)));
|
||||
uc_hook hh_mem;
|
||||
OK(uc_hook_add(uc, &hh_mem, UC_HOOK_MEM_READ | UC_HOOK_MEM_WRITE, test_arm64_mem_prot_regress_hook_mem, NULL, 1, 0));
|
||||
OK(uc_hook_add(uc, &hh_mem, UC_HOOK_MEM_READ | UC_HOOK_MEM_WRITE,
|
||||
test_arm64_mem_prot_regress_hook_mem, NULL, 1, 0));
|
||||
|
||||
uc_hook hh_prot;
|
||||
OK(uc_hook_add(uc, &hh_prot, UC_HOOK_MEM_READ_PROT | UC_HOOK_MEM_WRITE_PROT | UC_HOOK_MEM_FETCH_PROT, test_arm64_mem_prot_regress_hook_prot, NULL, 1, 0));
|
||||
OK(uc_hook_add(uc, &hh_prot,
|
||||
UC_HOOK_MEM_READ_PROT | UC_HOOK_MEM_WRITE_PROT |
|
||||
UC_HOOK_MEM_FETCH_PROT,
|
||||
test_arm64_mem_prot_regress_hook_prot, NULL, 1, 0));
|
||||
|
||||
uc_hook hh_unm;
|
||||
OK(uc_hook_add(uc, &hh_unm, UC_HOOK_MEM_READ_UNMAPPED | UC_HOOK_MEM_WRITE_UNMAPPED | UC_HOOK_MEM_FETCH_UNMAPPED, test_arm64_mem_prot_regress_hook_unm, NULL, 1, 0));
|
||||
OK(uc_hook_add(uc, &hh_unm,
|
||||
UC_HOOK_MEM_READ_UNMAPPED | UC_HOOK_MEM_WRITE_UNMAPPED |
|
||||
UC_HOOK_MEM_FETCH_UNMAPPED,
|
||||
test_arm64_mem_prot_regress_hook_unm, NULL, 1, 0));
|
||||
|
||||
const uint64_t value = 0x801b;
|
||||
OK(uc_reg_write(uc, UC_ARM64_REG_X0, &value));
|
||||
|
||||
Reference in New Issue
Block a user