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

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

?? mld6igmp_node.cc

?? MLDv2 support igmpv3 lite
?? CC
?? 第 1 頁 / 共 3 頁
字號:
    }        mld6igmp_vif->enable();        return (XORP_OK);}/** * Mld6igmpNode::disable_vif: * @vif_name: The name of the vif to disable. * @error_msg: The error message (if error). *  * Disable an existing MLD6IGMP vif. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::disable_vif(const string& vif_name, string& error_msg){    Mld6igmpVif *mld6igmp_vif = vif_find_by_name(vif_name);    if (mld6igmp_vif == NULL) {	error_msg = c_format("Cannot disable vif %s: no such vif",			     vif_name.c_str());	XLOG_ERROR("%s", error_msg.c_str());	return (XORP_ERROR);    }        mld6igmp_vif->disable();        return (XORP_OK);}/** * Mld6igmpNode::start_vif: * @vif_name: The name of the vif to start. * @error_msg: The error message (if error). *  * Start an existing MLD6IGMP vif. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::start_vif(const string& vif_name, string& error_msg){    Mld6igmpVif *mld6igmp_vif = vif_find_by_name(vif_name);    if (mld6igmp_vif == NULL) {	error_msg = c_format("Cannot start vif %s: no such vif",			     vif_name.c_str());	XLOG_ERROR("%s", error_msg.c_str());	return (XORP_ERROR);    }        if (mld6igmp_vif->start(error_msg) != XORP_OK) {	error_msg = c_format("Cannot start vif %s: %s",			     vif_name.c_str(), error_msg.c_str());	XLOG_ERROR("%s", error_msg.c_str());	return (XORP_ERROR);    }        return (XORP_OK);}/** * Mld6igmpNode::stop_vif: * @vif_name: The name of the vif to stop. * @error_msg: The error message (if error). *  * Stop an existing MLD6IGMP vif. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::stop_vif(const string& vif_name, string& error_msg){    Mld6igmpVif *mld6igmp_vif = vif_find_by_name(vif_name);    if (mld6igmp_vif == NULL) {	error_msg = c_format("Cannot stop vif %s: no such vif",			     vif_name.c_str());	XLOG_ERROR("%s", error_msg.c_str());	return (XORP_ERROR);    }        if (mld6igmp_vif->stop(error_msg) != XORP_OK) {	error_msg = c_format("Cannot stop vif %s: %s",			     vif_name.c_str(), error_msg.c_str());	XLOG_ERROR("%s", error_msg.c_str());	return (XORP_ERROR);    }        return (XORP_OK);}/** * Mld6igmpNode::start_all_vifs: * @:  *  * Start MLD/IGMP on all enabled interfaces. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::start_all_vifs(){    vector<Mld6igmpVif *>::iterator iter;    string error_msg;    int ret_value = XORP_OK;        for (iter = proto_vifs().begin(); iter != proto_vifs().end(); ++iter) {	Mld6igmpVif *mld6igmp_vif = (*iter);	if (mld6igmp_vif == NULL)	    continue;	if (start_vif(mld6igmp_vif->name(), error_msg) != XORP_OK)	    ret_value = XORP_ERROR;    }        return (ret_value);}/** * Mld6igmpNode::stop_all_vifs: * @:  *  * Stop MLD/IGMP on all interfaces it was running on. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::stop_all_vifs(){    vector<Mld6igmpVif *>::iterator iter;    string error_msg;    int ret_value = XORP_OK;        for (iter = proto_vifs().begin(); iter != proto_vifs().end(); ++iter) {	Mld6igmpVif *mld6igmp_vif = (*iter);	if (mld6igmp_vif == NULL)	    continue;	if (stop_vif(mld6igmp_vif->name(), error_msg) != XORP_OK)	    ret_value = XORP_ERROR;    }        return (ret_value);}/** * Mld6igmpNode::enable_all_vifs: * @:  *  * Enable MLD/IGMP on all interfaces. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::enable_all_vifs(){    vector<Mld6igmpVif *>::iterator iter;    string error_msg;    int ret_value = XORP_OK;        for (iter = proto_vifs().begin(); iter != proto_vifs().end(); ++iter) {	Mld6igmpVif *mld6igmp_vif = (*iter);	if (mld6igmp_vif == NULL)	    continue;	if (enable_vif(mld6igmp_vif->name(), error_msg) != XORP_OK)	    ret_value = XORP_ERROR;    }        return (ret_value);}/** * Mld6igmpNode::disable_all_vifs: * @:  *  * Disable MLD/IGMP on all interfaces. All running interfaces are stopped * first. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::disable_all_vifs(){    vector<Mld6igmpVif *>::iterator iter;    string error_msg;    int ret_value = XORP_OK;        for (iter = proto_vifs().begin(); iter != proto_vifs().end(); ++iter) {	Mld6igmpVif *mld6igmp_vif = (*iter);	if (mld6igmp_vif == NULL)	    continue;	if (disable_vif(mld6igmp_vif->name(), error_msg) != XORP_OK)	    ret_value = XORP_ERROR;    }        return (ret_value);}/** * Mld6igmpNode::delete_all_vifs: * @:  *  * Delete all MLD/IGMP vifs. **/voidMld6igmpNode::delete_all_vifs(){    list<string> vif_names;    vector<Mld6igmpVif *>::iterator iter;    //    // Create the list of all vif names to delete    //    for (iter = proto_vifs().begin(); iter != proto_vifs().end(); ++iter) {	Mld6igmpVif *mld6igmp_vif = (*iter);	if (mld6igmp_vif != NULL) {	    string vif_name = mld6igmp_vif->name();	    vif_names.push_back(mld6igmp_vif->name());	}    }    //    // Delete all vifs    //    list<string>::iterator vif_names_iter;    for (vif_names_iter = vif_names.begin();	 vif_names_iter != vif_names.end();	 ++vif_names_iter) {	const string& vif_name = *vif_names_iter;	string error_msg;	if (delete_vif(vif_name, error_msg) != XORP_OK) {	    error_msg = c_format("Cannot delete vif %s: internal error",				 vif_name.c_str());	    XLOG_ERROR("%s", error_msg.c_str());	}    }}/** * A method called when a vif has completed its shutdown. *  * @param vif_name the name of the vif that has completed its shutdown. */voidMld6igmpNode::vif_shutdown_completed(const string& vif_name){    vector<Mld6igmpVif *>::iterator iter;    //    // If all vifs have completed the shutdown, then de-register with    // the MFEA.    //    for (iter = proto_vifs().begin(); iter != proto_vifs().end(); ++iter) {	Mld6igmpVif *mld6igmp_vif = *iter;	if (mld6igmp_vif == NULL)	    continue;	if (! mld6igmp_vif->is_down())	    return;    }    //    // De-register with the FEA and MFEA    //    if (ServiceBase::status() == SERVICE_SHUTTING_DOWN) {	mfea_register_shutdown();	fea_register_shutdown();    }    UNUSED(vif_name);}intMld6igmpNode::proto_recv(const string& if_name,			 const string& vif_name,			 const IPvX& src_address,			 const IPvX& dst_address,			 uint8_t ip_protocol,			 int32_t ip_ttl,			 int32_t ip_tos,			 bool ip_router_alert,			 bool ip_internet_control,			 const vector<uint8_t>& payload,			 string& error_msg){    Mld6igmpVif *mld6igmp_vif = NULL;    int ret_value = XORP_ERROR;        debug_msg("Received message on %s/%s from %s to %s: "	      "ip_ttl = %d ip_tos = %#x ip_router_alert = %d "	      "ip_internet_control = %d rcvlen = %u\n",	      if_name.c_str(), vif_name.c_str(),	      cstring(src_address), cstring(dst_address),	      ip_ttl, ip_tos, ip_router_alert, ip_internet_control,	      XORP_UINT_CAST(payload.size()));    UNUSED(if_name);    //    // XXX: We registered to receive only one protocol, hence we ignore    // the ip_protocol value.    //    UNUSED(ip_protocol);    //    // Check whether the node is up.    //    if (! is_up()) {	error_msg = c_format("MLD/IGMP node is not UP");	return (XORP_ERROR);    }        //    // Find the vif for that packet    //    mld6igmp_vif = vif_find_by_name(vif_name);    if (mld6igmp_vif == NULL) {	error_msg = c_format("Cannot find vif with vif_name = %s",			     vif_name.c_str());	return (XORP_ERROR);    }        // Copy the data to the receiving #buffer_t    BUFFER_RESET(_buffer_recv);    BUFFER_PUT_DATA(&payload[0], _buffer_recv, payload.size());        // Process the data by the vif    ret_value = mld6igmp_vif->mld6igmp_recv(src_address, dst_address,					    ip_ttl, ip_tos,					    ip_router_alert,					    ip_internet_control,					    _buffer_recv,					    error_msg);        return (ret_value);     buflen_error:    XLOG_UNREACHABLE();    return (XORP_ERROR);}intMld6igmpNode::mld6igmp_send(const string& if_name,			    const string& vif_name,			    const IPvX& src_address,			    const IPvX& dst_address,			    uint8_t ip_protocol,			    int32_t ip_ttl,			    int32_t ip_tos,			    bool ip_router_alert,			    bool ip_internet_control,			    buffer_t *buffer,			    string& error_msg){    if (! is_up()) {	error_msg = c_format("MLD/IGMP node is not UP");	return (XORP_ERROR);    }        if (proto_send(if_name, vif_name, src_address, dst_address,		   ip_protocol, ip_ttl, ip_tos, ip_router_alert,		   ip_internet_control,		   BUFFER_DATA_HEAD(buffer),		   BUFFER_DATA_SIZE(buffer),		   error_msg)	!= XORP_OK) {	return (XORP_ERROR);    }        return (XORP_OK);}/** * Mld6igmpNode::add_protocol: * @module_instance_name: The module instance name of the protocol to add. * @module_id: The #xorp_module_id of the protocol to add. * @vif_index: The vif index of the interface to add the protocol to. *  * Add a protocol to the list of entries that would be notified if there * is membership change on a particular interface. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::add_protocol(const string& module_instance_name,			   xorp_module_id module_id,			   uint32_t vif_index){    Mld6igmpVif *mld6igmp_vif = vif_find_by_vif_index(vif_index);        if (mld6igmp_vif == NULL) {	XLOG_ERROR("Cannot add protocol instance %s on vif_index %d: "		   "no such vif",		   module_instance_name.c_str(), vif_index);	return (XORP_ERROR);    }        if (mld6igmp_vif->add_protocol(module_id, module_instance_name) != XORP_OK)	return (XORP_ERROR);        return (XORP_OK);}/** * Mld6igmpNode::delete_protocol: * @module_instance_name: The module instance name of the protocol to delete. * @module_id: The #xorp_module_id of the protocol to delete. * @vif_index: The vif index of the interface to delete the protocol from. *  * Delete a protocol from the list of entries that would be notified if there * is membership change on a particular interface. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::delete_protocol(const string& module_instance_name,			      xorp_module_id module_id,			      uint32_t vif_index){    Mld6igmpVif *mld6igmp_vif = vif_find_by_vif_index(vif_index);        if (mld6igmp_vif == NULL) {	XLOG_ERROR("Cannot delete protocol instance %s on vif_index %d: "		   "no such vif",		   module_instance_name.c_str(), vif_index);	return (XORP_ERROR);    }        if (mld6igmp_vif->delete_protocol(module_id, module_instance_name)	!= XORP_OK) {	return (XORP_ERROR);    }        return (XORP_OK);}/** * Mld6igmpNode::join_prune_notify_routing: * @module_instance_name: The module instance name of the protocol to notify. * @module_id: The #xorp_module_id of the protocol to notify. * @vif_index: The vif index of the interface with membership change. * @source: The source address of the (S,G) or (*,G) entry that has changed. * In case of group-specific membership, it is IPvX::ZERO(). * @group: The group address of the (S,G) or (*,G) entry that has changed. * @action_jp: The membership change type #action_jp_t: * either %ACTION_JOIN or %ACTION_PRUNE. *  * Notify the protocol instance with name @module_instance_name that there is * multicast membership change on interface with vif index of @vif_index. *  * Return value: %XORP_OK on success, otherwise %XORP_ERROR. **/intMld6igmpNode::join_prune_notify_routing(const string& module_instance_name,					xorp_module_id module_id,					uint32_t vif_index,					const IPvX& source,					const IPvX& group,					action_jp_t action_jp){    //    // Send add/delete membership to the registered protocol instance.    //    switch (action_jp) {    case ACTION_JOIN:	send_add_membership(module_instance_name, module_id,			    vif_index, source, group);	break;    case ACTION_PRUNE:	send_delete_membership(module_instance_name, module_id, 			       vif_index, source, group);	break;    default:	XLOG_UNREACHABLE();	break;    }        return (XORP_OK);}/** * Mld6igmpNode::is_directly_connected: * @mld6igmp_vif: The virtual interface to test against. * @ipaddr_test: The address to test. *  * Note that the virtual interface the address is directly connected to * must be UP. *  * Return value: True if @ipaddr_test is directly connected to @mld6igmp_vif, * otherwise false. **/boolMld6igmpNode::is_directly_connected(const Mld6igmpVif& mld6igmp_vif,				    const IPvX& ipaddr_test) const{    if (! mld6igmp_vif.is_up())	return (false);#if 0	// TODO: not implemented yet    //    // Test the alternative subnets    //    list<IPvXNet>::const_iterator iter;    for (iter = mld6igmp_vif.alternative_subnet_list().begin();	 iter != mld6igmp_vif.alternative_subnet_list().end();	 ++iter) {	const IPvXNet& ipvxnet = *iter;	if (ipvxnet.contains(ipaddr_test))	    return true;    }#endif    //    // Test the same subnet addresses, or the P2P addresses    //    return (mld6igmp_vif.is_same_subnet(ipaddr_test)	    || mld6igmp_vif.is_same_p2p(ipaddr_test));}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人激情免费网站| 不卡欧美aaaaa| 亚洲精品ww久久久久久p站| 91精选在线观看| 91网上在线视频| 国产精品综合一区二区三区| 亚洲一二三区在线观看| 欧美国产日韩一二三区| 日韩女优av电影在线观看| 欧美午夜一区二区三区免费大片| 国产黄色精品视频| 美女网站色91| 亚洲一区二区三区四区的| 国产精品视频一区二区三区不卡| 日韩欧美高清dvd碟片| 色av成人天堂桃色av| 成人av网站免费观看| 国产一区二区三区在线观看免费| 亚洲大片在线观看| 精品国产乱码久久久久久蜜臀| 色婷婷久久久亚洲一区二区三区| 国产在线精品一区二区夜色| 欧美变态tickle挠乳网站| 亚洲国产精品综合小说图片区| 91亚洲男人天堂| 综合在线观看色| 国产经典欧美精品| 久久久久久久久久久电影| 国产成人精品免费网站| 久久久一区二区三区| 制服丝袜中文字幕一区| 91成人在线精品| 97精品超碰一区二区三区| 国产99久久久久| 国精产品一区一区三区mba视频| 日本成人在线看| 天堂一区二区在线| 天堂av在线一区| 日韩国产欧美三级| 蜜臀91精品一区二区三区| 日本v片在线高清不卡在线观看| 亚洲成人av一区二区| 午夜欧美一区二区三区在线播放| 亚洲一区二区高清| 午夜电影一区二区三区| 午夜精品福利一区二区三区av| 亚洲 欧美综合在线网络| 亚洲高清免费观看| 天堂影院一区二区| 激情综合网天天干| 国产成人午夜片在线观看高清观看| 国产自产2019最新不卡| 国产二区国产一区在线观看| 国产**成人网毛片九色 | 日韩电影在线免费| 视频一区二区欧美| 精品中文字幕一区二区小辣椒| 国产乱妇无码大片在线观看| 成人永久看片免费视频天堂| 成人激情动漫在线观看| 欧洲一区二区av| 欧美一三区三区四区免费在线看| 精品乱码亚洲一区二区不卡| 欧美极品少妇xxxxⅹ高跟鞋| 亚洲欧美国产高清| 日本免费在线视频不卡一不卡二| 久久精品国产在热久久| 成人免费看视频| 欧美亚洲精品一区| 亚洲精品在线免费观看视频| 国产精品三级av| 亚洲综合图片区| 激情成人综合网| 成人av片在线观看| 欧美日韩aaaaa| 精品国一区二区三区| 亚洲天堂网中文字| 人人超碰91尤物精品国产| 成人综合日日夜夜| 在线播放中文一区| 国产精品久久久久一区| 五月天激情综合| 成人免费视频一区二区| 欧美日韩国产欧美日美国产精品| 国产亚洲一区二区三区四区| 亚洲午夜av在线| 懂色av一区二区三区免费看| 欧美在线不卡视频| 日本一区二区久久| 蜜臀av亚洲一区中文字幕| 91小宝寻花一区二区三区| 欧美不卡视频一区| 亚洲午夜久久久久中文字幕久| 国产在线精品视频| 5566中文字幕一区二区电影| 亚洲欧美自拍偷拍色图| 国产在线不卡一区| 欧美一级一区二区| 一区二区三区久久| 99这里都是精品| 2024国产精品视频| 日韩成人一区二区三区在线观看| 99国产精品久久久久久久久久 | 中文字幕精品在线不卡| 日本va欧美va欧美va精品| 91久久精品日日躁夜夜躁欧美| 久久综合色一综合色88| 日本女优在线视频一区二区| 在线观看91视频| 亚洲精品美国一| 99久久er热在这里只有精品15| 精品国产成人系列| 日本人妖一区二区| 欧美日韩久久不卡| 亚洲乱码国产乱码精品精98午夜| 国产精品18久久久久久久久久久久| 日韩欧美成人一区二区| 亚洲成av人片www| 欧美日韩午夜精品| 一区二区三区产品免费精品久久75| 99在线精品免费| 成人欧美一区二区三区视频网页| 国产馆精品极品| 久久精品欧美日韩精品| 黄页视频在线91| 精品久久一区二区| 久久91精品国产91久久小草 | 欧美一级在线观看| 婷婷中文字幕一区三区| 欧美精品在线一区二区三区| 亚洲小说欧美激情另类| 精品视频全国免费看| 一区二区免费在线播放| 日本精品视频一区二区| 亚洲一区二区三区四区在线观看| 91激情五月电影| 亚洲gay无套男同| 制服丝袜日韩国产| 免费一级片91| 久久久精品日韩欧美| 国产激情视频一区二区在线观看| 国产欧美视频在线观看| 成人免费看黄yyy456| 国产精品福利av| 91成人网在线| 香蕉久久夜色精品国产使用方法| 欧美肥妇bbw| 精品无码三级在线观看视频| 亚洲精品一区二区三区四区高清| 国产很黄免费观看久久| 国产精品久久久久婷婷二区次| 色婷婷综合激情| 日韩电影在线一区| 久久久91精品国产一区二区精品 | 久久女同性恋中文字幕| 国产丶欧美丶日本不卡视频| 一色屋精品亚洲香蕉网站| 在线亚洲高清视频| 蜜桃视频在线一区| 国产欧美一区二区精品忘忧草| 色综合久久66| 奇米777欧美一区二区| 久久久电影一区二区三区| 成人黄页毛片网站| 亚洲一级片在线观看| 亚洲精品一区二区三区福利| eeuss国产一区二区三区| 午夜天堂影视香蕉久久| 久久美女艺术照精彩视频福利播放 | 亚洲午夜电影在线观看| 欧美成人性战久久| 99久久99久久免费精品蜜臀| 午夜精品福利视频网站 | 亚洲va欧美va国产va天堂影院| 欧美一区日本一区韩国一区| 国产激情一区二区三区四区| 亚洲宅男天堂在线观看无病毒 | 天天综合天天做天天综合| 久久久国产精品不卡| 色噜噜夜夜夜综合网| 九九热在线视频观看这里只有精品| 欧美国产日产图区| 欧美一区二区三区电影| a级高清视频欧美日韩| 日本系列欧美系列| 一区视频在线播放| 欧美成人欧美edvon| 91视频在线看| 国产一区二区女| 图片区小说区区亚洲影院| 欧美激情综合五月色丁香 | 在线电影国产精品| 成人av电影在线播放| 青娱乐精品视频| 一区二区三区精品| 国产欧美综合在线观看第十页| 欧美日韩情趣电影| 白白色 亚洲乱淫| 精品一区二区三区免费毛片爱| 亚洲免费观看高清完整版在线 |