亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? interface_list.c

?? linux 下的aodv實現源代碼
?? C
字號:
/*               Kernel AODV  v2.1National Institute of Standards and Technology               Luke Klein-Berndt-----------------------------------------------------  Version 2.1 new features:     * Much more stable!     * Added locks around important areas     * Multihop Internet gatewaying now works     * Multicast hack added     * Many bug fixes!-----------------------------------------------------Originally based upon MadHoc code. I am notsure how much of it is left anymore, but MadHocproved to be a great starting point.MadHoc was written by - Fredrik Lilieblad,Oskar Mattsson, Petra Nylund, Dan Ouchterlonyand Anders Roxenhag Mail: mad-hoc@flyinglinux.netThis software is Open Source under the GNU General Public Licence.*/#include "interface_list.h"/****************************************************   interface_list----------------------------------------------------This is a list of the interfaces available on thecomputer****************************************************/struct interface_list_entry *interface_list;extern struct route_table_entry *g_my_entry;extern u_int32_t g_my_ip;extern u_int32_t g_broadcast_ip;/****************************************************   start_HELLO----------------------------------------------------Starts sending hello messages out for a givenIP address****************************************************/int start_HELLO (u_int32_t ip){    struct rrep *tmp_rrep;    u_int32_t random_number;    //creates the RREP you wish to send out as the hello message    if ((tmp_rrep = kmalloc(sizeof(struct rrep),GFP_ATOMIC)) == NULL)    {	  printk(KERN_WARNING "AODV: Not enough memory to create a Hello Message\n");	  return -ENOMEM;    }    //fillin the RREP    tmp_rrep->dst_ip=ip;    tmp_rrep->src_ip=ip;    tmp_rrep->hop_count=0;    tmp_rrep->lifetime=htonl (ALLOWED_HELLO_LOSS * HELLO_INTERVAL);    tmp_rrep->dst_seq=0;    tmp_rrep->type=2;    tmp_rrep->r=0;    tmp_rrep->reserved1=0;    tmp_rrep->reserved2=0;    tmp_rrep->prefix_sz=0;    tmp_rrep->a=0;    //Insert it into the timer queue!    get_random_bytes(&random_number,sizeof(u_int32_t));    random_number=(43*random_number)%HELLO_INTERVAL;    insert_timer_queue_entry(getcurrtime() + random_number, tmp_rrep, sizeof(struct rrep), tmp_rrep->dst_ip,0,1,EVENT_HELLO);    update_timer_queue();    return 0;}/****************************************************   init_interface_list----------------------------------------------------Discover the available interfaces and add themto the list****************************************************/int init_interface_list(){    struct route_table_entry *tmp_route;    struct interface_list_entry *new_entry=NULL;    struct net_device *dev;    struct in_device *tmp_indev;    struct in_device *in_dev;    int error;    //dev_base is a kernel variable pointing to a list of    //all the available netdevices and is maintained    //by the kernel    dev= dev_base;    interface_list=NULL;    //look at all the devices    read_lock(&dev_base_lock);    read_lock(&inetdev_lock);    for (dev=dev_base; dev; dev=dev->next) {      if ((in_dev=__in_dev_get(dev)) == NULL)	continue;            read_lock(&in_dev->lock);      for_primary_ifa(in_dev) 	{		  	  //we don't want to include the loopback device	  //or any device which doesn't have a completed	  //ip section	  	  if ((strcmp(dev->name,g_block_dev)!=0) &&	      ((strcmp(g_aodv_dev,"")==0) || (strcmp(dev->name,g_aodv_dev)==0)))	    {	      tmp_route=create_route_table_entry();	      tmp_route->dst_ip = ifa->ifa_address;	      printk(KERN_INFO "INTERFACE LIST: Adding interface: %s  IP: %s\n",dev->name, inet_ntoa(ifa->ifa_address));	      	      	      //fill in the info for the route	      tmp_route->self_route=1;	      tmp_route->dst_seq = 1;	      tmp_route->old_dst_seq=0;	      tmp_route->rreq_id = 1;	      tmp_route->hop_count = 0;	      tmp_route->next_hop = tmp_route->dst_ip;	      tmp_route->lifetime = -1;	      tmp_route->route_valid = 1;	      tmp_route->route_seq_valid = 1;	      tmp_route->precursors=NULL;	      tmp_route->dev=dev;	    	      //save the entry as being our own... so the last dev read in	      //becomes our default dev.	      	      g_my_entry = tmp_route;	      g_my_ip=g_my_entry->dst_ip;	      	      	      if ((strcmp(dev->name,"lo")!=0) || USE_LO)		{		  if ((new_entry = kmalloc(sizeof(struct interface_list_entry),GFP_ATOMIC)) == NULL)		    {		      /* Couldn't create a new entry in the routing table */		      printk(KERN_WARNING "AODV: Not enough memory to create Route Table Entry\n");		      return -ENOMEM;		    }		  		  //fill in the info on the dev		  new_entry->ip=tmp_route->dst_ip;		  new_entry->route_entry=tmp_route;		  new_entry->next=interface_list;		  new_entry->dev=dev;		  new_entry->last_hello=getcurrtime();		  new_entry->last_broadcast=0;		  interface_list=new_entry;		  strncpy(new_entry->name,dev->name,IFNAMSIZ);		  		  //start sending out a hello message for this dev		  start_HELLO(new_entry->ip);		  		  		  //insert a broadcast address into the kernel routing table using this dev		  //create the socket... set it to type datagram		  error = sock_create(PF_INET,SOCK_DGRAM,0,&(new_entry->sock));		  if (error<0)		    {		      kfree(new_entry);		      printk(KERN_ERR "Error during creation of socket; terminating, %d\n",error);		      return error;		    }				  init_sock(new_entry->sock,new_entry->ip,dev->name);		  insert_kernel_route_entry(tmp_route->dst_ip,tmp_route->dst_ip,new_entry->name);		}	      	    }	} endfor_ifa(in_dev);		read_unlock(&in_dev->lock);    }	read_unlock(&inetdev_lock);	read_unlock(&dev_base_lock);		 return 0;}struct interface_list_entry *find_first_interface_entry(){    return interface_list;}/****************************************************   find_dev_ip----------------------------------------------------It will find the IP for a dev****************************************************/u_int32_t find_dev_ip(struct net_device *dev){    struct in_device *tmp_indev;    //make sure we get a valid DEV    if (dev==NULL)    {        printk (KERN_WARNING "AODV: FIND_DEV_IP gotta NULL DEV! ");        return -EFAULT;    }    //make sure that dev has an IP section    if (dev->ip_ptr==NULL)    {        printk (KERN_WARNING "AODV: FIND_DEV_IP gotta NULL ip_ptr!! ");        return -EFAULT;    }    //find that ip!    tmp_indev=(struct in_device *) dev->ip_ptr;    if (tmp_indev && (tmp_indev->ifa_list!=NULL))      return  (tmp_indev->ifa_list->ifa_address);    else      return  0;}/****************************************************   find_interface_by_dev----------------------------------------------------Finds an interface by matching up the dev tothe dev in the interface list****************************************************/struct interface_list_entry *find_interface_by_dev(struct net_device *dev){    struct interface_list_entry *tmp_entry=interface_list;    struct in_device *tmp_indev;    u_int32_t tmp_ip;    //Make sure the dev is legit    if (dev==NULL)    {        printk (KERN_WARNING "AODV: FIND_INTERFACE_BY_DEV gotta NULL DEV! \n");        return NULL;    }    //make sure it has a legit ip section    if (dev->ip_ptr==NULL)    {        printk (KERN_WARNING "AODV: FIND_INTERFACE_BY_DEV gotta NULL ip_ptr!! \n");        return NULL;    }    //find the ip address for the dev    tmp_indev=(struct in_device *) dev->ip_ptr; if (tmp_indev->ifa_list==NULL)    {        printk (KERN_WARNING "AODV: FIND_INTERFACE_BY_DEV gotta NULL ifa_list!! \n");        return NULL;    }    tmp_ip = tmp_indev->ifa_list->ifa_address;    //search the interface list for a device with the same ip    while (tmp_entry!=NULL)    {        if (tmp_entry->ip==tmp_ip)            return tmp_entry;        tmp_entry=tmp_entry->next;    }    printk(KERN_WARNING "AODV: Failed search for matching interface for: %s which has an ip of: %s\n",dev->name,inet_ntoa(tmp_ip));    return NULL;}/****************************************************   find_interface_by_ip----------------------------------------------------Finds an interface list entry by comparing IPs****************************************************/struct interface_list_entry *find_interface_by_ip(u_int32_t ip){    struct interface_list_entry *tmp_entry=interface_list;    //go through the whole list    while (tmp_entry!=NULL)    {        //if it finds a match        if (tmp_entry->ip==ip)            return tmp_entry;        tmp_entry=tmp_entry->next;    }    return NULL;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产麻豆| 国产一二精品视频| 国产精品护士白丝一区av| 精品久久一区二区三区| 欧美成人在线直播| 欧美第一区第二区| 久久影音资源网| 久久久精品tv| 国产精品久久久久久福利一牛影视| 亚洲精品一区二区三区蜜桃下载| 久久无码av三级| 欧美国产精品一区二区三区| 国产精品福利电影一区二区三区四区| 国产精品久久一卡二卡| 亚洲男女毛片无遮挡| 亚洲一区二区不卡免费| 日本女优在线视频一区二区| 狠狠色狠狠色综合日日91app| 精品综合免费视频观看| 粉嫩高潮美女一区二区三区| 国产成人免费视频一区| 成人精品在线视频观看| 欧美自拍偷拍午夜视频| 7878成人国产在线观看| 欧美高清www午色夜在线视频| 国产精品久久久久久久裸模| 欧美国产成人精品| 136国产福利精品导航| 亚洲不卡在线观看| 加勒比av一区二区| 91片黄在线观看| 91麻豆精品国产91久久久久久| 精品国产制服丝袜高跟| 国产精品免费丝袜| 免费在线看一区| eeuss鲁一区二区三区| 欧美精品tushy高清| 国产午夜精品福利| 亚洲国产精品一区二区久久| 国产在线播放一区三区四| av中文字幕一区| 日韩精品一区二区三区视频播放| 国产精品卡一卡二卡三| 日本美女一区二区| 色婷婷av久久久久久久| www国产精品av| 亚洲va欧美va人人爽午夜| 久久99久久久久久久久久久| 91浏览器打开| 国产日韩av一区| 美日韩一级片在线观看| 一本大道久久a久久综合婷婷| 337p日本欧洲亚洲大胆精品| 亚洲电影你懂得| 91丨porny丨在线| 国产日韩欧美一区二区三区乱码| 亚洲1区2区3区视频| 99在线精品免费| 中文在线资源观看网站视频免费不卡 | 亚洲国产精品精华液ab| 日本亚洲三级在线| 欧美色国产精品| 亚洲黄色性网站| 91蝌蚪porny| 中文字幕一区二区三区乱码在线| 国产一区二区三区| 欧美成人video| 久久精品久久99精品久久| 欧美日本一区二区三区四区| 亚洲精品欧美在线| 在线亚洲人成电影网站色www| 国产精品视频观看| 成人a级免费电影| 国产精品免费久久| 丁香婷婷综合色啪| 国产精品久久毛片| 99r国产精品| 最新日韩在线视频| 91蝌蚪porny九色| 依依成人综合视频| 欧美性xxxxx极品少妇| 一区二区国产视频| 欧美色视频一区| 日韩激情av在线| 日韩一级黄色大片| 国产一区二区看久久| 久久精品夜色噜噜亚洲aⅴ| 国产91露脸合集magnet| 欧美国产日韩亚洲一区| 99久久精品一区| 一区二区在线看| 欧美日韩精品二区第二页| 午夜精品福利视频网站| 欧美一级黄色片| 国产精品自产自拍| 亚洲人成网站在线| 欧美欧美欧美欧美| 久久99国产精品尤物| 久久精品一区蜜桃臀影院| 成人激情黄色小说| 亚洲高清视频在线| 久久久久国产一区二区三区四区| 成人久久18免费网站麻豆| 亚洲电影一级片| 久久色成人在线| 欧日韩精品视频| 精品一区二区三区的国产在线播放| 中文字幕av在线一区二区三区| 91同城在线观看| 奇米精品一区二区三区在线观看一| 欧美mv和日韩mv的网站| 91在线视频官网| 免费成人在线观看视频| 国产精品超碰97尤物18| 3d成人h动漫网站入口| 成人综合婷婷国产精品久久 | 日韩视频免费观看高清完整版 | 国产v综合v亚洲欧| 日韩美女视频一区二区| 69堂成人精品免费视频| 国产乱码字幕精品高清av| 亚洲欧洲国产日韩| 日韩一区二区三区视频在线观看| 成人国产精品免费观看视频| 亚洲一区影音先锋| 国产亚洲欧美日韩日本| 欧美日韩精品一区二区三区四区| 国产麻豆成人精品| 日日摸夜夜添夜夜添国产精品| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 成人一区在线观看| 秋霞午夜鲁丝一区二区老狼| 亚洲欧美日韩成人高清在线一区| 韩国av一区二区| 亚洲综合激情小说| 国产精品女同互慰在线看| 欧美成人一区二区三区| 欧美亚洲动漫制服丝袜| 成人免费福利片| 韩国av一区二区三区四区| 日韩av一区二区三区| 一区二区三区 在线观看视频 | 亚洲国产精品精华液ab| 337p粉嫩大胆噜噜噜噜噜91av | 色婷婷av一区二区三区大白胸| 国产风韵犹存在线视精品| 免费成人性网站| 日韩福利视频导航| 日韩经典中文字幕一区| 性做久久久久久免费观看| 亚洲第一会所有码转帖| 亚洲欧美日韩在线不卡| 日韩一区二区三区四区五区六区| caoporen国产精品视频| 国产精品一二二区| 国产一区二区不卡老阿姨| 久久av资源站| 极品少妇xxxx精品少妇偷拍| 蜜桃视频一区二区三区| 麻豆精品一区二区三区| 麻豆精品国产传媒mv男同| 久久精品国产999大香线蕉| 美女精品一区二区| 国产最新精品精品你懂的| 国产一区欧美一区| av在线一区二区三区| 色综合中文综合网| 成人精品一区二区三区四区| 高清成人在线观看| 成人爽a毛片一区二区免费| 99热这里都是精品| 亚洲国产精品久久久久婷婷884| 亚洲欧洲av在线| 亚洲精品免费在线观看| 亚洲最大的成人av| 亚洲成人福利片| 精品一区二区三区在线播放视频 | 国产一区二区福利视频| 国产福利91精品| 色欧美88888久久久久久影院| 欧美揉bbbbb揉bbbbb| 日韩精品最新网址| 国产精品三级在线观看| 一区二区在线电影| 精品一区二区三区视频 | 在线观看亚洲精品视频| 欧美疯狂性受xxxxx喷水图片| 精品国产伦理网| 亚洲天天做日日做天天谢日日欢 | www.成人网.com| 9191成人精品久久| 国产午夜三级一区二区三| 亚洲专区一二三| 激情国产一区二区 | 亚洲成人一二三| 日日夜夜精品视频免费| 午夜伊人狠狠久久| 国产91丝袜在线18| 欧美三区在线视频| 欧美激情中文字幕|