亚洲欧美第一页_禁久久精品乱码_粉嫩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"

#include "usbmain.h"
#include "usbout.h"
#include "usblib.h"
#include "2440usb.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_LTS350Q1_PE1_Init(void) ;
extern void Lcd_Tft_LTS350Q1_PE1_Test( void ) ;
extern void Test_Lcd_VGA_640_480(void) ;
extern void Test_Lcd_VGA_800_600(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_MCP2510(void) ;
extern void Test_IrDA_Tx(void) ;
extern void PlayMusicTest(void) ;
extern void RecordTest( void ) ;
extern void Camera_Test( void ) ;
extern void Test_Iic(void) ;
extern void Test_SDI(void) ;
extern void CF_Card_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_LTS350Q1_PE1_Test, "Test LCD LQ035Q7DH01" } ,
				//{ LCD_BackLight_Control, "LCD backlight adjust" } ,
				{ Test_Lcd_VGA_640_480, "Test LCD to VGA 640*480" } ,
				//{ Test_Lcd_VGA_800_600, "Test LCD to VGA 800*600" } ,
				{ Test_IrDA_Tx, "Test IrDA" } ,
				{ Test_MCP2510, "CAN BUS MCP2510 Test" } ,
				{ Test_Iic, "Test IIC EEPROM" } ,
				{ PlayMusicTest, "UDA1341 play music" } ,
				{ RecordTest, "UDA1341 record voice" } ,
				{ Test_SDI, "Test SD Card" } ,
				{ CF_Card_Test, "Test CF Card "},
				{ Camera_Test, "Camera Preview Test" } ,
				
				{ 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 = 1;	// Uart 1 select for debug.
	Uart_Init( 0,115200 );
	Uart_Select( consoleNum );
	
	Beep(2000, 100);
	
	Uart_SendByte('\n');
	Uart_Printf("<***********************************************>\n");
	Uart_Printf("           SHARE-TECH Test Program VER1.0\n");
	Uart_Printf("                www.share-tech.com\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;
	

#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();
		MMU_Init();	//
		//Uart_Printf("NOR Flash ID is 0x%08x\n", GetFlashID());
  #ifdef DEBUG_VERSION
	//	comdownload();	//
	//	SectorProg(0, (U16 *)downloadAddress, downloadFileSize);
		//NandWrite();
  #endif
	//UsbdMain(); 
#endif
	
	pISR_SWI=(_ISR_STARTADDRESS+0xf0);	//for pSOS

	Led_Display(0x6);

#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_LTS350Q1_PE1_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一区二区三区免费野_久草精品视频
一区二区成人在线视频| 91伊人久久大香线蕉| 粉嫩aⅴ一区二区三区四区| 91久久国产综合久久| 欧美一级视频精品观看| 亚洲男人电影天堂| 国产乱人伦精品一区二区在线观看| 91亚洲男人天堂| 久久综合资源网| 午夜精品福利一区二区三区av| 国产成人精品三级| 6080亚洲精品一区二区| 日韩美女久久久| 国产精品一区二区在线观看不卡| 欧美日韩午夜在线视频| 亚洲图片另类小说| 国产盗摄一区二区三区| 日韩欧美国产不卡| 无码av免费一区二区三区试看 | 欧美成人一区二区三区| 一区二区久久久久久| 99re热视频这里只精品| 国产亚洲美州欧州综合国| 精品一区二区三区在线视频| 欧美一区二区在线免费观看| 一个色妞综合视频在线观看| 色一区在线观看| 国产精品久久久久影院色老大| 国产一区二区免费视频| xnxx国产精品| 国产伦精品一区二区三区在线观看| 在线成人av网站| 亚瑟在线精品视频| 欧美少妇xxx| 亚洲777理论| 91精品婷婷国产综合久久| 婷婷丁香激情综合| 欧美一区二区免费视频| 久久国产尿小便嘘嘘尿| 精品国精品自拍自在线| 狠狠色丁香久久婷婷综合丁香| 777久久久精品| 日韩精品成人一区二区在线| 欧美高清视频在线高清观看mv色露露十八 | ww亚洲ww在线观看国产| 国产一区二区主播在线| 久久久精品国产免费观看同学| 韩国精品免费视频| 国产欧美中文在线| 色婷婷精品久久二区二区蜜臀av | 亚洲色欲色欲www| 日本高清无吗v一区| 亚洲一区二区高清| 69av一区二区三区| 狠狠色丁香婷婷综合久久片| 国产情人综合久久777777| 成人av资源在线观看| 一区二区三区四区乱视频| 欧美高清激情brazzers| 国产精品一区免费在线观看| 亚洲区小说区图片区qvod| 欧美日本国产视频| 国产在线精品免费av| 国产精品白丝在线| 欧美另类变人与禽xxxxx| 精品午夜一区二区三区在线观看| 欧美激情艳妇裸体舞| 欧美日韩一区二区不卡| 韩国理伦片一区二区三区在线播放| 欧美国产激情一区二区三区蜜月| 欧洲av一区二区嗯嗯嗯啊| 国模娜娜一区二区三区| 亚洲精品中文字幕乱码三区| 91麻豆精品国产91久久久| 国产成人免费高清| 午夜av电影一区| 日本一区二区在线不卡| 欧美肥妇free| 97精品国产97久久久久久久久久久久| 天天操天天干天天综合网| 欧美激情中文不卡| 91精品久久久久久久久99蜜臂| 国产 欧美在线| 奇米888四色在线精品| **性色生活片久久毛片| 久久久久久久综合| 337p亚洲精品色噜噜噜| 99久久精品一区| 国产精华液一区二区三区| 亚洲va天堂va国产va久| 国产精品福利影院| 欧美精品一区二区三区蜜桃视频| 欧美影院精品一区| av欧美精品.com| 国产精品一区二区三区四区| 免费不卡在线视频| 亚洲国产美女搞黄色| 国产精品灌醉下药二区| 国产欧美日韩不卡免费| 欧美精品一区二| 欧美一二三四区在线| 欧美三区在线观看| 欧美视频一区在线观看| 91女神在线视频| 不卡区在线中文字幕| 丁香激情综合五月| 高清不卡在线观看av| 韩国v欧美v亚洲v日本v| 免费精品99久久国产综合精品| 亚洲午夜羞羞片| 亚洲一区av在线| 亚洲国产婷婷综合在线精品| 亚洲人成精品久久久久| 日韩毛片高清在线播放| 中文字幕视频一区二区三区久| 国产精品视频一二三区 | 一区二区三区影院| 综合欧美亚洲日本| 国产精品久久久久aaaa樱花| 国产精品无遮挡| 国产精品毛片高清在线完整版| 久久精品综合网| 亚洲国产精品精华液2区45| 中文字幕av一区二区三区| 亚洲欧洲一区二区在线播放| 亚洲色图19p| 一区二区视频在线| 亚洲国产精品天堂| 美腿丝袜亚洲三区| 国产美女视频一区| proumb性欧美在线观看| 色婷婷综合久久久| 欧美精品电影在线播放| 欧美成人一区二区| 国产日韩综合av| 亚洲日本在线a| 亚洲成人一区在线| 黄色小说综合网站| 99久久久国产精品| 欧美疯狂做受xxxx富婆| 久久久影院官网| 成人欧美一区二区三区白人 | 国产在线国偷精品免费看| 国产福利一区二区三区在线视频| 成人免费精品视频| 日本电影欧美片| 欧美成人精品3d动漫h| 国产精品入口麻豆九色| 亚洲一区二区在线视频| 久久精品国产99| 99久久综合精品| 91麻豆精品国产91久久久资源速度 | 欧美妇女性影城| 国产日韩精品久久久| 一区二区三区加勒比av| 久久机这里只有精品| av在线不卡免费看| 91麻豆精品国产自产在线| 国产精品欧美久久久久无广告 | 九九**精品视频免费播放| 成人天堂资源www在线| 欧美精品日日鲁夜夜添| 中文字幕制服丝袜成人av| 免费xxxx性欧美18vr| 色综合久久久久综合体| 久久久久国产精品麻豆| 午夜精品久久久久久久久久久| 国产麻豆精品久久一二三| 欧美日韩国产一级| 国产精品乱人伦中文| 另类小说视频一区二区| 欧美色图免费看| 国产精品动漫网站| 国产一区欧美日韩| 欧美精品精品一区| 亚洲一区在线视频| 成人app在线观看| 精品国产一区二区三区不卡| 亚洲超碰精品一区二区| 97精品电影院| 中文无字幕一区二区三区| 黄一区二区三区| 日韩亚洲电影在线| 亚洲一卡二卡三卡四卡五卡| 91老司机福利 在线| 国产精品天干天干在线综合| 国产精品亚洲午夜一区二区三区| 91精品国产综合久久精品性色| 一区二区三区在线视频播放| 成人免费高清在线观看| 国产亚洲一区字幕| 国精产品一区一区三区mba视频| 日韩情涩欧美日韩视频| 日本vs亚洲vs韩国一区三区| 欧美日韩国产在线播放网站| 婷婷综合另类小说色区| 欧美精品久久一区| 七七婷婷婷婷精品国产| 日韩免费在线观看| 毛片一区二区三区|