Update L2FIB entry timestamp only if BD aging enabled (VPP-1002) 45/8645/2
authorJohn Lo <loj@cisco.com>
Tue, 3 Oct 2017 21:39:00 +0000 (17:39 -0400)
committerDamjan Marion <dmarion.lists@gmail.com>
Wed, 4 Oct 2017 09:37:36 +0000 (09:37 +0000)
Change L2 learning path so it update stale timestamp in MAC entry
only if aging is enabled on the BD for the MAC entry.

Change-Id: I849154fe7ad2c6c68d6a94a66ca9345f6a98bc07
Signed-off-by: John Lo <loj@cisco.com>
src/vnet/buffer.h
src/vnet/l2/l2_input.c
src/vnet/l2/l2_learn.c

index 9aba34d..8d414fc 100644 (file)
@@ -177,6 +177,7 @@ typedef struct
       u8 l2_len;               /* ethernet header length */
       u8 shg;                  /* split-horizon group */
       u16 l2fib_sn;            /* l2fib bd/int seq_num */
+      u8 bd_age;               /* aging enabled */
     } l2;
 
     /* l2tpv3 softwire encap, only valid there */
index 9a3148c..c32f035 100644 (file)
@@ -210,6 +210,7 @@ classify_and_dispatch (vlib_main_t * vm,
       };
       /* *INDENT-ON* */
       vnet_buffer (b0)->l2.l2fib_sn = sn.as_u16;;
+      vnet_buffer (b0)->l2.bd_age = bd_config->mac_age;
 
       /*
        * Process bridge domain feature enables.
index 488ea1a..1b86310 100644 (file)
@@ -136,7 +136,7 @@ l2learn_process (vlib_node_runtime_t * node,
       /* Entry in L2FIB with matching sw_if_index matched - normal fast path */
       u32 dtime = timestamp - result0->fields.timestamp;
       u32 dsn = result0->fields.sn.as_u16 - vnet_buffer (b0)->l2.l2fib_sn;
-      u32 check = dtime | dsn;
+      u32 check = (dtime && vnet_buffer (b0)->l2.bd_age) || dsn;
 
       if (PREDICT_TRUE (check == 0))
        return;