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

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

?? usb.c

?? Texas Instruments的TUSB3410芯片接鍵盤輸入的固件程序源碼和驅動程序源碼。
?? C
?? 第 1 頁 / 共 4 頁
字號:
    // fill true configuration group size
    wTemp = sizeof(abromConfigurationDescriptorGroup);
    abDescriptor[2] = wTemp;
    abDescriptor[3] = wTemp>>8;

    usbClearOEP0ByteCount();
    wBytesRemainingOnIEP0 = sizeof(abromConfigurationDescriptorGroup);
    usbSendDataPacketOnEP0((PBYTE)&abDescriptor);
}

#ifdef RAW_STRING_DESCRIPTOR
VOID usbGetStringDescriptor(VOID)
{
    WORD bIndex;

    usbClearOEP0ByteCount();                    // for status stage 

    bIndex = 0x00;
    while(tSetupPacket.bValueL-- >  0x00) bIndex += abromStringDescriptor[bIndex];
    
    wBytesRemainingOnIEP0 = abromStringDescriptor[bIndex];
    usbSendDataPacketOnEP0((PBYTE)&abromStringDescriptor[bIndex]);
}
#else
BYTE strlen(char *string)
{
	BYTE str;
	for(str = 0; str < 255 ; str++)
		if( string[str] == 0x00 )
			return(str);
	return(0);
}

void usbGetStringDescriptor(void)
{
    BYTE bTemp;
    BYTE stringOffset = 0;

    usbClearOEP0ByteCount();

	switch(tSetupPacket.bValueL)
		{
		case 0: // LANGUAGE ID
			abDescriptor[0] = 4; // Length of language descriptor ID
			abDescriptor[1] = DESC_TYPE_STRING; // LANGID tag
			abDescriptor[2] = 0x09; // Low byte of 0x0409 (English)
			abDescriptor[3] = 0x04; // High byte of 0x0409 (English)
			break;
		case 1: // MANUFACTURER DESCRIPTION
			abDescriptor[stringOffset++] = strlen(mfgDescription) * 2 + 2; // Length of this string
			abDescriptor[stringOffset++] = DESC_TYPE_STRING; // String descriptor type
			for(bTemp = 0; bTemp < strlen(mfgDescription);bTemp++)
				{
				abDescriptor[stringOffset++] = mfgDescription[bTemp]; // Insert the character from the string
				abDescriptor[stringOffset++] = 0x00; // Insert a trailing 00h for Unicode representation
				}
			break;
		case 2: // PRODUCT DESCRIPTION
			abDescriptor[stringOffset++] = strlen(prodDescription) * 2 + 2;  // Length of this string
			abDescriptor[stringOffset++] = DESC_TYPE_STRING; // String descriptor type
			for(bTemp = 0; bTemp < strlen(prodDescription);bTemp++)
				{
				abDescriptor[stringOffset++] = prodDescription[bTemp]; // Insert the character from the string
				abDescriptor[stringOffset++] = 0x00; // Insert a trailing 00h for Unicode representation
				}
			break;
		case 3: // SERIAL NUMBER
			abDescriptor[stringOffset++] = strlen(serialNumber) * 2 + 2;  // Length of this string
			abDescriptor[stringOffset++] = DESC_TYPE_STRING; // String descriptor type
			for(bTemp = 0; bTemp < strlen(serialNumber);bTemp++)
				{
				abDescriptor[stringOffset++] = serialNumber[bTemp]; // Insert the character from the string	
				abDescriptor[stringOffset++] = 0x00; // Insert a trailing 00h for Unicode representation
				}
			break;
		default:
				break;
		}

    wBytesRemainingOnIEP0 = abDescriptor[0];
    usbSendDataPacketOnEP0((PBYTE)&abDescriptor);
}
#endif

//----------------------------------------------------------------------------
VOID usbGetInterface(VOID)
{

    // not fully supported, return one byte, zero
    usbClearOEP0ByteCount();                    // for status stage
    wBytesRemainingOnIEP0 = 0x01;
    abUsbRequestReturnData[0] = bInterfaceNumber;
    usbSendDataPacketOnEP0((PBYTE)&abUsbRequestReturnData[0]);
}

//----------------------------------------------------------------------------
VOID usbGetDeviceStatus(VOID)
{ 

    if((abromConfigurationDescriptorGroup[OFFSET_CONFIG_DESCRIPTOR_POWER] & 
        CFG_DESC_ATTR_SELF_POWERED) == CFG_DESC_ATTR_SELF_POWERED) 
        abUsbRequestReturnData[0] = DEVICE_STATUS_SELF_POWER;

//    if((abromConfigurationDescriptorGroup[OFFSET_CONFIG_DESCRIPTOR_POWER] & 
//        CFG_DESC_ATTR_REMOTE_WAKE) == CFG_DESC_ATTR_REMOTE_WAKE) 
//        abUsbRequestReturnData[0] |= DEVICE_STATUS_REMOTE_WAKEUP;

    if(bRemoteWakeup == ENABLE) 
        abUsbRequestReturnData[0] |= DEVICE_STATUS_REMOTE_WAKEUP;

    usbClearOEP0ByteCount();                    // for status stage    

    // Return self power status and remote wakeup status
    wBytesRemainingOnIEP0 = 2;
    usbSendDataPacketOnEP0((PBYTE)&abUsbRequestReturnData[0]);

}

//----------------------------------------------------------------------------
VOID usbGetInterfaceStatus(VOID)
{

    // check bIndexL for index number (not supported)

    usbClearOEP0ByteCount();                    // for status stage    

    // Return two zero bytes
    wBytesRemainingOnIEP0 = 2;
    usbSendDataPacketOnEP0((PBYTE)&abUsbRequestReturnData[0]);
}

//----------------------------------------------------------------------------
VOID usbGetEndpointStatus(VOID)
{
    BYTE bEndpointNumber;

    // Endpoint number is bIndexL
    bEndpointNumber = tSetupPacket.bIndexL & EP_DESC_ADDR_EP_NUM;
    if(bEndpointNumber == 0x00){
        if((tSetupPacket.bIndexL & EP_DESC_ADDR_DIR_IN) == EP_DESC_ADDR_DIR_IN){
            // input endpoint 0
            abUsbRequestReturnData[0] = (BYTE)(tEndPoint0DescriptorBlock.bIEPCNFG & EPCNF_STALL);
        }else{
            // output endpoint 0
            abUsbRequestReturnData[0] = (BYTE)(tEndPoint0DescriptorBlock.bOEPCNFG & EPCNF_STALL);
        }
        abUsbRequestReturnData[0] = abUsbRequestReturnData[0] >> 3; // STALL is on bit 3
        usbClearOEP0ByteCount();                    // for status stage    
        wBytesRemainingOnIEP0 = 0x02;
        usbSendDataPacketOnEP0((PBYTE)&abUsbRequestReturnData[0]);
    }else{
        bEndpointNumber--;
        #ifdef BOOTCODE         // bootcode only support output endpoint 1
        if((bEndpointNumber == 0) && ((tSetupPacket.bIndexL & EP_DESC_ADDR_DIR_IN) == 0x00)){
            // output endpoint 1
            abUsbRequestReturnData[0] = (BYTE)(tOutputEndPointDescriptorBlock[0].bEPCNF & EPCNF_STALL);
            abUsbRequestReturnData[0] = abUsbRequestReturnData[0] >> 3; // STALL is on bit 3
            usbClearOEP0ByteCount();                    // for status stage    
            wBytesRemainingOnIEP0 = 0x02;
            usbSendDataPacketOnEP0((PBYTE)&abUsbRequestReturnData[0]);
        }
        #else    
        // EP is from EP1 to EP7 while C language start from 0
        // Firmware should NOT response if specified endpoint is not supported. (charpter 8)
        if(bEndpointNumber < MAX_ENDPOINT_NUMBER){
            if(tSetupPacket.bIndexL & EP_DESC_ADDR_DIR_IN){
                // input endpoint
                abUsbRequestReturnData[0] = (BYTE)(tInputEndPointDescriptorBlock[bEndpointNumber].bEPCNF & EPCNF_STALL);
            }else{
                // output endpoint
                abUsbRequestReturnData[0] = (BYTE)(tOutputEndPointDescriptorBlock[bEndpointNumber].bEPCNF & EPCNF_STALL);
            }
        }   // no response if endpoint is not supported.
        abUsbRequestReturnData[0] = abUsbRequestReturnData[0] >> 3; // STALL is on bit 3        
        usbClearOEP0ByteCount();
        wBytesRemainingOnIEP0 = 0x02;
        usbSendDataPacketOnEP0((PBYTE)&abUsbRequestReturnData[0]);
        #endif
    } 
}

//----------------------------------------------------------------------------
VOID usbSetAddress(VOID)
{
    usbStallOEP0();                             // control write without data stage

    // bValueL contains device address
    if(tSetupPacket.bValueL < 128){
        // hardware will update the address after status stage
        // therefore, firmware can set the address now.
        bFUNADR = tSetupPacket.bValueL;         
        usbSendZeroLengthPacketOnIEP0();
    }else usbStallEndpoint0();
}

//----------------------------------------------------------------------------
VOID usbSetConfiguration(VOID)
{
    usbStallOEP0();                             // control write without data stage

    // configuration number is in bValueL
    // change the code if more than one configuration is supported
    bConfigurationNumber = tSetupPacket.bValueL;
    usbSendZeroLengthPacketOnIEP0();
}

/*
//----------------------------------------------------------------------------
VOID usbSetDeviceFeature(VOID)
{
    // stall because bootcode does not support
    usbStallEndpoint0();
    
    // bValueL contains feature selector
//    if(tSetupPacket.bValueL == FEATURE_REMOTE_WAKEUP){
//        abConfigurationDescriptorGroup[OFFSET_CONFIG_DESCRIPTOR_POWER] 
//        |= CFG_DESC_ATTR_REMOTE_WAKE;
//        usbSendZeroLengthPacketOnIEP0();        
//    }else usbStallEndpoint0();

}
*/

//----------------------------------------------------------------------------
VOID usbClearDeviceFeature(VOID)
{
    // bValueL contains feature selector
    if(tSetupPacket.bValueL == FEATURE_REMOTE_WAKEUP){
        bRemoteWakeup = DISABLE;
        bUSBMSK &= (USBMSK_WAKEUP^0xff);
        usbSendZeroLengthPacketOnIEP0();
    }else usbStallEndpoint0();
}

//----------------------------------------------------------------------------
VOID usbSetDeviceFeature(VOID)
{
    // bValueL contains feature selector
    if(tSetupPacket.bValueL == FEATURE_REMOTE_WAKEUP){
        bRemoteWakeup = ENABLE;
        usbSendZeroLengthPacketOnIEP0();
    }else usbStallEndpoint0();
}

//----------------------------------------------------------------------------
VOID usbSetEndpointFeature(VOID)
{ 
    BYTE bEndpointNumber;
    usbStallOEP0();                             // control write without data stage

    // wValue contains feature selector
    // bIndexL contains endpoint number
    // Endpoint number is in low byte of wIndex
    if(tSetupPacket.bValueL == FEATURE_ENDPOINT_STALL){
        bEndpointNumber = tSetupPacket.bIndexL & EP_DESC_ADDR_EP_NUM;
        if(bEndpointNumber == 0x00) usbSendZeroLengthPacketOnIEP0();  // do nothing for endpoint 0
        else{
            bEndpointNumber--;
            #ifdef BOOTCODE
            if((bEndpointNumber == 0x00) && ((tSetupPacket.bIndexL & EP_DESC_ADDR_DIR_IN) == 0x00)){  // endpoint 1
                // output endpoint 1
                tOutputEndPointDescriptorBlock[0].bEPCNF |= EPCNF_STALL;
                usbSendZeroLengthPacketOnIEP0();                
            } // no response if endpoint is not supported.
            #else
            // Firmware should NOT response if specified endpoint is not supported. (charpter 8)        
            if(bEndpointNumber < MAX_ENDPOINT_NUMBER){
                if(tSetupPacket.bIndexL & EP_DESC_ADDR_DIR_IN){
                    // input endpoint
                    tInputEndPointDescriptorBlock[bEndpointNumber].bEPCNF |= EPCNF_STALL;
                }else{
                    // output endpoint
                    tOutputEndPointDescriptorBlock[bEndpointNumber].bEPCNF |= EPCNF_STALL;
                }
                usbSendZeroLengthPacketOnIEP0();                            
            } // no response if endpoint is not supported.
            #endif        
        }
    }else usbStallEndpoint0();
}

//----------------------------------------------------------------------------
VOID usbSetInterface(VOID)
{
    // bValueL contains alternative setting
    // bIndexL contains interface number
    // change code if more than one interface is supported
    usbStallOEP0();                             // control write without data stage
    bInterfaceNumber = tSetupPacket.bIndexL;
    usbSendZeroLengthPacketOnIEP0();
}

//----------------------------------------------------------------------------
VOID usbInvalidRequest(VOID)
{
    // check if setup overwrite is set
    // if set, do nothing since we might decode it wrong
    // setup packet buffer could be modified by hardware if another setup packet
    // was sent while we are deocding setup packet
    if((bUSBSTA & USBSTA_STPOW) == 0x00) usbStallEndpoint0();
}








void usbGetHIDDescriptor(void)
{
//BYTE bTemp;
	// Copy the DEVICE DESCRIPTOR from program "ROM" to XRAM
	
//    for(bTemp=0;bTemp<SIZEOF_DEVICE_DESCRIPTOR;bTemp++)
//        abDescriptor[bTemp] = abromConfigurationDescriptorGroup[SIZEOF_CONFIG_DESCRIPTOR+SIZEOF_INTERFACE_DESCRIPTOR + bTemp];

    usbClearOEP0ByteCount();
    wBytesRemainingOnIEP0 = SIZEOF_KEYBD_HID_DESCRIPTOR;
    usbSendDataPacketOnEP0((PBYTE)&abromReportDescriptor);
}

void usbGetReportDescriptor(void)
{
    usbClearOEP0ByteCount();
    wBytesRemainingOnIEP0 = SIZEOF_REPORT_DESCRIPTOR;
    usbSendDataPacketOnEP0((PBYTE)&abromReportDescriptor);
}

extern BYTE bLED;
void usbSetReport(void)
{
    wBytesRemainingOnOEP0 = 1;
    usbReceiveDataPacketOnEP0((PBYTE) &bLED);
}

BYTE gbIdleRateL;
BYTE gbIdleRateH;
void usbSetIdle(void)
{
//    usbStallOEP0;
    gbIdleRateL = tSetupPacket.bValueL;
    gbIdleRateH = tSetupPacket.bValueH;
    usbSendZeroLengthPacketOnIEP0();
}

void usbGetIdle(void)
{
    wBytesRemainingOnIEP0 = 1;
    usbSendDataPacketOnEP0(&gbIdleRateH);
}

BYTE gbProtocol=1; // default is report protocol
void usbSetProtocol(void)
{
//    usbStallOEP0;
    gbProtocol = tSetupPacket.bValueL;
    usbSendZeroLengthPacketOnIEP0();
}

void usbGetProtocol(void)
{
    wBytesRemainingOnIEP0 = 1;
    usbSendDataPacketOnEP0(&gbProtocol);
}

//----------------------------------------------------------------------------
//  Bit definitions for DEVICE_REQUEST.bmRequestType
//  Bit 7:   Data direction
//  Bit 6-5: Type
//  Bit 4-0: Recipient
// bmRequestType bRequest bValueL bValueH bIndexL bIndexH bLengthL bLengthH bCompareMask *fp
//----------------------------------------------------------------------------
code tDEVICE_REQUEST_COMPARE tUsbRequestList[] =
{
    //
    // the following listing are for vendor specific USB requests
    //
    
    // Vendor Specific Request
    USB_REQ_TYPE_OUTPUT | USB_REQ_TYPE_VENDOR | USB_REQ_TYPE_INTERFACE,
    USB_REQ_SET_DBUS_T,             // interface set dbus transmitter configurable parameters
    0xff,0xff,                      // wValue(lsb): data[0], wValue(msb): data[3]
    0x00,0x00,                      // interface number 0
    0x00,0x00,                      // no data
    0xcf,&usbVendorRequest,

    // Vendor Specific Request
    USB_REQ_TYPE_OUTPUT | USB_REQ_TYPE_VENDOR | USB_REQ_TYPE_INTERFACE,
    USB_REQ_SET_DBUS_R,             // interface set dbus receiver configurable parameters
    0xff,0xff,                      // wValue(lsb): data[1], wValue(msb): data[2]
    0x00,0x00,                      // interface number 0
    0x00,0x00,                      // no data
    0xcf,&usbVendorRequest,

    // Vendor Specific Request

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美少妇xxx| 久久99国产精品免费网站| 91免费在线视频观看| 国产精品日韩成人| 成人性生交大片免费看视频在线| 国产精品欧美综合在线| 国产欧美日韩综合| 在线综合视频播放| 欧美中文字幕一二三区视频| 波多野结衣在线aⅴ中文字幕不卡| 蜜臀精品久久久久久蜜臀| 亚洲黄一区二区三区| 一区二区三区中文字幕精品精品| 中文字幕亚洲精品在线观看| 中文在线资源观看网站视频免费不卡| 欧美精品一区二区三区一线天视频| 欧美午夜精品一区二区三区| 色视频欧美一区二区三区| 另类小说色综合网站| 精品在线免费视频| 国产一区视频导航| 国产精品一区二区91| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲v中文字幕| 亚洲精品伦理在线| 一区二区三区在线视频观看58| 婷婷综合在线观看| 精品一区二区三区免费视频| 国产美女久久久久| 91视频免费观看| 日韩一二三四区| 国产精品成人网| 亚洲国产成人精品视频| 26uuu久久天堂性欧美| 日韩欧美一级二级三级| 中文字幕人成不卡一区| 视频在线观看一区二区三区| 日韩精品一区第一页| 大胆欧美人体老妇| 欧美性猛片aaaaaaa做受| 日韩亚洲欧美成人一区| 亚洲精品免费在线观看| 国产综合成人久久大片91| 在线观看www91| 中文字幕一区二区5566日韩| 麻豆精品视频在线观看免费| 日本乱码高清不卡字幕| 久久九九全国免费| 免费看黄色91| 欧美伦理影视网| 亚洲午夜久久久久久久久电影院| 国产激情一区二区三区四区| 欧美一卡2卡3卡4卡| 亚洲成在人线在线播放| 91高清视频在线| 亚洲免费成人av| 91精品福利视频| 一区二区三区四区激情| 国产精品一二三在| 久久精品视频在线看| 久久99精品久久久久久动态图| 在线观看日韩毛片| 亚洲欧美另类久久久精品| 成人av在线资源| 亚洲一区二区三区小说| 在线观看亚洲一区| 亚洲综合一二区| 9191精品国产综合久久久久久| 亚洲色图在线视频| 成人99免费视频| 欧美日韩精品三区| 亚洲成人一区二区在线观看| 欧美老年两性高潮| 精久久久久久久久久久| 国产精品乱码人人做人人爱 | 国产精品自在欧美一区| 亚洲国产成人午夜在线一区| 色婷婷av一区二区三区gif| 亚洲国产wwwccc36天堂| 精品国一区二区三区| av电影天堂一区二区在线| 亚洲欧美日韩综合aⅴ视频| 在线视频一区二区三区| 韩国v欧美v日本v亚洲v| 亚洲自拍偷拍av| 久久久久久一二三区| 日本精品免费观看高清观看| 亚洲永久精品国产| 在线观看一区日韩| 色吧成人激情小说| www.性欧美| 成人午夜电影久久影院| 国内成人自拍视频| 日本视频一区二区| 亚洲人成7777| 国产女主播一区| 中文字幕精品三区| 国产欧美日本一区二区三区| 欧美一区二区三区免费| 在线欧美小视频| 欧美日韩一区二区在线视频| 成人91在线观看| 国产v综合v亚洲欧| 国产精品一区久久久久| 性欧美疯狂xxxxbbbb| 日韩理论片网站| 一区二区三区不卡在线观看| 色一区在线观看| 精品一区二区免费在线观看| 日韩综合在线视频| 日韩精品国产精品| 国产乱子轮精品视频| 国产毛片精品视频| 99国产精品久| 欧美另类高清zo欧美| 色女孩综合影院| 日韩一区二区三区四区| 8v天堂国产在线一区二区| 久久久亚洲午夜电影| 中文字幕日韩av资源站| 亚洲成人精品一区二区| 日韩影院精彩在线| 成人黄色大片在线观看| 欧美一区二区视频免费观看| 欧美激情一区二区三区全黄 | 国产精品三级电影| 亚洲图片一区二区| 国产盗摄精品一区二区三区在线| 色屁屁一区二区| 久久蜜桃av一区二区天堂| 亚洲综合免费观看高清完整版| 一区二区三区四区乱视频| 国产福利91精品一区二区三区| 99久久伊人精品| 精品久久人人做人人爱| 五月天精品一区二区三区| 日韩精品一二区| jiyouzz国产精品久久| 精品国产91乱码一区二区三区 | 日本韩国精品一区二区在线观看| 久久亚洲一区二区三区明星换脸| 亚洲成人7777| 91成人免费电影| 亚洲一区在线观看视频| 在线视频中文字幕一区二区| 欧美色综合天天久久综合精品| 欧美在线一区二区三区| 国产亚洲精品资源在线26u| 激情五月婷婷综合| 国产一区二区三区电影在线观看 | 欧美日韩在线三区| 日韩精品一二三区| 久久蜜臀中文字幕| 91在线云播放| 国内精品在线播放| 亚洲人精品午夜| 精品日韩一区二区三区 | 欧美一区二区福利视频| 国产精品一二三区| 午夜久久福利影院| 久久久国产综合精品女国产盗摄| 色婷婷综合中文久久一本| 男男gaygay亚洲| 亚洲欧美日韩国产另类专区| 91精品国产丝袜白色高跟鞋| www.欧美色图| 国产乱理伦片在线观看夜一区| 亚洲一区日韩精品中文字幕| 国产日韩欧美一区二区三区综合| 欧美情侣在线播放| 91农村精品一区二区在线| 日本vs亚洲vs韩国一区三区二区 | 五月婷婷色综合| 亚洲人成影院在线观看| 欧美国产一区视频在线观看| 欧美成人一区二区三区在线观看| 欧美午夜宅男影院| 色伊人久久综合中文字幕| 国产精品中文字幕日韩精品| 精品写真视频在线观看| 蜜臀久久久久久久| 亚洲电影一区二区三区| 亚洲自拍与偷拍| 夜夜嗨av一区二区三区中文字幕| 自拍视频在线观看一区二区| 国产精品不卡在线| 精品久久国产老人久久综合| 99精品热视频| 99视频超级精品| 欧美日韩极品在线观看一区| 在线亚洲欧美专区二区| 91久久久免费一区二区| 色综合久久久久综合体桃花网| av在线不卡网| 91女厕偷拍女厕偷拍高清| 欧美亚洲国产一区在线观看网站| 欧美色中文字幕| 2020国产精品| 亚洲高清免费观看高清完整版在线观看 | 91精品午夜视频|