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

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

?? ipproto.c

?? vxwork源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/******************************************************************************** ipTkReceiveRtn - send a packet to the protocol from an NPT device** This routine transfers data to IP when an NPT device receives a packet* from a toolkit driver. The data contained in the <pMblk> argument is an* IP packet (without a link-level header). A toolkit driver updates the* flags in the mBlk to indicate a multicast or broadcast link-level frame.** RETURNS: TRUE, always.** NOMANUAL*/LOCAL BOOL ipTkReceiveRtn    (    void * ipCallbackId,      /* Sent down in muxTkBind call. */    long         type,        /* Protocol type.  */    M_BLK_ID     pMblk,       /* The whole packet. */    void *       pSpareData   /* out of band data */    )    {    IP_DRV_CTRL * pDrvCtrl = (IP_DRV_CTRL *)ipCallbackId;    struct ifnet *  pIfp;#ifdef ROUTER_STACK    struct ip* pIpHdr;    ULONG ipAddr=0;    struct sockaddr_in dstIpAddr;#endif  /* ROUTER_STACK */    if (pDrvCtrl == NULL)        {        logMsg ("ipProto: unknown device\n", 0, 0, 0, 0, 0, 0);        goto ipReceiveError;        }#ifdef IP_DEBUG    if (ipDebug)        logMsg("start of ipTkReceiveRtn!\n", 0, 0, 0, 0, 0, 0);#endif /* IP_DEBUG */    pIfp = (struct ifnet *)&pDrvCtrl->idr;    if ((pIfp->if_flags & IFF_UP) == 0)        {        pIfp->if_ierrors++;        goto ipReceiveError;        }    /* bump statistic */    pIfp->if_ipackets++;            pIfp->if_lastchange = tickGet();    pIfp->if_ibytes += pMblk->mBlkPktHdr.len;    if(pMblk->mBlkHdr.mFlags & M_MCAST)        pIfp->if_imcasts++;    pMblk->mBlkPktHdr.rcvif     = pIfp;    /* hand off the packet to ip layer */#ifdef ROUTER_STACK    /* Check to see if Fastpath is enabled on the received interface */    if (SHOULD_GIVE_PACKET_TO_FF (GET_IPV4_FF_ID, pIfp) &&         type == ETHERTYPE_IP)        {        pIpHdr=mtod(pMblk, struct ip*);        ipAddr=pIpHdr->ip_dst.s_addr;        bzero((char*)&dstIpAddr, sizeof(struct sockaddr_in));        dstIpAddr.sin_len = sizeof(struct sockaddr_in);        dstIpAddr.sin_family=AF_INET;        dstIpAddr.sin_addr.s_addr=NTOHL(ipAddr);        if (FF_NC_CALL (GET_IPV4_FF_ID, ffPktSend, \                        (GET_IPV4_FF_ID, (struct sockaddr*)&dstIpAddr, \                         pMblk, ETHERTYPE_IP, pIfp)) == OK)            {#ifdef DEBUG            logMsg("ipTkReceiveRtn: packet forwarded by Fastpath\n",0,0,0,0,0,0);#endif /* DEBUG */            return (TRUE);            }        }#endif /* ROUTER_STACK */    do_protocol_with_type (type, pMblk , (struct arpcom* )pIfp,                            pMblk->mBlkHdr.mLen);    return (TRUE);    ipReceiveError:         {         if (pMblk != NULL)             netMblkClChainFree (pMblk);         }    return (TRUE);    }/******************************************************************************** ipShutdownRtn - Shutdown the NULL protocol stack gracefully.* * This routine is called by the lower layer upon muxDevUnload or a similar* condition to tell the protocol to shut itself down.** RETURNS: OK, or ERROR if muxUnbind routine fails.** NOMANUAL*/LOCAL STATUS ipShutdownRtn    (    void * 	pCookie, 	/* protocol/device binding from muxBind() */    void * 	pSpare 		/* spare pointer from muxBind() */    )    {    IP_DRV_CTRL * 	pDrvCtrl = (IP_DRV_CTRL *)pSpare;    if (!pDrvCtrl->attached)	return (ERROR);    if_dettach(&pDrvCtrl->idr.ac_if);    KHEAP_FREE(pDrvCtrl->idr.ac_if.if_name);    netMblkFree (_pNetDpool, pDrvCtrl->pSrc);    netClFree (_pNetDpool, pDrvCtrl->pDstAddr);    netMblkFree (_pNetDpool, pDrvCtrl->pDst);    if (muxUnbind (pDrvCtrl->pIpCookie, ETHERTYPE_IP, ipReceiveRtn) != OK)	{	logMsg ("Could not un-bind from the IP MUX!", 0, 0, 0, 0, 0, 0);	return (ERROR);	}    if (pDrvCtrl->pArpCookie == NULL)        {        pDrvCtrl->attached = FALSE;        }    pDrvCtrl->pIpCookie = NULL;    return (OK);    }/******************************************************************************** arpShutdownRtn - Shutdown the NULL protocol stack gracefully.* * This routine is called by the lower layer upon muxDevUnload or a similar* condition to tell the protocol to shut itself down.** RETURNS: OK or ERROR.** NOMANUAL*/LOCAL STATUS arpShutdownRtn    (    void * 	pCookie, 	/* protocol/device binding from muxBind() */    void * 	pSpare 		/* spare pointer from muxBind() */    )    {    IP_DRV_CTRL * pDrvCtrl = (IP_DRV_CTRL *)pSpare;    if (pDrvCtrl == NULL)        return (ERROR);                if (!pDrvCtrl->attached)	return (ERROR);    if (muxUnbind (pDrvCtrl->pArpCookie, ETHERTYPE_ARP, ipReceiveRtn) != OK)	{	logMsg ("Could not un-bind from the ARP MUX!", 0, 0, 0, 0, 0, 0);	return (ERROR);	}    if (pDrvCtrl->pIpCookie == NULL)        {        pDrvCtrl->attached = FALSE;        }    pDrvCtrl->pArpCookie = NULL;    return (OK);    }/******************************************************************************** ipTkShutdownRtn - Shutdown the protocol stack bound to a toolkit driver** This routine is called by the lower layer upon muxDevUnload or a similar* condition to tell the protocol to shut itself down.** RETURNS: OK or ERROR depending on ipDetach.** NOMANUAL*/LOCAL STATUS ipTkShutdownRtn    (    void * ipCallbackId       /* protocol/device binding from muxTkBind() */    )    {    IP_DRV_CTRL * pDrvCtrl = (IP_DRV_CTRL *)ipCallbackId;    if (pDrvCtrl == NULL)        return (ERROR);        if (!pDrvCtrl->attached)        return (ERROR);    if_dettach(&pDrvCtrl->idr.ac_if);    KHEAP_FREE(pDrvCtrl->idr.ac_if.if_name);    netClFree (_pNetDpool, pDrvCtrl->pDstAddr);    if (muxUnbind(pDrvCtrl->pIpCookie, ETHERTYPE_IP, ipTkReceiveRtn) != OK)        {        logMsg("Could not un-bind from the IP MUX!", 1, 2, 3, 4, 5, 6);        return (ERROR);        }    if (pDrvCtrl->pArpCookie == NULL)        {        pDrvCtrl->attached = FALSE;        }    pDrvCtrl->pIpCookie=NULL;    return (OK);    }/******************************************************************************** arpTkShutdownRtn - shutdown the protocol stack bound to a toolkit driver. ** This routine is called by the lower layer upon muxDevUnload or a similar* condition to tell the protocol to shut itself down.** RETURNS: OK or ERROR.** NOMANUAL*/LOCAL STATUS arpTkShutdownRtn    (    void * ipCallbackId       /* Sent down in muxTkBind call. */    )    {    IP_DRV_CTRL * pDrvCtrl = (IP_DRV_CTRL *)ipCallbackId;    if (pDrvCtrl == NULL)        return (ERROR);    if (!pDrvCtrl->attached)        return (ERROR);    if (muxUnbind(pDrvCtrl->pArpCookie, ETHERTYPE_ARP, ipTkReceiveRtn) != OK)        {        logMsg("Could not un-bind from the ARP MUX!", 1, 2, 3, 4, 5, 6);        return (ERROR);        }    if (pDrvCtrl->pIpCookie == NULL)        {        pDrvCtrl->attached = FALSE;        }    pDrvCtrl->pArpCookie=NULL;    return (OK);    }/******************************************************************************** ipTkError - a routine to deal with toolkit device errors** This routine is called by the lower layer to handle a toolkit device error.** RETURNS: N/A** NOMANUAL**/void ipTkError    (    void * ipCallbackId,  /* Sent down in muxTkBind call. */    END_ERR* pError       /* Error message */    )    {    IP_DRV_CTRL * pDrvCtrl = (IP_DRV_CTRL *)ipCallbackId;    END_OBJ * pEnd  = NULL;    if (pDrvCtrl)	 pEnd = PCOOKIE_TO_ENDOBJ (pDrvCtrl->pIpCookie);    if (pDrvCtrl == NULL || pEnd == NULL)        return;    ipError (pEnd, pError, pDrvCtrl);    return;    }/******************************************************************************** ipError - a routine to deal with device errors** This routine handles all errors from NPT and END drivers.** RETURNS: N/A** NOMANUAL*/LOCAL void ipError    (    END_OBJ * 	pEnd, 		/* END reporting the error */    END_ERR * 	pError, 	/* the error message */    void * 	pSpare 		/* spare pointer from muxBind() */    )    {    int s;    IP_DRV_CTRL * pDrvCtrl = (IP_DRV_CTRL *)pSpare;    struct ifnet * pIfp;    USHORT newFlags;    if (pEnd == NULL || pDrvCtrl == NULL)    	return;    pIfp = (struct ifnet *)&pDrvCtrl->idr;    switch (pError->errCode)        {#ifdef IP_DEBUG        case END_ERR_INFO:            if (ipDebug && pError->pMesg != NULL)                logMsg ("INFO: Device: %s Unit: %d Msg: %s\n",                        (int)pEnd->devObject.name, pEnd->devObject.unit,                        (int)pError->pMesg, 0, 0, 0);                break;        case END_ERR_WARN:            if (ipDebug && pError->pMesg != NULL)                logMsg ("WARN: Device: %s Unit: %d Msg: %s\n",                        (int)pEnd->devObject.name, pEnd->devObject.unit,                        (int)pError->pMesg, 0, 0, 0);                break;#endif /* IP_DEBUG */        case END_ERR_RESET:#ifdef IP_DEBUG            if (ipDebug && pError->pMesg != NULL)                logMsg ("RESET: Device: %s Unit: %d Msg: %s\n",                        (int)pEnd->devObject.name, pEnd->devObject.unit,                        (int)pError->pMesg, 0, 0, 0);#endif /* IP_DEBUG */            pDrvCtrl->idr.ac_if.if_lastchange = tickGet();            break;        case END_ERR_UP:#ifdef IP_DEBUG            if (ipDebug && pError->pMesg != NULL)                logMsg ("UP: Device: %s Unit: %d Msg: %s\n",                        (int)pEnd->devObject.name, pEnd->devObject.unit,                        (int)pError->pMesg, 0, 0, 0);#endif /* IP_DEBUG */            if ( (pIfp->if_flags & IFF_UP) == 0)                {                s = splimp ();                if_up (pIfp);                splx (s);                }            pDrvCtrl->idr.ac_if.if_lastchange = tickGet();            ((IFNET *)&pDrvCtrl->idr)->if_flags |= (IFF_UP| IFF_RUNNING);            break;        case END_ERR_DOWN:#ifdef IP_DEBUG            if (ipDebug && pError->pMesg != NULL)                logMsg ("DOWN: Device: %s Unit: %d Msg: %s\n",                        (int)pEnd->devObject.name, pEnd->devObject.unit,                        (int)pError->pMesg, 0, 0, 0);#endif /* IP_DEBUG */            if ( (pIfp->if_flags & IFF_UP))                {                s = splimp ();                if_down (pIfp);                splx (s);                }            pDrvCtrl->idr.ac_if.if_lastchange = tickGet();            ((IFNET *)&pDrvCtrl->idr)->if_flags &= ~(IFF_UP| IFF_RUNNING);            break;        case END_ERR_FLAGS:#ifdef IP_DEBUG            if (ipDebug && pError->pMesg != NULL)                logMsg ("ipError:Msg from device %s Unit: %d Msg: %s\n",                        (int)pEnd->devObject.name, pEnd->devObject.unit,                        (int)pError->pMesg, 0, 0, 0);#endif /* IP_DEBUG */            newFlags = (USHORT) ( (UINT32)pError->pSpare);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡的av电影在线观看| 国产91精品精华液一区二区三区 | 欧美三级电影网| 免费看欧美女人艹b| 国产精品久久久久久亚洲毛片| 欧美日韩一区三区| 国产又粗又猛又爽又黄91精品| 亚洲一二三区在线观看| 国产人妖乱国产精品人妖| 在线成人小视频| 99久久久久免费精品国产| 国产麻豆视频精品| 免费在线成人网| 亚洲444eee在线观看| 国产精品电影一区二区三区| 久久影院电视剧免费观看| 欧美日韩高清一区二区不卡| 成人一区二区三区| 精品中文av资源站在线观看| 亚洲成av人片在线| 亚洲日本欧美天堂| 中文字幕中文字幕一区二区| 久久亚洲一区二区三区四区| 欧美精品 日韩| 91麻豆蜜桃一区二区三区| 成人美女视频在线观看18| 国产麻豆精品theporn| 麻豆成人综合网| 日韩福利视频导航| 天堂蜜桃91精品| 午夜久久久久久久久久一区二区| 夜夜嗨av一区二区三区网页| 亚洲乱码中文字幕综合| 亚洲男女毛片无遮挡| 国产精品对白交换视频| 亚洲国产精品天堂| 亚洲一区视频在线| 亚洲国产你懂的| 亚洲mv在线观看| 亚洲国产一区二区a毛片| 一区二区三区在线免费观看| 亚洲欧美国产三级| 成人免费视频在线观看| 亚洲女性喷水在线观看一区| 亚洲日本在线看| 亚洲激情av在线| 亚洲自拍与偷拍| 亚洲主播在线观看| 亚洲v精品v日韩v欧美v专区| 日韩电影网1区2区| 久久激五月天综合精品| 韩国女主播一区二区三区| 毛片不卡一区二区| 国产精品一二二区| 不卡av电影在线播放| 91片在线免费观看| 欧美午夜在线观看| 欧美精品三级在线观看| 日韩欧美激情四射| 久久久电影一区二区三区| 国产精品久久久久久久久久久免费看| 中文字幕永久在线不卡| 亚洲裸体在线观看| 亚洲高清免费视频| 另类专区欧美蜜桃臀第一页| 成人影视亚洲图片在线| 色综合视频一区二区三区高清| 欧美色图第一页| 精品少妇一区二区三区视频免付费 | 亚洲免费伊人电影| 亚洲国产精品久久久男人的天堂| 日韩电影网1区2区| 国产99一区视频免费| 欧美影院午夜播放| 精品精品国产高清一毛片一天堂| 国产精品人妖ts系列视频| 一区二区三国产精华液| 极品尤物av久久免费看| 色婷婷久久一区二区三区麻豆| 日韩欧美资源站| 最新中文字幕一区二区三区 | 亚洲国产经典视频| 一区二区三区精品视频| 免费看欧美美女黄的网站| 成人91在线观看| 91精品久久久久久久91蜜桃| 中文字幕第一区第二区| 日本女人一区二区三区| 色综合色狠狠综合色| 精品国产一区二区三区久久久蜜月 | 一区二区三区精品| 国产一区亚洲一区| 在线观看日韩精品| 久久午夜免费电影| 香蕉影视欧美成人| 成人黄色在线视频| 日韩欧美高清在线| 亚洲国产精品一区二区尤物区| 国产乱人伦偷精品视频免下载| 欧美日韩国产精选| 亚洲日本成人在线观看| 国产精品99久久久久久有的能看| 欧美日韩日本视频| 一区在线播放视频| 国产成人一区在线| 日韩精品一区国产麻豆| 亚洲国产日产av| 色婷婷亚洲综合| 国产精品夫妻自拍| 福利91精品一区二区三区| 日韩三级视频中文字幕| 亚洲va天堂va国产va久| 日本电影欧美片| 国产精品伦理一区二区| 国产精品原创巨作av| 久久综合久久综合久久综合| 日韩av中文在线观看| 欧美日韩国产片| 亚洲国产成人av网| 欧美性xxxxxx少妇| 亚洲国产综合91精品麻豆| 色88888久久久久久影院野外| 国产精品久久久久久户外露出 | 久久影院视频免费| 极品少妇xxxx偷拍精品少妇| 欧美一区二区日韩| 视频在线观看一区| 欧美三级中文字| 亚洲一区在线观看免费观看电影高清| av电影在线不卡| 国产精品久99| av在线不卡网| 亚洲激情图片一区| 欧美性猛片aaaaaaa做受| 亚洲综合一二区| 色哟哟一区二区在线观看| 国产精品传媒在线| 99久免费精品视频在线观看| 成人欧美一区二区三区黑人麻豆| 亚洲女人小视频在线观看| 欧美一二三区在线| 欧美日本国产视频| 国产裸体歌舞团一区二区| 国产精品久久久久久久久搜平片| 国产精品白丝jk白祙喷水网站| 26uuu欧美| 国产电影一区在线| 蜜臀精品久久久久久蜜臀| 亚洲精品中文字幕在线观看| 9191精品国产综合久久久久久| 亚洲欧美成aⅴ人在线观看| 91丨porny丨蝌蚪视频| 亚洲乱码国产乱码精品精可以看 | 国产不卡在线一区| 欧美极品xxx| 不卡av电影在线播放| 亚洲一区免费观看| 欧美一卡二卡在线| 国产乱码精品一区二区三区av| 中文在线免费一区三区高中清不卡| 99久久国产免费看| 婷婷亚洲久悠悠色悠在线播放| 日韩欧美不卡在线观看视频| 丰满岳乱妇一区二区三区| 亚洲欧美aⅴ...| 日韩欧美国产成人一区二区| 国产成人综合在线| 一区二区激情视频| 91麻豆精品国产自产在线| 国产一区二区h| 一区二区三区**美女毛片| 欧美一区二区三区日韩| 成人精品高清在线| 日韩精品一区第一页| 久久久.com| 色狠狠av一区二区三区| 久久超级碰视频| 一区在线观看视频| 日韩美女在线视频| 色哟哟欧美精品| 免费欧美在线视频| 亚洲少妇30p| 日韩精品一区国产麻豆| 99久久精品免费| 激情丁香综合五月| 亚洲综合一二区| 国产日韩欧美精品在线| 欧美区一区二区三区| 高清久久久久久| 日韩中文字幕91| 亚洲婷婷在线视频| 欧美成人aa大片| 在线影视一区二区三区| 国产一区在线精品| 午夜激情一区二区| 国产精品高清亚洲| 久久精品在线观看| 91精品欧美一区二区三区综合在 | 五月综合激情网| 亚洲欧洲性图库|