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

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

?? usbkeyboardlib.c

?? This the compressed USB driver source code for vxworks5.6. It has device controller driver and other
?? C
?? 第 1 頁 / 共 5 頁
字號:
    switch (attachAction)	{	case USBD_DYNA_ATTACH:	    /* A new device is being attached.  Check if we already 	     * have a structure for this device.	     */	    if (findSioChan (nodeId) != NULL)		break;	    /* Create a new structure to manage this device.  If there's	     * an error, there's nothing we can do about it, so skip the	     * device and return immediately. 	     */	    if ((pSioChan = createSioChan (nodeId, configuration, interface)) == NULL)		break;	    /* Notify registered callers that a new keyboard has been	     * added and a new channel created.	     */	    notifyAttach (pSioChan, USB_KBD_ATTACH);	    break;	case USBD_DYNA_REMOVE:	    /* A device is being detached.	Check if we have any	     * structures to manage this device.	     */	    if ((pSioChan = findSioChan (nodeId)) == NULL)		break;	    /* The device has been disconnected. */	    pSioChan->connected = FALSE;	    /* Notify registered callers that the keyboard has been	     * removed and the channel disabled. 	     *	     * NOTE: We temporarily increment the channel's lock count	     * to prevent usbKeyboardSioChanUnlock() from destroying the	     * structure while we're still using it.	     */	    pSioChan->lockCount++;	    notifyAttach (pSioChan, USB_KBD_REMOVE);	    pSioChan->lockCount--;	    /* If no callers have the channel structure locked, destroy	     * it now.  If it is locked, it will be destroyed later during	     * a call to usbKeyboardUnlock().	     */	    if (pSioChan->lockCount == 0)		destroySioChan (pSioChan);	    break;	}    OSS_MUTEX_RELEASE (kbdMutex);    }/***************************************************************************** doShutdown - shuts down USB keyboard SIO driver** <errCode> should be OK or S_usbKeyboardLib_xxxx.  This value will be* passed to ossStatus() and the return value from ossStatus() is the* return value of this function.** RETURNS: OK, or ERROR per value of <errCode> passed by caller** ERRNO: appropiate error code**\NOMANUAL*/LOCAL STATUS doShutdown    (    int errCode    )    {    pATTACH_REQUEST pRequest;    pUSB_KBD_SIO_CHAN pSioChan;    /* Kill typematic thread */    if (typematicThread != NULL)	{	killTypematic = TRUE;	while (!typematicExit)	    OSS_THREAD_SLEEP (1);	OSS_THREAD_DESTROY (typematicHandle);	}    /* Dispose of any outstanding notification requests */    while ((pRequest = usbListFirst (&reqList)) != NULL)	destroyAttachRequest (pRequest);    /* Dispose of any open keyboard connections. */    while ((pSioChan = usbListFirst (&sioList)) != NULL)	destroySioChan (pSioChan);        /* Release our connection to the USBD.  The USBD automatically      * releases any outstanding dynamic attach requests when a client     * unregisters.     */    if (usbdHandle != NULL)	{	usbdClientUnregister (usbdHandle);	usbdHandle = NULL;	}    /* Release resources. */    if (kbdMutex != NULL)	{	OSS_MUTEX_DESTROY (kbdMutex);	kbdMutex = NULL;	}    return ossStatus (errCode);    }/***************************************************************************** usbKeyboardDevInit - initialize USB keyboard SIO driver** Initializes the USB keyboard SIO driver. The USB keyboard SIO driver* maintains an initialization count, so calls to this function may be* nested.** RETURNS: OK, or ERROR if unable to initialize.** ERRNO:* \is* \i S_usbKeyboardLib_OUT_OF_RESOURCES* Sufficient resources are not available to create mutex** \i S_usbKeyboardLib_USBD_FAULT* Fault in the USBD Layer* \ie*/STATUS usbKeyboardDevInit (void)    {    /* If not already initialized, then initialize internal structures     * and connection to USBD.     */    if (initCount == 0)	{	/* Initialize lists, structures, resources. */	memset (&sioList, 0, sizeof (sioList));	memset (&reqList, 0, sizeof (reqList));	kbdMutex = NULL;	usbdHandle = NULL;	typematicHandle = NULL;	killTypematic = FALSE;	typematicExit = FALSE;	if (OSS_MUTEX_CREATE (&kbdMutex) != OK)	    return doShutdown (S_usbKeyboardLib_OUT_OF_RESOURCES);	/* Initialize typematic repeat thread */	if (OSS_THREAD_CREATE (typematicThread, 			       NULL, 			       OSS_PRIORITY_LOW,			       TYPEMATIC_NAME, 			       &typematicHandle) 			     != OK)	    return doShutdown (S_usbKeyboardLib_OUT_OF_RESOURCES);		/* Establish connection to USBD */	if (usbdClientRegister (KBD_CLIENT_NAME, &usbdHandle) != OK ||	    usbdDynamicAttachRegister (usbdHandle, 				       USB_CLASS_HID,				       USB_SUBCLASS_HID_BOOT, 				       USB_PROTOCOL_HID_BOOT_KEYBOARD,				       usbKeyboardAttachCallback) 				     != OK)		{		return doShutdown (S_usbKeyboardLib_USBD_FAULT);		}	}    initCount++;    return OK;    }/***************************************************************************** usbKeyboardDevShutdown - shuts down keyboard SIO driver** This function shuts down the keyboard driver. The driver is shutdown only * if <initCount> after decrementing. If it is more the 0, it is decremented.** RETURNS: OK, or ERROR if unable to shutdown.** ERRNO:* \is* \i S_usbKeyboardLib_NOT_INITIALIZED* Keyboard Driver not initialized* \ie*/STATUS usbKeyboardDevShutdown (void)    {    /* Shut down the USB keyboard SIO driver if the initCount goes to 0. */    if (initCount == 0)	return ossStatus (S_usbKeyboardLib_NOT_INITIALIZED);    if (--initCount == 0)	return doShutdown (OK);    return OK;    }/***************************************************************************** usbKeyboardDynamicAttachRegister - Register keyboard attach callback** <callback> is a caller-supplied function of the form:** \cs* typedef (*USB_KBD_ATTACH_CALLBACK)*     (*     pVOID arg,*     SIO_CHAN *pSioChan,*     UINT16 attachCode*     );* \ce** usbKeyboardLib will invoke <callback> each time a USB keyboard* is attached to or removed from the system.  <arg> is a caller-defined* parameter which will be passed to the <callback> each time it is* invoked.  The <callback> will also be passed a pointer to the * SIO_CHAN structure for the channel being created/destroyed and* an attach code of USB_KBD_ATTACH or USB_KBD_REMOVE.** RETURNS: OK, or ERROR if unable to register callback** ERRNO:* \is* \i S_usbKeyboardLib_BAD_PARAM* Bad Parameter are passed** \i S_usbKeyboardLib_OUT_OF_MEMORY* Not sufficient memory is available* \ie*/STATUS usbKeyboardDynamicAttachRegister    (    USB_KBD_ATTACH_CALLBACK callback,	/* new callback to be registered */    pVOID arg		    /* user-defined arg to callback */    )    {    pATTACH_REQUEST pRequest;    pUSB_KBD_SIO_CHAN pSioChan;    int status = OK;    /* Validate parameters */    if (callback == NULL)	return ossStatus (S_usbKeyboardLib_BAD_PARAM);    OSS_MUTEX_TAKE (kbdMutex, OSS_BLOCK);    /* Create a new request structure to track this callback request. */    if ((pRequest = OSS_CALLOC (sizeof (*pRequest))) == NULL)	status = S_usbKeyboardLib_OUT_OF_MEMORY;    else	{	pRequest->callback = callback;	pRequest->callbackArg = arg;	usbListLinkProt (&reqList, pRequest, &pRequest->reqLink, LINK_TAIL,kbdMutex);		/* Perform an initial notification of all currrently attached	 * keyboard devices.	 */	pSioChan = usbListFirst (&sioList);	while (pSioChan != NULL)	    {	    if (pSioChan->connected)		(*callback) (arg, (SIO_CHAN *) pSioChan, USB_KBD_ATTACH);	    pSioChan = usbListNext (&pSioChan->sioLink);	    }	}    OSS_MUTEX_RELEASE (kbdMutex);    return ossStatus (status);    }/***************************************************************************** usbKeyboardDynamicAttachUnregister - Unregisters keyboard attach callback** This function cancels a previous request to be dynamically notified for* keyboard attachment and removal.  The <callback> and <arg> paramters must* exactly match those passed in a previous call to * usbKeyboardDynamicAttachRegister().** RETURNS: OK, or ERROR if unable to unregister callback** ERRNO:* \is* \i S_usbKeyboardLib_NOT_REGISTERED* Could not register the callback* \ie*/STATUS usbKeyboardDynamicAttachUnRegister    (    USB_KBD_ATTACH_CALLBACK callback,	/* callback to be unregistered */    pVOID arg		    /* user-defined arg to callback */    )    {    pATTACH_REQUEST pRequest;    pUSB_KBD_SIO_CHAN pSioChan = NULL;    int status = S_usbKeyboardLib_NOT_REGISTERED;    OSS_MUTEX_TAKE (kbdMutex, OSS_BLOCK);    pRequest = usbListFirst (&reqList);    while (pRequest != NULL)	{	if (callback == pRequest->callback && arg == pRequest->callbackArg)	    {    	/* Perform a notification of all currrently attached	     * keyboard devices.	     */	    pSioChan = usbListFirst (&sioList);    	while (pSioChan != NULL)	        {	        if (pSioChan->connected)		       (*callback) (arg, (SIO_CHAN *) pSioChan, USB_KBD_REMOVE);  	        pSioChan = usbListNext (&pSioChan->sioLink);	        }	    /* We found a matching notification request. */	    destroyAttachRequest (pRequest);	    status = OK;	    break;	    }	pRequest = usbListNext (&pRequest->reqLink);	}    OSS_MUTEX_RELEASE (kbdMutex);    return ossStatus (status);    }/***************************************************************************** usbKeyboardSioChanLock - Marks SIO_CHAN structure as in use** A caller uses usbKeyboardSioChanLock() to notify usbKeyboardLib that* it is using the indicated SIO_CHAN structure.  usbKeyboardLib maintains* a count of callers using a particular SIO_CHAN structure so that it * knows when it is safe to dispose of a structure when the underlying* USB keyboard is removed from the system.  So long as the "lock count"* is greater than zero, usbKeyboardLib will not dispose of an SIO_CHAN* structure.** RETURNS: OK** ERRNO: none.*/STATUS usbKeyboardSioChanLock    (    SIO_CHAN *pChan	/* SIO_CHAN to be marked as in use */    )    {    pUSB_KBD_SIO_CHAN pSioChan = (pUSB_KBD_SIO_CHAN) pChan;    pSioChan->lockCount++;    return OK;    }/***************************************************************************** usbKeyboardSioChanUnlock - Marks SIO_CHAN structure as unused** This function releases a lock placed on an SIO_CHAN structure.  When a* caller no longer needs an SIO_CHAN structure for which it has previously* called usbKeyboardSioChanLock(), then it should call this function to* release the lock.** NOTE: If the underlying USB keyboard device has already been removed* from the system, then this function will automatically dispose of the* SIO_CHAN structure if this call removes the last lock on the structure.* Therefore, a caller must not reference the SIO_CHAN again structure after* making this call.** RETURNS: OK, or ERROR if unable to mark SIO_CHAN structure unused** ERRNO:* \is* \i S_usbKeyboardLib_NOT_LOCKED* No lock to unlock* \ie*/STATUS usbKeyboardSioChanUnlock    (    SIO_CHAN *pChan	/* SIO_CHAN to be marked as unused */    )    {    pUSB_KBD_SIO_CHAN pSioChan = (pUSB_KBD_SIO_CHAN) pChan;    int status = OK;    OSS_MUTEX_TAKE (kbdMutex, OSS_BLOCK);    if (pSioChan->lockCount == 0)	status = S_usbKeyboardLib_NOT_LOCKED;    else	{	/* If this is the last lock and the underlying USB keyboard is	 * no longer connected, then dispose of the keyboard.	 */	if (--pSioChan->lockCount == 0 && !pSioChan->connected)	    destroySioChan (pSioChan);	}    OSS_MUTEX_RELEASE (kbdMutex);    return ossStatus (status);    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天天av天天翘天天综合网| 国产一区二区三区免费在线观看| 亚洲国产精品久久久久婷婷884| 亚洲黄色小视频| 亚洲不卡在线观看| 精品亚洲成av人在线观看| 99在线精品免费| 欧美久久久久中文字幕| 国产日产欧美一区| 亚洲一区二区三区四区在线观看| 一区二区成人在线视频| 韩日欧美一区二区三区| 色婷婷综合久色| 欧美tk—视频vk| 亚洲国产成人av| 成人av网址在线观看| 91影视在线播放| 欧美r级在线观看| 亚洲妇女屁股眼交7| 懂色av一区二区三区蜜臀| 欧美日韩免费在线视频| 国产精品传媒入口麻豆| 久久成人免费电影| 国产精华液一区二区三区| 91精品在线观看入口| 综合在线观看色| 国产精品国产自产拍高清av| 国产一区二区福利| 欧美日韩一卡二卡三卡| 中文字幕一区免费在线观看| 国产制服丝袜一区| 欧美性感一区二区三区| 国产精品福利一区二区| 久久精品国产99国产| 欧美日韩国产高清一区二区| 亚洲美女在线国产| 成人激情综合网站| 久久久777精品电影网影网 | 99精品视频一区二区三区| 日韩一二三区不卡| 天堂午夜影视日韩欧美一区二区| 91久久人澡人人添人人爽欧美| 国产精品美女久久久久高潮| 亚洲国产视频网站| 色综合久久综合网97色综合| 中文字幕日韩av资源站| 成人av网站大全| 国产精品久久久久久久久图文区| 国产成人自拍网| 国产日韩精品久久久| 不卡视频一二三四| 综合电影一区二区三区 | 激情综合网av| 欧美电影免费提供在线观看| 久久精品国产色蜜蜜麻豆| 日韩一区二区三区观看| 国产综合色在线| 欧美人与性动xxxx| 琪琪一区二区三区| 精品久久久久久无| 国产精品456| 中文字幕一区二区视频| 日本电影亚洲天堂一区| 国产精品区一区二区三| 99久久久国产精品免费蜜臀| 夜夜嗨av一区二区三区四季av| 欧洲亚洲国产日韩| 免费看欧美女人艹b| 久久综合一区二区| 国模冰冰炮一区二区| 亚洲色图制服丝袜| 欧美日韩色一区| 国精产品一区一区三区mba视频 | 精品一区二区在线免费观看| 久久丝袜美腿综合| 波多野洁衣一区| 日本伊人色综合网| 日韩女优毛片在线| 播五月开心婷婷综合| 亚洲午夜在线视频| 精品国产精品一区二区夜夜嗨| 成人aa视频在线观看| 亚洲国产一区在线观看| 欧美精品一区二| 色老汉一区二区三区| 久久99精品视频| 国产精品高潮呻吟久久| 3751色影院一区二区三区| 亚洲午夜电影在线观看| 久久久久久免费| 欧美美女bb生活片| 国内精品伊人久久久久av一坑 | 久久亚洲私人国产精品va媚药| 成人永久免费视频| 免费观看在线综合色| 国产精品日韩精品欧美在线| 欧美日本韩国一区二区三区视频| 成人午夜在线免费| 亚洲午夜电影在线观看| 国产精品每日更新| 精品欧美一区二区在线观看| 欧美日韩综合在线| 国产乱码一区二区三区| 伊人色综合久久天天| 国产亚洲一区二区三区四区 | 国产亚洲欧美色| 欧洲国内综合视频| 成人禁用看黄a在线| 久久电影网站中文字幕| 一区二区三区日韩精品视频| 久久精品视频网| 国产欧美一区在线| 国产精品久久久久久户外露出 | 久久久久国产精品厨房| 久久伊人中文字幕| 久久久久久黄色| 欧美激情一区二区三区全黄| 中文子幕无线码一区tr| 国产精品白丝在线| 亚洲同性同志一二三专区| 亚洲精品免费播放| 亚欧色一区w666天堂| 免费久久精品视频| 国产在线观看免费一区| 成人免费av资源| 99国产精品久久久久久久久久久| 91麻豆123| 欧美美女黄视频| 欧美精品一区二区三区在线播放| 久久综合99re88久久爱| 中文字幕不卡在线播放| 亚洲在线成人精品| 日韩电影免费一区| 国产一区二区美女诱惑| 91影院在线免费观看| 56国语精品自产拍在线观看| 日韩一区二区免费电影| 中文字幕乱码日本亚洲一区二区| 国产精品成人网| 日韩中文字幕一区二区三区| 韩国在线一区二区| 91免费看`日韩一区二区| 91精品午夜视频| 中文字幕国产一区二区| 午夜精品久久久久久久久久久| 日韩电影在线免费看| 波多野结衣一区二区三区| 欧美日韩一区二区不卡| 国产亚洲欧美日韩日本| 午夜在线电影亚洲一区| 国产老女人精品毛片久久| 色婷婷亚洲综合| 日韩精品一区二区三区三区免费| 国产精品久久久久久久久久免费看| 亚洲第一综合色| 成人污视频在线观看| 欧美日韩国产首页在线观看| 国产无一区二区| 婷婷亚洲久悠悠色悠在线播放| 国产99久久久国产精品潘金| 欧美女孩性生活视频| 国产精品久久777777| 久久机这里只有精品| 色天使久久综合网天天| 久久久久久久久久看片| 亚洲午夜视频在线| 国产91丝袜在线18| 日韩精品一区二区三区在线| 亚洲最新视频在线观看| 国产成人精品亚洲777人妖| 日韩一区二区三区免费看 | 综合分类小说区另类春色亚洲小说欧美| 日韩av中文字幕一区二区| av电影天堂一区二区在线观看| 91精品欧美久久久久久动漫| 亚洲与欧洲av电影| 99国产精品国产精品毛片| 久久美女艺术照精彩视频福利播放| 亚洲成人综合网站| 91麻豆国产精品久久| 中文字幕一区二区三区四区不卡| 九九精品视频在线看| 日韩亚洲电影在线| 五月婷婷久久综合| 精品视频色一区| 亚洲综合视频在线| 色菇凉天天综合网| 亚洲视频一区二区免费在线观看| 国产二区国产一区在线观看| 久久夜色精品国产欧美乱极品| 久久69国产一区二区蜜臀| 欧美久久久久久蜜桃| 日韩精品五月天| 欧美日韩精品电影| 亚洲成人av资源| 欧美老女人在线| 视频一区二区三区入口| 制服视频三区第一页精品| 性感美女久久精品| 欧美一级在线观看|