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

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

?? usbqueuelib.c

?? vxworks的完整的源代碼
?? C
字號:
/* usbQueueLib.c - O/S-independent queue functions *//* Copyright 2000 Wind River Systems, Inc. *//*Modification history--------------------01a,07jun99,rcb  First.*//*DESCRIPTIONThis file contains a generic implementation of O/S-independent queuefunctions which are built on top of the the ossLib library's mutexand semaphore functions.The caller creates a queue of depth "n" by calling usbQueueCreate() andreceives a QUEUE_HANDLE in response.  The QUEUE_HANDLE must be used inall subsequent calls to usbQueuePut(), usbQueueGet(), and usbQueueDestroy().Each entry on a queue is described by a USB_QUEUE structure which contains<msg>, <wParam>, and <lParam> fields.  The values of these fields arecompletely arbitrary and may be used in any way desired by the callingapplication.*//* includes */#include "usb/usbPlatform.h"#include "string.h"#include "usb/ossLib.h"     #include "usb/usbQueueLib.h"	/* our API *//* typedefs *//* Internal queue control structure. */typedef struct usb_queue     {    UINT16 max; 		/* Number of USB_MESSAGE entries allocated */				/* in messages array */    UINT16 in;			/* Index of the next available message slot */    UINT16 out; 		/* Index to the next message to be retrieved */    SEM_HANDLE inUse;		/* Count of messages currently in queue */    SEM_HANDLE empty;		/* Count of empty message slots in queue */    MUTEX_HANDLE mutex; 	/* The handle of the mutex we use to gain */				/* temporary control of the OSS_QUEUE struct */    USB_MESSAGE messages [1];	/* Pointer to memory allocated for msg queue */    } USB_QUEUE, *pUSB_QUEUE;/* functions *//***************************************************************************** usbQueueCreate - Creates a O/S-independent queue structure** This function creates a queue which can accomodate a number of * USB_MESSAGE entries according to the <depth> parameter.  Returns the* <pQueueHandle) of the newly created queue if successful.** RETURNS: OK or ERROR** ERRNO:*  S_usbQueueLib_BAD_PARAMETER*  S_usbQueueLib_OUT_OF_MEMORY*  S_usbQueueLib_OUT_OF_RESOURCES*/STATUS usbQueueCreate     (    UINT16 depth,		    /* Max entries queue can handle */    pQUEUE_HANDLE pQueueHandle	    /* Handle of newly created queue */    )    {    pUSB_QUEUE pQueue;    UINT16 len;    /* Validate parameters (e.g., the depth of the queue must not be 0). */    if (depth < 1 || pQueueHandle == NULL) {	return ossStatus (S_usbQueueLib_BAD_PARAMETER);    }    /* Allocate the queue control structure. */    len = sizeof (*pQueue) + sizeof (USB_MESSAGE) * (depth - 1);    if ((pQueue = OSS_CALLOC (len)) == NULL)	return ossStatus (S_usbQueueLib_OUT_OF_MEMORY);        pQueue->max = depth;    /* Allocate queue control resources. */    if (OSS_SEM_CREATE (depth, 0, &pQueue->inUse) != OK ||	OSS_SEM_CREATE (depth, depth, &pQueue->empty) != OK ||	OSS_MUTEX_CREATE (&pQueue->mutex) != OK) 	{	usbQueueDestroy ((QUEUE_HANDLE) pQueue);	return ossStatus (S_usbQueueLib_OUT_OF_RESOURCES);	}    *pQueueHandle = (QUEUE_HANDLE) pQueue;    return OK;}/***************************************************************************** usbQueueDestroy - Destroys a queue** This function destroys a queue created by calling usbQueueCreate().** RETURNS: OK or ERROR.** ERRNO:*  S_usbQueueLib_BAD_HANDLE*/STATUS usbQueueDestroy     (    QUEUE_HANDLE queueHandle	    /* Hnadle of queue to destroy */    )    {    pUSB_QUEUE pQueue = (pUSB_QUEUE) queueHandle;    /* Qualify the queue handle. */    if (pQueue == NULL)	return ossStatus (S_usbQueueLib_BAD_HANDLE);    /* Release resources and memory associated with the queue. */    if (pQueue->inUse)	OSS_SEM_DESTROY (pQueue->inUse);    if (pQueue->empty)	OSS_SEM_DESTROY (pQueue->empty);    if (pQueue->mutex)	OSS_SEM_DESTROY (pQueue->mutex);    OSS_FREE (pQueue);    return OK;}/***************************************************************************** usbQueuePut - Puts a message onto a queue** Places the specified <msg>, <wParam>, and <lParam> onto <queueHandle>.* This function will only block if the specified queue is full.  If the * queue is full, <blockFlag> specifies the blocking behavior.  OSS_BLOCK* blocks indefinitely.	OSS_DONT_BLOCK does not block and returns an error* if the queue is full.  Other values of <blockFlag> are interpreted as* a count of milliseconds to block before declaring a failure.** RETURNS: OK or ERROR** ERRNO:*  S_usbQueueLib_BAD_HANDLE*  S_usbQueueLib_Q_NOT_AVAILABLE*/STATUS usbQueuePut     (    QUEUE_HANDLE queueHandle,	    /* queue handle */    UINT16 msg, 		    /* app-specific message */    UINT16 wParam,		    /* app-specific parameter */    UINT32 lParam,		    /* app-specific parameter */    UINT32 blockFlag		    /* specifies blocking action */    )    {    pUSB_QUEUE pQueue = (pUSB_QUEUE) queueHandle;    /* Qualify the queue handle. */    if (pQueue == NULL)	return ossStatus (S_usbQueueLib_BAD_HANDLE);    /* Wait for space to become available in the queue */    if ((OSS_SEM_TAKE (pQueue->empty, blockFlag)) != OK)	{	return ossStatus (S_usbQueueLib_Q_NOT_AVAILABLE);	}    else	{	/* Take the queue mutex before attempting to update the queue. */	if ((OSS_MUTEX_TAKE (pQueue->mutex, OSS_BLOCK)) != OK)	    {	    return ossStatus (S_usbQueueLib_Q_NOT_AVAILABLE);	    }	else	    {	    /* Add an entry to the queue. */	    pQueue->messages [pQueue->in].msg = msg;	    pQueue->messages [pQueue->in].wParam = wParam;	    pQueue->messages [pQueue->in].lParam = lParam;	    if (++pQueue->in == pQueue->max)		pQueue->in = 0;	    OSS_SEM_GIVE (pQueue->inUse);	    OSS_MUTEX_RELEASE (pQueue->mutex);	    }	}    return OK;    }/***************************************************************************** usbQueueGet - Retrieves a message from a queue** Retrieves a message from the specified <queueHandle> and stores it in* <pOssMsg>.  If the queue is empty, <blockFlag> specifies the blocking* behavior.  OSS_BLOCK blocks indefinitely.  OSS_DONT_BLOCK does not block* and returns an error immediately if the queue is empty.  Other values of* <blockFlag> are interpreted as a count of milliseconds to block before* declaring a failure.** RETURNS: OK or ERROR* * ERRNO:*  S_usbQueueLib_BAD_HANDLE*  S_usbQueueLib_Q_NOT_AVAILABLE*/STATUS usbQueueGet     (    QUEUE_HANDLE queueHandle,	    /* queue handle */    pUSB_MESSAGE pMsg,		    /* USB_MESSAGE to receive msg */    UINT32 blockFlag		    /* specifies blocking action */    )    {    pUSB_QUEUE pQueue = (pUSB_QUEUE) queueHandle;    /* Qualify the queue handle and msg parameters. */    if (pQueue == NULL)	return ossStatus (S_usbQueueLib_BAD_HANDLE);    if (pMsg == NULL)	return ossStatus (S_usbQueueLib_BAD_PARAMETER);    /* Wait for a message to arrive in the queue before proceeding */    if ((OSS_SEM_TAKE (pQueue->inUse, blockFlag)) != OK) 	{	return ossStatus (S_usbQueueLib_Q_NOT_AVAILABLE);	}    else	{	/* Take the queue mutex before attempting to update the queue. */	if ((OSS_MUTEX_TAKE (pQueue->mutex, OSS_BLOCK)) != OK) 	    {	    return ossStatus (S_usbQueueLib_Q_NOT_AVAILABLE);	    }	else	    {	    /* Take an entry off the queue. */	    memcpy (pMsg, &pQueue->messages [pQueue->out], 		sizeof (USB_MESSAGE));	    if (++pQueue->out == pQueue->max)		pQueue->out = 0;	    OSS_SEM_GIVE (pQueue->empty);	    OSS_MUTEX_RELEASE (pQueue->mutex);	    }	}    return OK;    }/* End of file */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
玖玖九九国产精品| 91精品麻豆日日躁夜夜躁| 亚洲视频每日更新| 中文字幕精品一区二区精品绿巨人| 久久一区二区三区四区| 视频一区中文字幕| 久久伊人中文字幕| 欧美影片第一页| 国产成人av自拍| 日韩综合小视频| 91麻豆免费看片| 中文字幕一区三区| 国产成人精品一区二| 日韩欧美国产高清| 国产夫妻精品视频| 欧美精品自拍偷拍| 午夜影院久久久| 欧美日韩一区二区在线视频| 亚洲成人自拍网| 日韩一区二区三区高清免费看看| 日韩精品亚洲一区二区三区免费| 欧美高清视频一二三区 | 亚洲欧洲日产国产综合网| 懂色中文一区二区在线播放| 亚洲精品免费一二三区| 久久亚洲一级片| 日本久久电影网| caoporn国产精品| 国产尤物一区二区| 免费人成在线不卡| 亚洲国产一区二区在线播放| 国产精品美女久久久久久久| 欧美一区午夜精品| 欧美日韩精品一区二区三区| 国产成人一级电影| 麻豆久久久久久| 青娱乐精品视频在线| 一区二区在线观看av| 中文一区二区完整视频在线观看| 欧美一区二区三区在线电影| 欧美三级视频在线播放| 在线一区二区三区| 91传媒视频在线播放| 精品久久国产字幕高潮| 国产精品123区| 中文字幕日韩av资源站| 亚洲成人av在线电影| 国产一区二区三区四区在线观看 | 国产精品久久久99| 国产精品福利一区二区| 一区二区三区精品在线观看| 国产精品国产三级国产| 一区二区日韩电影| 亚洲成年人影院| 久久精品国产久精国产| 天天操天天综合网| 久久精品国产在热久久| 国产一区二区三区精品视频 | 国产精品综合视频| 成人免费毛片app| 91超碰这里只有精品国产| 日韩三级中文字幕| √…a在线天堂一区| 亚洲线精品一区二区三区八戒| 日韩黄色小视频| 成人性生交大合| 日韩免费观看2025年上映的电影 | 国产在线看一区| 99久久精品国产一区二区三区| 91麻豆国产在线观看| 日韩欧美中文一区二区| 中文字幕一区二区三区乱码在线| 午夜精品成人在线视频| 成人妖精视频yjsp地址| 在线播放亚洲一区| 国产精品久久福利| 狠狠色丁香婷婷综合久久片| 色噜噜夜夜夜综合网| 久久久亚洲国产美女国产盗摄 | 亚洲一二三区不卡| 狠狠色综合播放一区二区| 在线观看一区二区精品视频| 精品美女一区二区| 日韩av一二三| 91电影在线观看| 亚洲欧美福利一区二区| 成人97人人超碰人人99| 亚洲人成在线播放网站岛国| 91亚洲男人天堂| 亚洲另类在线一区| 一本色道**综合亚洲精品蜜桃冫| 亚洲激情五月婷婷| 91精品一区二区三区久久久久久 | 日韩福利电影在线| 亚洲国产精品成人综合| 亚洲一区免费观看| 欧美日韩日日摸| 午夜影院久久久| 欧美日本国产一区| 免费人成黄页网站在线一区二区| 91精品国产综合久久精品麻豆| 午夜私人影院久久久久| 91麻豆精品国产91久久久久久久久| 亚洲一区二区三区四区在线观看| 欧美性色黄大片| 日韩av不卡在线观看| 亚洲视频免费看| 91亚洲午夜精品久久久久久| 亚洲综合无码一区二区| 欧美一区二区私人影院日本| 国产精品自拍在线| 亚洲激情一二三区| 精品久久久久久久久久久院品网 | 亚洲女厕所小便bbb| 欧美日韩精品免费| 国产经典欧美精品| 亚洲电影一级片| 久久久久一区二区三区四区| 色婷婷综合久久久中文字幕| 国产资源在线一区| 一区二区成人在线观看| 久久久99精品免费观看| 在线视频观看一区| 东方欧美亚洲色图在线| 偷拍亚洲欧洲综合| 中文字幕亚洲在| 久久久不卡影院| 在线播放日韩导航| 91久久线看在观草草青青| 国产一区二区看久久| 免费在线观看日韩欧美| 亚洲一区电影777| 自拍偷拍欧美激情| 国产欧美精品国产国产专区| 制服丝袜亚洲播放| 欧美三级日本三级少妇99| aaa欧美色吧激情视频| 国产999精品久久久久久| 久久99精品久久久久婷婷| 日韩高清电影一区| 日韩国产欧美三级| 99精品在线免费| 91网站黄www| 在线观看日韩毛片| 欧美亚洲免费在线一区| 在线影视一区二区三区| 欧美中文字幕一区二区三区亚洲| 91免费在线视频观看| 91麻豆蜜桃一区二区三区| 99v久久综合狠狠综合久久| 91女厕偷拍女厕偷拍高清| 一本色道久久综合狠狠躁的推荐| 日本道免费精品一区二区三区| 91.麻豆视频| 国产喂奶挤奶一区二区三区| 日韩国产欧美在线播放| 精品在线免费观看| av一区二区三区| 欧美年轻男男videosbes| 精品欧美一区二区久久| 亚洲欧洲另类国产综合| av在线一区二区| 久久综合狠狠综合久久激情| 日韩精品一区二区三区在线观看 | 久久久久久久一区| 久久久久国产精品厨房| 国产精品国产三级国产有无不卡| 亚洲色图制服诱惑 | 久久精品视频免费观看| 亚洲精品成人天堂一二三| 欧美aaaaaa午夜精品| 大陆成人av片| 欧美高清视频在线高清观看mv色露露十八| 日韩一区二区三区视频在线观看| 精品人在线二区三区| 亚洲乱码中文字幕综合| 国产福利一区二区三区| 91在线免费播放| 国产女人18水真多18精品一级做| 日韩国产成人精品| 欧美日韩国产综合视频在线观看| 久久亚洲一区二区三区四区| 久久精品国产久精国产| 欧美一级在线视频| 亚洲va韩国va欧美va| 色婷婷久久久综合中文字幕 | 日韩视频不卡中文| 日韩精品午夜视频| 欧美日韩精品一区二区天天拍小说| 国产精品麻豆欧美日韩ww| 国产一区二区三区四区五区美女| 欧美午夜精品电影| 亚洲黄色小说网站| 一本久久综合亚洲鲁鲁五月天| 国产精品免费视频观看| 福利视频网站一区二区三区| 欧美激情中文不卡| 色噜噜狠狠色综合欧洲selulu| 一区二区三区在线看| 成人h动漫精品|