Skip to content

Commit

Permalink
Fix: Use malloc and free for cv_stack to avoid dangling pointer warning
Browse files Browse the repository at this point in the history
  • Loading branch information
gemenerik committed Oct 15, 2024
1 parent 2cbf933 commit f4a3119
Showing 1 changed file with 9 additions and 3 deletions.
12 changes: 9 additions & 3 deletions scripts/kconfig/symbol.c
Original file line number Diff line number Diff line change
Expand Up @@ -1097,10 +1097,14 @@ static void sym_check_print_recursive(struct symbol *last_sym)
struct symbol *sym, *next_sym;
struct menu *menu = NULL;
struct property *prop;
struct dep_stack cv_stack;
struct dep_stack *cv_stack = malloc(sizeof(struct dep_stack));
if (!cv_stack) {
fprintf(stderr, "failed to allocate memory for recursive dependency check\n");
return;
}

if (sym_is_choice_value(last_sym)) {
dep_stack_insert(&cv_stack, last_sym);
dep_stack_insert(cv_stack, last_sym);
last_sym = prop_get_symbol(sym_get_choice_prop(last_sym));
}

Expand All @@ -1109,6 +1113,7 @@ static void sym_check_print_recursive(struct symbol *last_sym)
break;
if (!stack) {
fprintf(stderr, "unexpected recursive dependency error\n");
free(cv_stack);
return;
}

Expand Down Expand Up @@ -1161,8 +1166,9 @@ static void sym_check_print_recursive(struct symbol *last_sym)
}
}

if (check_top == &cv_stack)
if (check_top == cv_stack)
dep_stack_remove();
free(cv_stack);
}

static struct symbol *sym_check_expr_deps(struct expr *e)
Expand Down

0 comments on commit f4a3119

Please sign in to comment.