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

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

?? u241mon.c.bak

?? source for s3c2410 test program,including lcd ,nand flash ,uart and so on
?? BAK
字號:
/****************************************************************
 NAME: u241mon.c
 DESC: u241mon entry point,menu,download
 HISTORY:
 Mar.25.2002:purnnamu: S3C2400X profile.c is ported for S3C2410X.
 Mar.27.2002:purnnamu: DMA is enabled.
 Apr.01.2002:purnnamu: isDownloadReady flag is added.
 Apr.10.2002:purnnamu: - Selecting menu is available in the waiting loop. 
                         So, isDownloadReady flag gets not needed
                       - UART ch.1 can be selected for the console.
 Aug.20.2002:purnnamu: revision number change 0.2 -> R1.1       
 Sep.03.2002:purnnamu: For USB signal quality, the unused CLKOUT0,1 is disabled.
                       In real board, the VDDIO power should be stable for good USB signal quality.
 ****************************************************************/

#include <stdlib.h>
#include <string.h>
#include "def.h"
#include "option.h"
#include "2410addr.h"
#include "2410lib.h"
#include "2410slib.h"
#include "mmu.h"
#include "profile.h"
#include "memtest.h"

#include "usbmain.h"
#include "usbout.h"
#include "usblib.h"
#include "2410usb.h"

void Isr_Init(void);
void HaltUndef(void);
void HaltSwi(void);
void HaltPabort(void);
void HaltDabort(void);
void Lcd_Off(void);
void WaitDownload(void);
void Menu(void);

//#define DOWNLOAD_ADDRESS _RAM_STARTADDRESS
volatile U32 downloadAddress;

void (*restart)(void)=(void (*)(void))0x0;
void (*run)(void);


volatile unsigned char *downPt;
volatile U32 downloadFileSize;
volatile U16 checkSum;
volatile unsigned int err=0;
volatile U32 totalDmaCount;

volatile int isUsbdSetConfiguration;

int download_run=0;
U32 tempDownloadAddress;
int menuUsed=0;

extern char Image$$RW$$Limit[];
U32 *pMagicNum=(U32 *)Image$$RW$$Limit;
int consoleNum;

void Main(void)
{
    char *mode;
    int i;
    U8 key;
    
    #if ADS10   
    __rt_lib_init(); //for ADS 1.0
    #endif

    ChangeClockDivider(1,1);    // 1:2:4    
    //ChangeMPllValue(82,2,1);  //FCLK=135.0Mhz     
    ChangeMPllValue(82,1,1);    //FCLK=180.0Mhz     
    //ChangeMPllValue(161,3,1); //FCLK=202.8Mhz     
    
    Port_Init();
    
    rGPHCON = rGPHCON&~(0xf<<18)|(0x5<<18);   
    //To enhance the USB signal quality.
    //CLKOUT 0,1=OUTPUT to reduce the power consumption.
    
    Isr_Init();
    if(*pMagicNum!=0x12345678)
    	consoleNum=0;
    else
    	consoleNum=1;
    	
    Uart_Init(0,115200);
    Uart_Select(consoleNum);

    rMISCCR=rMISCCR&~(1<<3); // USBD is selected instead of USBH1 
    rMISCCR=rMISCCR&~(1<<13); // USB port 1 is enabled.

//
//  USBD should be initialized first of all.
//
    isUsbdSetConfiguration=0;

#if 0
    UsbdMain(); 
    MMU_Init(); //MMU should be reconfigured or turned off for the debugger, 
    //After downloading, MMU should be turned off for the MMU based program,such as WinCE.	
#else
    MMU_EnableICache();  
    UsbdMain(); 
#endif
    Delay(0);  //calibrate Delay()
    
    pISR_SWI=(_ISR_STARTADDRESS+0xf0);    //for pSOS

    Led_Display(0x6);

#if USBDMA
    mode="DMA";
#else
    mode="Int";
#endif

    Uart_Printf("\n\n");
    Uart_Printf("+--------------------------------------------+\n");
    Uart_Printf("| S3C2410X USB Downloader ver R1.1 AUG/20/02 |\n");
    Uart_Printf("+--------------------------------------------+\n");
    Uart_Printf("FCLK=%dMHz,%s mode\n",FCLK/1000000,mode); 
    Uart_Printf("USB: IN_ENDPOINT:1 OUT_ENDPOINT:3\n"); 
    Uart_Printf("FORMAT: <ADDR(DATA):4>+<SIZE(n+10):4>+<DATA:n>+<CS:2>\n");
    Uart_Printf("NOTE: 1. Power off/on or press the reset button for 1 sec\n");
    Uart_Printf("         in order to get a valid USB device address.\n");
    Uart_Printf("      2. For additional menu, Press any key. \n");
    Uart_Printf("\n");

    download_run=1; //The default menu is the Download & Run mode.

    while(1)
    {
    	if(menuUsed==1)Menu();
    	WaitDownload();    
    }

}



void Menu(void)
{
    int i;
    U8 key;
    menuUsed=1;
    while(1)
    {
        Uart_Printf("\n###### Select Menu ######\n");
        Uart_Printf(" [0] Download & Run\n");
        Uart_Printf(" [1] Download Only\n");
        Uart_Printf(" [2] Test SDRAM \n");
        Uart_Printf(" [3] Change The Console UART Ch.\n");
        key=Uart_Getch();
        
        switch(key)
        {
        case '0':
            Uart_Printf("\nDownload&Run is selected.\n\n");
            download_run=1;
            return;
        case '1':
            Uart_Printf("\nDownload Only is selected.\n");
            Uart_Printf("Enter a new temporary download address(0x3...):");
            tempDownloadAddress=Uart_GetIntNum();
            download_run=0;
            Uart_Printf("The temporary download address is 0x%x.\n\n",tempDownloadAddress);
            return;
        case '2':
            Uart_Printf("\nMemory Test is selected.\n");        
	    MemoryTest();
	    Menu();
	    return;
            break;
        case '3':
            Uart_Printf("\nWhich UART channel do you want to use for the console?[0/1]\n");
            if(Uart_Getch()!='1')
            {
	    	*pMagicNum=0x0;
		Uart_Printf("UART ch.0 will be used for console at next boot.\n");        	    	
	    }
	    else
	    {
	        *pMagicNum=0x12345678;
 		Uart_Printf("UART ch.1 will be used for console at next boot.\n");        
                Uart_Printf("UART ch.0 will be used after long power-off.\n");
	    }
            Uart_Printf("System is waiting for a reset. Please, Reboot!!!\n");
            while(1);
            break;

        default:
            break;
	}	
    }	    

}



void WaitDownload(void)
{
    U32 i;
    U32 j;
    U16 cs;
    U32 temp;
    U16 dnCS;
    int first=1;
    float time;
    U8 tempMem[16];
    U8 key;
    
    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    */
    /*******************************/
    j=0;

    if(isUsbdSetConfiguration==0)
    {
	Uart_Printf("USB host is not connected yet.\n");
    }

    while(downloadFileSize==0)
    {
        if(first==1 && isUsbdSetConfiguration!=0)
        {
            Uart_Printf("USB host is connected. Waiting a download.\n");
            first=0;
        }

	if(j%0x50000==0)Led_Display(0x6);
	if(j%0x50000==0x28000)Led_Display(0x9);
	j++;

	key=Uart_GetKey();
	if(key!=0)
	{
	    Menu();
            first=1; //To display the message,"USB host ...."
	}

    }

    Timer_InitEx();      
    Timer_StartEx();  

#if USBDMA    

    rINTMSK&=~(BIT_DMA2);  

    ClearEp3OutPktReady(); 
    	// indicate the first packit is processed.
    	// has been delayed for DMA2 cofiguration.

    if(downloadFileSize>EP3_PKT_SIZE)
    {
        if(downloadFileSize<=(0x80000))
        {
      	    ConfigEp3DmaMode(downloadAddress+EP3_PKT_SIZE-8,downloadFileSize-EP3_PKT_SIZE);	
  	    //wait until DMA reload occurs.
	    while((rDSTAT2&0xfffff)==0);

      	    //will not be used.
       	    rDIDST2=(downloadAddress+downloadFileSize-EP3_PKT_SIZE);  
       	    rDIDSTC2=(0<<1)|(0<<0);  
	    rDCON2=rDCON2&~(0xfffff)|(0);        	    
	}
      	else
      	{
      	    ConfigEp3DmaMode(downloadAddress+EP3_PKT_SIZE-8,0x80000-EP3_PKT_SIZE);
  	    //wait until DMA reload occurs.
	    while((rDSTAT2&0xfffff)==0);
      	    
    	    if(downloadFileSize>(0x80000*2))//for 1st autoreload
    	    {
        	rDIDST2=(downloadAddress+0x80000-8);  //for 1st autoreload.
        	rDIDSTC2=(0<<1)|(0<<0);  
    	        rDCON2=rDCON2&~(0xfffff)|(0x80000);        	  

  		while(rEP3_DMA_TTC<0xfffff)
  		{
  		    rEP3_DMA_TTC_L=0xff; 
  		    rEP3_DMA_TTC_M=0xff;
  		    rEP3_DMA_TTC_H=0xf;
  		}
    	    }	
 	    else
 	    {
 	        rDIDST2=(downloadAddress+0x80000-8);  //for 1st autoreload.
      	        rDIDSTC2=(0<<1)|(0<<0);  
 	        rDCON2=rDCON2&~(0xfffff)|(downloadFileSize-0x80000); 		

  		while(rEP3_DMA_TTC<0xfffff)
  		{
  		    rEP3_DMA_TTC_L=0xff; 
  		    rEP3_DMA_TTC_M=0xff;
  		    rEP3_DMA_TTC_H=0xf;
  		}
	    }
	}
 	totalDmaCount=0;
    }
    else
    {
	totalDmaCount=downloadFileSize;
    }
#endif

    Uart_Printf("\nNow, Downloading [ADDRESS:%xh,TOTAL:%d]\n",
    		downloadAddress,downloadFileSize);
    Uart_Printf("RECEIVED FILE SIZE:%8d",0);

#if USBDMA    
    j=0x10000;

    while(1)
    {
    	if( (rDCDST2-(U32)downloadAddress+8)>=j)
	{
	    Uart_Printf("\b\b\b\b\b\b\b\b%8d",j);
   	    j+=0x10000;
	}
	if(totalDmaCount>=downloadFileSize)break;
    }

#else
    j=0x10000;

    while(((U32)downPt-downloadAddress)<(downloadFileSize-8))
    {
	if( ((U32)downPt-downloadAddress)>=j)
	{
	    Uart_Printf("\b\b\b\b\b\b\b\b%8d",j);
   	    j+=0x10000;
	}
    }
#endif
    time=Timer_StopEx();
    Uart_Printf("\b\b\b\b\b\b\b\b%8d",downloadFileSize);	
    Uart_Printf("(%5.1fKB/S,%3.1fS)\n",(float)(downloadFileSize/time/1000.),time);
    
#if USBDMA    
    /*******************************/
    /*     Verify check sum        */
    /*******************************/

    Uart_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	  

    dnCS=*((unsigned char *)(downloadAddress+downloadFileSize-8-2))+
	(*( (unsigned char *)(downloadAddress+downloadFileSize-8-1) )<<8);

    if(checkSum!=dnCS)
    {
	Uart_Printf("Checksum Error!!! MEM:%x DN:%x\n",checkSum,dnCS);
	return;
    }

    Uart_Printf("Download O.K.\n\n");
    Uart_TxEmpty(consoleNum);


    if(download_run==1)
    {
        rINTMSK=BIT_ALLMSK;
    	run=(void (*)(void))downloadAddress;
	run();
    }
}




void Isr_Init(void)
{
    pISR_UNDEF=(unsigned)HaltUndef;
    pISR_SWI  =(unsigned)HaltSwi;
    pISR_PABORT=(unsigned)HaltPabort;
    pISR_DABORT=(unsigned)HaltDabort;
    rINTMOD=0x0;	  // All=IRQ mode
    rINTMSK=BIT_ALLMSK;	  // All interrupt is masked.

    //pISR_URXD0=(unsigned)Uart0_RxInt;	
    //rINTMSK=~(BIT_URXD0);   //enable UART0 RX Default value=0xffffffff

#if 1
    pISR_USBD =(unsigned)IsrUsbd;
    pISR_DMA2 =(unsigned)IsrDma2;
#else
    pISR_IRQ =(unsigned)IsrUsbd;	
    	//Why doesn't it receive the big file if use this. (???)
    	//It always stops when 327680 bytes are received.
#endif    
    ClearPending(BIT_DMA2);
    ClearPending(BIT_USBD);
    //rINTMSK&=~(BIT_USBD);  
   
    //pISR_FIQ,pISR_IRQ must be initialized
}


void HaltUndef(void)
{
    Uart_Printf("Undefined instruction exception!!!\n");
    while(1);
}

void HaltSwi(void)
{
    Uart_Printf("SWI exception!!!\n");
    while(1);
}

void HaltPabort(void)
{
    Uart_Printf("Pabort exception!!!\n");
    while(1);
}

void HaltDabort(void)
{
    Uart_Printf("Dabort exception!!!\n");
    while(1);
}



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久夜精品精品免费| 国产精品系列在线播放| 99久久精品国产一区二区三区| 亚洲精品一线二线三线| 国产综合久久久久影院| 2欧美一区二区三区在线观看视频| 国内精品久久久久影院色| 国产午夜精品理论片a级大结局| 国产一区二区日韩精品| 国产精品久久久久aaaa樱花| 91麻豆自制传媒国产之光| 亚洲高清免费在线| 91麻豆精品国产自产在线观看一区 | 在线观看国产日韩| 免费观看成人av| 国产欧美日韩不卡免费| 91蜜桃在线免费视频| 午夜精品免费在线观看| 精品少妇一区二区三区免费观看 | 日韩激情一二三区| 欧美精品一区二| 成人精品视频一区二区三区 | 激情综合亚洲精品| 综合欧美亚洲日本| 欧美日韩精品电影| 国产麻豆精品在线| 一区二区三区在线视频免费观看| 欧美一级精品在线| 99麻豆久久久国产精品免费| 亚洲成av人片www| 久久日韩精品一区二区五区| 波多野结衣中文字幕一区| 五月天中文字幕一区二区| 国产日韩欧美精品电影三级在线| 日本高清不卡aⅴ免费网站| 美女精品一区二区| 亚洲美女免费视频| 日韩久久精品一区| 一本一本大道香蕉久在线精品| 日本va欧美va瓶| 亚洲精品国产高清久久伦理二区| 日韩午夜激情视频| 91黄视频在线| 国产成人a级片| 日本亚洲三级在线| 亚洲综合色在线| 国产精品视频在线看| 91精品欧美久久久久久动漫| av网站免费线看精品| 精品亚洲国内自在自线福利| 夜夜精品视频一区二区| 国产精品视频一二三区| 精品久久久久久久久久久久包黑料| 91论坛在线播放| 高清在线不卡av| 久久99久久精品| 日本不卡一二三| 天天综合天天做天天综合| 最新久久zyz资源站| 久久亚洲二区三区| 精品少妇一区二区三区在线播放| 欧美日韩中字一区| 色欧美日韩亚洲| 成人av电影观看| 成人综合婷婷国产精品久久蜜臀 | 三级一区在线视频先锋 | 久久精品人人做| 欧美日韩在线播放| 日本aⅴ免费视频一区二区三区| 处破女av一区二区| 麻豆91在线播放| 日本一区中文字幕| 午夜国产精品影院在线观看| 亚洲图片另类小说| 中文字幕日韩一区二区| 久久精品视频在线免费观看| 精品乱码亚洲一区二区不卡| 欧美mv日韩mv| 久久久99精品久久| 国产日韩精品一区二区三区| 久久日一线二线三线suv| 欧美精品一区二区三区一线天视频 | 色综合久久久网| 99九九99九九九视频精品| 成人黄页毛片网站| 成人精品国产免费网站| 不卡高清视频专区| 99r国产精品| 91国产视频在线观看| 欧美日韩亚洲综合一区| 在线成人免费观看| 日韩欧美一区二区久久婷婷| 精品国产在天天线2019| 久久夜色精品一区| 国产精品国产三级国产普通话99| 国产精品激情偷乱一区二区∴| 国产精品你懂的| 一区二区三区色| 天天综合色天天综合色h| 奇米777欧美一区二区| 国产资源精品在线观看| 丁香天五香天堂综合| 91啪九色porn原创视频在线观看| 91麻豆国产福利精品| 在线电影欧美成精品| 久久久久国产一区二区三区四区| 国产精品国产三级国产普通话99| 亚洲专区一二三| 免费人成精品欧美精品| 国产成都精品91一区二区三| 91久久一区二区| 日韩欧美在线影院| 日本一区二区视频在线观看| 亚洲日本一区二区三区| 日韩国产精品久久| 国产高清成人在线| 欧洲生活片亚洲生活在线观看| 日韩欧美一级二级三级久久久| 国产精品天干天干在观线| 亚洲午夜电影在线| 国产精品一二三四| 欧美日韩国产成人在线免费| 国产日韩欧美一区二区三区乱码| 亚洲成a人片在线不卡一二三区| 精久久久久久久久久久| 色哟哟国产精品免费观看| 日韩一区二区免费在线电影| 亚洲丝袜精品丝袜在线| 免费不卡在线视频| 欧美在线一区二区| 欧美国产一区视频在线观看| 香蕉成人伊视频在线观看| 国产成人免费在线视频| 884aa四虎影成人精品一区| 国产精品美女久久久久高潮| 日本成人在线不卡视频| 色综合久久久久| 国产日韩av一区二区| 日韩电影在线观看一区| 色综合激情久久| 欧美激情一区二区三区| 久久成人久久爱| zzijzzij亚洲日本少妇熟睡| 91精品久久久久久久久99蜜臂| 岛国精品一区二区| 成人午夜激情影院| 在线电影国产精品| 亚洲精品五月天| 成人一级片网址| 久久久久久99精品| 久久疯狂做爰流白浆xx| 91精品在线一区二区| 一区二区三区四区精品在线视频| 成人福利在线看| 国产日韩欧美一区二区三区综合| 久久精品国产第一区二区三区| 欧美网站一区二区| 伊人婷婷欧美激情| 91美女片黄在线观看91美女| 中文字幕中文字幕一区二区| 国产精品99久久久久久有的能看| 日韩精品一区二区在线| 日韩vs国产vs欧美| 555www色欧美视频| 五月天久久比比资源色| 欧美日本国产一区| 性久久久久久久久| 精品视频123区在线观看| 亚洲一区二区三区在线看| 色呦呦日韩精品| 一区二区三区欧美激情| 亚洲精品视频在线| 中文字幕第一区综合| 欧美精品在欧美一区二区少妇| 蜜臀久久久99精品久久久久久| 久久精品免视看| 首页国产欧美久久| 色噜噜狠狠色综合中国| 一区二区三区在线播| 欧美色图片你懂的| 午夜精品福利久久久| 91精品国产综合久久久久久久久久| 蜜臀av性久久久久蜜臀av麻豆| 欧美一级日韩免费不卡| 黑人巨大精品欧美黑白配亚洲| 国产午夜精品福利| 91在线免费播放| 亚洲成人免费看| 日韩手机在线导航| 国产精品自产自拍| 亚洲视频免费观看| 精品视频一区二区不卡| 免费观看一级特黄欧美大片| 久久久不卡网国产精品一区| 成人国产免费视频| 亚洲成人免费影院| 久久久久97国产精华液好用吗| 盗摄精品av一区二区三区| 亚洲一区二区三区在线| 欧美大片日本大片免费观看|