Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 9 Mar 2009 17:36:15 GMT
From:      Sergey Matveychuk <sem@FreeBSD.org>
To:        freebsd-gnats-submit@FreeBSD.org
Subject:   conf/132476: [rc.d] [patch] add support setfib(1) in rc.d/routing
Message-ID:  <200903091736.n29HaFYe093680@www.freebsd.org>
Resent-Message-ID: <200903091740.n29He112076305@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         132476
>Category:       conf
>Synopsis:       [rc.d] [patch] add support setfib(1) in rc.d/routing
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          change-request
>Submitter-Id:   current-users
>Arrival-Date:   Mon Mar 09 17:40:01 UTC 2009
>Closed-Date:
>Last-Modified:
>Originator:     Sergey Matveychuk
>Release:        CURRENT
>Organization:
>Environment:
>Description:
Add support of setfib(1) in rc.d routing script. setfib works only with IPv4 so it's useless for IPv6.
>How-To-Repeat:

>Fix:


Patch attached with submission follows:

--- etc/rc.d/routing.orig	2009-03-04 12:36:15.000000000 +0300
+++ etc/rc.d/routing	2009-03-04 12:36:22.000000000 +0300
@@ -27,28 +27,44 @@
 
 routing_stop()
 {
-	route -n flush
+	_fibs_num=`sysctl -n net.fibs`
+	for i in `jot ${_fibs_num} 0`; do
+		setfib -F $i route -n flush
+	done
 }
 
 static_start()
 {
-	case ${defaultrouter} in
-	[Nn][Oo] | '')
-		;;
-	*)
-		static_routes="default ${static_routes}"
-		route_default="default ${defaultrouter}"
-		;;
-	esac
+	_fibs_num=`sysctl -n net.fibs`
+	if [ -n "${static_routes}" ]; then
+		static_routes_fib0=${static_routes}
+	fi
+	if [ -n "${defaultrouter}" ]; then
+		defaultrouter_fib0=${defaultrouter}
+	fi
 
 	# Setup static routes. This should be done before router discovery.
 	#
-	if [ -n "${static_routes}" ]; then
-		for i in ${static_routes}; do
-			eval route_args=\$route_${i}
-			route add ${route_args}
-		done
-	fi
+	for n in `jot ${_fibs_num} 0`; do
+		eval _drouter=\$defaultrouter_fib${n}
+		eval _routes=\$static_routes_fib${n}
+
+		case ${_drouter} in
+		[Nn][Oo] | '')
+			;;
+		*)
+			_routes="default ${_routes}"
+			route_default="default ${_drouter}"
+			;;
+		esac
+
+		if [ -n "${_routes}" ]; then
+			for i in ${_routes}; do
+				eval route_args=\$route_${i}
+				setfib -F $n route add ${route_args}
+			done
+		fi
+	done
 	# Now ATM static routes
 	#
 	if [ -n "${natm_static_routes}" ]; then
--- share/man/man5/rc.conf.5.orig	2009-03-04 12:41:55.000000000 +0300
+++ share/man/man5/rc.conf.5	2009-03-09 20:19:45.000000000 +0300
@@ -2187,7 +2187,14 @@
 .Dq Li NO ,
 create a default route to this host name or IP address
 (use an IP address if this router is also required to get to the
-name server!).
+name server!). It's an equivalent of
+.Va defaultrouter_fib0 .
+.It Va defaultrouter_fibN
+.Pq Vt str
+If not set to
+.Dq Li NO ,
+create a default route to this host name or IP address in FIB
+number N. See the setfib(1).
 .It Va ipv6_defaultrouter
 .Pq Vt str
 The IPv6 equivalent of
@@ -2195,10 +2202,9 @@
 .It Va static_routes
 .Pq Vt str
 Set to the list of static routes that are to be added at system
-boot time.
-If not set to
-.Dq Li NO
-then for each whitespace separated
+boot time. (It's an equivalent of
+.Va static_routes_fib0 )
+If not empty then for each whitespace separated
 .Ar element
 in the value, a
 .Va route_ Ns Aq Ar element
@@ -2212,6 +2218,10 @@
 route_mcast="-net 224.0.0.0/4 -iface gif0"
 route_gif0local="-host 169.254.1.1 -iface lo0"
 .Ed
+.It Va static_routes_fibN
+.Pq Vt str
+Set to the list of static routes that are to be added in FIB
+number N. See setfib(1).
 .It Va ipv6_static_routes
 .Pq Vt str
 The IPv6 equivalent of


>Release-Note:
>Audit-Trail:
>Unformatted:



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