summaryrefslogtreecommitdiffstats
path: root/src/parser_bison.y
diff options
context:
space:
mode:
authorFlorian Westphal <fw@strlen.de>2023-12-13 11:18:06 +0100
committerFlorian Westphal <fw@strlen.de>2023-12-13 12:08:19 +0100
commitd755c2a3ae7fe8272321a1d81eafbd90052c4f14 (patch)
treeea99407f68db393a0b8f59f0c09de6f87e6629d4 /src/parser_bison.y
parent28b3bbec5a97aaa57f7138fee8b2f22ff0e5b960 (diff)
parser_bison: fix memory leaks on hookspec error processing
prio_spec may contain an embedded expression, release it. We also need to release the device expr and the hook string. Signed-off-by: Florian Westphal <fw@strlen.de>
Diffstat (limited to 'src/parser_bison.y')
-rw-r--r--src/parser_bison.y7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/parser_bison.y b/src/parser_bison.y
index c69252fe..571eddf1 100644
--- a/src/parser_bison.y
+++ b/src/parser_bison.y
@@ -708,6 +708,8 @@ int nft_lex(void *, void *, void *);
%type <val> family_spec family_spec_explicit
%type <val32> int_num chain_policy
%type <prio_spec> extended_prio_spec prio_spec
+%destructor { expr_free($$.expr); } extended_prio_spec prio_spec
+
%type <string> extended_prio_name quota_unit basehook_device_name
%destructor { free_const($$); } extended_prio_name quota_unit basehook_device_name
@@ -2615,6 +2617,9 @@ hook_spec : TYPE close_scope_type STRING HOOK STRING dev_spec prio_spec
erec_queue(error(&@3, "unknown chain type"),
state->msgs);
free_const($3);
+ free_const($5);
+ expr_free($6);
+ expr_free($7.expr);
YYERROR;
}
$<chain>0->type.loc = @3;
@@ -2628,6 +2633,8 @@ hook_spec : TYPE close_scope_type STRING HOOK STRING dev_spec prio_spec
erec_queue(error(&@5, "unknown chain hook"),
state->msgs);
free_const($5);
+ expr_free($6);
+ expr_free($7.expr);
YYERROR;
}
free_const($5);