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

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

?? wdbbdmpktdrv.c

?? vxworks的完整的源代碼
?? C
字號:
/* wdbBdmPktDrv.c - Bdm packet driver for lightweight UDP/IP *//* Copyright 1998-2001 Wind River Systems, Inc. *//*This is an unsupported release of the Background Debug Mode (BDM) BackEnd. It is provided AS IS with no warranties of any kind.*/#include "copyright_wrs.h"/*modification history--------------------01b,15sep01,dat  Use of WRS_ASM macro01a,16jun98,vrd  written, inspired from wdbNetromPktDrv.c version 01h.*//*DESCRIPTIONOVERVIEWThis is a driver for WDB system which uses the BDM line and protocol tocommunicate with the HOST.USAGEThe driver is typically only called only from usrWdb.c. The only directlycallable routine in this module is wdbBdmPktDevInit().  Your configAll.hfile will have to be modified so that WDB_COMM_TYPE is defined asWDB_COMM_BDM.DATA BUFFERINGThe drivers only need to handle one input packet at a time becausethe WDB protocol only supports one outstanding host-request at a time.If multiple input packets arrive, the driver can simply drop them.The driver then loans the input buffer to the WDB agent, and the agentinvokes a driver callback when it is done with the buffer.For output, the agent will pass the driver a chain of mbufs, whichthe driver must send as a packet. When it is done with the mbufs,it calls wdbMbufChainFree() to free them.The header file wdbMbuflib.h provides the calls for allocating, freeing,and initializing mbufs for use with the lightweight UDP/IP interpreter.It ultimatly makes calls to the routines wdbMbufAlloc() and wdbMbufFree(),which are provided in source code in usrWdb.c.*//* includes */#include "vxWorks.h"#include "string.h"#include "errno.h"#include "intLib.h"#include "wdb/wdbLib.h"#include "wdb/wdbCommIfLib.h"#include "wdb/wdbMbufLib.h"#include "drv/wdb/wdbBdmPktDrv.h"/* defines */#define MIN min/* typedefs */typedef struct    {    UINT8	recvSem;    UINT8	padding;    UINT16	recvCount;    UINT8	recvBuffer [WDB_BDM_PKT_MTU];    UINT8	sendSem;    UINT8	padding2;    UINT16	sendCount;    UINT8	sendBuffer [WDB_BDM_PKT_MTU];    } BDM_COMM_BUFF;/* locals */LOCAL BDM_COMM_BUFF	bdmCommBuff;LOCAL BDM_COMM_BUFF *	pBdmCommBuff = &bdmCommBuff;LOCAL int		pollDelay = 2;	/* polling delay *//* forward declarations */LOCAL STATUS	wdbBdmPoll		(void *pDev);LOCAL STATUS	wdbBdmTx		(void *pDev, struct mbuf * pMbuf);LOCAL STATUS	wdbBdmModeSet		(void *pDev, uint_t newMode);LOCAL void	wdbBdmFree		(void *pDev);LOCAL void	wdbBdmPollTask		(void * pDev);LOCAL void	wdbBdmTargetStop	(void);LOCAL STATUS	wdbBdmInitHardware	(void);/******************************************************************************** wdbBdmTargetStop - stop the CPU** This routine contains CPU specific code to put the CPU in BDM mode.** RETURNS: N/A** NOMANUAL*/LOCAL void wdbBdmTargetStop (void)    {#if 	(CPU == CPU32)    WRS_ASM ("nop");    WRS_ASM (".word	0x4afa");#endif	/* (CPU == CPU32) */#if 	(CPU == PPC860)    WRS_ASM ("sc");			/* sc instruction */#if	FALSE    WRS_ASM ("tw	31,0,0");	/* trap instruction */#endif	/* FALSE */#endif	/* (CPU == PPC860) */    }/******************************************************************************** wdbBdmInitHardware - initialize the BDM communiction buffer** This routine computes the input and the output buffer address.** RETURNS: N/A** NOMANUAL*/LOCAL STATUS wdbBdmInitHardware (void)    {    /* reset memory */        bdmCommBuff.recvSem = 0;    bdmCommBuff.recvCount = 0;    bdmCommBuff.sendSem = 0;    bdmCommBuff.sendCount = 0;    /*     * Here you must put the IOBuff address in the first register (the first     * one for the Macraigor's ReadRegister routine and then put the CPU in     * background. The backend will restart the CPU.     */#if 	(CPU == CPU32)    WRS_ASM ("move.l	_pBdmCommBuff,D3");    WRS_ASM ("nop");    WRS_ASM (".word	0x4afa");#elif 	(CPU == PPC860)    WRS_ASM ("addi	3, 0, bdmCommBuff@ha");	/* move IOBuff@ha to R3 */    WRS_ASM ("rlwinm	3, 3, 16, 0, 15");	/* move IOBuff@ha to R3@ha */    WRS_ASM ("addi	3, 3, bdmCommBuff@l");	/* move IOBuff@l to R3 */    WRS_ASM ("sc");			/* sc instruction */#if 	FALSE    WRS_ASM ("tw	31, 0, 0");	/* trap instruction */#endif	/* FALSE */#endif 	/* CPU == CPU32 */    return(OK);    }/******************************************************************************** wdbBdmPktDevInit - initialize a bdm packet device.** RETRUNS: N/A** NOMANUAL*/STATUS wdbBdmPktDevInit    (    WDB_BDM_PKT_DEV	*pPktDev,	/* bdm device structure to init */    void		(*stackRcv)()	/* receive packet callback (udpRcv) */    )    {    /* initialize the wdbDrvIf field with driver info */    pPktDev->wdbDrvIf.mode	= WDB_COMM_MODE_POLL | WDB_COMM_MODE_INT;    pPktDev->wdbDrvIf.mtu	= WDB_BDM_PKT_MTU;    pPktDev->wdbDrvIf.stackRcv	= stackRcv;		/* udpRcv */    pPktDev->wdbDrvIf.devId	= (WDB_BDM_PKT_DEV *)pPktDev;    pPktDev->wdbDrvIf.pollRtn	= wdbBdmPoll;    pPktDev->wdbDrvIf.pktTxRtn	= wdbBdmTx;    pPktDev->wdbDrvIf.modeSetRtn = wdbBdmModeSet;    /*     * Put your hardware initialization code here. It should initialize     * the device structure's register addresses and initialize     * the hardware.     */    if (wdbBdmInitHardware() != OK)	return(ERROR);    /* put the device in a quiescent state */    wdbBdmModeSet (pPktDev, WDB_COMM_MODE_INT);    /* start the polling task if the OS is initialized */    if(taskIdCurrent)	{	taskSpawn ("tBdmPoll", 200, 0, 5000, (int (*)()) wdbBdmPollTask,		   (int) pPktDev, 0, 0, 0, 0, 0, 0, 0, 0, 0);	}    return(OK);    }/******************************************************************************** wdbBdmTx - transmit a packet.** The packet is realy a chain of mbufs. We may have to just queue up* this packet is we are already transmitting.** RETURNS: OK or ERROR** NOMANUAL*/LOCAL STATUS wdbBdmTx    (    void *		pDev,    struct mbuf *	pMbuf    )    {    UINT32		packetSize = 0;    /* copy transmit data to buffer */    wdbMbufDataGet (pMbuf, bdmCommBuff.sendBuffer,                    WDB_BDM_PKT_MTU, &packetSize);    /* send packet */    bdmCommBuff.sendCount = (UINT16) htons (packetSize);    bdmCommBuff.sendSem = 0xFF;    wdbBdmTargetStop ();    /* free mbuf chain */    wdbMbufChainFree (pMbuf);    return (OK);    }/******************************************************************************** wdbBdmFree - free the input buffer** This is the callback used to let us know the agent is done with the* input buffer we loaded it.** RETURNS: N/A** NOMANUAL*/LOCAL void wdbBdmFree    (    void *	pDev		/* unused */    )    {    bdmCommBuff.recvCount = 0;    bdmCommBuff.recvSem = 0;    }/******************************************************************************** wdbBdmModeSet - switch driver modes** RETURNS: OK for a supported mode, else ERROR** NOMANUAL*/LOCAL STATUS wdbBdmModeSet    (    void *	pDev,    uint_t	newMode    )    {    WDB_BDM_PKT_DEV * pPktDev = pDev;    if (newMode == WDB_COMM_MODE_INT)	pPktDev->mode = WDB_COMM_MODE_INT;    else if (newMode == WDB_COMM_MODE_POLL)	pPktDev->mode = WDB_COMM_MODE_POLL;    else	return (ERROR);    return (OK);    }/******************************************************************************** wdbBdmPoll - poll for a packet** This routine polls for a packet. If a packet has arrived it invokes* the agents callback.** RETURNS: OK if a packet has arrived, else ERROR.** NOMANUAL*/ LOCAL STATUS wdbBdmPoll    (    void *	pDev    )    {    WDB_BDM_PKT_DEV *	pPktDev = pDev;    struct mbuf *	pMbuf;    UINT16		packetSize = 0;    if (bdmCommBuff.recvSem)	{	/*	 * Fill the input buffer with the packet. Use an mbuf cluster to pass	 * the packet on to the agent.	 */		packetSize = ntohs (bdmCommBuff.recvCount);	pMbuf = wdbMbufAlloc();	if ((pMbuf == NULL) || (packetSize == 0))	    {	    bdmCommBuff.recvSem = 0;	    return (ERROR);	    }	wdbMbufClusterInit (pMbuf, bdmCommBuff.recvBuffer, (UINT32) packetSize,			    (int (*) ())wdbBdmFree, (int) pPktDev);	(*pPktDev->wdbDrvIf.stackRcv) (pMbuf);  /* invoke callback */	return (OK);	}    return (ERROR);    }/******************************************************************************** wdbBdmPollTask - poll for a packet** This routine polls for a packet. If a packet has arrived it invokes* the agents callback.** RETURNS: OK if a packet has arrived, else ERROR.** NOMANUAL*/ LOCAL void wdbBdmPollTask    (    void *	pDev    )    {    for (;;)	{	taskDelay (pollDelay);	wdbBdmPoll (pDev);	}    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品一二三区| 日韩欧美综合在线| 精品国产一区二区三区四区四 | 欧美一级理论性理论a| 中文字幕欧美激情| 蜜臀久久久99精品久久久久久| av网站免费线看精品| 日韩精品专区在线| 亚洲香肠在线观看| 91麻豆高清视频| 欧美国产欧美亚州国产日韩mv天天看完整| 亚洲第一电影网| 色婷婷久久久亚洲一区二区三区| 国产网站一区二区| 六月丁香婷婷久久| 欧美老肥妇做.爰bbww| 亚洲综合在线免费观看| 国产98色在线|日韩| 久久综合色天天久久综合图片| 亚洲最大的成人av| 91在线免费播放| 国产精品每日更新在线播放网址| 激情欧美一区二区| 欧美va亚洲va在线观看蝴蝶网| 视频一区欧美精品| 欧美一区二区三区四区久久| 亚洲va韩国va欧美va| 一本色道a无线码一区v| 亚洲免费伊人电影| 欧美在线观看一区二区| 亚洲乱码中文字幕综合| 91亚洲精华国产精华精华液| 国产精品动漫网站| 99国产精品一区| 一区二区三区免费看视频| 99久久久精品| 尤物av一区二区| 欧美日韩精品一区二区三区蜜桃| 亚洲一区二区欧美日韩 | 51午夜精品国产| 视频一区在线播放| 欧美电影免费观看完整版| 久久国产生活片100| 久久久久久97三级| 成人av在线资源网站| 亚洲欧洲日韩av| 欧美午夜精品理论片a级按摩| 亚洲午夜羞羞片| 91精品国产欧美日韩| 国产在线一区观看| 国产精品无人区| 在线视频欧美区| 日韩精品一卡二卡三卡四卡无卡| 欧美va在线播放| 成人激情动漫在线观看| 亚洲欧美成aⅴ人在线观看| 欧美日韩dvd在线观看| 美女网站在线免费欧美精品| 欧美mv和日韩mv的网站| 国产91综合网| 亚洲国产精品久久一线不卡| 欧美一级片在线看| eeuss鲁片一区二区三区在线观看| 伊人开心综合网| 精品国产乱码久久久久久蜜臀| 成人黄色777网| 亚洲午夜在线电影| 久久精品一区二区三区四区| 色视频一区二区| 国产在线观看一区二区| 亚洲欧洲一区二区在线播放| 欧美日韩午夜影院| 国产精品系列在线播放| 夜夜嗨av一区二区三区四季av| 欧美一级电影网站| 色偷偷88欧美精品久久久| 裸体歌舞表演一区二区| 亚洲一区二区三区四区五区黄 | 色婷婷久久99综合精品jk白丝| 青椒成人免费视频| 国产精品国产三级国产aⅴ入口| 欧美伦理电影网| 成人一区二区三区在线观看 | 67194成人在线观看| 粉嫩av一区二区三区粉嫩| 午夜精品免费在线| 亚洲同性gay激情无套| 久久精品一区二区三区不卡牛牛 | 久久久久久久性| 欧美日韩免费一区二区三区 | 国产乱码精品一区二区三区av| 亚洲国产精品精华液网站| 日本一区二区电影| 久久九九久精品国产免费直播| 884aa四虎影成人精品一区| 色婷婷精品大视频在线蜜桃视频| 国产一区二区免费看| 日本欧美韩国一区三区| 亚洲成人午夜电影| 最好看的中文字幕久久| 国产嫩草影院久久久久| 久久亚洲综合av| 久久久一区二区三区| 欧美电影免费观看高清完整版在线 | 夜夜亚洲天天久久| 国产午夜精品一区二区三区嫩草 | 欧美久久高跟鞋激| 色就色 综合激情| 99re66热这里只有精品3直播| 国产成人午夜视频| 国产成人综合网| 丁香五精品蜜臀久久久久99网站 | 欧美熟乱第一页| 欧美在线free| 欧美视频一区二区三区| 在线观看不卡视频| 欧美日韩精品福利| 91精品国产高清一区二区三区 | 欧美日本免费一区二区三区| 在线视频国内自拍亚洲视频| 99vv1com这只有精品| 91在线无精精品入口| 91免费国产在线| 欧美日韩一二区| 在线91免费看| 久久综合九色综合97婷婷女人| 久久久99精品久久| 综合自拍亚洲综合图不卡区| 亚洲综合视频在线观看| 三级精品在线观看| 久久99精品久久久久久久久久久久| 理论片日本一区| 国产精品一二三四五| 94-欧美-setu| 欧美日本一区二区三区| 久久久久青草大香线综合精品| 国产婷婷色一区二区三区四区| 国产女同互慰高潮91漫画| 亚洲欧美另类久久久精品2019| 亚洲一区视频在线| 精品写真视频在线观看| 91亚洲精品久久久蜜桃网站 | 天堂一区二区在线| 久久99国产精品尤物| 99综合电影在线视频| 欧美日韩视频第一区| 久久亚洲一级片| 怡红院av一区二区三区| 麻豆国产91在线播放| 成人做爰69片免费看网站| 欧美乱妇一区二区三区不卡视频| 精品99久久久久久| 伊人开心综合网| 国产精品99久| 欧美高清视频一二三区| 国产欧美一区二区在线| 日韩精品免费视频人成| 懂色av一区二区三区蜜臀| 欧美午夜精品久久久久久孕妇| 国产欧美精品日韩区二区麻豆天美| 亚洲一区免费在线观看| 国产寡妇亲子伦一区二区| 欧美少妇一区二区| 国产精品久久久久天堂| 久久国产三级精品| 欧美熟乱第一页| 亚洲欧美日韩人成在线播放| 九一九一国产精品| 欧美三级在线看| 自拍偷拍亚洲欧美日韩| 国产美女主播视频一区| 欧美日本乱大交xxxxx| 亚洲欧美综合色| 国产精品亚洲一区二区三区妖精 | 亚洲天堂2016| 国产在线国偷精品免费看| 欧美猛男超大videosgay| 亚洲国产精品v| 国产一区 二区| 欧美一级专区免费大片| 亚洲影视在线观看| 色一情一乱一乱一91av| 中文字幕第一页久久| 国产一区二区久久| 精品国产一区二区三区久久久蜜月 | 午夜婷婷国产麻豆精品| 91麻豆文化传媒在线观看| 国产丝袜在线精品| 国产精品一线二线三线| 精品精品国产高清a毛片牛牛| 午夜欧美在线一二页| 精品久久99ma| 日韩av一二三| 欧美精品一卡二卡| 天天色综合成人网| 欧美精品在线观看一区二区| 亚洲大型综合色站| 91精品国产综合久久福利软件| 亚洲成a人在线观看| 欧美日韩精品一区视频|