Blame SOURCES/bz1477587-exclude-mismatch-vips.patch

00db14
From f42914b07166db123b55a4acd31f4a6eb280d0f8 Mon Sep 17 00:00:00 2001
00db14
From: Ryan O'Hara <rohara@redhat.com>
00db14
Date: Mon, 11 Dec 2017 12:36:26 -0600
00db14
Subject: [PATCH] Exclude mixed family VIPs from VRRP advertisements
00db14
00db14
In previous releases of keepalived, it was allowed to have both IPv5
00db14
and IPv6 addresses in the 'virtual_ipaddress' block. The address count
00db14
in VRRP advertisements would reflect all VIPS, both IPv4 and IPv6, but
00db14
the address list would contain empty addresses for any VIP that did
00db14
not match the VRRP instance family. In VRRPv3 this is not allowed, and
00db14
recent releases will simply ignore any VIP that does not match the
00db14
instance family causing those VIPs to not be created in the interface.
00db14
00db14
Rather than ignore the VIP of mismatched family, this patch will move
00db14
non-matching VIP to the excluded list causing them to not be included
00db14
in the VRRP advertisements but still create them when in MASTER state.
00db14
---
00db14
 keepalived/vrrp/vrrp_parser.c | 3 ++-
00db14
 1 file changed, 2 insertions(+), 1 deletion(-)
00db14
00db14
diff --git a/keepalived/vrrp/vrrp_parser.c b/keepalived/vrrp/vrrp_parser.c
00db14
index 7a383153..d2cd720a 100644
00db14
--- a/keepalived/vrrp/vrrp_parser.c
00db14
+++ b/keepalived/vrrp/vrrp_parser.c
00db14
@@ -641,8 +641,9 @@ vrrp_vip_handler(__attribute__((unused)) vector_t *strvec)
00db14
 				if (vrrp->family == AF_UNSPEC)
00db14
 					vrrp->family = address_family;
00db14
 				else if (address_family != vrrp->family) {
00db14
-					log_message(LOG_INFO, "(%s): address family must match VRRP instance [%s] - ignoring", vrrp->iname, str);
00db14
+					log_message(LOG_WARNING, "(%s): address family does not match VRRP instance [%s]", vrrp->iname, str);
00db14
 					free_list_element(vrrp->vip, vrrp->vip->tail);
00db14
+					alloc_vrrp_evip(vec);
00db14
 				}
00db14
 			}
00db14
 
00db14
-- 
00db14
2.14.2
00db14