⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 aodv_rerr.c

📁 支持IPv6的adov路由协议(本人修改后)
💻 C
字号:
/***************************************************************************** * * Copyright (C) 2001 Uppsala University & Ericsson AB. * Copyright (C) 2003 Simon Fraser University and NewMIC * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * * Authors: Erik Nordstr鰉, <erik.nordstrom@it.uu.se> *        : Peter Lee       <peter.lee@shaw.ca> *           * *****************************************************************************/#include <netinet/in.h>#ifdef NS_PORT#include "aodv-uu.h"#else#include "aodv_rerr.h"#include "routing_table.h"#include "aodv_socket.h"#include "defs.h"#include "debug.h"//PL:#ifdef _IPV6#include "ipv6_utils.h"#endif /* _IPV6 */#endif//PL:#ifdef _IPV6RERR *NS_CLASS rerr_create(u_int8_t flags, struct in6_addr dest_addr,			   u_int32_t dest_seqno)#elseRERR *NS_CLASS rerr_create(u_int8_t flags, u_int32_t dest_addr,			   u_int32_t dest_seqno)#endif /* _IPV6 */{    RERR *rerr;    //PL:#ifdef _IPV6    DEBUG(LOG_DEBUG, 0, "rerr_create: Assembling RERR about %s seqno=%d",	  ip6_to_str(dest_addr), dest_seqno);#else    DEBUG(LOG_DEBUG, 0, "rerr_create: Assembling RERR about %s seqno=%d",	  ip_to_str(dest_addr), dest_seqno);#endif /* _IPV6 */    rerr = (RERR *) aodv_socket_new_msg();    rerr->type = AODV_RERR;    rerr->n = (flags & RERR_NODELETE ? 1 : 0);    rerr->res1 = 0;    rerr->res2 = 0;    //PL:#ifdef _IPV6    copy_in6_addr(&rerr->dest_addr, &dest_addr);#else    rerr->dest_addr = htonl(dest_addr);#endif /* _IPV */    rerr->dest_seqno = htonl(dest_seqno);    rerr->dest_count = 1;    return rerr;}//PL:#ifdef _IPV6void NS_CLASS rerr_add_udest(RERR * rerr,			     struct in6_addr udest, u_int32_t udest_seqno)#elsevoid NS_CLASS rerr_add_udest(RERR * rerr,			     u_int32_t udest, u_int32_t udest_seqno)#endif /* _IPV6 */{    RERR_udest *ud;    ud = (RERR_udest *) ((char *) rerr + RERR_CALC_SIZE(rerr));    //PL:#ifdef _IPV6    copy_in6_addr(&ud->dest_addr, &udest);#else    ud->dest_addr = htonl(udest);#endif /* _IPV6 */    ud->dest_seqno = htonl(udest_seqno);    rerr->dest_count++;}//PL:#ifdef _IPV6void NS_CLASS rerr_process(RERR * rerr, int rerrlen, struct in6_addr ip_src,			   struct in6_addr ip_dst)#elsevoid NS_CLASS rerr_process(RERR * rerr, int rerrlen, u_int32_t ip_src,			   u_int32_t ip_dst)#endif /* _IPV6 */{    RERR *new_rerr = NULL;    rt_table_t *entry;    //PL:#ifdef _IPV6    struct in6_addr rerr_dest, rerr_unicast_dest = in6addr_any;#else    u_int32_t rerr_dest, rerr_unicast_dest = 0;#endif /* _IPV6 */    u_int32_t rerr_dest_seqno;    int i, unicast_rerr = 0;    RERR_udest *udest;    //PL:#ifdef _IPV6    DEBUG(LOG_DEBUG, 0, "RERR_process: ip_src=%s", ip6_to_str(ip_src));#else    DEBUG(LOG_DEBUG, 0, "RERR_process: ip_src=%s", ip_to_str(ip_src));#endif /* _IPV6 */#ifdef DEBUG_OUTPUT    log_pkt_fields((AODV_msg *) rerr);#endif    if (rerrlen < ((int) RERR_CALC_SIZE(rerr)))       {	//PL:#ifdef _IPV6	log(LOG_WARNING, 0,	    "rerr_process: IP data too short (%u bytes) from %s to %s. Should be %d bytes.",	    rerrlen, ip6_to_str(ip_src), ip6_to_str(ip_dst),	    RERR_CALC_SIZE(rerr));#else	log(LOG_WARNING, 0,	    "rerr_process: IP data too short (%u bytes) from %s to %s. Should be %d bytes.",	    rerrlen, ip_to_str(ip_src), ip_to_str(ip_dst),	    RERR_CALC_SIZE(rerr));#endif /* _IPV6 */	return;      }    /* Check which destinations that are unreachable.  */    udest = RERR_UDEST_FIRST(rerr);    while (rerr->dest_count)       {	//PL:#ifdef _IPV6	copy_in6_addr(&rerr_dest, &udest->dest_addr);	rerr_dest_seqno = ntohl(udest->dest_seqno);	DEBUG(LOG_DEBUG, 0, "rerr_process: unreachable dest=%s seqno=%lu",	      ip6_to_str(rerr_dest), rerr_dest_seqno);	if ((entry = rt_table_find_active(rerr_dest)) != NULL &&	    memcmp(&entry->next_hop, &ip_src, sizeof(struct in6_addr)) == 0) 	  {	    DEBUG(LOG_DEBUG, 0,		  "rerr_process: removing rte %s - WAS IN RERR!!",		  ip6_to_str(rerr_dest));#else	rerr_dest = ntohl(udest->dest_addr);	rerr_dest_seqno = ntohl(udest->dest_seqno);	DEBUG(LOG_DEBUG, 0, "rerr_process: unreachable dest=%s seqno=%lu",	      ip_to_str(rerr_dest), rerr_dest_seqno);	if ((entry = rt_table_find_active(rerr_dest)) != NULL &&	    memcmp(&entry->next_hop, &ip_src, sizeof(u_int32_t)) == 0) 	  {	    DEBUG(LOG_DEBUG, 0,		  "rerr_process: removing rte %s - WAS IN RERR!!",		  ip_to_str(rerr_dest));#endif /* _IPV6 */	    /* Invalidate route: Hop count -> INFTY, dest_seqno++ */	    if (entry->hcnt != INFTY && !rerr->n)		rt_table_invalidate(entry);	    /* (a) updates the corresponding destination sequence number	       with the Destination Sequence Number in the packet, and */	    entry->dest_seqno = rerr_dest_seqno;	    /* (d) check precursor list for emptiness. If not empty, include	       the destination as an unreachable destination in the	       RERR... */	    if (entry->precursors) {		if (new_rerr == NULL) {		    u_int8_t flags = 0;		    if (rerr->n)			flags |= RERR_NODELETE;		    new_rerr = rerr_create(flags, entry->dest_addr,					   entry->dest_seqno);		    //PL:#ifdef _IPV6		    DEBUG(LOG_DEBUG, 0,			  "rerr_process: Added %s as unreachable, seqno=%lu",			  ip6_to_str(entry->dest_addr), entry->dest_seqno);#else		    DEBUG(LOG_DEBUG, 0,			  "rerr_process: Added %s as unreachable, seqno=%lu",			  ip_to_str(entry->dest_addr), entry->dest_seqno);#endif /* _IPV6 */		    if (!entry->precursors->next) {			unicast_rerr = 1;			rerr_unicast_dest = entry->precursors->neighbor;		    }		} else {		    rerr_add_udest(new_rerr, entry->dest_addr,				   entry->dest_seqno);		    //PL:#ifdef _IPV6		    DEBUG(LOG_DEBUG, 0,			  "rerr_process: Added %s as unreachable, seqno=%lu",			  ip6_to_str(entry->dest_addr), entry->dest_seqno);		    if (!(!entry->precursors->next &&			  (memcmp(&rerr_unicast_dest, &(entry->precursors->neighbor),				  sizeof(struct in6_addr)) == 0)			  ))			unicast_rerr = 0;#else		    DEBUG(LOG_DEBUG, 0,			  "rerr_process: Added %s as unreachable, seqno=%lu",			  ip_to_str(entry->dest_addr), entry->dest_seqno);		    if (!(!entry->precursors->next &&			  rerr_unicast_dest == entry->precursors->neighbor))			unicast_rerr = 0;#endif /* _IPV6 */		}	    }	    /* We should delete the precursor list for all unreachable	       destinations. */	    if (entry->hcnt == INFTY)		precursor_list_destroy(entry);	}	udest = RERR_UDEST_NEXT(udest);	rerr->dest_count--;      }				/* End while() */    /* If a RERR was created, then send it now... */    if (new_rerr) {	entry = rt_table_find(rerr_unicast_dest);	if (entry && new_rerr->dest_count == 1 && unicast_rerr)	    aodv_socket_send((AODV_msg *) new_rerr,			     rerr_unicast_dest,			     RERR_CALC_SIZE(new_rerr), 1,			     &DEV_IFINDEX(entry->ifindex));	else if (new_rerr->dest_count > 0) {	    /* FIXME: Should only transmit RERR on those interfaces	     * which have precursor nodes for the broken route */	    for (i = 0; i < MAX_NR_INTERFACES; i++) 	      {		if (!DEV_NR(i).enabled)		    continue;		//PL:#ifdef _IPV6		aodv_socket_send((AODV_msg *) new_rerr, ipv6_multicast_addr,				 RERR_CALC_SIZE(new_rerr), 1, &DEV_NR(i));#else		aodv_socket_send((AODV_msg *) new_rerr, AODV_BROADCAST,				 RERR_CALC_SIZE(new_rerr), 1, &DEV_NR(i));#endif /* _IPV6 */	      }	}    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -