Add support for new zebra protocol version used by Quagga 0.99.21
authorVasilis Tsiligiannis <acinonyx@openwrt.gr>
Thu, 31 May 2012 06:37:26 +0000 (08:37 +0200)
committerSaverio Proto <saverio.proto@garr.it>
Thu, 31 May 2012 17:38:41 +0000 (19:38 +0200)
lib/quagga/README_QUAGGA
lib/quagga/patches/quagga-0.99.21.diff [new file with mode: 0644]
lib/quagga/src/common.h
lib/quagga/src/packet.c
lib/quagga/src/packet.h
lib/quagga/src/parse.c
lib/quagga/src/plugin.c
lib/quagga/src/quagga.c

index 8e44f8d..32bbfc8 100644 (file)
@@ -11,9 +11,9 @@ It allows olsrd to redistribute from various quagga-protocols
 as well as to export olsr-routes to quagga so that they can be
 redistributed by the quagga-routing-daemons.
 
-You also need a source distribution of quagga-0.98.6 or quagga-0.99.15.
+You also need a source distribution of quagga-0.98.6 or quagga-0.99.21.
 The quagga source tree needs to be patched with quagga-0.98.6.diff or
-quagga-0.99.15.diff, respectively, compiled and installed via
+quagga-0.99.21.diff, respectively, compiled and installed via
 'make install'.
 
 ---------------------------------------------------------------------
@@ -48,7 +48,10 @@ PlParam "Port" "<port>"
 
 PlParam "Version" "<version>"
         sets the version of packet format to communicate with zebra.
-       use "0" for Quagga 0.98.x and "1" for Quagga 0.99.x.
+       use:
+          "0" for Quagga 0.98.x
+          "1" for Quagga 0.99.17 up to 0.99.20.1
+          "2" for Quagga 0.99.21 and above
        defaults to "0".
 
 ---------------------------------------------------------------------
@@ -65,9 +68,9 @@ LoadPlugin "olsrd_quagga.so.0.2.2"
        PlParam "Distance" "125" 
        PlParam "LocalPref" "false"
        PlParam "SockPath" "/var/run/zserv.api"
-       PlParam "Version" "1"
+       PlParam "Version" "2"
 }
 
 
 ---------------------------------------------------------------------
-EOF / 10.03.2010
+EOF / 31.05.2012
diff --git a/lib/quagga/patches/quagga-0.99.21.diff b/lib/quagga/patches/quagga-0.99.21.diff
new file mode 100644 (file)
index 0000000..c878a33
--- /dev/null
@@ -0,0 +1,273 @@
+diff --git a/lib/log.c b/lib/log.c
+index cbc935b..991b77e 100644
+--- a/lib/log.c
++++ b/lib/log.c
+@@ -929,13 +929,19 @@ proto_redistnum(int afi, const char *s)
+       return ZEBRA_ROUTE_STATIC;
+       else if (strncmp (s, "r", 1) == 0)
+       return ZEBRA_ROUTE_RIP;
+-      else if (strncmp (s, "o", 1) == 0)
++      else if (strncmp (s, "os", 2) == 0)
+       return ZEBRA_ROUTE_OSPF;
+       else if (strncmp (s, "i", 1) == 0)
+       return ZEBRA_ROUTE_ISIS;
+       else if (strncmp (s, "bg", 2) == 0)
+       return ZEBRA_ROUTE_BGP;
+-      else if (strncmp (s, "ba", 2) == 0)
++      else if (strncmp (s, "h", 1) == 0)
++      return ZEBRA_ROUTE_HSLS;
++      else if (strncmp (s, "ol", 2) == 0)
++      return ZEBRA_ROUTE_OLSR;
++      else if (strncmp (s, "bat", 3) == 0)
++      return ZEBRA_ROUTE_BATMAN;
++      else if (strncmp (s, "bab", 3) == 0)
+       return ZEBRA_ROUTE_BABEL;
+     }
+   if (afi == AFI_IP6)
+@@ -948,13 +954,19 @@ proto_redistnum(int afi, const char *s)
+       return ZEBRA_ROUTE_STATIC;
+       else if (strncmp (s, "r", 1) == 0)
+       return ZEBRA_ROUTE_RIPNG;
+-      else if (strncmp (s, "o", 1) == 0)
++      else if (strncmp (s, "os", 2) == 0)
+       return ZEBRA_ROUTE_OSPF6;
+       else if (strncmp (s, "i", 1) == 0)
+       return ZEBRA_ROUTE_ISIS;
+       else if (strncmp (s, "bg", 2) == 0)
+       return ZEBRA_ROUTE_BGP;
+-      else if (strncmp (s, "ba", 2) == 0)
++      else if (strncmp (s, "h", 1) == 0)
++      return ZEBRA_ROUTE_HSLS;
++      else if (strncmp (s, "ol", 2) == 0)
++      return ZEBRA_ROUTE_OLSR;
++      else if (strncmp (s, "bat", 3) == 0)
++      return ZEBRA_ROUTE_BATMAN;
++      else if (strncmp (s, "bab", 3) == 0)
+       return ZEBRA_ROUTE_BABEL;
+     }
+   return -1;
+diff --git a/lib/route_types.txt b/lib/route_types.txt
+index cebf01f..22bda24 100644
+--- a/lib/route_types.txt
++++ b/lib/route_types.txt
+@@ -51,13 +51,9 @@ ZEBRA_ROUTE_OSPF,       ospf,      ospfd,  'O', 1, 0, "OSPF"
+ ZEBRA_ROUTE_OSPF6,      ospf6,     ospf6d, 'O', 0, 1, "OSPFv6"
+ ZEBRA_ROUTE_ISIS,       isis,      isisd,  'I', 1, 1, "IS-IS"
+ ZEBRA_ROUTE_BGP,        bgp,       bgpd,   'B', 1, 1, "BGP"
+-# HSLS and OLSR both are AFI independent (so: 1, 1), however
+-# we want to disable for them for general Quagga distribution.
+-# This at least makes it trivial for users of these protocols
+-# to 'switch on' redist support (direct numeric entry remaining
+-# possible).
+-ZEBRA_ROUTE_HSLS,       hsls,      hslsd,  'H', 0, 0, "HSLS"
+-ZEBRA_ROUTE_OLSR,       olsr,      olsrd,  'o', 0, 0, "OLSR"
++ZEBRA_ROUTE_HSLS,       hsls,      hslsd,  'H', 1, 1, "HSLS"
++ZEBRA_ROUTE_OLSR,       olsr,      olsrd,  'o', 1, 1, "OLSR"
++ZEBRA_ROUTE_BATMAN,     batman,    batmand,'b', 1, 1, "BATMAN"
+ ZEBRA_ROUTE_BABEL,      babel,     babeld, 'A', 1, 1, "Babel"
+ ## help strings
+@@ -72,5 +68,6 @@ ZEBRA_ROUTE_OSPF6,  "Open Shortest Path First (IPv6) (OSPFv3)"
+ ZEBRA_ROUTE_ISIS,   "Intermediate System to Intermediate System (IS-IS)"
+ ZEBRA_ROUTE_BGP,    "Border Gateway Protocol (BGP)"
+ ZEBRA_ROUTE_HSLS,   "Hazy-Sighted Link State Protocol (HSLS)"
+-ZEBRA_ROUTE_OLSR,   "Optimised Link State Routing (OLSR)"
++ZEBRA_ROUTE_OLSR,   "Optimized Link State Routing (OLSR)"
++ZEBRA_ROUTE_BATMAN, "Better Approach to Mobile Ad-Hoc Networking (BATMAN)"
+ ZEBRA_ROUTE_BABEL,  "Babel routing protocol (Babel)"
+diff --git a/ripd/rip_zebra.c b/ripd/rip_zebra.c
+index 199e85e..5e344d1 100644
+--- a/ripd/rip_zebra.c
++++ b/ripd/rip_zebra.c
+@@ -206,9 +206,12 @@ static struct {
+   {ZEBRA_ROUTE_KERNEL,  1, "kernel"},
+   {ZEBRA_ROUTE_CONNECT, 1, "connected"},
+   {ZEBRA_ROUTE_STATIC,  1, "static"},
+-  {ZEBRA_ROUTE_OSPF,    1, "ospf"},
++  {ZEBRA_ROUTE_OSPF,    2, "ospf"},
+   {ZEBRA_ROUTE_BGP,     2, "bgp"},
+-  {ZEBRA_ROUTE_BABEL,   2, "babel"},
++  {ZEBRA_ROUTE_HSLS,    1, "hsls"},
++  {ZEBRA_ROUTE_OLSR,    2, "olsr"},
++  {ZEBRA_ROUTE_BATMAN,  3, "batman"},
++  {ZEBRA_ROUTE_BABEL,   3, "babel"},
+   {0, 0, NULL}
+ };
+diff --git a/ripngd/ripng_zebra.c b/ripngd/ripng_zebra.c
+index 8e76606..016c4bb 100644
+--- a/ripngd/ripng_zebra.c
++++ b/ripngd/ripng_zebra.c
+@@ -216,9 +216,12 @@ static struct {
+   {ZEBRA_ROUTE_KERNEL,  1, "kernel"},
+   {ZEBRA_ROUTE_CONNECT, 1, "connected"},
+   {ZEBRA_ROUTE_STATIC,  1, "static"},
+-  {ZEBRA_ROUTE_OSPF6,   1, "ospf6"},
++  {ZEBRA_ROUTE_OSPF6,   2, "ospf6"},
+   {ZEBRA_ROUTE_BGP,     2, "bgp"},
+-  {ZEBRA_ROUTE_BABEL,   2, "babel"},
++  {ZEBRA_ROUTE_HSLS,    1, "hsls"},
++  {ZEBRA_ROUTE_OLSR,    2, "olsr"},
++  {ZEBRA_ROUTE_BATMAN,  3, "batman"},
++  {ZEBRA_ROUTE_BABEL,   3, "babel"},
+   {0, 0, NULL}
+ };
+diff --git a/zebra/client_main.c b/zebra/client_main.c
+index 8b95907..b1016b4 100644
+--- a/zebra/client_main.c
++++ b/zebra/client_main.c
+@@ -119,6 +119,9 @@ struct zebra_info
+   { "ospf",   ZEBRA_ROUTE_OSPF },
+   { "ospf6",  ZEBRA_ROUTE_OSPF6 },
+   { "bgp",    ZEBRA_ROUTE_BGP },
++  { "hsls",   ZEBRA_ROUTE_HSLS },
++  { "olsr",   ZEBRA_ROUTE_OLSR },
++  { "batman", ZEBRA_ROUTE_BATMAN },
+   { NULL,     0 }
+ };
+diff --git a/zebra/rt_netlink.c b/zebra/rt_netlink.c
+index 5909131..92288bd 100644
+--- a/zebra/rt_netlink.c
++++ b/zebra/rt_netlink.c
+@@ -1623,6 +1623,9 @@ netlink_route_multipath (int cmd, struct prefix *p, struct rib *rib,
+                         addattr_l (&req.n, sizeof req, RTA_PREFSRC,
+                                &nexthop->src.ipv4, bytelen);
++                    if (rib->type == ZEBRA_ROUTE_OLSR)
++                      req.r.rtm_scope = RT_SCOPE_LINK;
++
+                     if (IS_ZEBRA_DEBUG_KERNEL)
+                       zlog_debug("netlink_route_multipath() (single hop): "
+                                  "nexthop via if %u", nexthop->ifindex);
+diff --git a/zebra/zebra_rib.c b/zebra/zebra_rib.c
+index 154e8d5..0090c39 100644
+--- a/zebra/zebra_rib.c
++++ b/zebra/zebra_rib.c
+@@ -67,6 +67,9 @@ static const struct
+   [ZEBRA_ROUTE_OSPF6]   = {ZEBRA_ROUTE_OSPF6,   110},
+   [ZEBRA_ROUTE_ISIS]    = {ZEBRA_ROUTE_ISIS,    115},
+   [ZEBRA_ROUTE_BGP]     = {ZEBRA_ROUTE_BGP,      20  /* IBGP is 200. */},
++  [ZEBRA_ROUTE_HSLS]    = {ZEBRA_ROUTE_HSLS,      0},
++  [ZEBRA_ROUTE_OLSR]    = {ZEBRA_ROUTE_OLSR,      0},
++  [ZEBRA_ROUTE_BATMAN]  = {ZEBRA_ROUTE_BATMAN,    0},
+   [ZEBRA_ROUTE_BABEL]   = {ZEBRA_ROUTE_BABEL,    95},
+   /* no entry/default: 150 */
+ };
+@@ -381,6 +384,18 @@ nexthop_active_ipv4 (struct rib *rib, struct nexthop *nexthop, int set,
+             
+             return 1;
+           }
++        else if (match->type == ZEBRA_ROUTE_OLSR)
++          {
++            for (newhop = match->nexthop; newhop; newhop = newhop->next)
++              if (CHECK_FLAG (newhop->flags, NEXTHOP_FLAG_FIB)
++                  && newhop->type == NEXTHOP_TYPE_IFINDEX)
++                {
++                  if (nexthop->type == NEXTHOP_TYPE_IPV4)
++                    nexthop->ifindex = newhop->ifindex;
++                  return 1;
++                }
++            return 0;
++          }
+         else if (CHECK_FLAG (rib->flags, ZEBRA_FLAG_INTERNAL))
+           {
+             for (newhop = match->nexthop; newhop; newhop = newhop->next)
+@@ -483,6 +498,18 @@ nexthop_active_ipv6 (struct rib *rib, struct nexthop *nexthop, int set,
+             
+             return 1;
+           }
++        else if (match->type == ZEBRA_ROUTE_OLSR)
++          {
++            for (newhop = match->nexthop; newhop; newhop = newhop->next)
++              if (CHECK_FLAG (newhop->flags, NEXTHOP_FLAG_FIB)
++                  && newhop->type == NEXTHOP_TYPE_IFINDEX)
++                {
++                  if (nexthop->type == NEXTHOP_TYPE_IPV6)
++                    nexthop->ifindex = newhop->ifindex;
++                  return 1;
++                }
++            return 0;
++          }
+         else if (CHECK_FLAG (rib->flags, ZEBRA_FLAG_INTERNAL))
+           {
+             for (newhop = match->nexthop; newhop; newhop = newhop->next)
+@@ -1236,6 +1263,8 @@ static const u_char meta_queue_map[ZEBRA_ROUTE_MAX] = {
+   [ZEBRA_ROUTE_ISIS]    = 2,
+   [ZEBRA_ROUTE_BGP]     = 3,
+   [ZEBRA_ROUTE_HSLS]    = 4,
++  [ZEBRA_ROUTE_OLSR]    = 4,
++  [ZEBRA_ROUTE_BATMAN]  = 4,
+   [ZEBRA_ROUTE_BABEL]   = 2,
+ };
+diff --git a/zebra/zebra_snmp.c b/zebra/zebra_snmp.c
+index 0fde4bb..23222f4 100644
+--- a/zebra/zebra_snmp.c
++++ b/zebra/zebra_snmp.c
+@@ -251,6 +251,12 @@ proto_trans(int type)
+       return 1; /* shouldn't happen */
+     case ZEBRA_ROUTE_BGP:
+       return 14; /* bgp */
++    case ZEBRA_ROUTE_HSLS:
++      return 1; /* other */
++    case ZEBRA_ROUTE_OLSR:
++      return 1; /* other */
++    case ZEBRA_ROUTE_BATMAN:
++      return 1; /* other */
+     default:
+       return 1; /* other */
+     }
+diff --git a/zebra/zebra_vty.c b/zebra/zebra_vty.c
+index dafcf75..277cc7a 100644
+--- a/zebra/zebra_vty.c
++++ b/zebra/zebra_vty.c
+@@ -558,7 +558,10 @@ vty_show_ip_route_detail (struct vty *vty, struct route_node *rn)
+         || rib->type == ZEBRA_ROUTE_OSPF
+         || rib->type == ZEBRA_ROUTE_BABEL
+         || rib->type == ZEBRA_ROUTE_ISIS
+-        || rib->type == ZEBRA_ROUTE_BGP)
++        || rib->type == ZEBRA_ROUTE_BGP
++        || rib->type == ZEBRA_ROUTE_HSLS
++        || rib->type == ZEBRA_ROUTE_OLSR
++        || rib->type == ZEBRA_ROUTE_BATMAN)
+       {
+         time_t uptime;
+         struct tm *tm;
+@@ -777,7 +780,10 @@ vty_show_ip_route (struct vty *vty, struct route_node *rn, struct rib *rib)
+         || rib->type == ZEBRA_ROUTE_OSPF
+         || rib->type == ZEBRA_ROUTE_BABEL
+         || rib->type == ZEBRA_ROUTE_ISIS
+-        || rib->type == ZEBRA_ROUTE_BGP)
++        || rib->type == ZEBRA_ROUTE_BGP
++        || rib->type == ZEBRA_ROUTE_HSLS
++        || rib->type == ZEBRA_ROUTE_OLSR
++        || rib->type == ZEBRA_ROUTE_BATMAN)
+       {
+         time_t uptime;
+         struct tm *tm;
+@@ -1536,7 +1542,10 @@ vty_show_ipv6_route_detail (struct vty *vty, struct route_node *rn)
+         || rib->type == ZEBRA_ROUTE_OSPF6
+         || rib->type == ZEBRA_ROUTE_BABEL
+         || rib->type == ZEBRA_ROUTE_ISIS
+-        || rib->type == ZEBRA_ROUTE_BGP)
++        || rib->type == ZEBRA_ROUTE_BGP
++        || rib->type == ZEBRA_ROUTE_HSLS
++        || rib->type == ZEBRA_ROUTE_OLSR
++        || rib->type == ZEBRA_ROUTE_BATMAN)
+       {
+         time_t uptime;
+         struct tm *tm;
+@@ -1716,7 +1725,10 @@ vty_show_ipv6_route (struct vty *vty, struct route_node *rn,
+         || rib->type == ZEBRA_ROUTE_OSPF6
+         || rib->type == ZEBRA_ROUTE_BABEL
+         || rib->type == ZEBRA_ROUTE_ISIS
+-        || rib->type == ZEBRA_ROUTE_BGP)
++        || rib->type == ZEBRA_ROUTE_BGP
++        || rib->type == ZEBRA_ROUTE_HSLS
++        || rib->type == ZEBRA_ROUTE_OLSR
++        || rib->type == ZEBRA_ROUTE_BATMAN)
+       {
+         time_t uptime;
+         struct tm *tm;
index b5ed2a4..b6a1a76 100644 (file)
@@ -2,7 +2,7 @@
  * OLSRd Quagga plugin
  *
  * Copyright (C) 2006-2008 Immo 'FaUl' Wehrenberg <immo@chaostreff-dortmund.de>
- * Copyright (C) 2007-2010 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
+ * Copyright (C) 2007-2012 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License version 2 as
@@ -21,7 +21,7 @@
 
 /* Zebra route types */
 #define ZEBRA_ROUTE_OLSR               11
-#define ZEBRA_ROUTE_MAX                        13
+#define ZEBRA_ROUTE_MAX                        14
 
 struct zebra {
   unsigned char status;
index 5a8eb13..e3d5cbc 100644 (file)
@@ -2,7 +2,7 @@
  * OLSRd Quagga plugin
  *
  * Copyright (C) 2006-2008 Immo 'FaUl' Wehrenberg <immo@chaostreff-dortmund.de>
- * Copyright (C) 2007-2010 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
+ * Copyright (C) 2007-2012 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License version 2 as
@@ -28,24 +28,43 @@ unsigned char
 {
   int count;
   uint8_t len;
-  uint16_t size;
+  uint16_t size, safi;
   uint32_t ind, metric;
   unsigned char *cmdopt, *t;
 
   cmdopt = olsr_malloc(ZEBRA_MAX_PACKET_SIZ, "QUAGGA: New route packet");
 
   t = &cmdopt[2];
-  if (zebra.version) {
-    *t++ = ZEBRA_HEADER_MARKER;
-    *t++ = zebra.version;
-    cmd = htons(cmd);
-    memcpy(t, &cmd, sizeof cmd);
-    t += sizeof cmd;
-  } else
+  switch (zebra.version) {
+    case 0:
       *t++ = (unsigned char) cmd;
+      break;
+    case 1:
+    case 2:
+      *t++ = ZEBRA_HEADER_MARKER;
+      *t++ = zebra.version;
+      cmd = htons(cmd);
+      memcpy(t, &cmd, sizeof cmd);
+      t += sizeof cmd;
+      break;
+    default:
+      break;
+  }
   *t++ = r->type;
   *t++ = r->flags;
   *t++ = r->message;
+  switch (zebra.version) {
+    case 0:
+    case 1:
+      break;
+    case 2:
+      safi = htons(r->safi);
+      memcpy(t, &safi, sizeof safi);
+      t += sizeof safi;
+      break;
+    default:
+      break;
+  }
   *t++ = r->prefixlen;
   len = (r->prefixlen + 7) / 8;
   if (olsr_cnf->ip_version == AF_INET)
@@ -97,14 +116,21 @@ unsigned char
   data = olsr_malloc(ZEBRA_MAX_PACKET_SIZ , "QUAGGA: New redistribute packet");
 
   pnt = &data[2];
-  if (zebra.version) {
-    *pnt++ = ZEBRA_HEADER_MARKER;
-    *pnt++ = zebra.version;
-    cmd = htons(cmd);
-    memcpy(pnt, &cmd, sizeof cmd);
-    pnt += sizeof cmd;
-  } else
+  switch (zebra.version) {
+    case 0:
       *pnt++ = (unsigned char) cmd;
+      break;
+    case 1:
+    case 2:
+      *pnt++ = ZEBRA_HEADER_MARKER;
+      *pnt++ = zebra.version;
+      cmd = htons(cmd);
+      memcpy(pnt, &cmd, sizeof cmd);
+      pnt += sizeof cmd;
+      break;
+    default:
+      break;
+  }
   *pnt++ = type;
   size = htons(pnt - data);
   memcpy(data, &size, sizeof size);
index 7f732f4..645e853 100644 (file)
@@ -2,7 +2,7 @@
  * OLSRd Quagga plugin
  *
  * Copyright (C) 2006-2008 Immo 'FaUl' Wehrenberg <immo@chaostreff-dortmund.de>
- * Copyright (C) 2007-2010 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
+ * Copyright (C) 2007-2012 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License version 2 as
@@ -32,6 +32,7 @@
 #define ZEBRA_IPV6_ROUTE_DELETE         10
 #define ZEBRA_REDISTRIBUTE_ADD         11
 #define ZEBRA_REDISTRIBUTE_DELETE      12
+#define ZEBRA_HELLO                    23
 
 /* Zebra nexthop flags */
 #define ZEBRA_NEXTHOP_IFINDEX          1
@@ -44,6 +45,9 @@
 #define ZAPI_MESSAGE_DISTANCE          0x04
 #define ZAPI_MESSAGE_METRIC            0x08
 
+/* Subsequent Address Family Identifier */
+#define SAFI_UNICAST                    1
+
 /* Zebra flags */
 #define ZEBRA_FLAG_SELECTED            0x10
 
@@ -51,6 +55,7 @@ struct zroute {
   unsigned char type;
   unsigned char flags;
   unsigned char message;
+  uint16_t safi;
   unsigned char prefixlen;
   union olsr_ip_addr prefix;
   unsigned char nexthop_num;
index 8672fab..e70d25c 100644 (file)
@@ -2,7 +2,7 @@
  * OLSRd Quagga plugin
  *
  * Copyright (C) 2006-2008 Immo 'FaUl' Wehrenberg <immo@chaostreff-dortmund.de>
- * Copyright (C) 2007-2010 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
+ * Copyright (C) 2007-2012 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License version 2 as
@@ -52,7 +52,17 @@ static struct zroute
   length = ntohs (length);
 
   r = olsr_malloc(sizeof *r, "QUAGGA: New zebra route");
-  pnt = (zebra.version ? &opt[6] : &opt[3]);
+  switch (zebra.version) {
+    case 0:
+      pnt = &opt[3];
+      break;
+    case 1:
+    case 2:
+      pnt = &opt[6];
+      break;
+    default:
+      break;
+  }
   r->type = *pnt++;
   r->flags = *pnt++;
   r->message = *pnt++;
@@ -68,6 +78,7 @@ static struct zroute
   switch (zebra.version) {
     case 0:
     case 1:
+    case 2:
       if (r->message & ZAPI_MESSAGE_NEXTHOP) {
         r->nexthop_num = *pnt++;
         r->nexthop = olsr_malloc((sizeof *r->nexthop) * r->nexthop_num, "QUAGGA: New zebra route nexthop");
@@ -137,13 +148,20 @@ zparse(void *foo __attribute__ ((unused)))
       length = ntohs (length);
       if (!length) // something weired happened
         olsr_exit("(QUAGGA) Zero message length!", EXIT_FAILURE);
-      if (zebra.version) {
-        if ((f[2] != ZEBRA_HEADER_MARKER) || (f[3] != zebra.version))
-          olsr_exit("(QUAGGA) Invalid zebra header received!", EXIT_FAILURE);
-        memcpy(&command, &f[4], sizeof command);
-        command = ntohs (command);
-      } else
+      switch (zebra.version) {
+        case 0:
           command = f[2];
+          break;
+        case 1:
+        case 2:
+          if ((f[2] != ZEBRA_HEADER_MARKER) || (f[3] != zebra.version))
+            olsr_exit("(QUAGGA) Invalid zebra header received!", EXIT_FAILURE);
+          memcpy(&command, &f[4], sizeof command);
+          command = ntohs (command);
+          break;
+        default:
+          break;
+      }
       if (olsr_cnf->ip_version == AF_INET) {
         switch (command) {
           case ZEBRA_IPV4_ROUTE_ADD:
index 58bca74..79eeb19 100644 (file)
@@ -2,7 +2,7 @@
  * OLSRd Quagga plugin
  *
  * Copyright (C) 2006-2008 Immo 'FaUl' Wehrenberg <immo@chaostreff-dortmund.de>
- * Copyright (C) 2007-2010 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
+ * Copyright (C) 2007-2012 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License version 2 as
@@ -50,7 +50,7 @@ zplugin_redistribute(const char *value, void *data __attribute__ ((unused)), set
 {
   const char *zroute_types[] = { "system", "kernel", "connect",
     "static", "rip", "ripng", "ospf", "ospf6", "isis", "bgp",
-    "hsls", "olsr", "batman"
+    "hsls", "olsr", "batman", "babel"
   };
   unsigned int i;
 
@@ -144,7 +144,7 @@ zplugin_version(const char *value, void *data __attribute__ ((unused)), set_plug
 
   if (set_plugin_int(value, &version, addon))
     return 1;
-  if (version < 0 || version > 1)
+  if (version < 0 || version > 2)
     return 1;
   zebra.version = version;
 
index a4e56c1..6f2f19e 100644 (file)
@@ -2,7 +2,7 @@
  * OLSRd Quagga plugin
  *
  * Copyright (C) 2006-2008 Immo 'FaUl' Wehrenberg <immo@chaostreff-dortmund.de>
- * Copyright (C) 2007-2011 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
+ * Copyright (C) 2007-2012 Vasilis Tsiligiannis <acinonyxs@yahoo.gr>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License version 2 as
@@ -63,6 +63,7 @@ zebra_addroute(const struct rt_entry *r)
   route.type = ZEBRA_ROUTE_OLSR;
   route.flags = zebra.flags;
   route.message = ZAPI_MESSAGE_NEXTHOP | ZAPI_MESSAGE_METRIC;
+  route.safi = SAFI_UNICAST;
   route.prefixlen = r->rt_dst.prefix_len;
   if (olsr_cnf->ip_version == AF_INET)
     route.prefix.v4.s_addr = r->rt_dst.prefix.v4.s_addr;
@@ -112,6 +113,7 @@ zebra_delroute(const struct rt_entry *r)
   route.type = ZEBRA_ROUTE_OLSR;
   route.flags = zebra.flags;
   route.message = ZAPI_MESSAGE_NEXTHOP | ZAPI_MESSAGE_METRIC;
+  route.safi = SAFI_UNICAST;
   route.prefixlen = r->rt_dst.prefix_len;
   if (olsr_cnf->ip_version == AF_INET)
     route.prefix.v4.s_addr = r->rt_dst.prefix.v4.s_addr;