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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? usb.c

?? 編寫用于S3c2410系列處理器的 BIOS源碼
?? C
字號:
#include "def.h"
#include "2410addr.h"
#include "2410lib.h"
#include "timer.h"

#include "option.h"
#include "2410usb.h"
#include "usblib.h"
#include "usbsetup.h"
#include "usbout.h"
#include "usbin.h"

//======================================================
volatile U32 downloadAddress = 0;
volatile U8 *downPt;
volatile U32 downloadFileSize = 0;
volatile U32 totalDmaCount;
volatile U16 checkSum;

volatile int isUsbdSetConfiguration;

//======================================================
void __irq IsrUsbd(void)
{
    U8 usbdIntpnd, epIntpnd;
    U8 saveIndexReg = rINDEX_REG;
    usbdIntpnd = rUSB_INT_REG;
    epIntpnd = rEP_INT_REG;

	//	printf("usbd i %x\n", usbdIntpnd);
    if(usbdIntpnd&SUSPEND_INT)
    {
    	rUSB_INT_REG=SUSPEND_INT;    	
    }
    if(usbdIntpnd&RESUME_INT)
    {
    	rUSB_INT_REG=RESUME_INT;    	
    }
    if(usbdIntpnd&RESET_INT)
    {
    	    	
    	//ResetUsbd();
    	ReconfigUsbd();

    	rUSB_INT_REG=RESET_INT;  //RESET_INT should be cleared after ResetUsbd().   	

        //PrepareEp1Fifo(); 
    }

    if(epIntpnd&EP0_INT)
    {
		rEP_INT_REG=EP0_INT;  
    	Ep0Handler();
    }
    if(epIntpnd&EP1_INT)
    {
    	rEP_INT_REG=EP1_INT;  
    	Ep1Handler();
    }

    if(epIntpnd&EP2_INT)
    {
    	rEP_INT_REG=EP2_INT;  
    	//Ep2Handler();
    }

    if(epIntpnd&EP3_INT)
    {
    	rEP_INT_REG=EP3_INT;
    	Ep3Handler();
    }

    if(epIntpnd&EP4_INT)
    {
    	rEP_INT_REG=EP4_INT;    		
    	//Ep4Handler();
    }

    ClearPending(BIT_USBD);	 
    
    rINDEX_REG=saveIndexReg;
}

U32 UsbState;
U32 UsbInLength;
U8 *UsbTxAddr;

void UsbdInit(U8 fun)
{
	isUsbdSetConfiguration = 0;
	ChangeUPllValue(40, 4, 1);  //UCLK=48Mhz     
	InitDescriptorTable(fun);
	ReconfigUsbd();
//	PrepareEp1Fifo();

	UsbState = 0;
}

//======================================================
void WaitDownload(void);

void UsbMain(void)
{	
	U8 fun;
	
	rGPHCON = rGPHCON&~(0xf<<18)|(0x5<<18);
    //To enhance the USB signal quality.
    //CLKOUT 0,1=OUTPUT to reduce the power consumption.	

	rGPGCON &= 0xfff3ffff;	//GPG9 input
/*	puts("Please select usb function\n1:download\n2:usb test\n");
	while(1)
	{
		fun = '1';//getch();
		if((fun=='1')||(fun=='2'))
		{
			fun -= '0';
			break;
		}	
		 
	}*/
	fun = 1;
	UsbdInit(fun);	
		
	Delay(1000);
	rGPGCON |= 0x00040000;	
	rGPGDAT |= 0x0200;		//GPG9 ouput 1

	pISR_USBD =(unsigned)IsrUsbd;
	ClearPending(BIT_USBD);
	EnableIrq(BIT_USBD);
	
	WaitDownload();
				
	DisableIrq(BIT_USBD);

	rGPGCON &= 0xfff3ffff;	//GPG9 input
}

U32 UsbPoll(void);

/*************************************************************/
static __inline void cpu_arm920_cache_clean_invalidate_all(void)
{
	__asm{
		mov	r1, #0		
		mov	r1, #7 << 5			  	/* 8 segments */
cache_clean_loop1:		
		orr	r3, r1, #63UL << 26	  	/* 64 entries */
cache_clean_loop2:	
		mcr	p15, 0, r3, c7, c14, 2	/* clean & invalidate D index */
		subs	r3, r3, #1 << 26
		bcs	cache_clean_loop2		/* entries 64 to 0 */
		subs	r1, r1, #1 << 5
		bcs	cache_clean_loop1		/* segments 7 to 0 */
		mcr	p15, 0, r1, c7, c5, 0	/* invalidate I cache */
		mcr	p15, 0, r1, c7, c10, 4	/* drain WB */
	}
}
void cache_clean_invalidate(void)
{
	cpu_arm920_cache_clean_invalidate_all();
}

static __inline void cpu_arm920_tlb_invalidate_all(void)
{
	__asm{
		mov	r0, #0
		mcr	p15, 0, r0, c7, c10, 4	/* drain WB */
		mcr	p15, 0, r0, c8, c7, 0	/* invalidate I & D TLBs */
	}
}

void tlb_invalidate(void)
{
	cpu_arm920_tlb_invalidate_all();
}

void disable_irq(void);

void call_linux(U32 a0, U32 a1, U32 a2)
{
	int i, j;
	void (*goto_start)(U32, U32);
	cache_clean_invalidate();
	tlb_invalidate();	

//	DisableInt();
	disable_irq();
	//If write-back is used,the DCache should be cleared.
	for(i=0; i<64; i++)
		for(j=0; j<8; j++)
			MMU_CleanInvalidateDCacheIndex((i<<26)|(j<<5));
	__asm {
		mov	r0, #0
		mcr	p15, 0, r0, c7, c10, 4	// drain WB
	}
	MMU_DisableDCache();
	MMU_DisableICache();
	MMU_InvalidateICache();
	MMU_DisableMMU();
	MMU_InvalidateTLB();

/*	__asm{
//		mov	r0, a0//%0
//		mov	r1, a1//%1
//		mov	r2, a2//%2
		mov	ip, #0
		mcr	p15, 0, ip, c13, c0, 0	// zero PID 
		mcr	p15, 0, ip, c7, c7, 0	// invalidate I,D caches
		mcr	p15, 0, ip, c7, c10, 4	// drain write buffer
		mcr	p15, 0, ip, c8, c7, 0	// invalidate I,D TLBs 
		mrc	p15, 0, ip, c1, c0, 0	// get control register 
		bic	ip, ip, #0x0001			// disable MMU 
		mcr	p15, 0, ip, c1, c0, 0	// write control register 
		//mov	pc, r2
		//nop
		//nop
		// no outpus 
		//: "r" (a0), "r" (a1), "r" (a2)
	}
*/
//	SetClockDivider(1, 1);
//	SetSysFclk(FCLK_200M);		//start kernel, use 200M
//	Delay(1000);
//	disable_irq();
	goto_start = (void (*)(U32, U32))a2;
	(*goto_start)(a0, a1);	
}

/*************************************************************/
void WaitDownload(void)
{
    U16 UsbConnected = 0;
    U32 i;
    U32 j;
    U16 cs;
    U16 dnCS;
    U32 temp;            
	U8 tempMem[16];    
    
    checkSum = 0;            
    downloadAddress=(U32)tempMem; 		//_RAM_STARTADDRESS; 
    downPt=(unsigned char *)downloadAddress;	//This address is used for receiving first 8 byte.
    downloadFileSize = 0;    
    
#if 0
    MMU_DisableICache(); 
        //For multi-ICE. 
        //If ICache is not turned-off, debugging is started with ICache-on.
#endif

    /*******************************/
    /*    Test program download    */
    /*******************************/
    
    puts("\nUSB download file, press Esc key to exit\n");
/*    
	//	while(!isUsbdSetConfiguration)
    //	{
    //		if(getkey()==0x1b)
    //		return;    		
	//	}	    	
    //	puts("USB connected\n");
    	
    	DisableIrq(BIT_USBD);
    	DisableIrq(BIT_DMA2);
    	
    	while(!UsbPoll())
    	{
	    	if(getkey()==0x1b)
	    	{	    	
		    	puts("USB download aborted.\n");
		    	return;    	
		    }
	    }
    	
    	DbgOut("End, Received %dBytes\n",(U32)downPt-downloadAddress);
    	checkSum=checkSum - *((unsigned char *)(downloadAddress+downloadFileSize-8-2))
				- *( (unsigned char *)(downloadAddress+downloadFileSize-8-1) );	
    	goto PollRxEnd;
*/    
	j=0;   

	while(downloadFileSize==0)
	{
	//	if(j%0x50000==0)
	//		Led_Display(0x1);
	//	if(j%0x50000==0x28000)
	//		Led_Display(0x0);
		j++;
		if(getkey()==0x1b)
		{	
			puts("USB download aborted.\n");			
			return;
		}
		
		if(isUsbdSetConfiguration)
		{
			if(!UsbConnected)
				puts("Now USB is connected.");
			UsbConnected = 1;			
		}		
    }  

#if USBDMA     
    ClearEp3OutPktReady();	//中斷處理讀完第一個(gè)包后未清OutPktReady位,在此清掉

    if(downloadFileSize>EP3_PKT_SIZE)
    {
        if(downloadFileSize<=(0x80000))
      	    ConfigEp3DmaMode(downloadAddress+EP3_PKT_SIZE-8,downloadFileSize-EP3_PKT_SIZE);		
      	else
			ConfigEp3DmaMode(downloadAddress+EP3_PKT_SIZE-8,0x80000-EP3_PKT_SIZE);		
 		totalDmaCount=0;
    }
    else					// downloadFileSize < EP3_PKT_SIZE    
		totalDmaCount=downloadFileSize;		    
#endif

	printf("\nNow, Downloading [ADDRESS:%xh,TOTAL:%d]\n",
			downloadAddress, downloadFileSize);	

	j=0x80000;
	
#if USBDMA    
    while(totalDmaCount<downloadFileSize)
    {
    	if((rDCDST2-(U32)downloadAddress+8)>=j)
		{
		/*	static int led = 0x0;
			
			led ^=2;
			Led_Display(led);*/
	    	putch('d');	    	
   	    	j+=0x80000;
		}		
		if(getkey()==0x1b)
		{
			int i;
			
			ConfigEp3IntMode();
			DisableIrq(BIT_DMA2);
			DbgOut("\nReceive process aborted.\n");
			DbgOut("Received %d bytes\n", totalDmaCount);
			for(i=0;i<48;i++)
			{
				printf("0x%x = %x\n", downloadAddress+i*0x100000, *(U32 *)(downloadAddress+i*0x100000));
			}
			return;
		}
    }
#else
    while(((U32)downPt-downloadAddress)<(downloadFileSize-8))
    {
		if(((U32)downPt-downloadAddress)>=j)
		{
			static int led = 0x0;
			
			led ^= 2;
			Led_Display(led);
	    	putch('i');
	   	    j+=0x80000;
		}
		if(getkey()==0x1b)
		{
			int i;			
			
			DbgOut("\nReceive process aborted.\n");
			DbgOut("Received %d bytes\n", (U32)downPt-downloadAddress);			
			for(i=0;i<48;i++)
			{
				printf("0x%x = %x\n", downloadAddress+i*0x100000, *(U32 *)(downloadAddress+i*0x100000));
			}			
			return;
		}
    }
#endif    
    
#if USBDMA    
    /*******************************/
    /*     Verify check sum        */
    /*******************************/

    printf("Now, Checksum calculation\n");

    cs=0;    
    i=(downloadAddress);
    j=(downloadAddress+downloadFileSize-10)&0xfffffffc;
    while(i<j)
    {
    	temp=*((U32 *)i);
    	i+=4;
    	cs+=(U16)(temp&0xff);
    	cs+=(U16)((temp&0xff00)>>8);
    	cs+=(U16)((temp&0xff0000)>>16);
    	cs+=(U16)((temp&0xff000000)>>24);
    }

    i=(downloadAddress+downloadFileSize-10)&0xfffffffc;
    j=(downloadAddress+downloadFileSize-10);
    while(i<j)
    {
	  	cs+=*((U8 *)i++);
    }
    
    checkSum = cs;
#else
	//checkSum was calculated including dnCS. So, dnCS should be subtracted.
	checkSum=checkSum - *((unsigned char *)(downloadAddress+downloadFileSize-8-2))
				- *( (unsigned char *)(downloadAddress+downloadFileSize-8-1) );	
#endif	  
//PollRxEnd:
    dnCS=*((unsigned char *)(downloadAddress+downloadFileSize-8-2))+
	(*((unsigned char *)(downloadAddress+downloadFileSize-8-1))<<8);

    if(checkSum!=dnCS)
    {
		printf("Checksum Error!!! MEM:%x DN:%x\n",checkSum,dnCS);
		return;
    }
	
	DisableIrq(BIT_USBD);
	
	printf("Download O.K.\n");
    Uart_TxEmpty(0);

	wait_print_end();
{
/*	U8 extra_info[256];
	U16 extra_len;
	
	extra_len = *(U16 *)downloadAddress;
	if(extra_len>=sizeof(extra_info)) {
		printf("Extra info length too long > %d\n", sizeof(extra_info)-1);
		return;
	}

	for(i=0; i<extra_len; i++)
		extra_info[i] = *(U8 *)(downloadAddress+i);
	extra_info[i] = 0;
	
	downloadFileSize -= extra_len+10;
	for(i=0; i<downloadFileSize; i++)
		*(U8 *)(downloadAddress+i) = *(U8 *)(downloadAddress+i+extra_len);
	
	printf("%s\n", extra_info+sizeof(extra_len));*/
	downloadFileSize -= 10;
}	
	puts("\nDo you want to run? [y/n] : ");
	
		rGPGCON &= 0xfff3ffff;	//GPG9 input
		
	while(1) {		
		U8 key;
		
		key = getch();
		if(key=='y'||key=='Y') {		
			putch(key);
			putch('\n');		
		
			rINTMSK = BIT_ALLMSK;
			Delay(2000);
			call_linux(0, 193, downloadAddress);
		/*	{
				void (*fun)(void) = (void (*)(void))downloadAddress;
				(*fun)();
			}*/
    	}
    	if(key=='n'||key=='N') {    	
    		putch(key);
    		putch('\n');
    		break;
    	}
    }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合色狠狠综合色| 99精品在线免费| 精品国内二区三区| 极品美女销魂一区二区三区| 久久综合九色综合97_久久久 | 亚洲最快最全在线视频| 欧美这里有精品| 五月天丁香久久| 精品国产免费视频| 成人理论电影网| 一区二区三区产品免费精品久久75| 欧美色爱综合网| 偷拍一区二区三区| 国产视频一区在线播放| 97超碰欧美中文字幕| 日韩国产精品91| 欧美国产日本视频| 在线播放亚洲一区| 国产精品乡下勾搭老头1| 亚洲理论在线观看| 日韩一区二区免费视频| 成人动漫一区二区在线| 天天爽夜夜爽夜夜爽精品视频| 精品国产露脸精彩对白| 色欧美乱欧美15图片| 美女一区二区久久| 中文字幕日本不卡| 日韩欧美精品三级| 91亚洲国产成人精品一区二三| 婷婷久久综合九色国产成人| 亚洲国产精品av| 欧美夫妻性生活| 懂色av一区二区夜夜嗨| 日韩电影免费在线看| 中文字幕欧美国产| 日韩三级av在线播放| 99re成人精品视频| 加勒比av一区二区| 亚洲精品国产成人久久av盗摄| 精品免费一区二区三区| 日本高清免费不卡视频| 国产精品综合在线视频| 午夜精品久久一牛影视| 亚洲视频资源在线| 久久久国产精华| 5566中文字幕一区二区电影| 99r国产精品| 国产精品综合一区二区| 美女一区二区三区在线观看| 亚洲午夜电影在线观看| 国产精品免费丝袜| 久久久www成人免费毛片麻豆| 欧美日韩亚洲丝袜制服| 99re这里只有精品视频首页| 国产精品一二三四| 蜜桃av噜噜一区二区三区小说| 亚洲国产视频在线| 依依成人精品视频| 中文字幕日韩av资源站| 日本一区二区成人在线| 久久一区二区三区国产精品| 日韩女优毛片在线| 91麻豆精品国产91久久久久久久久 | 亚洲精品在线网站| 日韩一区二区三| 4438x成人网最大色成网站| 欧美日韩中文另类| 欧美日韩综合在线免费观看| 色婷婷综合久色| 91蜜桃免费观看视频| 91网站视频在线观看| av激情综合网| k8久久久一区二区三区 | 中文字幕亚洲成人| 日韩一区在线免费观看| 国产精品美女久久久久aⅴ| 国产欧美日韩麻豆91| 国产午夜亚洲精品午夜鲁丝片 | 欧美一区中文字幕| 7799精品视频| 精品国产欧美一区二区| 久久综合色播五月| 国产日韩欧美不卡在线| 久久久亚洲综合| 中文字幕第一区二区| 亚洲视频在线观看三级| 一区二区三区国产精华| 亚洲aⅴ怡春院| 日韩av中文在线观看| 久久激情五月激情| 国产成人午夜视频| 9人人澡人人爽人人精品| 色吧成人激情小说| 欧美一级精品在线| 国产色产综合产在线视频| 精品一区二区三区在线视频| 五月婷婷久久丁香| 日本不卡免费在线视频| 黄页视频在线91| 懂色av一区二区三区免费观看 | 91黄色免费看| 欧美日韩不卡在线| 精品国产伦一区二区三区免费| 精品国产91乱码一区二区三区| 久久精品网站免费观看| 亚洲特级片在线| 亚洲成av人片一区二区三区| 精品中文字幕一区二区小辣椒| 国产69精品久久99不卡| 在线观看91视频| 精品国产乱码久久久久久闺蜜 | 亚洲主播在线播放| 捆绑紧缚一区二区三区视频| 成人综合婷婷国产精品久久免费| 色婷婷综合久色| 欧美精品黑人性xxxx| 欧美v日韩v国产v| 国产精品麻豆久久久| 水野朝阳av一区二区三区| 韩国毛片一区二区三区| 在线免费av一区| 欧美精品一区二区三区在线| 一区二区三区四区中文字幕| 久久黄色级2电影| 色94色欧美sute亚洲13| 久久久久久久久久久黄色| 亚洲成a人片在线不卡一二三区| 久久av老司机精品网站导航| 日本精品裸体写真集在线观看| 精品国产乱码久久久久久免费| 亚洲精品一二三四区| 国产精品996| 日韩一区二区三区在线视频| 亚洲精品v日韩精品| 国产成人精品网址| 日韩一区二区在线观看视频播放| 亚洲欧美乱综合| 国产精品88av| 精品少妇一区二区三区视频免付费| 夜夜嗨av一区二区三区中文字幕| 懂色av一区二区三区免费观看| 日韩精品专区在线影院重磅| 亚洲国产va精品久久久不卡综合| 欧美日韩视频第一区| 国产精品免费av| 奇米影视一区二区三区| 欧美午夜视频网站| 中文字幕亚洲一区二区va在线| 国产毛片精品视频| 日韩亚洲国产中文字幕欧美| 亚洲一区在线观看视频| 91色婷婷久久久久合中文| 国产精品无人区| 精品无码三级在线观看视频| 日韩欧美一级片| 日韩精品国产精品| 欧美日韩在线播放三区四区| 亚洲一区二区黄色| 在线亚洲+欧美+日本专区| 亚洲男人的天堂一区二区| 成人免费不卡视频| 国产精品看片你懂得| 国产成人综合视频| 国产日韩欧美精品一区| 国产一区二区三区黄视频 | 色94色欧美sute亚洲线路一久| 日韩理论电影院| 99精品视频在线免费观看| 国产精品久久久久久久久果冻传媒| 国产一区欧美日韩| 日本一区二区三区视频视频| 成人免费视频caoporn| 国产精品麻豆欧美日韩ww| eeuss国产一区二区三区| 欧美国产日韩在线观看| 成人三级在线视频| 亚洲欧洲综合另类| 精品视频免费在线| 免费在线看成人av| 久久久久久久久久久电影| 岛国精品一区二区| 亚洲视频精选在线| 欧美日韩一区小说| 久国产精品韩国三级视频| 欧美精品一区在线观看| 懂色一区二区三区免费观看| 亚洲视频小说图片| 欧美系列在线观看| 美女视频一区在线观看| 国产日韩欧美不卡| 色悠久久久久综合欧美99| 日韩成人一级片| 国产亚洲欧美一级| 色婷婷精品大在线视频| 香蕉成人伊视频在线观看| 久久综合狠狠综合久久综合88| 高清久久久久久| 五月婷婷激情综合| 日本一区二区视频在线| 欧美日韩精品一区二区三区蜜桃|