]> git.ipfire.org Git - thirdparty/bird.git/commitdiff
Filter: Add support for src filter op to access SADR source prefix
authorOndrej Zajicek (work) <santiago@crfreenet.org>
Wed, 16 May 2018 09:19:29 +0000 (11:19 +0200)
committerOndrej Zajicek (work) <santiago@crfreenet.org>
Wed, 16 May 2018 09:19:29 +0000 (11:19 +0200)
The patch allows to use 'net.src' to access SADR source prefix
from filters.

Thanks to Toke Hoiland-Jorgensen for the original patch for srclen.

filter/config.Y
filter/filter.c
filter/filter.h
lib/net.h

index f8170a834ea03c52bd0c553407319106d1731e98..e01e02efaf4385c1528b06b107132ca3eeef5d5c 100644 (file)
@@ -411,7 +411,7 @@ CF_KEYWORDS(FUNCTION, PRINT, PRINTN, UNSET, RETURN,
        TRUE, FALSE, RT, RO, UNKNOWN, GENERIC,
        FROM, GW, NET, MASK, PROTO, SOURCE, SCOPE, DEST, IFNAME, IFINDEX,
        PREFERENCE,
-       ROA_CHECK, ASN,
+       ROA_CHECK, ASN, SRC,
        IS_V4, IS_V6,
        LEN, MAXLEN,
        DEFINED,
@@ -898,6 +898,7 @@ term:
  | term '.' LEN { $$ = f_new_inst(FI_LENGTH); $$->a1.p = $1; }
  | term '.' MAXLEN { $$ = f_new_inst(FI_ROA_MAXLEN); $$->a1.p = $1; }
  | term '.' ASN { $$ = f_new_inst(FI_ROA_ASN); $$->a1.p = $1; }
+ | term '.' SRC { $$ = f_new_inst(FI_SADR_SRC); $$->a1.p = $1; }
  | term '.' MASK '(' term ')' { $$ = f_new_inst(FI_IP_MASK); $$->a1.p = $1; $$->a2.p = $5; }
  | term '.' FIRST { $$ = f_new_inst(FI_AS_PATH_FIRST); $$->a1.p = $1; }
  | term '.' LAST  { $$ = f_new_inst(FI_AS_PATH_LAST); $$->a1.p = $1; }
index 881ba420b4743d2397c33cefbf862706dabb2237..3d7b5c9f9101730ff8f677b39838f57e21be1c97 100644 (file)
@@ -1241,6 +1241,20 @@ interpret(struct f_inst *what)
     default: runtime( "Prefix, path, clist or eclist expected" );
     }
     break;
+  case FI_SADR_SRC:    /* Get SADR src prefix */
+    ONEARG;
+    if (v1.type != T_NET || !net_is_sadr(v1.val.net))
+      runtime( "SADR expected" );
+
+    {
+      net_addr_ip6_sadr *net = (void *) v1.val.net;
+      net_addr *src = lp_alloc(f_pool, sizeof(net_addr_ip6));
+      net_fill_ip6(src, net->src_prefix, net->src_pxlen);
+
+      res.type = T_NET;
+      res.val.net = src;
+    }
+    break;
   case FI_ROA_MAXLEN:  /* Get ROA max prefix length */
     ONEARG;
     if (v1.type != T_NET || !net_is_roa(v1.val.net))
@@ -1714,6 +1728,7 @@ i_same(struct f_inst *f1, struct f_inst *f2)
   case FI_RETURN: ONEARG; break;
   case FI_ROA_MAXLEN: ONEARG; break;
   case FI_ROA_ASN: ONEARG; break;
+  case FI_SADR_SRC: ONEARG; break;
   case FI_IP: ONEARG; break;
   case FI_IS_V4: ONEARG; break;
   case FI_ROUTE_DISTINGUISHER: ONEARG; break;
index d347924a670578a18b0a708674381fd660582d8d..982276f0904ef3f16387ca25a8df6f88fda1580d 100644 (file)
@@ -55,6 +55,7 @@
   F(FI_LENGTH,                   0, 'L') \
   F(FI_ROA_MAXLEN,             'R', 'M') \
   F(FI_ROA_ASN,                        'R', 'A') \
+  F(FI_SADR_SRC,               'n', 's') \
   F(FI_IP,                     'c', 'p') \
   F(FI_ROUTE_DISTINGUISHER,    'R', 'D') \
   F(FI_AS_PATH_FIRST,          'a', 'f') \
index ad4000fdced74047ecec7d63534758a4f1081f51..0cd5f735d6296fcc5aa7ffa6399dd1b04a3fde1c 100644 (file)
--- a/lib/net.h
+++ b/lib/net.h
@@ -268,6 +268,8 @@ static inline int net_is_roa(const net_addr *a)
 static inline int net_is_flow(const net_addr *a)
 { return (a->type == NET_FLOW4) || (a->type == NET_FLOW6); }
 
+static inline int net_is_sadr(const net_addr *a)
+{ return (a->type == NET_IP6_SADR); }
 
 static inline ip4_addr net4_prefix(const net_addr *a)
 { return ((net_addr_ip4 *) a)->prefix; }