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

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

?? host_sl811hst.c

?? TI的DSP處理器連接USB芯片訪問U盤的代碼.有點挑盤,只支持FAT16的文件系統.
?? C
?? 第 1 頁 / 共 3 頁
字號:
		{														// inserted at all time, then you will
			intr = SL811Read(IntStatus);						// wait for interrupt to be done, and 
			if((intr & USB_RESET) || (intr & INSERT_REMOVE))	// proceed to parse result from slave 
			{													// device.
				DATA_STOP = TRUE;								// if device is removed, set DATA_STOP
				return FALSE;									// flag true, so that main loop will 
			}													// know this condition and exit gracefully
			if(intr & USB_A_DONE)								
				break;											// interrupt done !!!
		}

		SL811Write(IntStatus,INT_CLEAR); 						// clear interrupt status
		result 	  = SL811Read(EP0Status);						// read EP0status register
		remainder = SL811Read(EP0Counter);						// remainder value in last pkt xfer

		//-------------------------ACK----------------------------
		if (result & EP0_ACK)									// Transmission ACK
		{	

			// SETUP TOKEN
			if(pid == PID_SETUP)								// do nothing for SETUP/OUT token 
				break;											// exit while(1) immediately

			// OUT TOKEN				
			else if(pid == PID_OUT)
				break;

			// IN TOKEN
			else if(pid == PID_IN)
			{													// for IN token only
				wLen  -= (WORD)xferLen;							// update remainding wLen value
				cmd   ^= 0x40;    								// toggle DATA0/DATA1
				dataX++;										// point to next dataX

				//------------------------------------------------	
				// If host requested for more data than the slave 
				// have, and if the slave's data len is a multiple
				// of its endpoint payload size/last xferLen. Do 
				// not overwrite data in previous buffer.
				//------------------------------------------------	
				if(remainder==xferLen)							// empty data detected
					bufLen = 0;									// do not overwriten previous data
				else											// reset bufLen to zero
					bufLen = xferLen;							// update previous buffer length
				
				//------------------------------------------------	
				// Arm for next data transfer when requested data 
				// length have not reach zero, i.e. wLen!=0, and
				// last xferlen of data was completed, i.e.
				// remainder is equal to zero, not a short pkt
				//------------------------------------------------	
				if(!remainder && wLen)							// remainder==0 when last xferLen
				{												// was all completed or wLen!=0
					addr    = (dataX & 1) ? data1:data0; 		// select next address for data
					xferLen = (BYTE)(wLen>=wPayload) ? wPayload:wLen;	// get data length required
					if (FULL_SPEED)								// sync with SOF transfer
						cmd |= 0x20;							// always sync SOF when FS, regardless 
					SL811Write(EP0XferLen, xferLen); 			// select next xfer length
					SL811Write(EP0Address, addr);           	// data buffer addr 
					SL811Write(IntStatus,INT_CLEAR);			// is a LS is on Hub.
					SL811Write(EP0Control,cmd);					// Enable USB transfer and re-arm
				}				

				//------------------------------------------------
				// Copy last IN token data pkt from prev transfer
				// Check if there was data available during the
				// last data transfer
				//------------------------------------------------
				if(bufLen)										
				{	
					SL811BufRead(((dataX&1)?data0:data1), buffer, bufLen);
					buffer += bufLen;								
				}

				//------------------------------------------------
				// Terminate on short packets, i.e. remainder!=0
				// a short packet or empty data packet OR when 
				// requested data len have completed, i.e.wLen=0
				// For a LOWSPEED device, the 1st device descp,
				// wPayload is default to 64-byte, LS device will
				// only send back a max of 8-byte device descp,
				// and host detect this as a short packet, and 
				// terminate with OUT status stage
				//------------------------------------------------
				if(remainder || !wLen)
					break;
			}							
		}
		
		//-------------------------NAK----------------------------
		if (result & EP0_NAK)									// NAK Detected
		{														
			if(endpoint==0)										// on ep0 during enumeration of LS device
			{													// happen when slave is not fast enough,
				SL811Write(IntStatus,INT_CLEAR);				// clear interrupt status, need to
				SL811Write(EP0Control,cmd);						// re-arm and request for last cmd, IN token
                result = 0;                                     // respond to NAK status only
			}
			else												// normal data endpoint, exit now !!! , non-zero ep
				break;											// main loop control the interval polling
		}
		
		//-----------------------TIMEOUT--------------------------
		if (result & EP0_TIMEOUT)								// TIMEOUT Detected
		{														
			if(endpoint==0)										// happens when hub enumeration
			{
				if(++timeout >= TIMEOUT_RETRY)
				{	
				    timeout--;
					break;										// exit on the timeout detected	
				}
				SL811Write(IntStatus,INT_CLEAR);				// clear interrupt status, need to
				SL811Write(EP0Control,cmd);						// re-arm and request for last cmd again
			}
			else												
			{													// all other data endpoint, data transfer 
				TIMEOUT_ERR = TRUE;								// failed, set flag to terminate transfer
				break;											// happens when data transfer on a device
			}													// through the hub
		}

		//-----------------------STALL----------------------------
		if (result & EP0_STALL)  								// STALL detected
			return TRUE;										// for unsupported request.
																		
		//----------------------OVEFLOW---------------------------
		if (result & EP0_OVERFLOW)  							// OVERFLOW detected
			break;
		//-----------------------ERROR----------------------------
		if (result & EP0_ERROR)  								// ERROR detected
			break;
	}	// end of While(1)
   
	if (result & EP0_ACK) 	// on ACK transmission
		return TRUE;		// return OK

	return FALSE;			// fail transmission
}

//*****************************************************************************************
// Control Endpoint 0's USB Data Xfer
// ep0Xfer, endpoint 0 data transfer
//*****************************************************************************************
int ep0Xfer(BYTE usbaddr, WORD payload, pSetupPKG setup, BYTE *pData)
{
	xdata BYTE	pid  = PID_IN;
	xdata WORD	wLen = setup->wLength&0xFF; //WordSwap(setup->wLength);		// swap back for correct length
	xdata BYTE	ep0 = 0;								// always endpoint zero

	//----------------------------------------------------
	// SETUP token with 8-byte request on endpoint 0
	//----------------------------------------------------
	if (!usbXfer(usbaddr, ep0, PID_SETUP, 0, payload, 8, (BYTE*)setup)) 
   		return FALSE;

	//----------------------------------------------------
	// IN or OUT data stage on endpoint 0	
	//----------------------------------------------------
   	if (wLen)											// if there are data for transfer
	{
		if (setup->bmRequest & 0x80)					// host-to-device : IN token
		{
			pid  = PID_OUT;	
			if(!usbXfer(usbaddr, ep0, PID_IN, 0, payload, wLen, pData))
				return FALSE;
			payload = 0;
		}
		else											// device-to-host : OUT token
   		{							
			if(!usbXfer(usbaddr, ep0, PID_OUT, 0, payload, wLen, pData))
				return FALSE;
		}
	}

	//----------------------------------------------------
	// Status stage IN or OUT zero-length data packet
	//----------------------------------------------------
	if(!usbXfer(usbaddr, ep0, pid, 0, payload, 0, NULL))
		return FALSE;

	return TRUE;											
}

//*****************************************************************************************
// Control endpoint
//*****************************************************************************************
int VendorCmd(BYTE usbaddr,BYTE bReq,BYTE bCmd,WORD wValue,WORD wIndex,WORD wLen,BYTE *pData)
{ 
    xdata SetupPKG setup;

    setup.bmRequest  = bReq;
    setup.bRequest   = bCmd;
    setup.wValue     = wValue;
    setup.wIndex     = wIndex;
    setup.wLength    = wLen;	//WordSwap(wLen);

   	return ep0Xfer(usbaddr, uDev[usbaddr].wPayLoad[0], &setup, pData);
}

//*****************************************************************************************
// Set Device Address : 
//*****************************************************************************************
int SetAddress(WORD addr)
{
//	return VendorCmd(0,0,SET_ADDRESS, WordSwap(addr), 0, 0, NULL);
	return VendorCmd(0,0,SET_ADDRESS, addr, 0, 0, NULL);
}

//*****************************************************************************************
// Set Device Configuration : 
//*****************************************************************************************
int Set_Configuration(BYTE usbaddr, WORD wVal)
{
	return VendorCmd(usbaddr, 0, SET_CONFIG, WordSwap(wVal), 0, 0, NULL);
//	return VendorCmd(usbaddr, 0, SET_CONFIG, wVal, 0, 0, NULL);
}

//*****************************************************************************************
// Get Device Descriptor : Device, Configuration, String
//*****************************************************************************************
int GetDesc(BYTE usbaddr, WORD wValue, 	WORD wIndex, WORD wLen, BYTE *desc)
{ 
	return VendorCmd(usbaddr, 0x80, GET_DESCRIPTOR, wValue, wIndex, wLen, desc);
}

//*****************************************************************************************
// HID Get_Desc :
//*****************************************************************************************
int GetHid_Desc(BYTE usbaddr, WORD wValue, WORD wLen, BYTE *desc)
{ 
	return VendorCmd(usbaddr, 0x81, GET_DESCRIPTOR, wValue, 0, wLen, desc);
}

//*****************************************************************************************
// GetHUBDesc :
//*****************************************************************************************
int GetHubDesc(BYTE usbaddr, WORD wValue, WORD wLen, BYTE *desc)
{ 
	return VendorCmd(usbaddr, 0xA0, GET_DESCRIPTOR, wValue, 0, wLen, desc);
}

//*****************************************************************************************
// Get Status : (HUB)
//*****************************************************************************************
int GetStatus(BYTE usbaddr, BYTE *desc)
{ 
	return VendorCmd(usbaddr, 0x80, GET_STATUS, 0, 0, 2, desc);		 
}

//*****************************************************************************************
// PortFeature : (SET_FEATURE, CLEAR_FEATURE)
//*****************************************************************************************
int PortFeature(BYTE usbaddr, BYTE bReq, WORD wValue, BYTE cPort)
{ 
//	return VendorCmd(usbaddr, 0x23, bReq, WordSwap(wValue), WordSwap((WORD)cPort), 0, NULL);	
	return VendorCmd(usbaddr, 0x23, bReq, wValue, cPort, 0, NULL);
}

//*****************************************************************************************
// GetPortStatus :
//*****************************************************************************************
int GetPortStatus(BYTE usbaddr, BYTE cPort, BYTE *desc)
{ 
//	return VendorCmd(usbaddr, 0xA3, GET_STATUS, 0, WordSwap((WORD)cPort), 0x04, desc);
	return VendorCmd(usbaddr, 0xA3, GET_STATUS, 0, cPort, 0x04, desc);
}


//*****************************************************************************************
// USB Data Endpoint Read/Write
// wLen is in low byte first format
//*****************************************************************************************
int DataRW(BYTE usbaddr, BYTE epaddr, WORD wPayload, WORD wLen, BYTE *pData)
{
	xdata BYTE pid = PID_OUT;

	if(epaddr & 0x80)	// get direction of transfer
		pid = PID_IN;				

	if(usbXfer(usbaddr,epaddr&0x0F,pid,0,wPayload,wLen,pData))
		return TRUE;

	return FALSE;
}

//*****************************************************************************************
// USB Device Enumeration Process
// Support 1 confguration and interface #0 and alternate setting #0 only
// Support up to 1 control endpoint + 4 data endpoint only
//*****************************************************************************************
int EnumUsbDev(BYTE usbaddr)
{  
	int i;											// always reset USB transfer address 
	xdata BYTE uAddr = 0;							// for enumeration to Address #0
	xdata BYTE epLen;
	xdata WORD strLang;

	//------------------------------------------------
	// Reset only Slave device attached directly
	//------------------------------------------------
	uDev[0].wPayLoad[0] = 64;						// default 64-byte payload of Endpoint 0, address #0
	if(usbaddr == 1)								// bus reset for the device attached to SL811HS only
		USBReset();									// that will always have the USB address = 0x01 (for a hub)
    EZUSB_Delay(25);

	//------------------------------------------------
	// Get USB Device Descriptors on EP0 & Addr 0
	// with default 64-byte payload
	//------------------------------------------------
	pDev =(pDevDesc)DBUF;							// ask for 64 bytes on Addr #0
	if (!GetDesc(uAddr,DEVICE,0,18,DBUF))			// and determine the wPayload size
		return FALSE;								// get correct wPayload of Endpoint 0
	uDev[usbaddr].wPayLoad[0]=pDev->bMaxPacketSize0;// on current non-zero USB address

	//------------------------------------------------
	// Set Slave USB Device Address
	//------------------------------------------------
	if (!SetAddress(usbaddr)) 						// set to specific USB address
		return FALSE;								//
	uAddr = usbaddr;								// transfer using this new address

	//------------------------------------------------
	// Get USB Device Descriptors on EP0 & Addr X

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品日韩成人| 成人福利电影精品一区二区在线观看| 色美美综合视频| 亚洲色图在线视频| 色噜噜狠狠成人网p站| 亚洲影院理伦片| 欧美一区二区三区日韩视频| 美女诱惑一区二区| 欧美成人艳星乳罩| 国产精品一品视频| 国产精品黄色在线观看| 99久久精品国产一区| 亚洲在线成人精品| 欧美一区二区免费视频| 国产在线播放一区二区三区| 国产精品素人视频| 在线精品视频一区二区| 日本成人中文字幕在线视频| 久久亚洲综合色一区二区三区| 国产激情一区二区三区| 亚洲欧美日韩成人高清在线一区| 欧美三级韩国三级日本一级| 日韩电影网1区2区| 久久午夜老司机| 91香蕉视频mp4| 日韩国产精品91| 中文成人综合网| 91麻豆精品国产无毒不卡在线观看| 男人的天堂亚洲一区| 日本一区二区三级电影在线观看 | 欧美性大战久久| 久久精品国产精品亚洲精品| 日本一区二区免费在线| 欧美美女一区二区三区| 国产成人亚洲精品青草天美| 一区二区久久久久| 久久久精品tv| 欧美疯狂性受xxxxx喷水图片| 国产黑丝在线一区二区三区| 亚洲国产一区二区a毛片| 精品国产一区二区国模嫣然| 91国在线观看| 国产成人综合亚洲91猫咪| 亚洲一区二区黄色| 国产欧美精品一区| 日韩午夜精品电影| 欧洲精品中文字幕| 成人蜜臀av电影| 久久99精品国产.久久久久| 最新国产の精品合集bt伙计| 日韩一级欧美一级| 欧美丝袜丝交足nylons图片| 从欧美一区二区三区| 蜜桃91丨九色丨蝌蚪91桃色| 一区二区三区高清在线| 欧美国产1区2区| 亚洲福利一区二区三区| 国产天堂亚洲国产碰碰| 日韩精品在线网站| 色婷婷久久综合| 成人看片黄a免费看在线| 免费精品视频在线| 三级久久三级久久| 亚洲成人av一区二区三区| 日韩码欧中文字| 国产精品午夜春色av| 亚洲精品在线网站| 日韩欧美中文一区| 欧美一级日韩不卡播放免费| 欧美猛男男办公室激情| 欧美天天综合网| 色噜噜狠狠色综合欧洲selulu| 99国产精品久久久久| 成人黄色一级视频| 成人国产精品免费观看视频| 国产福利电影一区二区三区| 国产九色sp调教91| 国产成人在线影院| 国产成a人亚洲精| 成人毛片视频在线观看| 成a人片国产精品| 99久久综合精品| 色猫猫国产区一区二在线视频| k8久久久一区二区三区| av一区二区三区在线| jizzjizzjizz欧美| 国产欧美一区二区在线| 久久先锋影音av| 国产精品乱人伦| 亚洲免费观看高清完整版在线观看熊| 亚洲九九爱视频| 午夜电影一区二区三区| 免费看欧美女人艹b| 国产在线精品一区二区夜色| 国产真实精品久久二三区| 国产一区二区毛片| youjizz久久| 欧美在线一二三四区| 欧美欧美欧美欧美| 精品久久久久一区二区国产| 国产三级精品视频| 亚洲美腿欧美偷拍| 亚洲18女电影在线观看| 美女视频网站久久| va亚洲va日韩不卡在线观看| 欧美在线影院一区二区| 精品欧美乱码久久久久久1区2区| 国产日韩欧美制服另类| 一区二区三区波多野结衣在线观看| 亚洲精品欧美专区| 日本女人一区二区三区| 成人黄色片在线观看| 欧美亚洲高清一区| 久久日韩粉嫩一区二区三区| 亚洲柠檬福利资源导航| 麻豆91小视频| 99久久777色| 欧美一区二区三区在| 欧美激情资源网| 天天综合色天天综合色h| 国产传媒日韩欧美成人| 欧美性色aⅴ视频一区日韩精品| 欧美xxxxxxxx| 亚洲自拍偷拍网站| 国产一区二区三区日韩| 欧美亚洲综合久久| 欧美激情综合网| 日韩综合在线视频| 不卡的电影网站| 日韩午夜在线观看| 亚洲蜜臀av乱码久久精品| 国产九色精品成人porny| 欧美日韩亚洲丝袜制服| 国产精品区一区二区三| 另类专区欧美蜜桃臀第一页| 国产乱人伦精品一区二区在线观看| 一本色道久久综合亚洲aⅴ蜜桃 | 制服丝袜av成人在线看| 国产欧美日韩三区| 日韩黄色免费电影| 91视频免费看| 日本一区二区三区dvd视频在线| 日韩av一区二区三区四区| 91视频一区二区三区| 久久婷婷久久一区二区三区| 亚洲国产毛片aaaaa无费看| www.在线成人| 久久久精品中文字幕麻豆发布| 午夜精品影院在线观看| 在线观看一区不卡| 国产精品不卡一区二区三区| 国内外成人在线视频| 日韩一卡二卡三卡四卡| 偷拍一区二区三区| 欧美中文字幕久久| 粗大黑人巨茎大战欧美成人| 精品免费99久久| 视频一区视频二区中文| 欧美午夜精品久久久| 一区二区三区小说| 色哟哟在线观看一区二区三区| 国产精品日日摸夜夜摸av| 国产成人在线色| 久久影院午夜论| 国产成人一级电影| 国产日韩综合av| 国产传媒欧美日韩成人| 国产欧美精品在线观看| 成人黄色小视频| 亚洲图片你懂的| 色琪琪一区二区三区亚洲区| 日韩毛片一二三区| 欧洲国内综合视频| 亚洲一区二区精品久久av| 欧美视频在线观看一区| 日韩在线a电影| 欧美一级精品在线| 激情综合网最新| 国产肉丝袜一区二区| 99久久亚洲一区二区三区青草| 亚洲欧美一区二区视频| 色猫猫国产区一区二在线视频| 亚洲一二三四久久| 91精品久久久久久久99蜜桃| 秋霞电影一区二区| 久久精品一区二区三区不卡| 国产99精品国产| 亚洲女同ⅹxx女同tv| 欧美在线一二三四区| 美国欧美日韩国产在线播放| 久久久久9999亚洲精品| 99精品久久免费看蜜臀剧情介绍| 一区二区三区欧美日| 欧美精品欧美精品系列| 国产真实乱子伦精品视频| 自拍视频在线观看一区二区| 欧美日韩第一区日日骚| 韩国成人福利片在线播放| 国产精品久久久久久户外露出 | 91精品国产综合久久小美女|