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

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

?? main.c

?? Samsung ARM for 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一区二区三区免费野_久草精品视频
国产精品美女久久久久aⅴ | 97久久超碰国产精品| 在线观看中文字幕不卡| 国产天堂亚洲国产碰碰| 亚洲电影欧美电影有声小说| av成人免费在线观看| 久久亚洲一区二区三区明星换脸| 亚洲成人自拍网| fc2成人免费人成在线观看播放| 日韩一区二区三区电影在线观看| 一区二区三区在线免费播放| 国产1区2区3区精品美女| 日韩欧美的一区| 亚洲第一主播视频| 在线观看视频欧美| 亚洲男人的天堂网| 99在线精品一区二区三区| 久久久久久久久久久电影| 日本不卡免费在线视频| 欧美性xxxxx极品少妇| 亚洲欧美激情插 | ㊣最新国产の精品bt伙计久久| 另类成人小视频在线| 91精品欧美综合在线观看最新 | 韩国欧美国产一区| 精品日韩av一区二区| 蜜臀久久99精品久久久画质超高清 | 亚洲麻豆国产自偷在线| 成人性生交大片免费看在线播放 | 欧美大片一区二区| 日本亚洲三级在线| 欧美一区二区精品| 蜜臀av在线播放一区二区三区| 欧美精品久久久久久久多人混战| 天天av天天翘天天综合网色鬼国产| 91精品1区2区| 三级亚洲高清视频| 日韩欧美在线观看一区二区三区| 蜜桃av一区二区三区| 日韩欧美国产精品一区| 精品一区二区成人精品| 久久久午夜精品理论片中文字幕| 国产电影一区二区三区| 国产精品女主播在线观看| 91天堂素人约啪| 一区二区欧美视频| 欧美丰满高潮xxxx喷水动漫| 麻豆成人在线观看| 26uuuu精品一区二区| 国产成a人亚洲| 最新日韩在线视频| 欧美精品久久99久久在免费线| 麻豆中文一区二区| 国产欧美视频一区二区三区| 97成人超碰视| 婷婷成人激情在线网| 欧美不卡一区二区三区四区| 粉嫩av一区二区三区| 亚洲免费观看高清完整版在线观看熊 | 国产成人亚洲综合a∨婷婷| 1区2区3区精品视频| 欧美久久一二三四区| 国产一区二区精品久久99| 国产精品久久久久久亚洲伦 | 91在线精品一区二区三区| 亚洲一二三区不卡| 久久综合久久鬼色| 色哟哟一区二区三区| 蜜桃av噜噜一区二区三区小说| 国产欧美中文在线| 欧美久久久久久蜜桃| 国产精品88888| 亚洲大片免费看| 欧美激情在线一区二区| 欧美日韩国产综合一区二区三区| 国产成人免费视频网站| 偷拍一区二区三区四区| 最新国产精品久久精品| 日韩一级片网址| 一本到不卡精品视频在线观看| 久久精品免费观看| 亚洲一区国产视频| 中文字幕精品一区| 日韩精品综合一本久道在线视频| 94-欧美-setu| 国产成人精品免费视频网站| 日本亚洲电影天堂| 亚洲一区二区免费视频| 中文字幕不卡在线观看| 欧美哺乳videos| 欧美精品 日韩| 99视频精品在线| 国产真实精品久久二三区| 婷婷中文字幕一区三区| 一区二区三区四区激情| 中文乱码免费一区二区 | 日韩一区二区视频| 在线中文字幕一区二区| 成人av资源在线| 极品尤物av久久免费看| 美脚の诱脚舐め脚责91 | 日韩二区三区四区| 亚洲国产中文字幕| 亚洲色图视频免费播放| 国产精品久久久久久久久搜平片| 久久只精品国产| 2024国产精品| 久久影音资源网| 精品福利一二区| 欧美mv日韩mv国产网站| 欧美日韩国产美女| 欧美女孩性生活视频| 在线日韩av片| 欧美亚洲一区二区在线观看| 日本精品免费观看高清观看| 99视频超级精品| 91日韩精品一区| 色综合网站在线| 色综合天天综合狠狠| 色综合久久88色综合天天 | 亚洲精品国产一区二区精华液 | 国产欧美一区在线| 国产精品美女久久久久高潮| 国产精品白丝在线| 亚洲理论在线观看| 亚洲香肠在线观看| 日本欧美久久久久免费播放网| 日本不卡高清视频| 国产一区二区免费在线| a美女胸又www黄视频久久| 91亚洲精品乱码久久久久久蜜桃| 色呦呦日韩精品| 欧美一区二区三区视频在线| 久久久蜜臀国产一区二区| 国产精品你懂的| 一区av在线播放| 免费成人在线影院| 国产精品白丝jk黑袜喷水| 99久久精品免费精品国产| 欧亚洲嫩模精品一区三区| 日韩欧美中文字幕制服| 欧美激情综合五月色丁香小说| 亚洲精品国产无天堂网2021 | 三级不卡在线观看| 国产综合色在线视频区| www.成人网.com| 欧美高清精品3d| 国产拍欧美日韩视频二区 | 亚洲三级在线观看| 日韩电影免费在线观看网站| 成人午夜视频在线| 欧美剧情片在线观看| 国产亚洲精品免费| 亚洲午夜久久久久久久久电影院 | 欧美xxxxx裸体时装秀| 国产精品久久久久精k8| 免费美女久久99| 99免费精品视频| 日韩一区二区三区三四区视频在线观看 | 国产欧美一区二区精品婷婷| 一区二区三区精品在线| 激情文学综合丁香| 欧美日韩欧美一区二区| 国产欧美综合色| 免费精品视频在线| 色88888久久久久久影院按摩| 日韩精品一区二区三区老鸭窝 | 欧美日韩国产免费| 18欧美乱大交hd1984| 国产在线不卡视频| 欧美日韩和欧美的一区二区| 亚洲视频 欧洲视频| 国产麻豆成人精品| 欧美一区二区视频网站| 亚洲美女在线国产| jizz一区二区| 国产日本欧洲亚洲| 国模套图日韩精品一区二区 | 美女被吸乳得到大胸91| 欧美日韩一区二区在线观看| 日韩理论片在线| 国产成人午夜高潮毛片| 欧美videossexotv100| 丝袜亚洲另类欧美综合| 色久优优欧美色久优优| 亚洲国产成人在线| 国产经典欧美精品| 欧美成人免费网站| 日产国产欧美视频一区精品| 欧美日韩在线播放| 伊人一区二区三区| 91麻豆国产自产在线观看| 国产精品丝袜久久久久久app| 国产乱人伦偷精品视频免下载 | 在线播放/欧美激情| 亚洲综合一区在线| 欧美在线视频不卡| 一区二区在线观看视频在线观看| eeuss鲁一区二区三区| 一区二区中文视频|