Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 19 Nov 2024 00:26:46 GMT
From:      Cy Schubert <cy@FreeBSD.org>
To:        src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org
Subject:   git: d46948338cd2 - stable/14 - ipfilter: Avoid overrunning the message buffer
Message-ID:  <202411190026.4AJ0QkpF063628@gitrepo.freebsd.org>

next in thread | raw e-mail | index | archive | help
The branch stable/14 has been updated by cy:

URL: https://cgit.FreeBSD.org/src/commit/?id=d46948338cd2565f4845ac53ddd810bf47068a2f

commit d46948338cd2565f4845ac53ddd810bf47068a2f
Author:     Cy Schubert <cy@FreeBSD.org>
AuthorDate: 2024-11-07 01:22:57 +0000
Commit:     Cy Schubert <cy@FreeBSD.org>
CommitDate: 2024-11-19 00:26:04 +0000

    ipfilter: Avoid overrunning the message buffer
    
    Avoid overrunning the message buffer when printing an ippool btree error.
    We do this in two ways. First we increase the message buffer from 80 to
    255 bytes and secondly we replace strcat(3) with strlcat(3).
    
    (cherry picked from commit 42935716286e7887bfeb9dd8daea72d6a5d40908)
---
 sbin/ipf/libipf/load_poolnode.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/sbin/ipf/libipf/load_poolnode.c b/sbin/ipf/libipf/load_poolnode.c
index 5c9fd838bfa0..8d65f019da43 100644
--- a/sbin/ipf/libipf/load_poolnode.c
+++ b/sbin/ipf/libipf/load_poolnode.c
@@ -52,11 +52,11 @@ load_poolnode(int role, char *name, ip_pool_node_t *node, int ttl,
 
 	if (err != 0) {
 		if ((opts & OPT_DONOTHING) == 0) {
-			char msg[80];
+			char msg[255];
 
 			snprintf(msg, sizeof(msg), "%s pool node(%s/", what,
 				inet_ntoa(pn.ipn_addr.adf_addr.in4));
-			strcat(msg, inet_ntoa(pn.ipn_mask.adf_addr.in4));
+			strlcat(msg, inet_ntoa(pn.ipn_mask.adf_addr.in4), sizeof(msg));
 			return (ipf_perror_fd(pool_fd(), iocfunc, msg));
 		}
 	}



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202411190026.4AJ0QkpF063628>