Blame SOURCES/ntp-4.2.6p5-cve-2016-7429.patch

6e16f6
diff -up ntp-4.2.6p5/ntpd/ntp_peer.c.cve-2016-7429 ntp-4.2.6p5/ntpd/ntp_peer.c
6e16f6
--- ntp-4.2.6p5/ntpd/ntp_peer.c.cve-2016-7429	2016-11-21 16:47:51.738767270 +0100
6e16f6
+++ ntp-4.2.6p5/ntpd/ntp_peer.c	2016-11-21 16:52:02.434034046 +0100
6e16f6
@@ -241,7 +241,8 @@ findpeer(
6e16f6
 	hash = NTP_HASH_ADDR(srcadr);
6e16f6
 	for (p = peer_hash[hash]; p != NULL; p = p->next) {
6e16f6
 		if (SOCK_EQ(srcadr, &p->srcadr) &&
6e16f6
-		    NSRCPORT(srcadr) == NSRCPORT(&p->srcadr)) {
6e16f6
+		    NSRCPORT(srcadr) == NSRCPORT(&p->srcadr) &&
6e16f6
+		    (p->hmode == MODE_BCLIENT || p->dstadr == rbufp->dstadr)) {
6e16f6
 
6e16f6
 			/*
6e16f6
 			 * if the association matching rules determine
6e16f6
@@ -288,13 +289,6 @@ findpeer(
6e16f6
 	 */
6e16f6
 	if (NULL == p) {
6e16f6
 		*action = MATCH_ASSOC(NO_PEER, pkt_mode);
6e16f6
-	} else if (p->dstadr != rbufp->dstadr) {
6e16f6
-		set_peerdstadr(p, rbufp->dstadr);
6e16f6
-		if (p->dstadr == rbufp->dstadr) {
6e16f6
-			DPRINTF(1, ("Changed %s local address to match response\n",
6e16f6
-				    stoa(&p->srcadr)));
6e16f6
-			return findpeer(rbufp, pkt_mode, action);
6e16f6
-		}
6e16f6
 	}
6e16f6
 	return p;
6e16f6
 }
6e16f6
@@ -548,6 +542,11 @@ set_peerdstadr(
6e16f6
 {
6e16f6
 	struct peer *	unlinked;
6e16f6
 
6e16f6
+	DEBUG_INSIST(p != NULL);
6e16f6
+
6e16f6
+	if (p == NULL)
6e16f6
+		return;
6e16f6
+
6e16f6
 	if (p->dstadr == dstadr)
6e16f6
 		return;
6e16f6