Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 12 Jun 2026 16:28:48 +0000
From:      Pouria Mousavizadeh Tehrani <pouria@FreeBSD.org>
To:        src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org
Subject:   git: 9f80c8b90bda - main - rc.d/routing: Silence errors for loopback routes
Message-ID:  <6a2c33c0.39eaa.7da55c48@gitrepo.freebsd.org>

index | next in thread | raw e-mail

The branch main has been updated by pouria:

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

commit 9f80c8b90bdaa8ffac887a8c478a16c84d74a87b
Author:     Pouria Mousavizadeh Tehrani <pouria@FreeBSD.org>
AuthorDate: 2026-06-10 11:26:07 +0000
Commit:     Pouria Mousavizadeh Tehrani <pouria@FreeBSD.org>
CommitDate: 2026-06-12 16:18:28 +0000

    rc.d/routing: Silence errors for loopback routes
    
    _loopback entry in `static_routes` ensures a loopback route
    exists in all routing tables.
    However, loopback routes may already be added by the kernel.
    Therefore, re-adding them triggers an `EEXIST` error on every boot.
    This change suppresses those harmless errors.
    
    PR:             259553
    MFC after:      1 week
    Reviewed by:    glebius, jlduran, markj
    Differential Revision:  https://reviews.freebsd.org/D57470
---
 libexec/rc/rc.d/routing | 19 ++++++++++++++++---
 1 file changed, 16 insertions(+), 3 deletions(-)

diff --git a/libexec/rc/rc.d/routing b/libexec/rc/rc.d/routing
index dd75604125a3..93e41c41a52b 100755
--- a/libexec/rc/rc.d/routing
+++ b/libexec/rc/rc.d/routing
@@ -190,7 +190,13 @@ static_inet()
 			if [ $_skip = 0 ]; then
 				route_args=`get_if_var ${i%:*} route_IF`
 				if [ -n "$route_args" ]; then
-					${ROUTE_CMD} ${_action} ${route_args}
+					# Loopback routes may already be added by the kernel; ignore EEXIST.
+					if [ "${i%:*}" = "_loopback" ]; then
+						${ROUTE_CMD} ${_action} ${route_args} 2>&1 >/dev/null |
+						    sed -e '/route: message indicates error: File exists/d' >&2
+					else
+						${ROUTE_CMD} ${_action} ${route_args}
+					fi
 				else
 					warn "route_${i%:*} not found."
 				fi
@@ -267,8 +273,15 @@ static_inet6()
 			if [ $_skip = 0 ]; then
 				ipv6_route_args=`get_if_var ${i%:*} ipv6_route_IF`
 				if [ -n "$ipv6_route_args" ]; then
-					${ROUTE_CMD} ${_action} \
-						-inet6 ${ipv6_route_args}
+					# Loopback routes may already be added by the kernel; ignore EEXIST.
+					if [ "${i%:*}" = "_loopback" ]; then
+						${ROUTE_CMD} ${_action} -inet6 \
+						    ${ipv6_route_args} 2>&1 >/dev/null |
+						    sed -e '/route: message indicates error: File exists/d' >&2
+					else
+						${ROUTE_CMD} ${_action} \
+						    -inet6 ${ipv6_route_args}
+					fi
 				else
 					warn "route_${i%:*} not found"
 				fi


home | help

Want to link to this message? Use this
URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?6a2c33c0.39eaa.7da55c48>