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

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

?? combi.c

?? USB接口鼠標電路以及程序設計
?? C
?? 第 1 頁 / 共 5 頁
字號:
			break;
	}
	return(byte_count1);										//returns the number of bytes loaded
}


/*
**
** FUNCTION:		SetConfiguration
**
** PURPOSE:			Implements the Set Configuration Command
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered Set Configuration request has been received from the host.
**					
*/

void SetConfiguration(void)
{
    if ( (ENDPOINT_A0_FIFO[USB_bmRequestType] == (HOST_TO_DEVICE | STANDARD | DEVICE)) &&
		 ((ENDPOINT_A0_FIFO[USB_wValue] == UNCONFIGURED) || (ENDPOINT_A0_FIFO[USB_wValue] == CONFIGURED) ))
    {
        DeviceStatus.bConfiguration = ENDPOINT_A0_FIFO[USB_wValue];			//set the configuration 
        DeviceStatus.bEP1Stall = 0;											//and clear EP1 stall	
        EP_A1_COUNTER &= ~DATATOGGLE;										//clear EP1's data toggle
        if(DeviceStatus.bConfiguration == UNCONFIGURED)
			EP_A1_MODE = USB_MODE_DISABLE;									//not configured -- disable EP1 from responding
        else
 			EP_A1_MODE = USB_MODE_NAK_IN;									//configured -- NAK traffic on EP1
        SET_EP0_MODE(USB_MODE_STATUS_ONLY);	
 
    }
    else
	//something was awry with the command, stall
    SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
}


/*
**
** FUNCTION:		SetAddress
**
** PURPOSE:			Implements Set Address command 
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered whenever a SETUP request to set the address has been received.
**					The address change cannot actually take place until the ensuing status-in is received
**					from the host -- so we just save the address and set a flag to indicate that a new
**					address was just received.  The code that handles INs will recognize this and set the address
**					properly.
**			
**					
*/

void SetAddress(void)
{
	if (ENDPOINT_A0_FIFO[USB_bmRequestType] != HOST_TO_DEVICE | STANDARD | DEVICE)
	{
		SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
	}
	else
	{
	    DeviceStatus.bAddress = 0x80 | ENDPOINT_A0_FIFO[USB_wValue];  //save address away, we can't actually use it yet
		SET_EP0_MODE(USB_MODE_STATUS_ONLY);
	}

}
											

/*
**
** FUNCTION:		ClearFeature
**
** PURPOSE:			Handles Clear Feature requests
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine checks for either a clear-remote-wakeup request,
**					or a clear-endpoint-stall request on endpoint 1 -- the only two valid clear
**					feature requests for this device.
**					
*/

void ClearFeature(void)
{

	if ((ENDPOINT_A0_FIFO[USB_bmRequestType] ==(HOST_TO_DEVICE | STANDARD | DEVICE))
		&& (ENDPOINT_A0_FIFO[USB_wValue] == USB_DEVICE_REMOTE_WAKEUP ) &&
		   ( !ENDPOINT_A0_FIFO[USB_wValueHi]))
		{
			DeviceStatus.bRemoteWakeup = DISABLE_REMOTE_WAKEUP; /* disable remote wakeup */
			SET_EP0_MODE(USB_MODE_STATUS_ONLY);
			return;
		}
	if ((ENDPOINT_A0_FIFO[USB_bmRequestType] == (HOST_TO_DEVICE | STANDARD | ENDPOINT)) &&
		   (DeviceStatus.bConfiguration == CONFIGURED) &&
		(!ENDPOINT_A0_FIFO[USB_wValueHi]) &&
		(ENDPOINT_A0_FIFO[USB_wIndex] == 0x81)&&	
		(ENDPOINT_A0_FIFO[USB_wValue] == USB_ENDPOINT_STALL)) 
		{																/*ep1 stall request*/
			DeviceStatus.bEP1Stall = 0;									/* not stalled */
			EP_A1_COUNTER &= ~DATATOGGLE;								/* clear data 0/1 bit */
			EP_A1_MODE = USB_MODE_NAK_IN_OUT;							//nak anything on endpoint 1 until ready
			SET_EP0_MODE(USB_MODE_STATUS_ONLY);
			return;
	   }
	SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
 	return;
}


/*
**
** FUNCTION:		SetFeature
**
**
**
** PURPOSE:			Handles Set Feature requests 
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine checks for either a set-remote-wakeup request,
**					or a set-endpoint-stall request on endpoint 1 -- the only two valid set
**					feature requests for this device.
**					
*/

void SetFeature(void)
{
	if ( (ENDPOINT_A0_FIFO[USB_bmRequestType] == (HOST_TO_DEVICE | STANDARD | DEVICE)) &&
		( ENDPOINT_A0_FIFO[USB_wValue] == USB_DEVICE_REMOTE_WAKEUP ) &&
		 ( !ENDPOINT_A0_FIFO[USB_wValueHi]))
		{
 			DeviceStatus.bRemoteWakeup = ENABLE_REMOTE_WAKEUP; /* set remote wakeup */
			SET_EP0_MODE(USB_MODE_STATUS_ONLY);
			return;
		}
	if ( (ENDPOINT_A0_FIFO[USB_bmRequestType] == (HOST_TO_DEVICE | STANDARD | ENDPOINT)) &&
		(DeviceStatus.bConfiguration == CONFIGURED) &&
			(!ENDPOINT_A0_FIFO[USB_wValueHi]) &&
			(ENDPOINT_A0_FIFO[USB_wIndex] == 0x81) && 
			(ENDPOINT_A0_FIFO[USB_wValue] == USB_ENDPOINT_STALL)) 
		{
			DeviceStatus.bEP1Stall = 1;								//mark endpoint as stalled
			EP_A1_MODE = USB_MODE_STALL_IN_OUT;						//stall traffic on endpoint 1
			SET_EP0_MODE(USB_MODE_STATUS_ONLY);
			return;
		}
	//command not valid
    SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
	return;
}


/*
**
** FUNCTION:		GetDescriptor
**
** PURPOSE:			Gets the requested descriptor 
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered when a Get Descriptor request is received.
**					It decodes the descriptor request and initializes XmtBuff to the
**					proper descriptor, then initiates the transfer by calling USB_control_read
**					
**					
*/

void GetDescriptor(void)
{
 	if ( (ENDPOINT_A0_FIFO[USB_bmRequestType] != (DEVICE_TO_HOST | STANDARD | DEVICE)) && 
		 (ENDPOINT_A0_FIFO[USB_bmRequestType] != (DEVICE_TO_HOST | STANDARD | INTERFACE)) &&
		 (ENDPOINT_A0_FIFO[USB_bmRequestType] != (DEVICE_TO_HOST | STANDARD | ENDPOINT)))		
	{
			 SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
			return;
	}
    switch (ENDPOINT_A0_FIFO[USB_wValueHi]) 
    {
		//decode descriptor request
        case USB_DEVICE :
            XmtBuff.bLength = device_desc_table[0];
            XmtBuff.p = device_desc_table;
            break;
        case USB_CONFIGURATION :
            XmtBuff.bLength = sizeof(config_desc_table) + 
							sizeof(Interface_Descriptor) + 
							sizeof(Class_Descriptor) + 
							sizeof(Endpoint_Descriptor);
            XmtBuff.p=config_desc_table;
            break;
        case USB_STRING :
            switch(ENDPOINT_A0_FIFO[USB_wValue])
            {
            case 0x00 :
                XmtBuff.bLength = sizeof(USBStringLanguageDescription);
                XmtBuff.p=USBStringLanguageDescription;
                break;
            case 0x01 :
                XmtBuff.bLength = sizeof(USBStringDescription1);
                XmtBuff.p=USBStringDescription1;
               break;
            case 0x02 :
                XmtBuff.bLength = sizeof(USBStringDescription2);
                XmtBuff.p=USBStringDescription2;
               break;
            case 0x03 :
                XmtBuff.bLength = sizeof(USBStringDescription3);
                XmtBuff.p=USBStringDescription3;
                break;
            case 0x04 :
                XmtBuff.bLength = sizeof(USBStringDescription4);
                XmtBuff.p=USBStringDescription4;
                break;
            case 0x05 :
                XmtBuff.bLength = sizeof(USBStringDescription5);
                XmtBuff.p=USBStringDescription5;
                break;
           default       :
                SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
                return;
            }
            break;
        case USB_HID :
            XmtBuff.bLength = sizeof(Class_Descriptor);
            XmtBuff.p=Class_Descriptor;
            break;
        case USB_REPORT :
            XmtBuff.bLength = sizeof(hid_report_desc_table); 
            XmtBuff.p=hid_report_desc_table;
            break;
        default :
			//not a recognizable request, stall
            SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
            return;
    }
	//initiate the transfer
    USB_control_read();
}


/*
**
** FUNCTION:		GetStatus
**
** PURPOSE:			Implements a Get Status request 
**
** PARAMETERS:		none
**
** DESCRIPTION:	    This routine checks for either a request to get the device
**					status, the interface status, or the endpoint status,
**					sets up XmtBuff to point to the appropriate status, and
**					calls USB_control_read to initiate the transfer.
**					
**					
**					
*/

void GetStatus(void)
{
	switch (ENDPOINT_A0_FIFO[USB_bmRequestType])
	{
     case (DEVICE_TO_HOST | STANDARD | DEVICE):
      	XmtBuff.bLength = 2;										//send 2 bytes
		XmtBuff.p = &DeviceStatus.bRemoteWakeup;					//point at remote wakeup status
		break;
	case (DEVICE_TO_HOST | STANDARD | INTERFACE):
		XmtBuff.bLength = sizeof(get_interface_status_table);		//point at interface status
		XmtBuff.p=get_interface_status_table;
		break;
	case (DEVICE_TO_HOST | STANDARD | ENDPOINT):
	    XmtBuff.bLength = 2;										//send two bytes 
		XmtBuff.p = &DeviceStatus.bEP1Stall;						//point at endpoint stall status
		break;
	default:
		SET_EP0_MODE(USB_MODE_STALL_IN_OUT);						//bogus request, complain
		return;
	}
 	USB_control_read();												//initiate transfer
 }


/*
**
** FUNCTION:		SetIdle
**
** PURPOSE:			implements a request to set the idle period
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered whenever a Set Idle request is received.
**					See the HID spec for the rules on setting idle periods.				
*/

void SetIdle(void)

{
	if ( ((ENDPOINT_A0_FIFO[USB_bmRequestType] !=  (HOST_TO_DEVICE | CLASS    | INTERFACE)) &&
		(ENDPOINT_A0_FIFO[USB_bmRequestType] !=  (HOST_TO_DEVICE | CLASS    | ENDPOINT)))  ||
		(ENDPOINT_A0_FIFO[USB_wIndex]) || (ENDPOINT_A0_FIFO[USB_wIndexHi]))
	{
		//request not valid, stall
		SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
		return;
	}
	if (!MouseStatus.bIdlePeriod)
	{
		//current idle setting is off. set both the new period and the counter
		MouseStatus.bIdlePeriod = ENDPOINT_A0_FIFO[USB_wValueHi];
		MouseStatus.bIdleCounter = MouseStatus.bIdlePeriod;
		SET_EP0_MODE(USB_MODE_STATUS_ONLY);
		return;
	}

	if (MouseStatus.bIdleCounter <= 2)
	{
		// counter for current idle period is nearly expiring.  leave it alone,
		//but set new idle period
		MouseStatus.bIdlePeriod = ENDPOINT_A0_FIFO[USB_wValueHi];
		SET_EP0_MODE(USB_MODE_STATUS_ONLY);
		return;
	}
	if ( ENDPOINT_A0_FIFO[USB_wValueHi] > MouseStatus.bIdleCounter)
	{
		//new period is shorter than the old one.  Force current idle period to expire soon,
		//and set new idle period
	      MouseStatus.bIdlePeriod = ENDPOINT_A0_FIFO[USB_wValueHi];
		MouseStatus.bIdleCounter = 1;
	}
	else
	{
		//new period is longer than old one. set new idle period, and adjust current period
		//to be equal to the new period, minus the counts that have already expired for the old one
		 MouseStatus.bIdlePeriod  = ENDPOINT_A0_FIFO[USB_wValueHi];
		MouseStatus.bIdleCounter = ENDPOINT_A0_FIFO[USB_wValueHi] - MouseStatus.bIdlePeriod;
	}
	SET_EP0_MODE(USB_MODE_STATUS_ONLY);
	return;
}


/*
**
** FUNCTION:		SetProtocol
**
** PURPOSE:			Implements the set-protocol request 
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered whenever an Set Protocol request is received
**					
*/

void SetProtocol(void)
{

	if (((ENDPOINT_A0_FIFO[USB_bmRequestType] !=  (HOST_TO_DEVICE | CLASS | INTERFACE)) &&
		(ENDPOINT_A0_FIFO[USB_bmRequestType] !=  (HOST_TO_DEVICE | CLASS | ENDPOINT))) ||
	    (ENDPOINT_A0_FIFO[USB_wIndex]) || 
		(ENDPOINT_A0_FIFO[USB_wIndexHi]) ||
		(ENDPOINT_A0_FIFO[USB_wValue] > REPORT_PROTOCOL))
		//invalid request, stall
        SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
    else
    {
        DeviceStatus.bProtocol = ENDPOINT_A0_FIFO[USB_wValue];		//set the new protocol
        SET_EP0_MODE(USB_MODE_STATUS_ONLY);										//acknowledge
    }
}


/*
**
** FUNCTION:		GetReport
**
** PURPOSE:			Implements the GetReport request 
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered whenever a request to get a report is received.
**					The most recent mouse data report is in the EP1 fifo.
**					
*/

void GetReport(void)
{

	if (ENDPOINT_A0_FIFO[USB_bmRequestType] !=  (DEVICE_TO_HOST | CLASS  | INTERFACE)) 
	{
		SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
		return;
	}
	//depending upon the current protocol, either send a 3 or 4-byte mouse packet
	//
    XmtBuff.bLength = (DeviceStatus.bProtocol == REPORT_PROTOCOL ? 4 : 3);	
    XmtBuff.p = &Mouse.bButtons;
    USB_control_read();
}


/*
**
** FUNCTION:		GetIdle
**
** PURPOSE:			Implements the Get Idle Request 
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered whenever a Get Idle request is received.
**					
**					
*/

void GetIdle(void)
{

	if (ENDPOINT_A0_FIFO[USB_bmRequestType] !=  (DEVICE_TO_HOST | CLASS | INTERFACE)) 
	{
		SET_EP0_MODE(USB_MODE_STALL_IN_OUT);
		return;
	}
    XmtBuff.bLength = 1;								//idle is 1-byte long
    XmtBuff.p=&MouseStatus.bIdlePeriod;					//point at it
    USB_control_read();									//initiate transfer
}


/*
**
** FUNCTION:		GetProtocol
**
** PURPOSE:			Implements the Get Protocol Request 
**
** PARAMETERS:		none
**
** DESCRIPTION:	 
**					This routine is entered whenever a Get Protocol request is received
**					
*/

void GetProtocol(void)
{

	if (ENDPOINT_A0_FIFO[USB_bmRequestType] !=  (DEVICE_TO_HOST | CLASS    | INTERFACE)) 
	{
		SET_EP0_MODE(USB_MODE_STALL_IN_OUT);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人动漫av在线| 欧美一区二区在线看| 日本高清不卡一区| 欧美一级一区二区| 亚洲欧美日韩精品久久久久| 美女视频免费一区| 欧美无人高清视频在线观看| 国产日韩欧美电影| 蜜臀国产一区二区三区在线播放 | 国产麻豆欧美日韩一区| 一本到三区不卡视频| 精品国产乱码久久| 日韩成人一区二区三区在线观看| 成人av免费网站| 国产亚洲精品中文字幕| 日韩成人av影视| 欧美日韩一区不卡| 亚洲三级在线免费观看| 成人做爰69片免费看网站| 精品国产一区二区亚洲人成毛片| 亚洲国产精品欧美一二99| 99久久久国产精品免费蜜臀| 国产日韩欧美一区二区三区综合| 蜜桃av噜噜一区二区三区小说| 欧美视频一区二区三区在线观看| 中文字幕乱码久久午夜不卡| 久久爱www久久做| 欧美一区二区三区在线电影| 亚洲第一主播视频| 日本高清视频一区二区| 日韩毛片视频在线看| a美女胸又www黄视频久久| 国产婷婷色一区二区三区在线| 久久精品国产亚洲5555| 欧美成人猛片aaaaaaa| 免费一区二区视频| 日韩欧美国产一区二区三区| 男男gaygay亚洲| 日韩一区二区三区在线| 亚洲1区2区3区视频| 欧美视频在线观看一区二区| 亚洲国产精品尤物yw在线观看| 欧美亚洲国产bt| 天堂一区二区在线免费观看| 日韩一区日韩二区| 99视频在线观看一区三区| 亚洲三级电影网站| 欧美制服丝袜第一页| 性做久久久久久免费观看欧美| 欧美老肥妇做.爰bbww视频| 日韩国产精品91| 久久久久久久久久久久久久久99| 国产精品69毛片高清亚洲| 国产精品精品国产色婷婷| 成人18视频在线播放| 一区二区三区四区亚洲| 欧美人妇做爰xxxⅹ性高电影| 奇米精品一区二区三区在线观看一| 欧美不卡视频一区| 成a人片亚洲日本久久| 亚洲精品视频免费观看| 6080亚洲精品一区二区| 久久不见久久见中文字幕免费| 欧美经典一区二区| 色婷婷久久久综合中文字幕| 免费xxxx性欧美18vr| 欧美极品另类videosde| 日本丶国产丶欧美色综合| 日本不卡在线视频| 国产精品午夜在线观看| 欧美日韩国产综合久久| 国产成a人亚洲| 一区二区三区四区不卡视频| 日韩一区二区三区免费看 | 东方欧美亚洲色图在线| 亚洲综合在线视频| 精品久久久久久久久久久院品网| 国产成人午夜精品5599| 亚洲一区二区在线观看视频| 日韩视频一区二区三区| jvid福利写真一区二区三区| 香港成人在线视频| 中文字幕一区二区视频| 欧美精品一卡两卡| 99久久精品情趣| 欧美日韩中文另类| 国产一区二区久久| 午夜久久电影网| 中文字幕一区二区三区四区 | 日韩精品一区二区在线| 色诱亚洲精品久久久久久| 国产一区二区在线看| 亚洲mv在线观看| 亚洲天堂免费看| 国产亚洲1区2区3区| 欧美一级免费大片| 欧美影视一区二区三区| 成人黄色在线视频| 毛片一区二区三区| 日韩精品色哟哟| 亚洲精品成a人| 国产精品久久久久久久午夜片| 日韩欧美成人午夜| 678五月天丁香亚洲综合网| 欧洲在线/亚洲| 99re热这里只有精品视频| 国产精品99久久久久久似苏梦涵| 免费久久精品视频| 免费观看91视频大全| 亚洲va韩国va欧美va| 亚洲一区二区三区四区在线观看 | 婷婷国产在线综合| 一区二区在线观看视频在线观看| 久久精品欧美日韩精品| 久久久一区二区| 久久亚洲综合av| 久久久久久久性| 国产午夜精品美女毛片视频| 久久久高清一区二区三区| 欧美精品一区二区精品网| 久久先锋资源网| 国产精品色噜噜| 日韩一区有码在线| 樱花草国产18久久久久| 亚洲福利国产精品| 婷婷丁香久久五月婷婷| 秋霞成人午夜伦在线观看| 麻豆精品一二三| 国产一区91精品张津瑜| www.日韩精品| 欧美天天综合网| 日韩亚洲电影在线| 久久嫩草精品久久久精品 | 日韩欧美精品三级| 亚洲精品在线观看网站| 久久蜜臀中文字幕| 国产精品久久久久9999吃药| 亚洲综合成人在线视频| 亚洲一区二区三区在线看| av电影天堂一区二区在线| av一区二区三区在线| 在线欧美日韩国产| 在线播放欧美女士性生活| 2019国产精品| 亚洲欧洲日产国产综合网| 亚洲香蕉伊在人在线观| 免费看日韩精品| 成人免费av在线| 日本高清不卡一区| 精品国产乱码久久久久久1区2区 | 中文字幕欧美区| 伊人色综合久久天天人手人婷| 丝瓜av网站精品一区二区| 国产一区二区三区av电影| 色综合咪咪久久| 欧美成人一区二区三区在线观看| 国产精品国产a级| 免费看欧美美女黄的网站| 97精品久久久久中文字幕| 日韩一区国产二区欧美三区| 国产精品福利影院| 免费精品视频在线| 一本到不卡免费一区二区| 精品国产99国产精品| 一二三四区精品视频| 国产美女主播视频一区| 欧美片网站yy| 1区2区3区国产精品| 久久99精品久久只有精品| 色香蕉成人二区免费| 国产亚洲精品7777| 视频一区二区三区入口| 91视频国产观看| 久久精品亚洲麻豆av一区二区| 午夜精品福利一区二区三区av| 成人精品小蝌蚪| 欧美精品一区二区不卡 | 欧美日韩精品电影| 亚洲欧美怡红院| 风间由美一区二区三区在线观看 | 国产精品99久| 欧美一区二区三区在线| 一区二区三区中文字幕精品精品| 国产99久久久国产精品潘金| 日韩欧美国产系列| 日日夜夜免费精品| 欧美性色黄大片手机版| 亚洲色大成网站www久久九九| 国产iv一区二区三区| 久久先锋影音av鲁色资源网| 日韩在线一区二区三区| 91免费小视频| 亚洲啪啪综合av一区二区三区| 成人精品在线视频观看| 国产偷国产偷亚洲高清人白洁| 久久精品国产99国产| 欧美一区二区三区在线电影| 日本欧美一区二区在线观看| 欧美日韩在线播放三区四区| 亚洲一区视频在线观看视频|