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

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

?? main.c

?? 裸跑測試程序
?? C
字號:
/****************************************************************
 NAME: u2440mon.c
 DESC: u2440mon 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: To remove the power noise in the USB signal, the unused CLKOUT0,1 is disabled.
 ****************************************************************/
#define	GLOBAL_CLK		1

#include <stdlib.h>
#include <string.h>
#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440lib.h"
#include "2440slib.h"
#include "mmu.h"
#include "profile.h"
#include "memtest.h"
#include "LED.h"  // lci

extern char Image$$RO$$Limit[];
extern char Image$$RO$$Base[];
extern char Image$$RW$$Limit[];
extern char Image$$RW$$Base[];
extern char Image$$ZI$$Limit[];
extern char Image$$ZI$$Base[];

void Isr_Init(void);
void HaltUndef(void);
void HaltSwi(void);
void HaltPabort(void);
void HaltDabort(void);
void ClearMemory(void);


void Clk0_Enable(int clock_sel);	
void Clk1_Enable(int clock_sel);
void Clk0_Disable(void);
void Clk1_Disable(void);

extern void Lcd_Tft_LTP700_Init(void) ;  // LCZ ADD 
extern void Lcd_Tft_LTP700_Test( void ) ;  // LCZ ADD 

extern void Test_Touchpanel(void) ;
extern void Test_Adc(void) ;		//adc test
extern void KeyScan_Test(void) ;
extern void RTC_Display(void) ;
extern void Test_IrDA_Tx(void) ;
extern void PlayMusicTest(void) ;
extern void RecordTest( void ) ;
extern void Test_Iic(void) ;
extern void Test_SDI(void) ;
extern void LEDFlash(void); //lci
extern void LEDTEST(void); // lci  
volatile U32 downloadAddress;

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

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;

static U32 cpu_freq;
static U32 UPLL;
static void cal_cpu_bus_clk(void)
{
	U32 val;
	U8 m, p, s;
	
	val = rMPLLCON;
	m = (val>>12)&0xff;
	p = (val>>4)&0x3f;
	s = val&3;

	//(m+8)*FIN*2 不要超出32位數!
	FCLK = ((m+8)*(FIN/100)*2)/((p+2)*(1<<s))*100;
	
	val = rCLKDIVN;
	m = (val>>1)&3;
	p = val&1;	
	val = rCAMDIVN;
	s = val>>8;
	
	switch (m) {
	case 0:
		HCLK = FCLK;
		break;
	case 1:
		HCLK = FCLK>>1;
		break;
	case 2:
		if(s&2)
			HCLK = FCLK>>3;
		else
			HCLK = FCLK>>2;
		break;
	case 3:
		if(s&1)
			HCLK = FCLK/6;
		else
			HCLK = FCLK/3;
		break;
	}
	
	if(p)
		PCLK = HCLK>>1;
	else
		PCLK = HCLK;
	
	if(s&0x10)
		cpu_freq = HCLK;
	else
		cpu_freq = FCLK;
		
	val = rUPLLCON;
	m = (val>>12)&0xff;
	p = (val>>4)&0x3f;
	s = val&3;
	UPLL = ((m+8)*FIN)/((p+2)*(1<<s));
	UCLK = (rCLKDIVN&8)?(UPLL>>1):UPLL;
}


void Temp_function() { Uart_Printf("\nPlease input 1-11 to select test!!!\n"); }

struct {
	void (*fun)(void);
	char *tip;
}CmdTip[] = {
				{ Temp_function, "Please input 1-12 to select test" } ,// lci fixed 0804
				{ BUZZER_PWM_Test, "Test PWM" } , // lci masked 0804
				{ RTC_Display, "RTC time display" } ,
				{ Test_Adc, "Test ADC" } ,// lci masked 0804
				{ KeyScan_Test, "Test interrupt and key scan" } ,
				{ Test_Touchpanel, "Test Touchpanel" } ,
				{ Lcd_Tft_LTP700_Test, "Test LCD LTP700" } ,
				{ Test_Iic, "Test IIC EEPROM" } ,// lci masked 0804
				{ PlayMusicTest, "UDA1341 play music" } ,
				{ RecordTest, "UDA1341 record voice" } ,
				{ Test_SDI, "Test SD Card" } ,
				{ LEDFlash, "Test LED show" } ,
				{ 0, 0}						
			};


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

	Port_Init();
	
	Isr_Init();
	
	i = 2 ;	//don't use 100M!
		//boot_params.cpu_clk.val = 3;
	switch ( i ) {
	case 0:	//200
		key = 12;
		mpll_val = (92<<12)|(4<<4)|(1);
		break;
	case 1:	//300
		key = 13;
		mpll_val = (67<<12)|(1<<4)|(1);
		break;
	case 2:	//400
		key = 14;
		mpll_val = (92<<12)|(1<<4)|(1);
		break;
	case 3:	//440!!!
		key = 14;
		mpll_val = (102<<12)|(1<<4)|(1);
		break;
	default:
		key = 14;
		mpll_val = (92<<12)|(1<<4)|(1);
		break;
	}
	
	//init FCLK=400M, so change MPLL first
	ChangeMPllValue((mpll_val>>12)&0xff, (mpll_val>>4)&0x3f, mpll_val&3);
	ChangeClockDivider(key, 12);
	cal_cpu_bus_clk();
	
	consoleNum = 0;	// Uart 1 select for debug.
	Uart_Init( 0,115200 );
	Uart_Select( consoleNum );
	
	Beep(2000, 100);
	
	Uart_SendByte('\n');
	Uart_Printf("<***********************************************>\n");
	Uart_Printf("           SKY2440 Test Program VER1.0\n");
	Uart_Printf("                www.embedsky.net\n"); // lci 
	Uart_Printf("      Build time is: %s  %s\n", __DATE__ , __TIME__  );
/*      //LCI masked 0804 start
	Uart_Printf( "          Image$$RO$$Base  = 0x%x\n", Image$$RO$$Base );
	Uart_Printf( "          Image$$RO$$Limit = 0x%x\n", Image$$RO$$Limit );
	Uart_Printf( "          Image$$RW$$Base  = 0x%x\n", Image$$RW$$Base );
	Uart_Printf( "          Image$$RW$$Limit = 0x%x\n", Image$$RW$$Limit );
    Uart_Printf( "          Image$$ZI$$Base  = 0x%x\n", Image$$ZI$$Base );
    Uart_Printf( "          Image$$ZI$$Limit = 0x%x\n", Image$$ZI$$Limit );
*/  //LCI masked 0804 end 
	Uart_Printf("<***********************************************>\n");

	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;
	
//	rd_dm9000_id();			//
//	rGPBCON &= ~(3<<20);	//CF_CARD Power
//	rGPBCON |= 1<<20;
//	rGPBDAT |= 1<<10;
//	rDSC0 = 0x155;
//	rDSC1 = 0x15555555;
	rDSC0 = 0x2aa;
	rDSC1 = 0x2aaaaaaa;
	//Enable NAND, USBD, PWM TImer, UART0,1 and GPIO clock,
	//the others must be enabled in OS!!!
	rCLKCON = 0xfffff0;
	


	//MMU_EnableICache();
		MMU_Init();	//
		//Uart_Printf("NOR Flash ID is 0x%08x\n", GetFlashID());

	pISR_SWI=(_ISR_STARTADDRESS+0xf0);	//for pSOS

	Led_Display(0x66);

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

	// CLKOUT0/1 select.
	//Uart_Printf("CLKOUT0:MPLL in, CLKOUT1:RTC clock.\n");
	//Clk0_Enable(0);	// 0:MPLLin, 1:UPLL, 2:FCLK, 3:HCLK, 4:PCLK, 5:DCLK0
	//Clk1_Enable(2);	// 0:MPLLout, 1:UPLL, 2:RTC, 3:HCLK, 4:PCLK, 5:DCLK1	
	Clk0_Disable();
	Clk1_Disable();
	
	mpll_val = rMPLLCON;

	Lcd_Tft_LTP700_Init() ;		// LCD initial
	
	download_run=1; //The default menu is the Download & Run mode.

	while(1)
	{
		U8 idx;
		
		Uart_Printf("\nPlease select function : \n");	
		for(i=0; CmdTip[i].fun!=0; i++)
			Uart_Printf("%d : %s\n", i, CmdTip[i].tip);
		idx = Uart_GetIntNum_GJ() ;	
		if(idx<i)
		{
			(*CmdTip[idx].fun)();
			Delay(20);
			Uart_Init( 0,115200 );
		}	
	
	}	  	

}

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);
}


void ClearMemory(void)
{
	//int i;
	//U32 data;
	int memError=0;
	U32 *pt;
	
	Uart_Printf("Clear Memory (%xh-%xh):WR",_RAM_STARTADDRESS,HEAPEND);

	pt=(U32 *)_RAM_STARTADDRESS;
	while((U32)pt < HEAPEND)
	{
		*pt=(U32)0x0;
		pt++;
	}
	
	if(memError==0)Uart_Printf("\b\bO.K.\n");
}

void Clk0_Enable(int clock_sel)	
{	// 0:MPLLin, 1:UPLL, 2:FCLK, 3:HCLK, 4:PCLK, 5:DCLK0
	rMISCCR = rMISCCR&~(7<<4) | (clock_sel<<4);
	rGPHCON = rGPHCON&~(3<<18) | (2<<18);
}
void Clk1_Enable(int clock_sel)
{	// 0:MPLLout, 1:UPLL, 2:RTC, 3:HCLK, 4:PCLK, 5:DCLK1	
	rMISCCR = rMISCCR&~(7<<8) | (clock_sel<<8);
	rGPHCON = rGPHCON&~(3<<20) | (2<<20);
}
void Clk0_Disable(void)
{
	rGPHCON = rGPHCON&~(3<<18);	// GPH9 Input
}
void Clk1_Disable(void)
{
	rGPHCON = rGPHCON&~(3<<20);	// GPH10 Input
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲亚洲人成综合网络| 日韩一卡二卡三卡四卡| 欧美日韩激情一区二区| 欧美电影免费观看高清完整版在| 国产日韩欧美精品一区| 亚洲美女免费在线| 久热成人在线视频| 99精品视频免费在线观看| 欧美人狂配大交3d怪物一区| 久久免费偷拍视频| 亚洲综合色区另类av| 精品一区二区三区免费| 一本色道久久加勒比精品| 日韩欧美久久一区| 亚洲精选免费视频| 狂野欧美性猛交blacked| 91一区二区三区在线观看| 日韩亚洲欧美综合| 最新国产成人在线观看| 麻豆成人在线观看| 色先锋资源久久综合| 精品久久国产字幕高潮| 一区二区三区精品在线| 国产一区二区三区在线观看免费视频| 在线免费不卡视频| 国产香蕉久久精品综合网| 亚洲线精品一区二区三区| 懂色中文一区二区在线播放| 欧美精品三级日韩久久| 国产精品久久久久久久浪潮网站 | 欧美色图第一页| 中文字幕第一页久久| 免费高清视频精品| 在线免费观看日本欧美| 中文字幕乱码久久午夜不卡| 美女爽到高潮91| 欧美日韩一区二区三区视频| 一区在线播放视频| 国产一区二区电影| 制服丝袜成人动漫| 亚洲一区二区三区四区在线免费观看 | 成人av网址在线| 欧美大度的电影原声| 亚洲电影第三页| 一本久道中文字幕精品亚洲嫩| 久久综合五月天婷婷伊人| 午夜av电影一区| 色婷婷av一区| 亚洲欧洲av一区二区三区久久| 国产精品18久久久久| 日韩三级视频在线看| 亚洲h精品动漫在线观看| 色婷婷av一区| 亚洲日本电影在线| 成人午夜免费视频| 国产午夜精品福利| 国产综合色产在线精品| 日韩欧美在线影院| 日本aⅴ亚洲精品中文乱码| 精品视频免费看| 夜夜嗨av一区二区三区| 99精品黄色片免费大全| 国产精品久久久久永久免费观看| 国产美女视频一区| 精品国产伦一区二区三区观看方式 | 久久99国内精品| 日韩午夜中文字幕| 日本在线不卡一区| 91精品国产综合久久精品app| 亚洲国产wwwccc36天堂| 欧美影院一区二区| 亚洲一区二区三区精品在线| 91久久精品国产91性色tv| 亚洲区小说区图片区qvod| av影院午夜一区| 中文字幕日韩欧美一区二区三区| 成人精品鲁一区一区二区| 国产精品久久久久久久久免费相片 | 91视频.com| 一区二区激情小说| 欧美日韩www| 奇米影视一区二区三区| 欧美v国产在线一区二区三区| 韩国v欧美v日本v亚洲v| 国产欧美一区二区精品婷婷| 成人精品国产免费网站| 亚洲乱码精品一二三四区日韩在线| a美女胸又www黄视频久久| 伊人性伊人情综合网| 欧美少妇性性性| 美女网站在线免费欧美精品| 久久日韩粉嫩一区二区三区| 豆国产96在线|亚洲| 亚洲人精品午夜| 欧美日韩国产天堂| 久久不见久久见中文字幕免费| 欧美r级电影在线观看| 国产成人免费视| 亚洲色图欧洲色图婷婷| 欧美三级韩国三级日本三斤| 麻豆精品久久久| 国产精品区一区二区三| 91久久精品日日躁夜夜躁欧美| 日韩黄色小视频| 久久婷婷成人综合色| av一二三不卡影片| 亚洲成人免费视| 久久一区二区三区四区| 91丨九色porny丨蝌蚪| 亚洲成人av一区二区三区| 欧美一二三区在线| 成人三级伦理片| 香蕉成人伊视频在线观看| 欧美精品一区二区三区在线播放 | 国产精品女同互慰在线看| 欧美亚洲丝袜传媒另类| 麻豆成人在线观看| 亚洲欧美在线视频| 日韩一区二区在线播放| 成人av网站在线观看| 日韩精品欧美精品| 国产精品大尺度| 日韩视频免费观看高清完整版| 波多野结衣中文一区| 日日噜噜夜夜狠狠视频欧美人 | 国产精品18久久久久| 亚洲一区二区三区小说| 久久久亚洲精品一区二区三区 | 天堂一区二区在线| 国产精品日产欧美久久久久| 欧美精品一级二级| 成人的网站免费观看| 视频一区视频二区中文| 国产精品初高中害羞小美女文| 在线电影欧美成精品| a在线欧美一区| 激情综合亚洲精品| 亚洲一区二区三区视频在线 | 国产不卡在线视频| 蜜臀av一区二区在线观看| 亚洲人成在线观看一区二区| 精品99久久久久久| 欧美亚洲自拍偷拍| 99久久免费视频.com| 韩国一区二区视频| 日韩中文字幕1| 亚洲人吸女人奶水| 欧美国产日韩精品免费观看| 日韩欧美综合一区| 欧美日韩视频在线观看一区二区三区| 风间由美一区二区av101| 裸体一区二区三区| 性久久久久久久久| 伊人开心综合网| 国产精品二三区| 国产欧美一区二区精品久导航| 欧美一区二区三区爱爱| 欧洲视频一区二区| bt欧美亚洲午夜电影天堂| 国产成人在线视频播放| 久久电影网电视剧免费观看| 午夜精品久久久久久久99水蜜桃| 亚洲精品伦理在线| 18成人在线观看| 国产精品入口麻豆原神| 久久精品一区二区三区不卡牛牛| 日韩欧美在线123| 欧美男男青年gay1069videost| 在线一区二区三区四区| 色综合天天综合在线视频| 成人免费观看视频| 成人性色生活片免费看爆迷你毛片| 国内不卡的二区三区中文字幕| 久色婷婷小香蕉久久| 蜜臀久久久99精品久久久久久| 视频精品一区二区| 首页欧美精品中文字幕| 日韩精品亚洲一区二区三区免费| 亚洲www啪成人一区二区麻豆 | 欧美一区日本一区韩国一区| 欧美天天综合网| 欧美在线一区二区| 在线一区二区三区四区| 欧美三级电影一区| 欧美精品免费视频| 91精品在线观看入口| 日韩欧美中文字幕公布| 欧美tickling网站挠脚心| www精品美女久久久tv| 国产无人区一区二区三区| 欧美激情中文字幕| 亚洲天堂网中文字| 一二三四区精品视频| 亚洲成av人片一区二区| 蜜桃视频第一区免费观看| 久久精品久久久精品美女| 国产中文一区二区三区| 成人免费高清在线| 色婷婷久久综合| 欧美精品少妇一区二区三区|