aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Johnston <markj@FreeBSD.org>2025-12-08 14:09:02 +0000
committerMark Johnston <markj@FreeBSD.org>2025-12-08 14:09:02 +0000
commit0f0662c6b4cc611d6e400f823656f908ffce5c04 (patch)
tree1846e72299e741c7be7c1fd442ce2a239a55ae20
parent73586fcea630c2c4fb83e966920c039aee8a5fc9 (diff)
pf: Fix error handling in pf_handle_get_tstats()
- pfr_table_count() can return an error. - We must check for failure from mallocarray(M_NOWAIT). Fixes: 9e8d2962aad3 ("pf: convert DIOCRGETTSTATS to netlink") Reported by: Kevin Day <kevin@your.org> Reviewed by: kp MFC after: 1 week Differential Revision: https://reviews.freebsd.org/D54094
-rw-r--r--sys/netpfil/pf/pf_nl.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/sys/netpfil/pf/pf_nl.c b/sys/netpfil/pf/pf_nl.c
index bd49d0a1850f..8d0c7a2cf543 100644
--- a/sys/netpfil/pf/pf_nl.c
+++ b/sys/netpfil/pf/pf_nl.c
@@ -1954,8 +1954,18 @@ pf_handle_get_tstats(struct nlmsghdr *hdr, struct nl_pstate *npt)
PF_RULES_RLOCK();
n = pfr_table_count(&attrs.pfrio_table, attrs.pfrio_flags);
+ if (n < 0) {
+ PF_RULES_RUNLOCK();
+ PF_TABLE_STATS_UNLOCK();
+ return (EINVAL);
+ }
pfrtstats = mallocarray(n,
sizeof(struct pfr_tstats), M_PF, M_NOWAIT | M_ZERO);
+ if (pfrtstats == NULL) {
+ PF_RULES_RUNLOCK();
+ PF_TABLE_STATS_UNLOCK();
+ return (ENOMEM);
+ }
error = pfr_get_tstats(&attrs.pfrio_table, pfrtstats,
&n, attrs.pfrio_flags | PFR_FLAG_USERIOCTL);