diff options
| author | Mobashshera Rasool <mrasool@vmware.com> | 2022-11-21 03:15:28 -0800 | 
|---|---|---|
| committer | Mobashshera Rasool <mrasool@vmware.com> | 2022-11-21 22:00:10 -0800 | 
| commit | a23a485cbff96fc3cfca50a309977fd5dea06639 (patch) | |
| tree | 141ef20a27b4deb56ccc39d755b4abca75343d41 /pimd/pim_join.c | |
| parent | c6950cb34358181d5830f0c8fdefed590fbe0586 (diff) | |
pim6d, pimd: Discard (*,G) prune if WC bit is set but RPT bit is unset.
As per RFC 7761, Section 4.9.1
The RPT (or Rendezvous Point Tree) bit is a 1-bit value for use
with PIM Join/Prune messages (see Section 4.9.5.1). If the
WC bit is 1, the RPT bit MUST be 1.
ANVL conformance test case is trying to verify this and is failing.
Issue: #12354
Signed-off-by: Mobashshera Rasool <mrasool@vmware.com>
Diffstat (limited to 'pimd/pim_join.c')
| -rw-r--r-- | pimd/pim_join.c | 17 | 
1 files changed, 15 insertions, 2 deletions
diff --git a/pimd/pim_join.c b/pimd/pim_join.c index 7b252ad572..e028b6aa77 100644 --- a/pimd/pim_join.c +++ b/pimd/pim_join.c @@ -140,8 +140,21 @@ static void recv_prune(struct interface *ifp, struct pim_neighbor *neigh,  	++pim_ifp->pim_ifstat_prune_recv; -	if ((source_flags & PIM_RPT_BIT_MASK) -	    && (source_flags & PIM_WILDCARD_BIT_MASK)) { +	if (CHECK_FLAG(source_flags, PIM_WILDCARD_BIT_MASK)) { +		/* As per RFC 7761 Section 4.9.1: +		 * The RPT (or Rendezvous Point Tree) bit is a 1-bit value for +		 * use with PIM Join/Prune messages (see Section 4.9.5.1). If +		 * the WC bit is 1, the RPT bit MUST be 1. +		 */ +		if (!CHECK_FLAG(source_flags, PIM_RPT_BIT_MASK)) { +			if (PIM_DEBUG_PIM_J_P) +				zlog_debug( +					"Discarding (*,G)=%pSG prune since WC bit is set but RPT bit is unset", +					sg); + +			return; +		} +  		/*  		 * RFC 4601 Section 4.5.2:  		 * Received Prune(*,G) messages are processed even if the  | 
