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

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

?? main.c

?? 迷你2440最新的源碼實例
?? 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"


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_NEC35_Init(void);
extern void Lcd_Tft_800x480_Init(void);
extern void Lcd_VGA_1024x768_Init(void);
extern void Lcd_Tft_NEC35_Test( void ) ;
extern void Test_Lcd_TFT_640_480(void);
extern void Test_VGA_1024x768(void);

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 Camera_Test( void ) ;

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-16 to select test!!!\n"); }

struct {
	void (*fun)(void);
	char *tip;
}CmdTip[] = {
				{ Temp_function, "Please input 1-16 to select test" } ,
				{ BUZZER_PWM_Test, "Test PWM" } ,
				{ RTC_Display, "RTC time display" } ,
				{ Test_Adc, "Test ADC" } ,
				{ KeyScan_Test, "Test interrupt and key scan" } ,
				{ Test_Touchpanel, "Test Touchpanel" } ,
				{ Lcd_Tft_NEC35_Test, "Test NEC 3.5\" LCD" } ,
				{ Test_Lcd_TFT_640_480, "Test LCD TFT 800x480" } ,
				{ Test_VGA_1024x768, "Test VGA 1024x768@70Hz" } ,
				{ Test_Iic, "Test IIC EEPROM, if use QQ2440, please remove the LCD" } ,
				{ PlayMusicTest, "UDA1341 play music" } ,
				{ RecordTest, "UDA1341 record voice" } ,
				{ Test_SDI, "Test SD Card" } ,
				{ Camera_Test, "Test CMOS Camera"},
				{ 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("           SBC2440 Test Program VER1.0\n");
	Uart_Printf("                www.arm9.net\n");
	Uart_Printf("      Build time is: %s  %s\n", __DATE__ , __TIME__  );
    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 );
	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;
	
#if LCD_TYPE==LCD_TYPE_N35
	Lcd_Tft_NEC35_Init();
#elif LCD_TYPE==LCD_TYPE_A70
	Lcd_Tft_800x480_Init();
#elif LCD_TYPE==LCD_TYPE_VGA1024x768
	Lcd_VGA_1024x768_Init();	
#endif	

		
	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久久99精品免视看婷婷| 日本一区二区三区在线观看| 97成人超碰视| 国产一区三区三区| 亚洲最新视频在线观看| 国产精品视频在线看| 国产91丝袜在线18| 污片在线观看一区二区| 爽爽淫人综合网网站| 午夜婷婷国产麻豆精品| 美女一区二区在线观看| 韩国av一区二区三区| 欧美激情一区不卡| 成人av网站大全| 国内外成人在线视频| 亚洲一区欧美一区| 亚洲天堂中文字幕| 国产色一区二区| 欧美变态凌虐bdsm| 欧美伊人精品成人久久综合97 | 亚洲欧洲性图库| 久久久久99精品国产片| 欧美刺激午夜性久久久久久久 | 欧美午夜片在线看| 欧美日韩免费视频| 欧美体内she精高潮| 91麻豆精品国产91久久久| 欧美性受xxxx黑人xyx| 欧美日韩成人综合在线一区二区| 99re亚洲国产精品| thepron国产精品| 99久久久久久| 欧美日韩小视频| 日韩欧美国产小视频| 久久久精品国产免大香伊| 久久久综合精品| 专区另类欧美日韩| 天天操天天干天天综合网| 美女国产一区二区| 99re在线视频这里只有精品| 在线看不卡av| 久久午夜羞羞影院免费观看| 国产欧美日韩精品一区| 亚洲少妇30p| 免费一区二区视频| 99久久综合国产精品| 在线播放国产精品二区一二区四区 | 国产成人精品亚洲午夜麻豆| 97精品国产露脸对白| 在线成人免费观看| 亚洲一级电影视频| 风间由美一区二区三区在线观看 | 欧美人伦禁忌dvd放荡欲情| 欧美国产日韩在线观看| 蜜臀精品久久久久久蜜臀| 99国产精品一区| 日本一区二区综合亚洲| 免费精品视频在线| 69堂亚洲精品首页| 一区二区三区在线看| 99久久综合狠狠综合久久| 久久毛片高清国产| 国产一区二区免费看| 日韩欧美一二区| 奇米色一区二区| 欧美电影精品一区二区| 久久99精品久久久久久动态图| 欧美一区二区三区视频免费 | 日韩精品免费视频人成| 欧美偷拍一区二区| 蜜臀av国产精品久久久久| 欧美日韩三级在线| 免费看日韩a级影片| 日韩一区二区三区免费看| 国产精品99久久久久| 国产欧美日韩激情| 欧美中文字幕一二三区视频| 亚洲va欧美va国产va天堂影院| 欧美日韩综合在线免费观看| 蜜臀久久久99精品久久久久久| 久久久三级国产网站| 91在线小视频| 激情久久久久久久久久久久久久久久| 久久综合九色综合97_久久久| 99re视频精品| 日本欧洲一区二区| 中文字幕高清不卡| 91麻豆精品国产无毒不卡在线观看| 激情综合五月天| 亚洲不卡一区二区三区| 欧美国产在线观看| 日韩无一区二区| 欧美中文字幕不卡| 成人精品国产一区二区4080| 三级一区在线视频先锋| 中文字幕一区在线| 国产日韩欧美在线一区| 在线播放视频一区| 欧美色涩在线第一页| 99re这里都是精品| 丁香激情综合五月| 国产精品一二三四| 美女视频一区二区| 久久99精品国产.久久久久久| 国产精品久99| 国产日韩亚洲欧美综合| 欧美日本国产视频| 青青草一区二区三区| 欧美日本一区二区在线观看| 亚洲区小说区图片区qvod| 欧美日韩国产中文| 视频一区中文字幕国产| 久久亚洲捆绑美女| 在线观看视频一区二区 | 欧美一级高清大全免费观看| 日韩精品欧美成人高清一区二区| 欧美午夜精品一区| 九九精品一区二区| 日韩一区日韩二区| 美国av一区二区| 黄一区二区三区| 亚洲欧美偷拍卡通变态| 5月丁香婷婷综合| 欧美午夜一区二区三区免费大片| 日本欧美一区二区| 亚洲国产aⅴ成人精品无吗| 亚洲一本大道在线| 亚洲视频在线一区观看| 久久婷婷一区二区三区| 日韩精品中文字幕一区| 26uuu国产电影一区二区| 欧美日韩亚洲综合一区| 亚洲精品在线三区| 中文字幕一区二区三区av| 三级欧美在线一区| 日本女优在线视频一区二区| 婷婷开心激情综合| 国产精品一线二线三线精华| 99精品视频在线观看免费| 在线亚洲精品福利网址导航| 精品国免费一区二区三区| 综合婷婷亚洲小说| 成人av免费在线| 日韩欧美国产电影| 无码av免费一区二区三区试看| 欧美嫩在线观看| 亚洲精品国产a久久久久久 | 91精品国产高清一区二区三区 | 欧美mv日韩mv国产网站| 午夜精品一区二区三区电影天堂| 春色校园综合激情亚洲| 久久久午夜精品理论片中文字幕| 亚洲精品视频在线观看免费| 91 com成人网| 成人av中文字幕| 性做久久久久久| 亚洲欧洲色图综合| 久久先锋资源网| 日韩欧美一级二级三级久久久| 成人小视频在线| 国产亚洲一二三区| 成人综合激情网| 国产精品久久久久婷婷| 欧美色图第一页| 韩国理伦片一区二区三区在线播放| 久久精品亚洲一区二区三区浴池| 丁香激情综合国产| 肉色丝袜一区二区| 久久久久久久久伊人| 色婷婷一区二区三区四区| 午夜一区二区三区在线观看| 久久新电视剧免费观看| 欧美在线免费播放| 成人妖精视频yjsp地址| 亚洲444eee在线观看| 国产精品萝li| 欧美一级生活片| 欧美日韩在线播放| 北岛玲一区二区三区四区| 精品伊人久久久久7777人| 1024国产精品| 成人欧美一区二区三区白人| 亚洲精品一区二区精华| 日韩精品一区二区三区视频| 在线精品观看国产| 欧美在线高清视频| 99精品热视频| 色噜噜狠狠一区二区三区果冻| 国产福利视频一区二区三区| 韩国精品久久久| 韩国三级在线一区| 黄色小说综合网站|