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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? anycastm.nc

?? 主要用于無(wú)線傳感網(wǎng)絡(luò)的編寫(xiě)的書(shū)籍.對(duì)于初學(xué)者有著很大的用處
?? NC
字號(hào):
/* Anycast Implmentation. *//* Written by Kin Sun Ho (ksho@cse) *//* Last Modified: 07 September 2005 *//* History:   15/07/05: Created File   18/07/05: Implmented the handling of JOIN and the routing table   19/07/05: Started Testing, Received empty broadcast from monitor   20/07/05: Fixed the sending of packets from the monitor   21/07/05: Editing the header file (MN.h) for changes to Anycast   22/07/05: Implmented Sensor Data Packets             Done some testing, AnycastM seems to be fine	     UART is not printing the message correctly   25/07/05: Rewritten ACBase from TOSBase, it works now!             Minor Bug fix in AnycastM due to message buffers	     Implemented multihop forwarding   26/07/05: Testing multihop... however, it may not work very well...   27/07/05: Worked on exp1: refer to it.             Wen Hu points out:             1. the routing table may need an atomic to prevent preempt	     2. the renewal of sequence # will result in network hang after a	        while	     => tried to add atomic on point 1 but network performance 	     decrease sharply	     => fixing the second point with force update if seq# <= 10   29/07/05: Done experiments, the maximum hop achieved is 3, although it is             rare. But it is proved that a multihop of 2 would work   05/07/05: Done experiments with Tatiana. Removed ADC from Anycast.             Wen points out table entries are still accessed after invalid             => fixed             added atomic statements within update of table   05/08/05: Modified doData for forwarding packets   07/09/05: Fixed possible synchronization problem in doJoin   LEDS:      green:  deliver packet to parent   yellow: forward packet from child   red:    broadcast from mote/base received*/includes Sasha;module AnycastM{  provides interface StdControl;  uses {    interface Timer as Table_Timer;    interface Timer as Sensor_Timer;    interface Timer as Sleep_Timer;    interface Leds;    interface StdControl as CommControl;    interface ReceiveMsg;    interface SendMsg;  }}implementation{  TOS_Msg msg[2];  // data msg unicast buffer  TOS_Msg jmsg[2]; // join msg rebroadcast buffer  TOS_Msg fmsg[2]; // forwarding msg unicast buffer  uint8_t currentMsg; // select between one and zero  uint8_t jcurrentMsg;  uint8_t fcurrentMsg;  struct Mrouting *rtable[ROUTING_TABLE]; // routing table  bool sleeping;  uint8_t sequences;    uint8_t find_entry();    /**   * Used to initialize this component.   */  command result_t StdControl.init() {        uint8_t i;        call Leds.init();             // initalize Leds    call CommControl.init();      // initalize Radio    sleeping = FALSE;        atomic {    for(i=0; i<ROUTING_TABLE;i++) {      rtable[i] = (struct Mrouting*) malloc(sizeof(struct Mrouting));      rtable[i]->empty = TRUE;      rtable[i]->sinkID = -1;    }    currentMsg = 0;    jcurrentMsg = 0;    fcurrentMsg = 0;    sequences=0;    }    dbg(DBG_BOOT, "Anycast initialized\n");    return SUCCESS;  }    /**   * Starts the SensorControl and CommControl components.   * @return Always returns SUCCESS.   */  command result_t StdControl.start() {    call CommControl.start();    call Table_Timer.start(TIMER_REPEAT, TABLE_TIMER);    call Sensor_Timer.start(TIMER_REPEAT, SENSOR_TIMER);    return SUCCESS;  }    /**   * Stops the SensorControl and CommControl components.   * @return Always returns SUCCESS.   */  command result_t StdControl.stop() {    call CommControl.stop();    call Table_Timer.stop();    return SUCCESS;  }    /**   * Signalled when the clock ticks.   * @return Always returns SUCCESS.   */  event result_t Table_Timer.fired() {    int8_t i;        //check for routing table timeout and time--    for(i=0; i<ROUTING_TABLE; i++) {      atomic {	rtable[i]->timer--;	if(rtable[i]->timer == 0 && rtable[i]->empty == FALSE) {	  rtable[i]->empty = TRUE;	}      }    }        return SUCCESS;  }    /* awake from sleep */  event result_t Sleep_Timer.fired() {    sleeping = FALSE;    call StdControl.start();    call Sleep_Timer.stop();    return SUCCESS;  }  /* request for sensor data */    event result_t Sensor_Timer.fired() {    struct Anycast *sendt;    int8_t use_entry;    atomic {      sendt = (struct Anycast *)msg[currentMsg].data;    }        use_entry = find_entry();    if(use_entry == -1) {      return SUCCESS;    }    atomic {	sendt->type   = DATA;	sendt->seqNum = sequences++;	sendt->src    = TOS_LOCAL_ADDRESS;	sendt->parent = rtable[use_entry]->parent;	sendt->hop    = rtable[use_entry]->hop;	sendt->from    = TOS_LOCAL_ADDRESS;		msg[currentMsg].length = TOSH_DATA_LENGTH;	msg[currentMsg].group  = TOS_AM_GROUP;	msg[currentMsg].addr   = sendt->parent;			  	  	  		/* send the message to the parent */	if (call SendMsg.send(sendt->parent,TOSH_DATA_LENGTH,			      &msg[currentMsg])){	  currentMsg ^= 0x1;	  call Leds.greenToggle();	}    }    return SUCCESS;  }    event result_t SendMsg.sendDone(TOS_MsgPtr sent, result_t success) {    return SUCCESS;  }  /* This will sleep the mote */  void doSleep() {    sleeping = TRUE;    call StdControl.stop();    call Sleep_Timer.start(TIMER_ONE_SHOT, SLEEP_TIMER);  }    /* Operation to be done when the mote receive a Join from the monitor */  void doJoin(TOS_MsgPtr rmsg) {    uint8_t i;    uint8_t t_seq;    struct Anycast *join;    struct Anycast *sendt;    join = (struct Anycast *)rmsg->data;        atomic {      /* check if sink exist */      for(i=0; i<ROUTING_TABLE; i++) {	if(rtable[i]->sinkID == join->src && rtable[i]->empty == FALSE)	  // do not set sinkID = 2^16 = -1	  break;      }      t_seq = 0;      /* if sink does exist */      if(i < ROUTING_TABLE)	t_seq = rtable[i]->seqNum;     }    /* check seq number: maximum 240 */    if(join->seqNum <= t_seq && t_seq < MAX_SEQ && i < ROUTING_TABLE) {      // drop the rmsg      return;    }    /* update the table */    else {      atomic {	rtable[i]->sinkID = join->src;	rtable[i]->parent = join->parent;	rtable[i]->seqNum = join->seqNum;	rtable[i]->hop    = join->hop;	rtable[i]->timer  = TABLE_EXIST;	rtable[i]->empty  = FALSE;      }    }    /* if sink does not exist */    if(i >= ROUTING_TABLE) {      atomic {	/* check if any entry empty */	for(i=0; i<ROUTING_TABLE; i++) {	  if(rtable[i]->empty == TRUE)	    break;	}	/* if there is entry empty */	if(i < ROUTING_TABLE) {	  /* add sink */	  rtable[i]->sinkID = join->src;	  rtable[i]->parent = join->parent;	  rtable[i]->hop  = join->hop;	  rtable[i]->seqNum = join->seqNum;	  rtable[i]->timer  = TABLE_EXIST;	  rtable[i]->empty = FALSE;	}	else {	  uint8_t depth = rtable[0]->hop;	  uint8_t max   = 0;	  	  /* find the entry with max hop count */	  for(i=1; i<ROUTING_TABLE; i++) {	    if(rtable[i]->hop > depth && rtable[i]->empty == FALSE) {	      depth = rtable[i]->hop;	      max = i;		    }	  }	  	  /* replace sink with max hop count */	  rtable[i]->sinkID = join->src;	  rtable[i]->hop    = join->hop;	  rtable[i]->seqNum = join->seqNum;	  rtable[i]->timer  = TABLE_EXIST;	  rtable[i]->parent = join->parent;	  rtable[i]->empty  = FALSE;	}      }    }        atomic {      sendt         = (struct Anycast *)jmsg[jcurrentMsg].data;      sendt->type   = JOIN;      sendt->src    = join->src; // sinkID      sendt->parent = TOS_LOCAL_ADDRESS;      sendt->seqNum = join->seqNum;      sendt->hop    = join->hop+1;      jmsg[jcurrentMsg].length = TOSH_DATA_LENGTH;      jmsg[jcurrentMsg].group  = TOS_AM_GROUP;      jmsg[jcurrentMsg].addr   = TOS_BCAST_ADDR;             /* rebroadcast the message */      if(call SendMsg.send(TOS_BCAST_ADDR,TOSH_DATA_LENGTH,&jmsg[jcurrentMsg]))	{	  jcurrentMsg ^= 0x1;	  call Leds.redToggle();	}	    }  }    /* find a shortest path sink */  uint8_t find_entry() {        uint8_t i,j;    uint8_t min, min_i;    // find first valid entry    for(i=0; i<ROUTING_TABLE; i++) {      if(rtable[i]->empty == FALSE)	break;    }    if(i == ROUTING_TABLE)      return -1;    min = rtable[i]->hop;    min_i = i;    for(j=i; j<ROUTING_TABLE; j++) {      if(rtable[j]->hop < min && rtable[i]->empty == FALSE) {	min = rtable[j]->hop;	min_i = j;	      }    }    return min_i;  }  void doData(TOS_MsgPtr rmsg) {    int8_t i;    int16_t parent;    TOS_MsgPtr fmsgpt;    /*Find the shortes path*/    int8_t use_entry = find_entry();        if(use_entry == -1) {      return; // if there is no route to parent, there is nothing we can do    }    atomic {      parent = rtable[use_entry]->parent;      fmsgpt = &fmsg[fcurrentMsg];      for(i=0; i<TOSH_DATA_LENGTH; i++) {	fmsgpt->data[i] = rmsg->data[i];      }      fmsg[fcurrentMsg].length = TOSH_DATA_LENGTH;      fmsg[fcurrentMsg].group  = TOS_AM_GROUP;      fmsg[fcurrentMsg].addr   = parent;            /* forward the message to the parent */      if (call SendMsg.send(parent,TOSH_DATA_LENGTH,&fmsg[fcurrentMsg])){	fcurrentMsg ^= 0x1;	call Leds.yellowToggle();      }    }  }    event TOS_MsgPtr ReceiveMsg.receive(TOS_MsgPtr rmsg){        switch (rmsg->data[0]) {          case(JOIN):      doJoin(rmsg);      break;    case(DATA):      doData(rmsg);      break;    default:      break;    }    return rmsg;  }}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久国产精品不卡| 色综合网色综合| 青青草国产精品97视觉盛宴| 亚洲一区二区三区四区在线 | 精品福利在线导航| 欧美一区二区三区精品| 欧美一区二区视频在线观看2022| 欧美性色欧美a在线播放| 欧美在线观看视频一区二区| 欧美自拍偷拍一区| 欧美美女网站色| 日韩三级免费观看| 国产亚洲精品中文字幕| 中文字幕一区免费在线观看| 一区二区三区在线视频观看58| 亚洲综合免费观看高清在线观看| 亚洲国产日日夜夜| 蜜臀av一区二区在线观看| 韩国女主播一区| 97久久超碰精品国产| 欧美日韩精品系列| 欧美mv日韩mv亚洲| 亚洲欧美日韩系列| 午夜av区久久| 国产凹凸在线观看一区二区| 色婷婷久久久亚洲一区二区三区| 欧美日韩国产精选| 欧美激情中文不卡| 亚洲高清中文字幕| 粉嫩在线一区二区三区视频| 日本韩国一区二区三区| 日韩欧美一级精品久久| 国产精品无圣光一区二区| 天堂va蜜桃一区二区三区| 国产成人日日夜夜| 欧美电影一区二区三区| 中文字幕 久热精品 视频在线| 亚洲精品乱码久久久久久黑人| 极品美女销魂一区二区三区| 99久精品国产| 久久久久九九视频| 亚洲国产精品久久人人爱| 国产精品一区在线| 欧美一区在线视频| 亚洲欧美综合色| 狠狠久久亚洲欧美| 欧美女孩性生活视频| 亚洲日本在线天堂| 国产91精品一区二区麻豆亚洲| 欧美午夜电影网| 亚洲日本免费电影| 成人综合激情网| 精品久久国产97色综合| 午夜欧美一区二区三区在线播放| 成人黄色av电影| 久久人人97超碰com| 青青草成人在线观看| 欧美亚洲图片小说| 亚洲精选免费视频| eeuss国产一区二区三区| 久久九九久久九九| 久久成人久久爱| 91精品中文字幕一区二区三区| 亚洲欧美另类小说| 99r国产精品| 亚洲三级理论片| 日本乱人伦一区| 成人午夜私人影院| 欧美绝品在线观看成人午夜影视| 国产精品女主播av| 国产91综合一区在线观看| 久久女同精品一区二区| 九一九一国产精品| 日韩一区二区免费在线电影| 视频一区二区不卡| 8v天堂国产在线一区二区| 日韩av一级电影| 日韩三级av在线播放| 青青草一区二区三区| 欧美大片在线观看| 精一区二区三区| 久久久一区二区| 高清不卡在线观看| 中文字幕字幕中文在线中不卡视频| 成人午夜激情片| 亚洲欧美日韩在线| 欧美日韩免费电影| 日韩中文字幕区一区有砖一区 | 亚洲r级在线视频| 欧美日韩一级黄| 久久精品国产亚洲高清剧情介绍| 欧美一区国产二区| 国产成人自拍在线| 亚洲另类在线一区| 9191成人精品久久| 国产精品一级在线| 亚洲另类一区二区| 欧美一区二区私人影院日本| 国产一区二区在线影院| 国产精品久久久久久久久免费丝袜 | 欧美一区二区三区视频在线观看 | 国产·精品毛片| 亚洲免费在线播放| 欧美一级久久久久久久大片| 国产精品羞羞答答xxdd| 一区二区三区四区中文字幕| 8x8x8国产精品| 波波电影院一区二区三区| 日韩在线播放一区二区| 欧美精品一区二区三区在线播放| 99国产精品久久久久久久久久| 亚洲午夜激情av| 亚洲国产精品精华液ab| 欧美日本高清视频在线观看| 国产91精品一区二区| 日韩精品国产精品| 国产精品乱码久久久久久| 欧美日韩国产综合一区二区| 国产成人精品亚洲日本在线桃色| 一区二区成人在线视频| 国产午夜精品一区二区三区嫩草| 欧美亚日韩国产aⅴ精品中极品| 韩国视频一区二区| 五月开心婷婷久久| 中文字幕日本不卡| 综合av第一页| 久久精品二区亚洲w码| 国产精品午夜久久| 欧美一区二区三区色| 9i看片成人免费高清| 国内久久婷婷综合| 日本亚洲最大的色成网站www| 国产精品系列在线| 久久精子c满五个校花| 欧美不卡一区二区三区四区| 欧美日韩国产综合草草| av一本久道久久综合久久鬼色| 国产一区二区三区免费| 麻豆国产精品官网| 蜜臀av一区二区在线免费观看| 亚洲综合999| 亚洲综合一二区| 亚洲黄色免费网站| 亚洲另类一区二区| 一区二区三区国产豹纹内裤在线| 国产女主播一区| 久久你懂得1024| 久久精品视频一区二区| 欧美成人艳星乳罩| 2020国产精品自拍| 久久精品视频网| 亚洲国产高清在线观看视频| 亚洲永久精品大片| 亚洲一区二区三区中文字幕| 最新国产成人在线观看| 国产精品久久久久久户外露出 | 欧美成人精品高清在线播放| 91精品国产一区二区三区| 欧美精品1区2区3区| 欧美精品1区2区| 精品国产污污免费网站入口| 亚洲精品在线电影| 久久久久国产精品免费免费搜索| xfplay精品久久| 国产精品伦一区二区三级视频| 亚洲欧美aⅴ...| 麻豆精品一区二区综合av| 亚洲国产精品一区二区久久| 夜夜操天天操亚洲| 午夜精品国产更新| 久久国产夜色精品鲁鲁99| 国产一二三精品| 99精品视频一区二区| 欧美日韩国产高清一区二区三区| 欧美一区二区三区系列电影| 26uuu色噜噜精品一区二区| 国产精品毛片久久久久久 | 成人精品国产一区二区4080| 91视频在线看| 欧美一区二区三区视频在线 | 中文字幕在线不卡| 日日夜夜精品免费视频| 精品一区二区三区在线播放视频| www.99精品| 7777精品伊人久久久大香线蕉的 | 99热精品一区二区| 欧美日韩国产美| 国产女人aaa级久久久级| 亚洲自拍偷拍综合| 国产suv精品一区二区883| 欧美午夜精品久久久久久超碰 | 成人免费毛片app| 欧美日本精品一区二区三区| 国产日产欧产精品推荐色| 一区二区久久久| 不卡在线视频中文字幕| 91精品国产色综合久久久蜜香臀| 国产亲近乱来精品视频| 蜜桃精品视频在线| 色婷婷综合五月|