mirror of
				https://git.proxmox.com/git/mirror_frr
				synced 2025-10-26 02:16:21 +00:00 
			
		
		
		
	2004-10-22 Paul Jakma <paul@dishone.st>
* ripd.c: Collapse redundant passing of various address structs,
          struct interface and struct connected as arguments to functions
          down to two key arguments, namely struct connected and, possibly,
          address of source/destination. Testing for RIPv1 would be useful.
          (rip_read) lookup struct connected for the received packet, pass
          it on.
        * rip_interface.c: With previous changes, we no longer have to tread
          carefully with struct connected, as it will always be there and
          valid.
			
			
This commit is contained in:
		
							parent
							
								
									6b6942f936
								
							
						
					
					
						commit
						c49ad8f1b0
					
				| @ -1,3 +1,15 @@ | |||||||
|  | 2004-10-22 Paul Jakma <paul@dishone.st> | ||||||
|  | 
 | ||||||
|  | 	* ripd.c: Collapse redundant passing of various address structs, | ||||||
|  |           struct interface and struct connected as arguments to functions | ||||||
|  |           down to two key arguments, namely struct connected and, possibly, | ||||||
|  |           address of source/destination. Testing for RIPv1 would be useful. | ||||||
|  |           (rip_read) lookup struct connected for the received packet, pass | ||||||
|  |           it on. | ||||||
|  |         * rip_interface.c: With previous changes, we no longer have to tread | ||||||
|  |           carefully with struct connected, as it will always be there and | ||||||
|  |           valid. | ||||||
|  | 
 | ||||||
| 2004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com> | 2004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com> | ||||||
| 
 | 
 | ||||||
| 	* ripd.c: (rip_update_interface) if connected->destination is NULL, | 	* ripd.c: (rip_update_interface) if connected->destination is NULL, | ||||||
|  | |||||||
| @ -145,19 +145,15 @@ rip_interface_multicast_set (int sock, struct connected *connected) | |||||||
|   struct sockaddr_in from; |   struct sockaddr_in from; | ||||||
|   struct in_addr addr; |   struct in_addr addr; | ||||||
|   struct prefix_ipv4 *p; |   struct prefix_ipv4 *p; | ||||||
| 
 |    | ||||||
|   if (connected != NULL)  |   assert (connected != NULL); | ||||||
|     { |    | ||||||
|       if (if_is_pointopoint(connected->ifp) && CONNECTED_DEST_HOST(connected)) |   if (if_is_pointopoint(connected->ifp) && CONNECTED_DEST_HOST(connected)) | ||||||
| 	p = (struct prefix_ipv4 *) connected->destination; |     p = (struct prefix_ipv4 *) connected->destination; | ||||||
|       else |   else | ||||||
| 	p = (struct prefix_ipv4 *) connected->address; |     p = (struct prefix_ipv4 *) connected->address; | ||||||
|       addr = p->prefix; |    | ||||||
|     } |   addr = p->prefix; | ||||||
|   else  |  | ||||||
|     { |  | ||||||
|       addr.s_addr = INADDR_ANY; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|   if (setsockopt_multicast_ipv4 (sock, IP_MULTICAST_IF, addr, 0,  |   if (setsockopt_multicast_ipv4 (sock, IP_MULTICAST_IF, addr, 0,  | ||||||
|                                  connected->ifp->ifindex) < 0)  |                                  connected->ifp->ifindex) < 0)  | ||||||
| @ -165,7 +161,7 @@ rip_interface_multicast_set (int sock, struct connected *connected) | |||||||
|       zlog_warn ("Can't setsockopt IP_MULTICAST_IF on fd %d to " |       zlog_warn ("Can't setsockopt IP_MULTICAST_IF on fd %d to " | ||||||
| 		 "source address %s for interface %s", | 		 "source address %s for interface %s", | ||||||
| 		 sock, inet_ntoa(addr), | 		 sock, inet_ntoa(addr), | ||||||
| 		 (connected ? connected->ifp->name : "(unknown)")); | 		 connected->ifp->name); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -181,9 +177,7 @@ rip_interface_multicast_set (int sock, struct connected *connected) | |||||||
| 
 | 
 | ||||||
|   /* Address should be any address. */ |   /* Address should be any address. */ | ||||||
|   from.sin_family = AF_INET; |   from.sin_family = AF_INET; | ||||||
|   if (connected) |   from.sin_addr = connected->address->u.prefix4; | ||||||
|     addr = ((struct prefix_ipv4 *) connected->address)->prefix; |  | ||||||
|   from.sin_addr = addr; |  | ||||||
| #ifdef HAVE_SIN_LEN | #ifdef HAVE_SIN_LEN | ||||||
|   from.sin_len = sizeof (struct sockaddr_in); |   from.sin_len = sizeof (struct sockaddr_in); | ||||||
| #endif /* HAVE_SIN_LEN */ | #endif /* HAVE_SIN_LEN */ | ||||||
| @ -198,7 +192,7 @@ rip_interface_multicast_set (int sock, struct connected *connected) | |||||||
| 		 "interface %s: %s", | 		 "interface %s: %s", | ||||||
| 	      	 sock,inet_ntoa(from.sin_addr), | 	      	 sock,inet_ntoa(from.sin_addr), | ||||||
| 		 (int)ntohs(from.sin_port), | 		 (int)ntohs(from.sin_port), | ||||||
| 		 (connected ? connected->ifp->name : "(unknown)"), | 		 connected->ifp->name, | ||||||
| 		  strerror (errno)); | 		  strerror (errno)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										216
									
								
								ripd/ripd.c
									
									
									
									
									
								
							
							
						
						
									
										216
									
								
								ripd/ripd.c
									
									
									
									
									
								
							| @ -64,9 +64,7 @@ long rip_global_queries = 0; | |||||||
| /* Prototypes. */ | /* Prototypes. */ | ||||||
| void rip_event (enum rip_event, int); | void rip_event (enum rip_event, int); | ||||||
| 
 | 
 | ||||||
| void rip_output_process (struct interface *, struct prefix *, | void rip_output_process (struct connected *, struct sockaddr_in *, int, u_char); | ||||||
| 			 struct sockaddr_in *, int, u_char,  |  | ||||||
|                          struct connected *, struct prefix_ipv4 *); |  | ||||||
| 
 | 
 | ||||||
| /* RIP output routes type. */ | /* RIP output routes type. */ | ||||||
| enum | enum | ||||||
| @ -1042,13 +1040,12 @@ rip_auth_md5_set (struct stream *s, struct interface *ifp) | |||||||
| /* RIP routing information. */ | /* RIP routing information. */ | ||||||
| void | void | ||||||
| rip_response_process (struct rip_packet *packet, int size,  | rip_response_process (struct rip_packet *packet, int size,  | ||||||
| 		      struct sockaddr_in *from, struct interface *ifp) | 		      struct sockaddr_in *from, struct connected *ifc) | ||||||
| { | { | ||||||
|   caddr_t lim; |   caddr_t lim; | ||||||
|   struct rte *rte; |   struct rte *rte; | ||||||
|   struct prefix_ipv4 ifaddr; |   struct prefix_ipv4 ifaddr; | ||||||
|   struct prefix_ipv4 ifaddrclass; |   struct prefix_ipv4 ifaddrclass; | ||||||
|   struct connected *c; |  | ||||||
|   int subnetted; |   int subnetted; | ||||||
|        |        | ||||||
|   /* We don't know yet. */ |   /* We don't know yet. */ | ||||||
| @ -1207,18 +1204,14 @@ rip_response_process (struct rip_packet *packet, int size, | |||||||
| 	  u_int32_t destination; | 	  u_int32_t destination; | ||||||
| 
 | 
 | ||||||
| 	  if (subnetted == -1) | 	  if (subnetted == -1) | ||||||
| 	    { |             { | ||||||
| 	      c = connected_lookup_address (ifp, from->sin_addr); |               memcpy (&ifaddr, ifc->address, sizeof (struct prefix_ipv4)); | ||||||
| 	      if (c != NULL) |               memcpy (&ifaddrclass, &ifaddr, sizeof (struct prefix_ipv4)); | ||||||
| 		{ |               apply_classful_mask_ipv4 (&ifaddrclass); | ||||||
| 		  memcpy (&ifaddr, c->address, sizeof (struct prefix_ipv4)); |               subnetted = 0; | ||||||
| 		  memcpy (&ifaddrclass, &ifaddr, sizeof (struct prefix_ipv4)); |               if (ifaddr.prefixlen > ifaddrclass.prefixlen) | ||||||
| 		  apply_classful_mask_ipv4 (&ifaddrclass); |                 subnetted = 1; | ||||||
| 		  subnetted = 0; |             } | ||||||
| 		  if (ifaddr.prefixlen > ifaddrclass.prefixlen) |  | ||||||
| 		    subnetted = 1; |  | ||||||
| 		} |  | ||||||
| 	    } |  | ||||||
| 
 | 
 | ||||||
| 	  destination = ntohl (rte->prefix.s_addr); | 	  destination = ntohl (rte->prefix.s_addr); | ||||||
| 
 | 
 | ||||||
| @ -1277,18 +1270,23 @@ rip_response_process (struct rip_packet *packet, int size, | |||||||
| 	} | 	} | ||||||
| 	   | 	   | ||||||
|       /* Routing table updates. */ |       /* Routing table updates. */ | ||||||
|       rip_rte_process (rte, from, ifp); |       rip_rte_process (rte, from, ifc->ifp); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* RIP packet send to destination address. */ | /* RIP packet send to destination address, on interface denoted by
 | ||||||
|  |  * by connected argument. NULL to argument denotes destination should be | ||||||
|  |  * should be RIP multicast group | ||||||
|  |  */ | ||||||
| int | int | ||||||
| rip_send_packet (u_char * buf, int size, struct sockaddr_in *to,  | rip_send_packet (u_char * buf, int size, struct sockaddr_in *to, | ||||||
| 		 struct interface *ifp, struct connected *connected) |                  struct connected *ifc) | ||||||
| { | { | ||||||
|   int ret, send_sock; |   int ret, send_sock; | ||||||
|   struct sockaddr_in sin; |   struct sockaddr_in sin; | ||||||
| 
 |    | ||||||
|  |   assert (ifc != NULL); | ||||||
|  |    | ||||||
|   if (IS_RIP_DEBUG_PACKET) |   if (IS_RIP_DEBUG_PACKET) | ||||||
|     { |     { | ||||||
|       char dst[20]; |       char dst[20]; | ||||||
| @ -1302,10 +1300,10 @@ rip_send_packet (u_char * buf, int size, struct sockaddr_in *to, | |||||||
|           strcpy(dst, inet_ntoa(sin.sin_addr)); |           strcpy(dst, inet_ntoa(sin.sin_addr)); | ||||||
|         } |         } | ||||||
|       zlog_info("rip_send_packet %s > %s (%s)", |       zlog_info("rip_send_packet %s > %s (%s)", | ||||||
|                 (connected ? inet_ntoa(connected->address->u.prefix4) : ""), |                 inet_ntoa(ifc->address->u.prefix4), | ||||||
|                 dst, ifp->name); |                 dst, ifc->ifp->name); | ||||||
|     } |     } | ||||||
|   if (connected && connected->flags & ZEBRA_IFA_SECONDARY) |   if ( CHECK_FLAG (ifc->flags, ZEBRA_IFA_SECONDARY) ) | ||||||
|     { |     { | ||||||
|       /*
 |       /*
 | ||||||
|        * ZEBRA_IFA_SECONDARY is set on linux when an interface is configured |        * ZEBRA_IFA_SECONDARY is set on linux when an interface is configured | ||||||
| @ -1361,7 +1359,7 @@ rip_send_packet (u_char * buf, int size, struct sockaddr_in *to, | |||||||
| #ifdef RIP_RECVMSG | #ifdef RIP_RECVMSG | ||||||
|       setsockopt_pktinfo (send_sock); |       setsockopt_pktinfo (send_sock); | ||||||
| #endif /* RIP_RECVMSG */ | #endif /* RIP_RECVMSG */ | ||||||
|       rip_interface_multicast_set (send_sock, connected); |       rip_interface_multicast_set (send_sock, ifc); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|   ret = sendto (send_sock, buf, size, 0, (struct sockaddr *)&sin, |   ret = sendto (send_sock, buf, size, 0, (struct sockaddr *)&sin, | ||||||
| @ -1507,7 +1505,7 @@ rip_redistribute_delete (int type, int sub_type, struct prefix_ipv4 *p, | |||||||
| /* Response to request called from rip_read ().*/ | /* Response to request called from rip_read ().*/ | ||||||
| void | void | ||||||
| rip_request_process (struct rip_packet *packet, int size,  | rip_request_process (struct rip_packet *packet, int size,  | ||||||
| 		     struct sockaddr_in *from, struct interface *ifp) | 		     struct sockaddr_in *from, struct connected *ifc) | ||||||
| { | { | ||||||
|   caddr_t lim; |   caddr_t lim; | ||||||
|   struct rte *rte; |   struct rte *rte; | ||||||
| @ -1517,18 +1515,18 @@ rip_request_process (struct rip_packet *packet, int size, | |||||||
|   struct rip_interface *ri; |   struct rip_interface *ri; | ||||||
| 
 | 
 | ||||||
|   /* Does not reponse to the requests on the loopback interfaces */ |   /* Does not reponse to the requests on the loopback interfaces */ | ||||||
|   if (if_is_loopback (ifp)) |   if (if_is_loopback (ifc->ifp)) | ||||||
|     return; |     return; | ||||||
| 
 | 
 | ||||||
|   /* Check RIP process is enabled on this interface. */ |   /* Check RIP process is enabled on this interface. */ | ||||||
|   ri = ifp->info; |   ri = ifc->ifp->info; | ||||||
|   if (! ri->running) |   if (! ri->running) | ||||||
|     return; |     return; | ||||||
| 
 | 
 | ||||||
|   /* When passive interface is specified, suppress responses */ |   /* When passive interface is specified, suppress responses */ | ||||||
|   if (ri->passive) |   if (ri->passive) | ||||||
|     return; |     return; | ||||||
| 
 |    | ||||||
|   /* RIP peer update. */ |   /* RIP peer update. */ | ||||||
|   rip_peer_update (from, packet->version); |   rip_peer_update (from, packet->version); | ||||||
| 
 | 
 | ||||||
| @ -1559,8 +1557,7 @@ rip_request_process (struct rip_packet *packet, int size, | |||||||
|       saddr.prefix = from->sin_addr; |       saddr.prefix = from->sin_addr; | ||||||
| 
 | 
 | ||||||
|       /* All route with split horizon */ |       /* All route with split horizon */ | ||||||
|       rip_output_process (ifp, NULL, from, rip_all_route, packet->version,  |       rip_output_process (ifc, from, rip_all_route, packet->version); | ||||||
|                           NULL, &saddr); |  | ||||||
|     } |     } | ||||||
|   else |   else | ||||||
|     { |     { | ||||||
| @ -1592,7 +1589,7 @@ rip_request_process (struct rip_packet *packet, int size, | |||||||
| 	} | 	} | ||||||
|       packet->command = RIP_RESPONSE; |       packet->command = RIP_RESPONSE; | ||||||
| 
 | 
 | ||||||
|       rip_send_packet ((u_char *)packet, size, from, ifp, NULL); |       rip_send_packet ((u_char *)packet, size, from, ifc); | ||||||
|     } |     } | ||||||
|   rip_global_queries++; |   rip_global_queries++; | ||||||
| } | } | ||||||
| @ -1686,6 +1683,7 @@ rip_read (struct thread *t) | |||||||
|   int len; |   int len; | ||||||
|   socklen_t fromlen; |   socklen_t fromlen; | ||||||
|   struct interface *ifp; |   struct interface *ifp; | ||||||
|  |   struct connected *ifc; | ||||||
|   struct rip_interface *ri; |   struct rip_interface *ri; | ||||||
| 
 | 
 | ||||||
|   /* Fetch socket then register myself. */ |   /* Fetch socket then register myself. */ | ||||||
| @ -1717,7 +1715,7 @@ rip_read (struct thread *t) | |||||||
| 
 | 
 | ||||||
|   /* Which interface is this packet comes from. */ |   /* Which interface is this packet comes from. */ | ||||||
|   ifp = if_lookup_address (from.sin_addr); |   ifp = if_lookup_address (from.sin_addr); | ||||||
| 
 |    | ||||||
|   /* RIP packet received */ |   /* RIP packet received */ | ||||||
|   if (IS_RIP_DEBUG_EVENT) |   if (IS_RIP_DEBUG_EVENT) | ||||||
|     zlog_info ("RECV packet from %s port %d on %s", |     zlog_info ("RECV packet from %s port %d on %s", | ||||||
| @ -1727,7 +1725,15 @@ rip_read (struct thread *t) | |||||||
|   /* If this packet come from unknown interface, ignore it. */ |   /* If this packet come from unknown interface, ignore it. */ | ||||||
|   if (ifp == NULL) |   if (ifp == NULL) | ||||||
|     { |     { | ||||||
|       zlog_info ("packet comes from unknown interface"); |       zlog_info ("rip_read: packet comes from unknown interface"); | ||||||
|  |       return -1; | ||||||
|  |     } | ||||||
|  |    | ||||||
|  |   ifc = connected_lookup_address (ifp, from.sin_addr); | ||||||
|  |    | ||||||
|  |   if (ifc == NULL) | ||||||
|  |     { | ||||||
|  |       zlog_info ("rip_read: packet comes from unknown network"); | ||||||
|       return -1; |       return -1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -1924,11 +1930,11 @@ rip_read (struct thread *t) | |||||||
|   switch (packet->command) |   switch (packet->command) | ||||||
|     { |     { | ||||||
|     case RIP_RESPONSE: |     case RIP_RESPONSE: | ||||||
|       rip_response_process (packet, len, &from, ifp); |       rip_response_process (packet, len, &from, ifc); | ||||||
|       break; |       break; | ||||||
|     case RIP_REQUEST: |     case RIP_REQUEST: | ||||||
|     case RIP_POLL: |     case RIP_POLL: | ||||||
|       rip_request_process (packet, len, &from, ifp); |       rip_request_process (packet, len, &from, ifc); | ||||||
|       break; |       break; | ||||||
|     case RIP_TRACEON: |     case RIP_TRACEON: | ||||||
|     case RIP_TRACEOFF: |     case RIP_TRACEOFF: | ||||||
| @ -2094,9 +2100,8 @@ rip_write_rte (int num, struct stream *s, struct prefix_ipv4 *p, | |||||||
| 
 | 
 | ||||||
| /* Send update to the ifp or spcified neighbor. */ | /* Send update to the ifp or spcified neighbor. */ | ||||||
| void | void | ||||||
| rip_output_process (struct interface *ifp, struct prefix *ifaddr, | rip_output_process (struct connected *ifc, struct sockaddr_in *to,  | ||||||
| 		    struct sockaddr_in *to, int route_type, u_char version, |                     int route_type, u_char version) | ||||||
|                     struct connected *connected, struct prefix_ipv4 *saddr) |  | ||||||
| { | { | ||||||
|   int ret; |   int ret; | ||||||
|   struct stream *s; |   struct stream *s; | ||||||
| @ -2106,7 +2111,6 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
|   struct prefix_ipv4 *p; |   struct prefix_ipv4 *p; | ||||||
|   struct prefix_ipv4 classfull; |   struct prefix_ipv4 classfull; | ||||||
|   struct prefix_ipv4 ifaddrclass; |   struct prefix_ipv4 ifaddrclass; | ||||||
|   struct connected *c; |  | ||||||
|   int num; |   int num; | ||||||
|   int rtemax; |   int rtemax; | ||||||
|   int subnetted = 0; |   int subnetted = 0; | ||||||
| @ -2118,7 +2122,7 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
| 	zlog_info ("update routes to neighbor %s", inet_ntoa (to->sin_addr)); | 	zlog_info ("update routes to neighbor %s", inet_ntoa (to->sin_addr)); | ||||||
|       else |       else | ||||||
| 	zlog_info ("update routes on interface %s ifindex %d", | 	zlog_info ("update routes on interface %s ifindex %d", | ||||||
| 		   ifp->name, ifp->ifindex); | 		   ifc->ifp->name, ifc->ifp->ifindex); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|   /* Set output stream. */ |   /* Set output stream. */ | ||||||
| @ -2130,7 +2134,7 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
|   rtemax = (RIP_PACKET_MAXSIZ - 4) / 20; |   rtemax = (RIP_PACKET_MAXSIZ - 4) / 20; | ||||||
| 
 | 
 | ||||||
|   /* Get RIP interface. */ |   /* Get RIP interface. */ | ||||||
|   ri = ifp->info; |   ri = ifc->ifp->info; | ||||||
|      |      | ||||||
|   /* If output interface is in simple password authentication mode, we
 |   /* If output interface is in simple password authentication mode, we
 | ||||||
|      need space for authentication data.  */ |      need space for authentication data.  */ | ||||||
| @ -2162,22 +2166,10 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
| 
 | 
 | ||||||
|   if (version == RIPv1) |   if (version == RIPv1) | ||||||
|     { |     { | ||||||
|       if (ifaddr == NULL) |       memcpy (&ifaddrclass, ifc->address, sizeof (struct prefix_ipv4)); | ||||||
| 	{ |  | ||||||
| 	  c = connected_lookup_address (ifp, to->sin_addr); |  | ||||||
| 	  if (c != NULL) |  | ||||||
| 	    ifaddr = c->address; |  | ||||||
| 	} |  | ||||||
|       if (ifaddr == NULL) |  | ||||||
| 	{ |  | ||||||
| 	  zlog_warn ("cannot find source address for packets to neighbor %s", |  | ||||||
| 		     inet_ntoa (to->sin_addr)); |  | ||||||
| 	  return; |  | ||||||
| 	} |  | ||||||
|       memcpy (&ifaddrclass, ifaddr, sizeof (struct prefix_ipv4)); |  | ||||||
|       apply_classful_mask_ipv4 (&ifaddrclass); |       apply_classful_mask_ipv4 (&ifaddrclass); | ||||||
|       subnetted = 0; |       subnetted = 0; | ||||||
|       if (ifaddr->prefixlen > ifaddrclass.prefixlen) |       if (ifc->address->prefixlen > ifaddrclass.prefixlen) | ||||||
|         subnetted = 1; |         subnetted = 1; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -2199,7 +2191,7 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
| 	    if (subnetted && | 	    if (subnetted && | ||||||
| 		prefix_match ((struct prefix *) &ifaddrclass, &rp->p)) | 		prefix_match ((struct prefix *) &ifaddrclass, &rp->p)) | ||||||
| 	      { | 	      { | ||||||
| 		if ((ifaddr->prefixlen != rp->p.prefixlen) && | 		if ((ifc->address->prefixlen != rp->p.prefixlen) && | ||||||
| 		    (rp->p.prefixlen != 32)) | 		    (rp->p.prefixlen != 32)) | ||||||
| 		  continue; | 		  continue; | ||||||
| 	      } | 	      } | ||||||
| @ -2243,10 +2235,10 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
|              * configured on the same interface). |              * configured on the same interface). | ||||||
|              */ |              */ | ||||||
| 	    if (rinfo->type == ZEBRA_ROUTE_RIP  && | 	    if (rinfo->type == ZEBRA_ROUTE_RIP  && | ||||||
|                  rinfo->ifindex == ifp->ifindex)  |                  rinfo->ifindex == ifc->ifp->ifindex)  | ||||||
| 	      continue; | 	      continue; | ||||||
| 	    if (rinfo->type == ZEBRA_ROUTE_CONNECT && | 	    if (rinfo->type == ZEBRA_ROUTE_CONNECT && | ||||||
|                  prefix_match((struct prefix *)p, (struct prefix *)saddr)) |                  prefix_match((struct prefix *)p, ifc->address)) | ||||||
| 	      continue; | 	      continue; | ||||||
| 	  } | 	  } | ||||||
| 
 | 
 | ||||||
| @ -2255,7 +2247,7 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
| 	rinfo->nexthop_out.s_addr = 0; | 	rinfo->nexthop_out.s_addr = 0; | ||||||
| 	rinfo->metric_out = rinfo->metric; | 	rinfo->metric_out = rinfo->metric; | ||||||
| 	rinfo->tag_out = rinfo->tag; | 	rinfo->tag_out = rinfo->tag; | ||||||
| 	rinfo->ifindex_out = ifp->ifindex; | 	rinfo->ifindex_out = ifc->ifp->ifindex; | ||||||
| 
 | 
 | ||||||
| 	/* In order to avoid some local loops,
 | 	/* In order to avoid some local loops,
 | ||||||
| 	 * if the RIP route has a nexthop via this interface, keep the nexthop, | 	 * if the RIP route has a nexthop via this interface, keep the nexthop, | ||||||
| @ -2264,7 +2256,7 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
| 	 * to avoid an IGP multi-level recursive look-up. | 	 * to avoid an IGP multi-level recursive look-up. | ||||||
| 	 * see (4.4) | 	 * see (4.4) | ||||||
| 	 */ | 	 */ | ||||||
| 	if (rinfo->ifindex == ifp->ifindex) | 	if (rinfo->ifindex == ifc->ifp->ifindex) | ||||||
| 	  rinfo->nexthop_out = rinfo->nexthop; | 	  rinfo->nexthop_out = rinfo->nexthop; | ||||||
| 
 | 
 | ||||||
| 	/* Interface route-map */ | 	/* Interface route-map */ | ||||||
| @ -2321,7 +2313,7 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
| 
 | 
 | ||||||
| 	/* Apply offset-list */ | 	/* Apply offset-list */ | ||||||
| 	if (rinfo->metric != RIP_METRIC_INFINITY) | 	if (rinfo->metric != RIP_METRIC_INFINITY) | ||||||
| 	  rip_offset_list_apply_out (p, ifp, &rinfo->metric_out); | 	  rip_offset_list_apply_out (p, ifc->ifp, &rinfo->metric_out); | ||||||
| 
 | 
 | ||||||
| 	if (rinfo->metric_out > RIP_METRIC_INFINITY) | 	if (rinfo->metric_out > RIP_METRIC_INFINITY) | ||||||
| 	  rinfo->metric_out = RIP_METRIC_INFINITY; | 	  rinfo->metric_out = RIP_METRIC_INFINITY; | ||||||
| @ -2341,22 +2333,22 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
|              * configured on the same interface). |              * configured on the same interface). | ||||||
|              */ |              */ | ||||||
| 	  if (rinfo->type == ZEBRA_ROUTE_RIP  && | 	  if (rinfo->type == ZEBRA_ROUTE_RIP  && | ||||||
| 	       rinfo->ifindex == ifp->ifindex) | 	       rinfo->ifindex == ifc->ifp->ifindex) | ||||||
| 	       rinfo->metric_out = RIP_METRIC_INFINITY; | 	       rinfo->metric_out = RIP_METRIC_INFINITY; | ||||||
| 	  if (rinfo->type == ZEBRA_ROUTE_CONNECT && | 	  if (rinfo->type == ZEBRA_ROUTE_CONNECT && | ||||||
|               prefix_match((struct prefix *)p, (struct prefix *)saddr)) |               prefix_match((struct prefix *)p, ifc->address)) | ||||||
| 	       rinfo->metric_out = RIP_METRIC_INFINITY; | 	       rinfo->metric_out = RIP_METRIC_INFINITY; | ||||||
| 	} | 	} | ||||||
|   |   | ||||||
| 	/* Write RTE to the stream. */ | 	/* Write RTE to the stream. */ | ||||||
| 	num = rip_write_rte (num, s, p, version, rinfo, to ? NULL : ifp); | 	num = rip_write_rte (num, s, p, version, rinfo, to ? NULL : ifc->ifp); | ||||||
| 	if (num == rtemax) | 	if (num == rtemax) | ||||||
| 	  { | 	  { | ||||||
| 	    if (version == RIPv2 && ri->auth_type == RIP_AUTH_MD5) | 	    if (version == RIPv2 && ri->auth_type == RIP_AUTH_MD5) | ||||||
| 	      rip_auth_md5_set (s, ifp); | 	      rip_auth_md5_set (s, ifc->ifp); | ||||||
| 
 | 
 | ||||||
| 	    ret = rip_send_packet (STREAM_DATA (s), stream_get_endp (s), | 	    ret = rip_send_packet (STREAM_DATA (s), stream_get_endp (s), | ||||||
| 				   to, ifp, connected); | 				   to, ifc); | ||||||
| 
 | 
 | ||||||
| 	    if (ret >= 0 && IS_RIP_DEBUG_SEND) | 	    if (ret >= 0 && IS_RIP_DEBUG_SEND) | ||||||
| 	      rip_packet_dump ((struct rip_packet *)STREAM_DATA (s), | 	      rip_packet_dump ((struct rip_packet *)STREAM_DATA (s), | ||||||
| @ -2370,10 +2362,9 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
|   if (num != 0) |   if (num != 0) | ||||||
|     { |     { | ||||||
|       if (version == RIPv2 && ri->auth_type == RIP_AUTH_MD5) |       if (version == RIPv2 && ri->auth_type == RIP_AUTH_MD5) | ||||||
| 	rip_auth_md5_set (s, ifp); | 	rip_auth_md5_set (s, ifc->ifp); | ||||||
| 
 | 
 | ||||||
|       ret = rip_send_packet (STREAM_DATA (s), stream_get_endp (s), to, ifp,  |       ret = rip_send_packet (STREAM_DATA (s), stream_get_endp (s), to, ifc); | ||||||
| 			     connected); |  | ||||||
| 
 | 
 | ||||||
|       if (ret >= 0 && IS_RIP_DEBUG_SEND) |       if (ret >= 0 && IS_RIP_DEBUG_SEND) | ||||||
| 	rip_packet_dump ((struct rip_packet *)STREAM_DATA (s), | 	rip_packet_dump ((struct rip_packet *)STREAM_DATA (s), | ||||||
| @ -2388,55 +2379,44 @@ rip_output_process (struct interface *ifp, struct prefix *ifaddr, | |||||||
| 
 | 
 | ||||||
| /* Send RIP packet to the interface. */ | /* Send RIP packet to the interface. */ | ||||||
| void | void | ||||||
| rip_update_interface (struct interface *ifp, u_char version, int route_type, | rip_update_interface (struct connected *ifc, u_char version, int route_type) | ||||||
|                       struct connected *sconn) |  | ||||||
| { | { | ||||||
|   struct connected *connected; |  | ||||||
|   struct listnode *node; |  | ||||||
|   struct sockaddr_in to; |   struct sockaddr_in to; | ||||||
|   struct prefix_ipv4 *saddr = (struct prefix_ipv4 *) sconn->address; |  | ||||||
| 
 | 
 | ||||||
|   /* When RIP version is 2 and multicast enable interface. */ |   /* When RIP version is 2 and multicast enable interface. */ | ||||||
|   if (version == RIPv2 && if_is_multicast (ifp))  |   if (version == RIPv2 && if_is_multicast (ifc->ifp))  | ||||||
|     { |     { | ||||||
|       if (IS_RIP_DEBUG_EVENT) |       if (IS_RIP_DEBUG_EVENT) | ||||||
| 	zlog_info ("multicast announce on %s ", ifp->name); | 	zlog_info ("multicast announce on %s ", ifc->ifp->name); | ||||||
| 
 | 
 | ||||||
|       rip_output_process (ifp, NULL, NULL, route_type, version,  |       rip_output_process (ifc, NULL, route_type, version); | ||||||
|                           sconn, saddr); |  | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
| 
 |    | ||||||
|   /* If we can't send multicast packet, send it with unicast. */ |   /* If we can't send multicast packet, send it with unicast. */ | ||||||
|   if (if_is_broadcast (ifp) || if_is_pointopoint (ifp)) |   if (if_is_broadcast (ifc->ifp) || if_is_pointopoint (ifc->ifp)) | ||||||
|     { |     { | ||||||
|       for (node = listhead (ifp->connected); node; nextnode (node)) |       if (ifc->address->family == AF_INET) | ||||||
| 	{	     |         { | ||||||
| 	  connected = getdata (node); |           /* Destination address and port setting. */ | ||||||
|  |           memset (&to, 0, sizeof (struct sockaddr_in)); | ||||||
|  |           if (ifc->destination) | ||||||
|  |             /* use specified broadcast or point-to-point destination addr */ | ||||||
|  |             to.sin_addr = ifc->destination->u.prefix4; | ||||||
|  |           else | ||||||
|  |             /* calculate the appropriate broadcast address */ | ||||||
|  |             to.sin_addr.s_addr = | ||||||
|  |               ipv4_broadcast_addr(ifc->address->u.prefix4.s_addr, | ||||||
|  |                                   ifc->address->prefixlen); | ||||||
|  |           to.sin_port = htons (RIP_PORT_DEFAULT); | ||||||
| 
 | 
 | ||||||
| 	  if (connected->address->family == AF_INET) |           if (IS_RIP_DEBUG_EVENT) | ||||||
| 	    { |             zlog_info ("%s announce to %s on %s", | ||||||
| 	      /* Destination address and port setting. */ |                        if_is_pointopoint (ifc->ifp) ? "unicast" : "broadcast", | ||||||
| 	      memset (&to, 0, sizeof (struct sockaddr_in)); |                        inet_ntoa (to.sin_addr), ifc->ifp->name); | ||||||
| 	      if (connected->destination) |  | ||||||
| 		/* use specified broadcast or point-to-point destination addr */ |  | ||||||
| 	        to.sin_addr = connected->destination->u.prefix4; |  | ||||||
| 	      else |  | ||||||
| 		/* calculate the appropriate broadcast address */ |  | ||||||
| 	        to.sin_addr.s_addr = |  | ||||||
| 		  ipv4_broadcast_addr(connected->address->u.prefix4.s_addr, |  | ||||||
| 				      connected->address->prefixlen); |  | ||||||
| 	      to.sin_port = htons (RIP_PORT_DEFAULT); |  | ||||||
| 
 | 
 | ||||||
| 	      if (IS_RIP_DEBUG_EVENT) |           rip_output_process (ifc, &to, route_type, version); | ||||||
| 		zlog_info ("%s announce to %s on %s", |         } | ||||||
| 			   if_is_pointopoint (ifp) ? "unicast" : "broadcast", |  | ||||||
| 			   inet_ntoa (to.sin_addr), ifp->name); |  | ||||||
| 
 |  | ||||||
| 	      rip_output_process (ifp, connected->address, &to, route_type, |  | ||||||
| 				 version, connected, saddr); |  | ||||||
| 	    } |  | ||||||
| 	} |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -2502,9 +2482,9 @@ rip_update_process (int route_type) | |||||||
| 		continue; | 		continue; | ||||||
| 
 | 
 | ||||||
|               if ((vsend & RIPv1) && !done) |               if ((vsend & RIPv1) && !done) | ||||||
| 	        rip_update_interface (ifp, RIPv1, route_type, connected); | 	        rip_update_interface (connected, RIPv1, route_type); | ||||||
|               if ((vsend & RIPv2) && if_is_multicast(ifp)) |               if ((vsend & RIPv2) && if_is_multicast(ifp)) | ||||||
| 	        rip_update_interface (ifp, RIPv2, route_type, connected); | 	        rip_update_interface (connected, RIPv2, route_type); | ||||||
|               done = 1; |               done = 1; | ||||||
|               if (!(vsend & RIPv2) || !if_is_multicast(ifp)) |               if (!(vsend & RIPv2) || !if_is_multicast(ifp)) | ||||||
|                 break; |                 break; | ||||||
| @ -2522,19 +2502,25 @@ rip_update_process (int route_type) | |||||||
| 	ifp = if_lookup_address (p->prefix); | 	ifp = if_lookup_address (p->prefix); | ||||||
| 	if (! ifp) | 	if (! ifp) | ||||||
| 	  { | 	  { | ||||||
| 	    zlog_warn ("Neighbor %s doesn't exist direct connected network", | 	    zlog_warn ("Neighbor %s doesnt have connected interface!", | ||||||
| 		       inet_ntoa (p->prefix)); | 		       inet_ntoa (p->prefix)); | ||||||
| 	    continue; | 	    continue; | ||||||
| 	  } | 	  } | ||||||
| 
 |          | ||||||
|  |         if ( (connected = connected_lookup_address (ifp, p->prefix)) == NULL) | ||||||
|  |           { | ||||||
|  |             zlog_warn ("Neighbor %s doesnt have connected network", | ||||||
|  |                        inet_ntoa (p->prefix)); | ||||||
|  |             continue; | ||||||
|  |           } | ||||||
|  |          | ||||||
| 	/* Set destination address and port */ | 	/* Set destination address and port */ | ||||||
| 	memset (&to, 0, sizeof (struct sockaddr_in)); | 	memset (&to, 0, sizeof (struct sockaddr_in)); | ||||||
| 	to.sin_addr = p->prefix; | 	to.sin_addr = p->prefix; | ||||||
| 	to.sin_port = htons (RIP_PORT_DEFAULT); | 	to.sin_port = htons (RIP_PORT_DEFAULT); | ||||||
| 
 | 
 | ||||||
| 	/* RIP version is rip's configuration. */ | 	/* RIP version is rip's configuration. */ | ||||||
| 	rip_output_process (ifp, NULL, &to, route_type, rip->version_send,  | 	rip_output_process (connected, &to, route_type, rip->version_send); | ||||||
|                             NULL, p); |  | ||||||
|       } |       } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -2731,7 +2717,7 @@ rip_request_send (struct sockaddr_in *to, struct interface *ifp, | |||||||
|        * over each connected address for this case. |        * over each connected address for this case. | ||||||
|        */ |        */ | ||||||
|       if (rip_send_packet ((u_char *) &rip_packet, sizeof (rip_packet),  |       if (rip_send_packet ((u_char *) &rip_packet, sizeof (rip_packet),  | ||||||
|                             to, ifp, connected) != sizeof (rip_packet)) |                             to, connected) != sizeof (rip_packet)) | ||||||
|         return -1; |         return -1; | ||||||
|       else |       else | ||||||
|         return sizeof (rip_packet); |         return sizeof (rip_packet); | ||||||
| @ -2748,7 +2734,7 @@ rip_request_send (struct sockaddr_in *to, struct interface *ifp, | |||||||
|         continue; |         continue; | ||||||
| 
 | 
 | ||||||
|       if (rip_send_packet ((u_char *) &rip_packet, sizeof (rip_packet),  |       if (rip_send_packet ((u_char *) &rip_packet, sizeof (rip_packet),  | ||||||
|                             to, ifp, connected) != sizeof (rip_packet)) |                             to, connected) != sizeof (rip_packet)) | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|   return sizeof (rip_packet); |   return sizeof (rip_packet); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 paul
						paul