mirror of
https://github.com/frida/tinycc
synced 2025-02-02 08:25:02 +03:00
tccgen: inline_functions double free fix
Fix double free of the inline function token_string which could happen when an error/longjmp occurred while compiling the inline function.
This commit is contained in:
parent
7e7f2e5d1b
commit
7c28c9b13f
2
tcc.h
2
tcc.h
@ -532,7 +532,7 @@ typedef struct TokenString {
|
||||
|
||||
/* inline functions */
|
||||
typedef struct InlineFunc {
|
||||
TokenString func_str;
|
||||
TokenString *func_str;
|
||||
Sym *sym;
|
||||
char filename[1];
|
||||
} InlineFunc;
|
||||
|
16
tccgen.c
16
tccgen.c
@ -6523,7 +6523,7 @@ static void gen_inline_functions(TCCState *s)
|
||||
sym->r = VT_SYM | VT_CONST;
|
||||
sym->type.t &= ~VT_INLINE;
|
||||
|
||||
begin_macro(&fn->func_str, 0);
|
||||
begin_macro(fn->func_str, 1);
|
||||
next();
|
||||
cur_text_section = text_section;
|
||||
gen_function(sym);
|
||||
@ -6544,8 +6544,10 @@ ST_FUNC void free_inline_functions(TCCState *s)
|
||||
/* free tokens of unused inline functions */
|
||||
for (i = 0; i < s->nb_inline_fns; ++i) {
|
||||
struct InlineFunc *fn = s->inline_fns[i];
|
||||
if (fn->sym)
|
||||
tok_str_free(fn->func_str.str);
|
||||
if (fn->sym) {
|
||||
tok_str_free(fn->func_str->str);
|
||||
tal_free(tokstr_alloc, fn->func_str);
|
||||
}
|
||||
}
|
||||
dynarray_reset(&s->inline_fns, &s->nb_inline_fns);
|
||||
}
|
||||
@ -6701,14 +6703,14 @@ static int decl0(int l, int is_for_loop_init)
|
||||
fn = tcc_malloc(sizeof *fn + strlen(filename));
|
||||
strcpy(fn->filename, filename);
|
||||
fn->sym = sym;
|
||||
tok_str_new(&fn->func_str);
|
||||
fn->func_str = tok_str_alloc();
|
||||
|
||||
block_level = 0;
|
||||
for(;;) {
|
||||
int t;
|
||||
if (tok == TOK_EOF)
|
||||
tcc_error("unexpected end of file");
|
||||
tok_str_add_tok(&fn->func_str);
|
||||
tok_str_add_tok(fn->func_str);
|
||||
t = tok;
|
||||
next();
|
||||
if (t == '{') {
|
||||
@ -6719,8 +6721,8 @@ static int decl0(int l, int is_for_loop_init)
|
||||
break;
|
||||
}
|
||||
}
|
||||
tok_str_add(&fn->func_str, -1);
|
||||
tok_str_add(&fn->func_str, 0);
|
||||
tok_str_add(fn->func_str, -1);
|
||||
tok_str_add(fn->func_str, 0);
|
||||
dynarray_add((void ***)&tcc_state->inline_fns, &tcc_state->nb_inline_fns, fn);
|
||||
|
||||
} else {
|
||||
|
Loading…
x
Reference in New Issue
Block a user