Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 29 Apr 2021 09:17:24 GMT
From:      "Alexander V. Chernikov" <melifaro@FreeBSD.org>
To:        src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org
Subject:   git: 59b3b210a69e - stable/13 - [fib algo] always commit static routes synchronously.
Message-ID:  <202104290917.13T9HOMW032759@gitrepo.freebsd.org>

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

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

commit 59b3b210a69e5eda9e36aac740c2a8da0bf39409
Author:     Alexander V. Chernikov <melifaro@FreeBSD.org>
AuthorDate: 2021-04-27 08:23:29 +0000
Commit:     Alexander V. Chernikov <melifaro@FreeBSD.org>
CommitDate: 2021-04-29 08:47:32 +0000

    [fib algo] always commit static routes synchronously.
    
    Modular fib lookup framework features logic that allows
     route update batching for the algorithms that cannot easily
     apply the routing change without rebuilding. As a result,
     dataplane lookups may return old data until the the sync
     takes place. With the default sync timeout of 50ms, it is
     possible that new binary like ping(8) executed exactly after
     route(8) will still use the old fib data.
    
    To address some aspects of the problem, framework executes
     all rtable changes without RTF_GATEWAY synchronously.
    
    To fix the aforementioned problem, this diff extends sync
     execution for all RTF_STATIC routes (e.g. ones maintained by
     route(8).
    This fixes a bunch of tests in the networking space.
    
    Reported by:    ci, arichardson
    MFC after:      2 weeks
    
    (cherry picked from commit 439d087d0b55574db81f4a2799a411c1236d95e3)
---
 sys/net/route/fib_algo.c | 16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

diff --git a/sys/net/route/fib_algo.c b/sys/net/route/fib_algo.c
index 5dff2690454d..9fdc80001986 100644
--- a/sys/net/route/fib_algo.c
+++ b/sys/net/route/fib_algo.c
@@ -667,13 +667,21 @@ need_immediate_sync(struct fib_data *fd, struct rib_cmd_info *rc)
 	switch (rc->rc_cmd) {
 	case RTM_ADD:
 		nh = rc->rc_nh_new;
-		if (!NH_IS_NHGRP(nh) && (!(nh->nh_flags & NHF_GATEWAY)))
-			return (true);
+		if (!NH_IS_NHGRP(nh)) {
+			if (!(nh->nh_flags & NHF_GATEWAY))
+				return (true);
+			if (nhop_get_rtflags(nh) & RTF_STATIC)
+				return (true);
+		}
 		break;
 	case RTM_DELETE:
 		nh = rc->rc_nh_old;
-		if (!NH_IS_NHGRP(nh) && (!(nh->nh_flags & NHF_GATEWAY)))
-			return (true);
+		if (!NH_IS_NHGRP(nh)) {
+			if (!(nh->nh_flags & NHF_GATEWAY))
+				return (true);
+			if (nhop_get_rtflags(nh) & RTF_STATIC)
+				return (true);
+		}
 		break;
 	}
 



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