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

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

?? ospf_transmit_update.c

?? vxworks下ospf協議棧
?? C
?? 第 1 頁 / 共 3 頁
字號:
                }            }            else /* if sending to other router than DR or BDR, timestamp of last multicast transmission                    to all SPF routers would do */            {                if (sptr_retx_timestamp_node->neighbor_id == OSPF_ADDR_ALLSPF)                {                    /* found timestamp of last transmission of this LSA as multicast (all SPF routers),                    and this is unicast to a router on this interface. Accept timestamp of last                    multicast transmission.                    Record timestamp */                    *last_tx_time = sptr_retx_timestamp_node->timestamp;                    break;                }            }        }    } /* for every timestamp in the list */    return sptr_retx_timestamp_node;    } /* ospf_find_timestamp_for_lsdb_entry *//**********************************************************************************************************************************//* Function ospf_update_lsa_transmit_timestamp    updates the LSA transmission timestamp   Pseudocode:    if transmit timestamp node of database node is given,        just update timestamp    else        create transmit timestamp node        update its timestamp        enqueue in database node's list of transmit timestamps*/static void ospf_update_lsa_transmit_timestamp    (    OSPF_LS_DATABASE_ENTRY *sptr_database_entry,    OSPF_LSA_TIMESTAMP_PER_INTERFACE_LIST *sptr_timestamp_node,    ULONG current_time,    ULONG destination_router,    OSPF_NEIGHBOR *sptr_neighbor,    ULONG if_index    )    {    OSPF_LSA_TIMESTAMP_PER_INTERFACE_LIST *sptr_new_timestamp = NULL;    ULONG id = 0L;    /* param validation */    if (sptr_database_entry == NULL)    {        return;    }    if (sptr_neighbor == NULL)    {        id = destination_router;    }    else    {        id = sptr_neighbor->id;    }    /* if timestamp of last retransmission exists, update it with current time */    if (sptr_timestamp_node != NULL)    {        /* just update timestamp in existing node, was already transmitted before */        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "\n          LSA timestamp set from %ld to %ld, LSA type %d, id %08lx, seq. %08lx, to %p, dest %08lx, \n\t timestamp at %p, if %08lx, dst %08lx,  ",               sptr_timestamp_node->timestamp,               current_time,               sptr_database_entry->advertisement.sptr_router->ls_header.type,               sptr_database_entry->advertisement.sptr_router->ls_header.id,               sptr_database_entry->advertisement.sptr_router->ls_header.sequence_number,               sptr_neighbor,               destination_router,               sptr_timestamp_node,               sptr_timestamp_node->if_index,               sptr_timestamp_node->neighbor_id);        sptr_timestamp_node->timestamp = current_time;        return;    }    /* if timestamp of last retransmission does not exist, create it */    sptr_new_timestamp = (OSPF_LSA_TIMESTAMP_PER_INTERFACE_LIST *)                                table_malloc  (1, sizeof (OSPF_LSA_TIMESTAMP_PER_INTERFACE_LIST));    if (sptr_new_timestamp != NULL)    {        /* initialize timestamp node */        sptr_new_timestamp->neighbor_id = id;        sptr_new_timestamp->if_index = if_index;        sptr_new_timestamp->timestamp = current_time;        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "\n          LSA timestamp created, LSA type %d, id %08lx, seq. %08lx, to %p, dest %08lx, \n\t timestamp at %p, if %08lx, dst %08lx, timestamp %08lx ",               sptr_database_entry->advertisement.sptr_router->ls_header.type,               sptr_database_entry->advertisement.sptr_router->ls_header.id,               sptr_database_entry->advertisement.sptr_router->ls_header.sequence_number,               sptr_neighbor,               destination_router,               sptr_new_timestamp,               sptr_new_timestamp->if_index,               sptr_new_timestamp->neighbor_id,               sptr_new_timestamp->timestamp);        /* queue time stamp node in list of timestamps of its lsdb node */        if (sptr_database_entry->sptr_lsa_retransmit_timestamps_per_neighbor == NULL)        {            /* first timestamp node */            sptr_database_entry->sptr_lsa_retransmit_timestamps_per_neighbor =                sptr_new_timestamp;        }        else        {            /* another timestamp for this LSA (LSA was recently transmitted to other destinations / interfaces) */            ospf_add_node_to_end_of_list(                (OSPF_GENERIC_NODE *)sptr_new_timestamp,                (OSPF_GENERIC_NODE *)sptr_database_entry->sptr_lsa_retransmit_timestamps_per_neighbor);        }    }    } /* ospf_update_lsa_transmit_timestamp *//**********************************************************************************************************************************//* Function ospf_check_if_advertisement_should_be_sent    Validates if the LSA should be transmitted on the given interface to the given destination router    or not according to RxmtInterval (enabled or not and configured with value per interface)   Pseudocode:    If flooding not enabled for this LSA,        return FALSE (prevent transmitting LSA)    Locate LSDB entry for this LSA    If LSA not found in LSDB        return FALSE (should not flood an LSA that is not in LSDB)    Locate timestamp of last LSA transmission of this LSA to this neighbor    If timestamp not found (first transmission of this LSA to this neighbor)        create timestamp        queue timestamp to LSDB node of this LSA        return TRUE; (accept transmitting LSA)    Compute elapsed time        if (elapsed time < sptr_interface->retransmit_interval)            return FALSE (prevent transmitting LSA)        else            record new timestamp of transmission to this neighbor            return TRUE (accept transmitting LSA)*/static enum BOOLEAN ospf_check_if_advertisement_should_be_sent    (    OSPF_LS_DATABASE_NODE   *sptr_database_node,    OSPF_INTERFACE          *sptr_interface,    ULONG                   destination_router,    enum BOOLEAN            retransmit_flag,    OSPF_NEIGHBOR           *sptr_neighbor    )    {    ULONG   current_time = 0,            elapsed_time = 0,            last_tx_time = 0L;    ULONG   destination_router_id = 0L;    OSPF_LSA_TIMESTAMP_PER_INTERFACE_LIST   *sptr_lsa_timestamp = NULL;    OSPF_LS_DATABASE_ENTRY                  *sptr_lsdb_entry = NULL;    ULONG   id = 0;    ULONG   hash_id = 0;    ULONG   advertising_router = 0;    BYTE_ENUM (OSPF_LS_TYPE) type = 0;    OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "OSPF: Entering ospf_check_if_advertisement_should_be_sent\r\n");    if (sptr_database_node == NULL)        {        return FALSE;        }    /* Pseudocode:        If flooding not enabled for this LSA,            return FALSE (prevent transmitting LSA) */    if ((retransmit_flag == FALSE) && (sptr_database_node->flood == FALSE))        {        /* should not flood this LSA */        return FALSE;        }    if (sptr_database_node->sptr_ls_database_entry == NULL)        {        /* param error, recover */        return FALSE;        }    /* get current time */    current_time = ospf_get_system_elapsed_time_second ();    if ((destination_router == 0L) || (destination_router == OSPF_ADDR_ALLDR))        {        /* neighbor to send this LSA to is the DR on this interface */        destination_router_id = sptr_interface->designated_router.id;        }    else        {        /* unicast to a neighbor or multicast to all SPF routers */        destination_router_id = destination_router;        }/* just for debug start */    OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "\nTransmit LSA of type %d, id %lx, seq.%lx, age %d, ",           sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.type,           sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.id,           sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.sequence_number,           sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.age);    if (destination_router == OSPF_ADDR_ALLSPF)        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "multicast to %lx ", destination_router_id);    else if (destination_router == OSPF_ADDR_ALLDR)        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "unicast to DR %lx sent to %lx ", destination_router, destination_router_id);    else        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "unicast to %lx ", destination_router_id);    if (sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.age > OSPF_MAXIMUM_AGE)        {        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "MAXAGE ");        }/* just for debug end */    /* Pseudocode: locate the LSDB node pointing to this LSA, locate its timestamp */    id = ntohl(sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.id);    hash_id = id;    hash_id = hash_id & OSPF_HASH_MASK;    advertising_router = ntohl(sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.advertising_router);    type = sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.type;    if (sptr_interface != NULL)        {        sptr_lsdb_entry = ospf_find_LSA (sptr_interface->sptr_area, id, advertising_router, type);        if ((sptr_lsdb_entry != NULL) &&            (sptr_lsdb_entry != sptr_database_node->sptr_ls_database_entry))            {            /* Found LSDB entry pointing to same LSA, search timestamp of LSDB entry */            sptr_lsa_timestamp = ospf_find_timestamp_for_lsdb_entry(                                        sptr_lsdb_entry,                                        destination_router_id,                                        sptr_interface,                                        &last_tx_time,                                        sptr_neighbor);            }        }    if (sptr_lsdb_entry == NULL)        {        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF, "\n          LSA not found in LSDB of interface %p, area %ld: type %d, id %08lx, advrtr %08lx, seq. %lx ",               sptr_interface,               sptr_interface->sptr_area->area_id,               sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.type,               sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.id,               sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.advertising_router,               sptr_database_node->sptr_ls_database_entry->advertisement.sptr_router->ls_header.sequence_number);        /* should not flood an LSA that is not in LSDB (TBD behavior for MAXAGE LSA) */        return FALSE;        }    /* If this is the first transmission of this LSA (no timestamp of a previous transmission),            then create a timestamp for it and accept transmission */    if (sptr_lsa_timestamp == NULL)        {        ospf_update_lsa_transmit_timestamp(sptr_lsdb_entry,                                           NULL,                                           current_time,                                           destination_router_id,                                           sptr_neighbor,                                           sptr_interface->ifnet_index);        OSPF_PRINTF_DEBUG (OSPF_DEBUG_PRINTF,"\n        LSA transmit accepted");        return TRUE;        }    /* This is not first transmission of the LSA,        compute elapsed time since last transmission

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产喷白浆一区二区三区| 在线观看日产精品| 日韩精品每日更新| 亚洲一区二区三区国产| 亚洲欧美偷拍卡通变态| 亚洲欧美偷拍卡通变态| 亚洲激情一二三区| 午夜视频一区在线观看| 午夜精品久久久久久久99水蜜桃 | 视频一区二区三区在线| 午夜精品一区二区三区三上悠亚| 亚洲超碰精品一区二区| 日韩电影在线看| 韩国精品主播一区二区在线观看 | 亚洲精品高清在线观看| 亚洲一区影音先锋| 日本成人超碰在线观看| 激情文学综合插| 北条麻妃一区二区三区| 在线观看国产日韩| 日韩一级片在线播放| 国产亚洲精品资源在线26u| 中文字幕日本不卡| 亚洲影院久久精品| 久久99精品久久久久久国产越南 | 亚洲综合在线五月| 日韩成人一区二区| 国产成人av资源| 91在线精品秘密一区二区| 欧美精品久久99| 国产欧美日韩在线| 亚洲gay无套男同| 国产精一品亚洲二区在线视频| 99久久99久久精品国产片果冻| 欧美日韩三级一区| 国产欧美一区二区在线观看| 亚洲一区二区中文在线| 国产一区不卡视频| 欧美视频中文一区二区三区在线观看| 日韩欧美精品三级| 夜夜揉揉日日人人青青一国产精品| 麻豆成人免费电影| 欧洲在线/亚洲| 国产日产精品1区| 日韩电影免费在线观看网站| 91色视频在线| 亚洲国产精品ⅴa在线观看| 午夜精品免费在线观看| jizzjizzjizz欧美| 久久新电视剧免费观看| 天天av天天翘天天综合网| 不卡一区二区三区四区| 欧美va亚洲va国产综合| 亚洲第一二三四区| 91在线免费播放| 国产午夜一区二区三区| 蜜臀va亚洲va欧美va天堂| 欧美午夜一区二区| ●精品国产综合乱码久久久久 | 国产欧美精品一区| 久久精品国产一区二区三| 精品视频一区 二区 三区| 综合中文字幕亚洲| 不卡视频免费播放| 欧美激情在线一区二区三区| 久久 天天综合| 日韩天堂在线观看| 免费成人深夜小野草| 欧美久久久影院| 午夜精品一区二区三区三上悠亚| 欧洲精品在线观看| 亚洲亚洲精品在线观看| 欧美日韩综合不卡| 亚洲成国产人片在线观看| 欧美三区在线视频| 亚欧色一区w666天堂| 欧美日韩色综合| 日韩专区一卡二卡| 欧美一级日韩免费不卡| 蜜桃av一区二区三区| 精品欧美一区二区久久| 国产一区二区网址| 中文字幕久久午夜不卡| heyzo一本久久综合| 一区二区三区在线免费视频| 欧美视频一区在线| 奇米精品一区二区三区在线观看| 日韩欧美中文一区二区| 国产大陆亚洲精品国产| 国产精品你懂的在线| 99v久久综合狠狠综合久久| 亚洲美腿欧美偷拍| 欧美美女视频在线观看| 麻豆精品新av中文字幕| 国产日本欧美一区二区| 色悠悠久久综合| 性做久久久久久久久| 欧美va亚洲va香蕉在线 | 中文字幕一区二区三区不卡在线| www.成人在线| 亚洲无人区一区| 久久亚洲春色中文字幕久久久| 成人手机在线视频| 一区二区三区不卡在线观看| 欧美一区二区免费| 色婷婷精品久久二区二区蜜臂av | 国产精品亚洲人在线观看| 国产喂奶挤奶一区二区三区| 99久久精品一区二区| 婷婷国产v国产偷v亚洲高清| 亚洲精品一区在线观看| 色婷婷综合在线| 捆绑调教美女网站视频一区| 国产精品久久国产精麻豆99网站| 欧美三级日韩三级国产三级| 国产成人精品亚洲日本在线桃色| 亚洲自拍欧美精品| 欧美精品一区二区蜜臀亚洲| 色婷婷国产精品久久包臀| 极品少妇xxxx精品少妇偷拍| 一级特黄大欧美久久久| 国产亚洲精品中文字幕| 欧美精品一二三四| 94-欧美-setu| 国产成人在线视频网址| 青青草国产成人99久久| 亚洲猫色日本管| 中文字幕av资源一区| 日韩精品一区二区三区四区| 欧美亚洲动漫制服丝袜| 不卡的av电影| 国产精品自拍av| 老司机午夜精品| 午夜av电影一区| 亚洲一区二三区| 亚洲精品乱码久久久久久| 中文字幕精品—区二区四季| 精品精品国产高清a毛片牛牛| 欧美午夜精品久久久久久超碰 | 成人黄色av电影| 国产一区二区精品久久99| 日韩综合小视频| 亚洲第一狼人社区| 性欧美大战久久久久久久久| 亚洲一区二区欧美日韩| 一区二区三区免费观看| 亚洲人成亚洲人成在线观看图片| 国产清纯在线一区二区www| 26uuu另类欧美亚洲曰本| 欧美一级理论片| 91精品国产乱| 欧美电影免费观看完整版| 欧美一区二区三区在线观看| 69精品人人人人| 日韩一区二区三区观看| 日韩欧美视频在线| 久久亚洲一区二区三区明星换脸| 欧美成人性战久久| 久久午夜老司机| 国产精品女主播在线观看| 国产精品私人影院| 亚洲精品乱码久久久久| 亚洲午夜影视影院在线观看| 午夜亚洲国产au精品一区二区| 亚洲成人激情社区| 欧美a级一区二区| 韩国三级在线一区| 成人一区二区视频| 91视频在线观看| 欧美三级中文字| 久久免费国产精品| 《视频一区视频二区| 亚洲成人7777| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲一二三区不卡| 日韩**一区毛片| 国产成人综合网站| 91黄色激情网站| 欧美mv日韩mv亚洲| 日韩毛片一二三区| 日韩综合在线视频| 大胆亚洲人体视频| 欧美色手机在线观看| 精品少妇一区二区三区日产乱码 | 日本在线不卡视频| 国产精品白丝av| 欧美色网站导航| 精品国产乱码久久久久久1区2区 | 久久精品一级爱片| 亚洲一区二区精品3399| 激情欧美一区二区三区在线观看| 99久久精品费精品国产一区二区| 欧美日韩国产精选| 中文幕一区二区三区久久蜜桃| 亚洲国产一区视频| 高清不卡一二三区| 91精品国模一区二区三区| 国产精品第一页第二页第三页| 天天综合色天天| bt7086福利一区国产|