diff options
author | Gaelan Steele <gbs@canishe.com> | 2020-04-28 13:45:53 -0700 |
---|---|---|
committer | Nico Williams <nico@cryptonector.com> | 2023-10-08 12:32:22 -0500 |
commit | c10cbbff34b25f447d45d1a997cf8606769875c8 (patch) | |
tree | bce6cc824440155be70b090198290a098bcb1870 | |
parent | 6b6feaffbbb258e9a6aed3495cb4e5100dd8ce84 (diff) |
Remove undefined behavior caught by LLVM 10 UBSAN.
-rw-r--r-- | src/exec_stack.h | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/exec_stack.h b/src/exec_stack.h index 57e13650..2a063e8c 100644 --- a/src/exec_stack.h +++ b/src/exec_stack.h @@ -61,8 +61,10 @@ static void stack_init(struct stack* s) { static void stack_reset(struct stack* s) { assert(s->limit == 0 && "stack freed while not empty"); - char* mem_start = s->mem_end - ( -s->bound + ALIGNMENT); - free(mem_start); + if(s->mem_end != NULL) { + char* mem_start = s->mem_end - ( -s->bound + ALIGNMENT); + free(mem_start); + } stack_init(s); } @@ -80,7 +82,7 @@ static stack_ptr* stack_block_next(struct stack* s, stack_ptr p) { static void stack_reallocate(struct stack* s, size_t sz) { int old_mem_length = -(s->bound) + ALIGNMENT; - char* old_mem_start = s->mem_end - old_mem_length; + char* old_mem_start = (s->mem_end != NULL) ? (s->mem_end - old_mem_length) : NULL; int new_mem_length = align_round_up((old_mem_length + sz + 256) * 2); char* new_mem_start = jv_mem_realloc(old_mem_start, new_mem_length); |