| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *	BIRD -- OSPF | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2004-06-04 18:24:15 +00:00
										 |  |  |  *	(c) 1999--2004 Ondrej Filip <feela@network.cz> | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |  *	(c) 2009--2014 Ondrej Zajicek <santiago@crfreenet.org> | 
					
						
							|  |  |  |  *	(c) 2009--2014 CZ.NIC z.s.p.o. | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  *	Can be freely distributed and used under the terms of the GNU GPL. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "ospf.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | struct ospf_dbdes2_packet | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   struct ospf_packet hdr; | 
					
						
							| 
									
										
										
										
											2018-04-25 15:50:57 +02:00
										 |  |  |   union ospf_auth2 auth; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  |   u16 iface_mtu; | 
					
						
							|  |  |  |   u8 options; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   u8 imms;			/* I, M, MS bits */ | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  |   u32 ddseq; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   struct ospf_lsa_header lsas[]; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | struct ospf_dbdes3_packet | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   struct ospf_packet hdr; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  |   u32 options; | 
					
						
							|  |  |  |   u16 iface_mtu; | 
					
						
							|  |  |  |   u8 padding; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   u8 imms;			/* I, M, MS bits */ | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  |   u32 ddseq; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   struct ospf_lsa_header lsas[]; | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-25 15:50:57 +02:00
										 |  |  | uint | 
					
						
							|  |  |  | ospf_dbdes3_options(struct ospf_packet *pkt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct ospf_dbdes3_packet *ps = (void *) pkt; | 
					
						
							|  |  |  |   return ntohl(ps->options); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | static inline uint | 
					
						
							|  |  |  | ospf_dbdes_hdrlen(struct ospf_proto *p) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return ospf_is_v2(p) ? | 
					
						
							|  |  |  |     sizeof(struct ospf_dbdes2_packet) : sizeof(struct ospf_dbdes3_packet); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | ospf_dbdes_body(struct ospf_proto *p, struct ospf_packet *pkt, | 
					
						
							|  |  |  | 		struct ospf_lsa_header **body, uint *count) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   uint plen = ntohs(pkt->length); | 
					
						
							|  |  |  |   uint hlen = ospf_dbdes_hdrlen(p); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   *body = ((void *) pkt) + hlen; | 
					
						
							|  |  |  |   *count = (plen - hlen) / sizeof(struct ospf_lsa_header); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-07-19 17:28:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | static void | 
					
						
							|  |  |  | ospf_dump_dbdes(struct ospf_proto *p, struct ospf_packet *pkt) | 
					
						
							| 
									
										
										
										
											2009-04-06 16:17:47 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   struct ospf_lsa_header *lsas; | 
					
						
							|  |  |  |   uint i, lsa_count; | 
					
						
							|  |  |  |   u32 pkt_ddseq; | 
					
						
							|  |  |  |   u16 pkt_iface_mtu; | 
					
						
							|  |  |  |   u8 pkt_imms; | 
					
						
							| 
									
										
										
										
											2009-04-06 16:17:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   ASSERT(pkt->type == DBDES_P); | 
					
						
							|  |  |  |   ospf_dump_common(p, pkt); | 
					
						
							| 
									
										
										
										
											2009-04-06 16:17:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   if (ospf_is_v2(p)) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     struct ospf_dbdes2_packet *ps = (void *) pkt; | 
					
						
							|  |  |  |     pkt_iface_mtu = ntohs(ps->iface_mtu); | 
					
						
							|  |  |  |     pkt_imms = ps->imms; | 
					
						
							|  |  |  |     pkt_ddseq = ntohl(ps->ddseq); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else /* OSPFv3 */ | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     struct ospf_dbdes3_packet *ps = (void *) pkt; | 
					
						
							|  |  |  |     pkt_iface_mtu = ntohs(ps->iface_mtu); | 
					
						
							|  |  |  |     pkt_imms = ps->imms; | 
					
						
							|  |  |  |     pkt_ddseq = ntohl(ps->ddseq); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-04-06 16:17:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   log(L_TRACE "%s:     mtu      %u", p->p.name, pkt_iface_mtu); | 
					
						
							|  |  |  |   log(L_TRACE "%s:     imms     %s%s%s", p->p.name, | 
					
						
							|  |  |  |       (pkt_imms & DBDES_I) ? "I " : "", | 
					
						
							|  |  |  |       (pkt_imms & DBDES_M) ? "M " : "", | 
					
						
							|  |  |  |       (pkt_imms & DBDES_MS) ? "MS" : ""); | 
					
						
							|  |  |  |   log(L_TRACE "%s:     ddseq    %u", p->p.name, pkt_ddseq); | 
					
						
							| 
									
										
										
										
											2009-04-06 16:17:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   ospf_dbdes_body(p, pkt, &lsas, &lsa_count); | 
					
						
							|  |  |  |   for (i = 0; i < lsa_count; i++) | 
					
						
							|  |  |  |     ospf_dump_lsahdr(p, lsas + i); | 
					
						
							| 
									
										
										
										
											2009-04-06 16:17:47 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  | ospf_prepare_dbdes(struct ospf_proto *p, struct ospf_neighbor *n) | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | { | 
					
						
							|  |  |  |   struct ospf_iface *ifa = n->ifa; | 
					
						
							|  |  |  |   struct ospf_packet *pkt; | 
					
						
							|  |  |  |   uint length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   u16 iface_mtu = (ifa->type == OSPF_IT_VLINK) ? 0 : ifa->iface->mtu; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   /* Update DBDES buffer */ | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   if (n->ldd_bsize != ifa->tx_length) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     mb_free(n->ldd_buffer); | 
					
						
							|  |  |  |     n->ldd_buffer = mb_allocz(n->pool, ifa->tx_length); | 
					
						
							|  |  |  |     n->ldd_bsize = ifa->tx_length; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   pkt = n->ldd_buffer; | 
					
						
							|  |  |  |   ospf_pkt_fill_hdr(ifa, pkt, DBDES_P); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (ospf_is_v2(p)) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     struct ospf_dbdes2_packet *ps = (void *) pkt; | 
					
						
							|  |  |  |     ps->iface_mtu = htons(iface_mtu); | 
					
						
							| 
									
										
										
										
											2019-07-10 18:25:36 +02:00
										 |  |  |     ps->options = ifa->oa->options & DBDES2_OPT_MASK; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     ps->imms = 0;	/* Will be set later */ | 
					
						
							|  |  |  |     ps->ddseq = htonl(n->dds); | 
					
						
							|  |  |  |     length = sizeof(struct ospf_dbdes2_packet); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else /* OSPFv3 */ | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     struct ospf_dbdes3_packet *ps = (void *) pkt; | 
					
						
							| 
									
										
										
										
											2019-07-10 18:25:36 +02:00
										 |  |  |     u32 options = ifa->oa->options | (ifa->autype == OSPF_AUTH_CRYPT ? OPT_AT : 0); | 
					
						
							|  |  |  |     ps->options = htonl(options & DBDES3_OPT_MASK); | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     ps->iface_mtu = htons(iface_mtu); | 
					
						
							|  |  |  |     ps->padding = 0; | 
					
						
							|  |  |  |     ps->imms = 0;	/* Will be set later */ | 
					
						
							|  |  |  |     ps->ddseq = htonl(n->dds); | 
					
						
							|  |  |  |     length = sizeof(struct ospf_dbdes3_packet); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   /* Prepare DBDES body */ | 
					
						
							|  |  |  |   if (!(n->myimms & DBDES_I) && (n->myimms & DBDES_M)) | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   { | 
					
						
							|  |  |  |     struct ospf_lsa_header *lsas; | 
					
						
							|  |  |  |     struct top_hash_entry *en; | 
					
						
							|  |  |  |     uint i = 0, lsa_max; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ospf_dbdes_body(p, pkt, &lsas, &lsa_max); | 
					
						
							|  |  |  |     en = (void *) s_get(&(n->dbsi)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while (i < lsa_max) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       if (!SNODE_VALID(en)) | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  | 	n->myimms &= ~DBDES_M;	/* Unset More bit */ | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if ((en->lsa.age < LSA_MAXAGE) && | 
					
						
							| 
									
										
										
										
											2019-01-24 22:34:33 +01:00
										 |  |  | 	  lsa_flooding_allowed(en->lsa_type, en->domain, ifa) && | 
					
						
							|  |  |  | 	  lsa_is_acceptable(en->lsa_type, n, p)) | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       { | 
					
						
							|  |  |  | 	lsa_hton_hdr(&(en->lsa), lsas + i); | 
					
						
							|  |  |  | 	i++; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       en = SNODE_NEXT(en); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     s_put(&(n->dbsi), SNODE en); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     length += i * sizeof(struct ospf_lsa_header); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (ospf_is_v2(p)) | 
					
						
							|  |  |  |     ((struct ospf_dbdes2_packet *) pkt)->imms = n->myimms; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     ((struct ospf_dbdes3_packet *) pkt)->imms = n->myimms; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   pkt->length = htons(length); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | ospf_do_send_dbdes(struct ospf_proto *p, struct ospf_neighbor *n) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct ospf_iface *ifa = n->ifa; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSPF_PACKET(ospf_dump_dbdes, n->ldd_buffer, | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  | 	      "DBDES packet sent to nbr %R on %s", n->rid, ifa->ifname); | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   sk_set_tbuf(ifa->sk, n->ldd_buffer); | 
					
						
							|  |  |  |   ospf_send_to(ifa, n->ip); | 
					
						
							|  |  |  |   sk_set_tbuf(ifa->sk, NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-06-07 22:53:51 +00:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |  * ospf_send_dbdes - transmit database description packet | 
					
						
							| 
									
										
										
										
											2016-05-12 15:49:44 +02:00
										 |  |  |  * @p: OSPF protocol instance | 
					
						
							| 
									
										
										
										
											2000-06-07 22:53:51 +00:00
										 |  |  |  * @n: neighbor | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  |  * Sending of a database description packet is described in 10.8 of RFC 2328. | 
					
						
							| 
									
										
										
										
											2003-08-23 10:42:41 +00:00
										 |  |  |  * Reception of each packet is acknowledged in the sequence number of another. | 
					
						
							|  |  |  |  * When I send a packet to a neighbor I keep a copy in a buffer. If the neighbor | 
					
						
							|  |  |  |  * does not reply, I don't create a new packet but just send the content | 
					
						
							|  |  |  |  * of the buffer. | 
					
						
							| 
									
										
										
										
											2000-06-07 22:53:51 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | void | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  | ospf_send_dbdes(struct ospf_proto *p, struct ospf_neighbor *n) | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   /* RFC 2328 10.8 */ | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   ASSERT((n->state == NEIGHBOR_EXSTART) || (n->state == NEIGHBOR_EXCHANGE)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-30 20:12:59 +02:00
										 |  |  |   if (!n->ifa->oa->rt && !p->gr_recovery) | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2000-06-08 19:02:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   ospf_prepare_dbdes(p, n); | 
					
						
							|  |  |  |   ospf_do_send_dbdes(p, n); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  | void | 
					
						
							|  |  |  | ospf_rxmt_dbdes(struct ospf_proto *p, struct ospf_neighbor *n) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   ASSERT(n->state > NEIGHBOR_EXSTART); | 
					
						
							| 
									
										
										
										
											2004-06-04 18:51:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   if (!n->ldd_buffer) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     log(L_WARN "%s: No DBDES packet for retransmit", p->p.name); | 
					
						
							|  |  |  |     ospf_neigh_sm(n, INM_SEQMIS); | 
					
						
							|  |  |  |     return; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2000-03-29 12:32:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   /* Send last packet */ | 
					
						
							|  |  |  |   ospf_do_send_dbdes(p, n); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-02-06 17:46:01 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-03 17:31:27 +01:00
										 |  |  | void | 
					
						
							|  |  |  | ospf_reset_ldd(struct ospf_proto *p UNUSED, struct ospf_neighbor *n) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   mb_free(n->ldd_buffer); | 
					
						
							|  |  |  |   n->ldd_buffer = NULL; | 
					
						
							|  |  |  |   n->ldd_bsize = 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | static int | 
					
						
							|  |  |  | ospf_process_dbdes(struct ospf_proto *p, struct ospf_packet *pkt, struct ospf_neighbor *n) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   struct ospf_iface *ifa = n->ifa; | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   struct ospf_lsa_header *lsas, lsa; | 
					
						
							|  |  |  |   struct top_hash_entry *en, *req; | 
					
						
							|  |  |  |   const char *err_dsc = NULL; | 
					
						
							|  |  |  |   u32 lsa_type, lsa_domain; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   uint i, lsa_count; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ospf_dbdes_body(p, pkt, &lsas, &lsa_count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < lsa_count; i++) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     lsa_ntoh_hdr(lsas + i, &lsa); | 
					
						
							|  |  |  |     lsa_get_type_domain(&lsa, ifa, &lsa_type, &lsa_domain); | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     /* RFC 2328 10.6 and RFC 5340 4.2.2 */ | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     if (!lsa_type) | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       DROP1("LSA of unknown type"); | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     if (!oa_is_ext(ifa->oa) && (LSA_SCOPE(lsa_type) == LSA_SCOPE_AS)) | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       DROP1("LSA with AS scope in stub area"); | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     /* Errata 3746 to RFC 2328 - rt-summary-LSAs forbidden in stub areas */ | 
					
						
							|  |  |  |     if (!oa_is_ext(ifa->oa) && (lsa_type == LSA_T_SUM_RT)) | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       DROP1("rt-summary-LSA in stub area"); | 
					
						
							| 
									
										
										
										
											2000-03-29 17:18:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     /* Not explicitly mentioned in RFC 5340 4.2.2 but makes sense */ | 
					
						
							|  |  |  |     if (LSA_SCOPE(lsa_type) == LSA_SCOPE_RES) | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       DROP1("LSA with invalid scope"); | 
					
						
							| 
									
										
										
										
											2000-03-29 17:18:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-30 20:12:59 +02:00
										 |  |  |     /* RFC 3623 2.2 (2) special case - check for my router-LSA (GR recovery) */ | 
					
						
							|  |  |  |     if ((lsa_type == LSA_T_RT) && (lsa.rt == p->router_id)) | 
					
						
							|  |  |  |       n->got_my_rt_lsa = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     en = ospf_hash_find(p->gr, lsa_domain, lsa.id, lsa.rt, lsa_type); | 
					
						
							|  |  |  |     if (!en || (lsa_comp(&lsa, &(en->lsa)) == CMP_NEWER)) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  |       /* This should be splitted to ospf_lsa_lsrq_up() */ | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       req = ospf_hash_get(n->lsrqh, lsa_domain, lsa.id, lsa.rt, lsa_type); | 
					
						
							| 
									
										
										
										
											2000-03-30 00:18:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       if (!SNODE_VALID(req)) | 
					
						
							|  |  |  | 	s_add_tail(&n->lsrql, SNODE req); | 
					
						
							| 
									
										
										
										
											2000-03-30 00:18:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  |       if (!SNODE_VALID(n->lsrqi)) | 
					
						
							|  |  |  | 	n->lsrqi = req; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       req->lsa = lsa; | 
					
						
							| 
									
										
										
										
											2014-07-18 18:24:12 +02:00
										 |  |  |       req->lsa_body = LSA_BODY_DUMMY; | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-28 17:43:20 +01:00
										 |  |  |       if (!tm_active(n->lsrq_timer)) | 
					
						
							|  |  |  | 	tm_start(n->lsrq_timer, 0); | 
					
						
							| 
									
										
										
										
											2000-03-30 19:37:26 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2000-03-30 00:18:59 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  | drop: | 
					
						
							|  |  |  |   LOG_LSA1("Bad LSA (Type: %04x, Id: %R, Rt: %R) in DBDES", lsa_type, lsa.id, lsa.rt); | 
					
						
							|  |  |  |   LOG_LSA2("  received from nbr %R on %s - %s", n->rid, ifa->ifname, err_dsc); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   ospf_neigh_sm(n, INM_SEQMIS); | 
					
						
							|  |  |  |   return -1; | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | ospf_receive_dbdes(struct ospf_packet *pkt, struct ospf_iface *ifa, | 
					
						
							| 
									
										
										
										
											2009-08-21 09:27:52 +02:00
										 |  |  | 		   struct ospf_neighbor *n) | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   struct ospf_proto *p = ifa->oa->po; | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   const char *err_dsc = NULL; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   u32 rcv_ddseq, rcv_options; | 
					
						
							|  |  |  |   u16 rcv_iface_mtu; | 
					
						
							|  |  |  |   u8 rcv_imms; | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  |   uint plen, err_val = 0; | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   /* RFC 2328 10.6 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   plen = ntohs(pkt->length); | 
					
						
							|  |  |  |   if (plen < ospf_dbdes_hdrlen(p)) | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  |   { | 
					
						
							|  |  |  |     LOG_PKT("Bad DBDES packet from nbr %R on %s - %s (%u)", n->rid, ifa->ifname, "too short", plen); | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-10-29 23:57:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   OSPF_PACKET(ospf_dump_dbdes, pkt, "DBDES packet received from nbr %R on %s", n->rid, ifa->ifname); | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-06-05 19:45:06 +00:00
										 |  |  |   ospf_neigh_sm(n, INM_HELLOREC); | 
					
						
							| 
									
										
										
										
											2000-05-10 12:22:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   if (ospf_is_v2(p)) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     struct ospf_dbdes2_packet *ps = (void *) pkt; | 
					
						
							|  |  |  |     rcv_iface_mtu = ntohs(ps->iface_mtu); | 
					
						
							|  |  |  |     rcv_options = ps->options; | 
					
						
							|  |  |  |     rcv_imms = ps->imms; | 
					
						
							|  |  |  |     rcv_ddseq = ntohl(ps->ddseq); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else /* OSPFv3 */ | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     struct ospf_dbdes3_packet *ps = (void *) pkt; | 
					
						
							|  |  |  |     rcv_options = ntohl(ps->options); | 
					
						
							|  |  |  |     rcv_iface_mtu = ntohs(ps->iface_mtu); | 
					
						
							|  |  |  |     rcv_imms = ps->imms; | 
					
						
							|  |  |  |     rcv_ddseq = ntohl(ps->ddseq); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-07-19 17:28:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-03 15:45:43 +01:00
										 |  |  |   /* Reject packets with non-matching MTU */ | 
					
						
							|  |  |  |   if ((ifa->type != OSPF_IT_VLINK) && | 
					
						
							|  |  |  |       (rcv_iface_mtu != ifa->iface->mtu) && | 
					
						
							|  |  |  |       (rcv_iface_mtu != 0) && (ifa->iface->mtu != 0)) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     LOG_PKT("MTU mismatch with nbr %R on %s (remote %d, local %d)", | 
					
						
							|  |  |  | 	    n->rid, ifa->ifname, rcv_iface_mtu, ifa->iface->mtu); | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |   switch (n->state) | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |   case NEIGHBOR_DOWN: | 
					
						
							|  |  |  |   case NEIGHBOR_ATTEMPT: | 
					
						
							|  |  |  |   case NEIGHBOR_2WAY: | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |     OSPF_TRACE(D_PACKETS, "DBDES packet ignored - lesser state than ExStart"); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |   case NEIGHBOR_INIT: | 
					
						
							|  |  |  |     ospf_neigh_sm(n, INM_2WAYREC); | 
					
						
							|  |  |  |     if (n->state != NEIGHBOR_EXSTART) | 
					
						
							|  |  |  |       return; | 
					
						
							| 
									
										
										
										
											2018-09-18 14:21:11 +02:00
										 |  |  |     /* fallthrough */ | 
					
						
							| 
									
										
										
										
											2012-03-15 13:45:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |   case NEIGHBOR_EXSTART: | 
					
						
							| 
									
										
										
										
											2017-10-09 01:16:29 +02:00
										 |  |  |     if (((rcv_imms & DBDES_IMMS) == DBDES_IMMS) && | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 	(n->rid > p->router_id) && | 
					
						
							|  |  |  | 	(plen == ospf_dbdes_hdrlen(p))) | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |       /* I'm slave! */ | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       n->dds = rcv_ddseq; | 
					
						
							|  |  |  |       n->ddr = rcv_ddseq; | 
					
						
							|  |  |  |       n->options = rcv_options; | 
					
						
							|  |  |  |       n->myimms &= ~DBDES_MS; | 
					
						
							|  |  |  |       n->imms = rcv_imms; | 
					
						
							| 
									
										
										
										
											2017-11-28 17:43:20 +01:00
										 |  |  |       tm_stop(n->dbdes_timer); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |       ospf_neigh_sm(n, INM_NEGDONE); | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       ospf_send_dbdes(p, n); | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     if (!(rcv_imms & DBDES_I) && | 
					
						
							|  |  |  | 	!(rcv_imms & DBDES_MS) && | 
					
						
							| 
									
										
										
										
											2014-07-19 17:28:38 +02:00
										 |  |  | 	(n->rid < p->router_id) && | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 	(n->dds == rcv_ddseq)) | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  |       /* I'm master! */ | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       n->options = rcv_options; | 
					
						
							|  |  |  |       n->ddr = rcv_ddseq - 1;	/* It will be set corectly a few lines down */ | 
					
						
							|  |  |  |       n->imms = rcv_imms; | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  |       ospf_neigh_sm(n, INM_NEGDONE); | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  |       /* Continue to the NEIGHBOR_EXCHANGE case */ | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       DBG("%s: Nothing happend to %I (imms=%d)\n", p->name, n->ip, rcv_imms); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2004-06-11 09:34:48 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |   case NEIGHBOR_EXCHANGE: | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     if ((rcv_imms == n->imms) && | 
					
						
							|  |  |  | 	(rcv_options == n->options) && | 
					
						
							|  |  |  | 	(rcv_ddseq == n->ddr)) | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       goto duplicate; | 
					
						
							| 
									
										
										
										
											2000-03-29 17:18:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |     if ((rcv_imms & DBDES_MS) != (n->imms & DBDES_MS)) | 
					
						
							|  |  |  |       DROP("MS-bit mismatch", rcv_imms); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |     if (rcv_imms & DBDES_I) | 
					
						
							|  |  |  |       DROP("I-bit mismatch", rcv_imms); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (rcv_options != n->options) | 
					
						
							|  |  |  |       DROP("options mismatch", rcv_options); | 
					
						
							| 
									
										
										
										
											1999-11-17 15:50:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     n->ddr = rcv_ddseq; | 
					
						
							|  |  |  |     n->imms = rcv_imms; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (n->myimms & DBDES_MS) | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       /* MASTER */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (rcv_ddseq != n->dds) | 
					
						
							|  |  |  | 	DROP("DD sequence number mismatch", rcv_ddseq); | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |       n->dds++; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       if (ospf_process_dbdes(p, pkt, n) < 0) | 
					
						
							|  |  |  | 	return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (!(n->myimms & DBDES_M) && !(n->imms & DBDES_M)) | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  |       { | 
					
						
							| 
									
										
										
										
											2017-11-28 17:43:20 +01:00
										 |  |  | 	tm_stop(n->dbdes_timer); | 
					
						
							| 
									
										
										
										
											2019-02-03 17:31:27 +01:00
										 |  |  | 	ospf_reset_ldd(p, n); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  | 	ospf_neigh_sm(n, INM_EXDONE); | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  | 	break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       ospf_send_dbdes(p, n); | 
					
						
							| 
									
										
										
										
											2017-11-28 17:43:20 +01:00
										 |  |  |       tm_start(n->dbdes_timer, n->ifa->rxmtint S); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       /* SLAVE */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (rcv_ddseq != (n->dds + 1)) | 
					
						
							|  |  |  | 	DROP("DD sequence number mismatch", rcv_ddseq); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |       n->ddr = rcv_ddseq; | 
					
						
							|  |  |  |       n->dds = rcv_ddseq; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (ospf_process_dbdes(p, pkt, n) < 0) | 
					
						
							|  |  |  | 	return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       ospf_send_dbdes(p, n); | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       if (!(n->myimms & DBDES_M) && !(n->imms & DBDES_M)) | 
					
						
							| 
									
										
										
										
											2019-02-03 17:31:27 +01:00
										 |  |  |       { | 
					
						
							|  |  |  | 	/* Use dbdes timer to postpone freeing of Last DBDES packet buffer */ | 
					
						
							|  |  |  | 	tm_start(n->dbdes_timer, n->ifa->deadint S); | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  | 	ospf_neigh_sm(n, INM_EXDONE); | 
					
						
							| 
									
										
										
										
											2019-02-03 17:31:27 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |     break; | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |   case NEIGHBOR_LOADING: | 
					
						
							|  |  |  |   case NEIGHBOR_FULL: | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  |     if ((rcv_imms == n->imms) && | 
					
						
							|  |  |  | 	(rcv_options == n->options) && | 
					
						
							|  |  |  | 	(rcv_ddseq == n->ddr)) | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |       goto duplicate; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     DROP("too late for DD exchange", n->state); | 
					
						
							| 
									
										
										
										
											2014-06-26 11:58:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-05 09:29:38 +00:00
										 |  |  |   default: | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |     bug("Undefined interface state"); | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | duplicate: | 
					
						
							|  |  |  |   OSPF_TRACE(D_PACKETS, "DBDES packet is duplicate"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Slave should retransmit DBDES packet */ | 
					
						
							|  |  |  |   if (!(n->myimms & DBDES_MS)) | 
					
						
							|  |  |  |     ospf_rxmt_dbdes(p, n); | 
					
						
							|  |  |  |   return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | drop: | 
					
						
							|  |  |  |   LOG_PKT("Bad DBDES packet from nbr %R on %s - %s (%u)", | 
					
						
							|  |  |  | 	  n->rid, ifa->ifname, err_dsc, err_val); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-03 10:42:55 +01:00
										 |  |  |   ospf_neigh_sm(n, INM_SEQMIS); | 
					
						
							| 
									
										
										
										
											2014-10-24 10:27:21 +02:00
										 |  |  |   return; | 
					
						
							| 
									
										
										
										
											2004-06-04 17:49:25 +00:00
										 |  |  | } |