diff options
author | Dominik Maier <domenukk@gmail.com> | 2020-02-10 14:07:12 +0100 |
---|---|---|
committer | Dominik Maier <domenukk@gmail.com> | 2020-02-10 14:07:12 +0100 |
commit | 16286e3e2fbb12a1af0ccd084bd2cf09b90d28ba (patch) | |
tree | 6397a924495459f4dd46e709a085f2eea151bb30 /unicorn_mode | |
parent | bf1898736915d34906704f82202d1a8890a3cec4 (diff) | |
download | afl++-16286e3e2fbb12a1af0ccd084bd2cf09b90d28ba.tar.gz |
minor fixes to c examples
Diffstat (limited to 'unicorn_mode')
-rw-r--r-- | unicorn_mode/samples/c/harness.c | 19 | ||||
-rw-r--r-- | unicorn_mode/samples/persistent/harness.c | 12 |
2 files changed, 16 insertions, 15 deletions
diff --git a/unicorn_mode/samples/c/harness.c b/unicorn_mode/samples/c/harness.c index fd2da68b..2eddeb8e 100644 --- a/unicorn_mode/samples/c/harness.c +++ b/unicorn_mode/samples/c/harness.c @@ -71,7 +71,7 @@ static void hook_strlen(uc_engine *uc, uint64_t address, uint32_t size, void *us //Hook //116b: e8 c0 fe ff ff call 1030 <strlen@plt> // We place the return at RAX - //printf("Strlen hook at addr 0x%lx (size: 0x%x), result: %ld\n", address, size, current_input_len); + //printf("Strlen hook at addr 0x%llx (size: 0x%x), result: %ld\n", address, size, current_input_len); uc_reg_write(uc, UC_X86_REG_RAX, ¤t_input_len); // We skip the actual call by updating RIP uint64_t next_addr = address + size; @@ -125,12 +125,6 @@ static bool place_input_callback( return false; } - // For persistent mode, we have to set up stack and memory each time. - uc_reg_write(uc, UC_X86_REG_RIP, &CODE_ADDRESS); // Set the instruction pointer back - // Set up the function parameters accordingly RSI, RDI (see calling convention/disassembly) - uc_reg_write(uc, UC_X86_REG_RSI, &INPUT_LOCATION); // argv - uc_reg_write(uc, UC_X86_REG_RDI, &EMULATED_ARGC); // argc == 2 - // We need a valid c string, make sure it never goes out of bounds. input[input_len-1] = '\0'; // Write the testcase to unicorn. @@ -144,7 +138,7 @@ static bool place_input_callback( static void mem_map_checked(uc_engine *uc, uint64_t addr, size_t size, uint32_t mode) { size = pad(size); - //printf("SIZE %lx, align: %lx\n", size, ALIGNMENT); + //printf("SIZE %llx, align: %llx\n", size, ALIGNMENT); uc_err err = uc_mem_map(uc, addr, size, mode); if (err != UC_ERR_OK) { printf("Error mapping %ld bytes at 0x%lx: %s (mode: %d)\n", size, addr, uc_strerror(err), mode); @@ -209,7 +203,7 @@ int main(int argc, char **argv, char **envp) { // Setup the Stack mem_map_checked(uc, STACK_ADDRESS - STACK_SIZE, STACK_SIZE, UC_PROT_READ | UC_PROT_WRITE); uint64_t stack_val = STACK_ADDRESS; - printf("%ld", stack_val); + printf("%lu", stack_val); uc_reg_write(uc, UC_X86_REG_RSP, &stack_val); // reserve some space for our input data @@ -235,6 +229,13 @@ int main(int argc, char **argv, char **envp) { uc_hook strlen_hook; uc_hook_add(uc, &strlen_hook, UC_HOOK_CODE, hook_strlen, NULL, strlen_hook_pos, strlen_hook_pos); + // For persistent-iters=1, we don't need to reset this as it's restarted/reforked for each run. + uc_reg_write(uc, UC_X86_REG_RIP, &CODE_ADDRESS); // Set the instruction pointer back + // Set up the function parameters accordingly RSI, RDI (see calling convention/disassembly) + uc_reg_write(uc, UC_X86_REG_RSI, &INPUT_LOCATION); // argv + uc_reg_write(uc, UC_X86_REG_RDI, &EMULATED_ARGC); // argc == 2 + + printf("Starting to fuzz :)\n"); fflush(stdout); diff --git a/unicorn_mode/samples/persistent/harness.c b/unicorn_mode/samples/persistent/harness.c index d8ebffbc..02d96e90 100644 --- a/unicorn_mode/samples/persistent/harness.c +++ b/unicorn_mode/samples/persistent/harness.c @@ -77,7 +77,7 @@ static void hook_strlen(uc_engine *uc, uint64_t address, uint32_t size, void *us // We place the return at RAX uc_reg_write(uc, UC_X86_REG_RAX, ¤t_input_len); // We skip the actual call by updating RIP - //printf("Strlen hook at addr 0x%lx (size: 0x%x), result: %ld\n", address, size, current_input_len); + //printf("Strlen hook at addr 0x%llx (size: 0x%x), result: %ld\n", address, size, current_input_len); uint64_t next_addr = address + size; uc_reg_write(uc, UC_X86_REG_RIP, &next_addr); } @@ -101,7 +101,7 @@ static off_t afl_mmap_file(char *filename, char **buf_ptr) { off_t in_len = st.st_size; if (in_len == -1) { /* This can only ever happen on 32 bit if the file is exactly 4gb. */ - fprintf(stderr, "Filesize of %s too large", filename); + fprintf(stderr, "Filesize of %s too large\n", filename); goto exit; } @@ -148,7 +148,7 @@ static bool place_input_callback( static void mem_map_checked(uc_engine *uc, uint64_t addr, size_t size, uint32_t mode) { size = pad(size); - //printf("SIZE %lx, align: %lx\n", size, ALIGNMENT); + //printf("SIZE %llx, align: %llx\n", size, ALIGNMENT); uc_err err = uc_mem_map(uc, addr, size, mode); if (err != UC_ERR_OK) { printf("Error mapping %ld bytes at 0x%lx: %s (mode: %d)\n", size, addr, uc_strerror(err), mode); @@ -213,7 +213,7 @@ int main(int argc, char **argv, char **envp) { // Setup the Stack mem_map_checked(uc, STACK_ADDRESS - STACK_SIZE, STACK_SIZE, UC_PROT_READ | UC_PROT_WRITE); uint64_t stack_val = STACK_ADDRESS; - printf("%ld", stack_val); + printf("%lu", stack_val); uc_reg_write(uc, UC_X86_REG_RSP, &stack_val); // reserve some space for our input data @@ -256,11 +256,11 @@ int main(int argc, char **argv, char **envp) { ); switch(afl_ret) { case UC_AFL_RET_ERROR: - printf("Error starting to fuzz"); + printf("Error starting to fuzz\n"); return -3; break; case UC_AFL_RET_NO_AFL: - printf("No AFL attached - We are done with a single run."); + printf("No AFL attached - We are done with a single run.\n"); break; default: break; |