summaryrefslogtreecommitdiffstats
path: root/pimd/pim_msdp_socket.c
diff options
context:
space:
mode:
authoranuradhak <anuradhak@cumulusnetworks.com>2016-10-31 20:29:17 +0100
committerDonald Sharp <sharpd@cumulusnetworks.com>2016-12-22 02:26:14 +0100
commit3c72d6549515c6b4603a9458ff2af76ed85fe70b (patch)
tree37d98e49c053f94bfc663955dc96882c069f6e7e /pimd/pim_msdp_socket.c
parentpimd: Store ifchannel information in a global list too. (diff)
downloadfrr-3c72d6549515c6b4603a9458ff2af76ed85fe70b.tar.xz
frr-3c72d6549515c6b4603a9458ff2af76ed85fe70b.zip
pim-msdp: part-2: SA cache support
This commit includes - 1. Maintaining SA cache with local and remote entries. 2. Local SA entries - there are two cases where we pick up these - - We are RP and got a source-register from the FHR. - We are RP and FHR and learnt a new directly connected source on a DR interface. 3. Local entries are pushed to peers immediately on addition and periodically. An immediate push is also done when peer session is established. 4. Remote SA entries - from other peers in the mesh group and passed peer-RPF checks. 5. Remote entries are aged out. No other way to del them currently. In the future we may add a knob to flush entries on peer-down. Testing done - Misc topologies with CL routers plus basic interop with another vendor ( we can process their SA updates and they ours). Sample output - root@rp:~# vtysh -c "show ip msdp sa" Source Group RP Uptime 33.1.1.1 239.1.1.2 local 00:02:34 33.1.1.1 239.1.1.3 local 00:02:19 44.1.1.1 239.1.1.4 100.1.3.1 00:01:12 44.1.1.1 239.1.1.5 100.1.3.1 00:00:55 root@rp:~# Ticket: CM-13306 Signed-off-by: Anuradha Karuppiah <anuradhak@cumulusnetworks.com> Acked-by: Donald Sharp <sharpd@cumulusnetworks.com>
Diffstat (limited to 'pimd/pim_msdp_socket.c')
-rw-r--r--pimd/pim_msdp_socket.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/pimd/pim_msdp_socket.c b/pimd/pim_msdp_socket.c
index fdb77c530..f71d23e4a 100644
--- a/pimd/pim_msdp_socket.c
+++ b/pimd/pim_msdp_socket.c
@@ -22,8 +22,9 @@
#include <lib/log.h>
#include <lib/network.h>
-#include <lib/thread.h>
#include <lib/sockunion.h>
+#include <lib/thread.h>
+#include <lib/vty.h>
#include "pimd.h"
@@ -149,11 +150,11 @@ pim_msdp_sock_listen(void)
safe_strerror (errno));
}
- /* bond to well known TCP port */
+ /* bind to well known TCP port */
rc = bind(sock, (struct sockaddr *)&sin, socklen);
if (pimd_privs.change(ZPRIVS_LOWER)) {
- zlog_err ("pim_msdp_socket: could not raise privs, %s",
+ zlog_err ("pim_msdp_socket: could not lower privs, %s",
safe_strerror (errno));
}