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

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

?? init_flash.c

?? 基于atmel公司的at91rm9200的boot程序
?? C
字號:
//*----------------------------------------------------------------------------
//*         ATMEL Microcontroller Software Support  -  ROUSSET  -
//*----------------------------------------------------------------------------
//* The software is delivered "AS IS" without warranty or condition of any
//* kind, either express, implied or statutory. This includes without
//* limitation any warranty or condition with respect to merchantability or
//* fitness for any particular purpose, or against the infringements of
//* intellectual property rights of others.
//*----------------------------------------------------------------------------
//* File Name           : init.c
//* Object              : Low level initialisations written in C
//* Creation            : FB   23/10/2002
//*
//*----------------------------------------------------------------------------

#include "AT91RM9200.h"
#include "lib_AT91RM9200.h"

/////////////////////////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////////////////////////////

#define	FALSE					0
#define	TRUE					1
#define	DELAY_PLL				100
#define DELAY_MAIN_FREQ			100

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Configuration for a Quartz 18.432000 MHz
/////////////////////////////////////////////////////////////////////////////////////////////////////

#define	PLLAR 					0x20263E04	//* 179,712000 MHz for PCK 
#define	PLLBR 					0x10483E0E	//* 48,054857 MHz (divider by 2 for USB)
#define	MCKR  					0x00000202	//* PCK/3 = MCK Master Clock = 59,904000MHz with PLLA selected 
#define SLOWCLOCK				32768		//* In Hz

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Frequencies Range
/////////////////////////////////////////////////////////////////////////////////////////////////////

#define INPUT_FREQ_MIN			900000
#define INPUT_FREQ_MAX			32000000

#ifdef AT91RM9200

#define BASE_EBI_CS0_ADDRESS	0x10000000	//* base address to access memory on CS0
#define BASE_EBI_CS1_ADDRESS	0x20000000	//* base address to access memory on CS1

#define OUTPUT_FREQ_MIN			80000000
#define OUTPUT_FREQ_MAX			240000000

#else
#ifdef AT91RM3400
	
#define OUTPUT_FREQ_MIN			20000000
#define OUTPUT_FREQ_MAX			100000000

#endif
#endif

/////////////////////////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////////////////////////////

//*----------------------------------------------------------------------------
//* \fn    AT91F_WaitForMainClockFrequency
//* \brief This function performs very low level HW initialization
//*----------------------------------------------------------------------------
unsigned char AT91F_WaitForMainClockFrequency()
{
	volatile char	tmp	= 0;

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Step 2.
// Checking the Main Oscillator Frequency (Optional)
/////////////////////////////////////////////////////////////////////////////////////////////////////

	//* Determine the main clock frequency
	while(!(AT91C_BASE_CKGR->CKGR_MCFR & AT91C_CKGR_MAINRDY) && (tmp++ < DELAY_MAIN_FREQ));

	if (tmp >= DELAY_MAIN_FREQ)
		return FALSE;

	return TRUE;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_CheckPLL_FrequencyRange
//* \brief This function performs very low level HW initialiszation
//*----------------------------------------------------------------------------
unsigned char AT91F_CheckPLL_FrequencyRange(int MainClock,int pllDivider ,int pllMultiplier)
{
	if(pllDivider == 0)
		return FALSE;

	//* Check Input Frequency
	if( ((MainClock/pllDivider) < INPUT_FREQ_MIN)
	 || ((MainClock/pllDivider) > INPUT_FREQ_MAX) )
		return FALSE;

	//* Check Output Frequency
	if( ((MainClock/pllDivider*pllMultiplier) < OUTPUT_FREQ_MIN)
	 || ((MainClock/pllDivider*pllMultiplier) > OUTPUT_FREQ_MAX) )
		return FALSE;

	return TRUE;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_InitClocks
//* \brief This function performs very low level HW initialization
//*----------------------------------------------------------------------------
unsigned char AT91F_InitClocks(int PLLAR_Register,int PLLBR_Register ,int MCKR_Register)
{
	volatile char 	tmp = 0;
	unsigned int	MainClock;
	unsigned int 	pllDivider,pllMultiplier;

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Optionnal
/////////////////////////////////////////////////////////////////////////////////////////////////////

	//* Check if Input & Output Frequencies are in the correct range

	MainClock 		= AT91F_CKGR_GetMainClock(AT91C_BASE_CKGR,SLOWCLOCK);

	pllDivider    	= (PLLAR_Register  & AT91C_CKGR_DIVA);
	pllMultiplier 	= ((PLLAR_Register  & AT91C_CKGR_MULA) >> 16) + 1;
	if(AT91F_CheckPLL_FrequencyRange(MainClock, pllDivider , pllMultiplier) == FALSE)
		return FALSE;

	pllDivider    	= (PLLBR_Register  & AT91C_CKGR_DIVB);
	pllMultiplier 	= ((PLLBR_Register  & AT91C_CKGR_MULB) >> 16) + 1;
	if(AT91F_CheckPLL_FrequencyRange(MainClock, pllDivider , pllMultiplier) == FALSE)
		return FALSE;

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Step 3.
// Setting PLLA and Divider A
/////////////////////////////////////////////////////////////////////////////////////////////////////

	AT91C_BASE_CKGR->CKGR_PLLAR = PLLAR_Register;
	//* Wait for PLLA stabilization LOCKA bit in PMC_SR
	tmp = 0;
	while( !(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_LOCKA) && (tmp++ < DELAY_PLL) ) ;

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Step 4.
// Setting PLLB and Divider B
/////////////////////////////////////////////////////////////////////////////////////////////////////

	AT91C_BASE_CKGR->CKGR_PLLBR = PLLBR_Register;
	//* Wait for PLLB stabilization LOCKB bit in PMC_SR
	tmp = 0;
	while( !(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_LOCKB) && (tmp++ < DELAY_PLL) ) ;

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Step 5.
// Selection of Master Clock MCK (and Processor Clock PCK)
/////////////////////////////////////////////////////////////////////////////////////////////////////

	AT91C_BASE_PMC->PMC_MCKR = MCKR_Register;
	//* Wait until the master clock is established
	tmp = 0;
	while( !(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_MCKRDY) && (tmp++ < DELAY_MAIN_FREQ) );

	return TRUE;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_InitSDRAM
//* \brief This function performs very low level HW initialisation
//*----------------------------------------------------------------------------
void AT91F_InitSDRAM()
{
	int 	i;
	int 	*pSDRAM = (int *)BASE_EBI_CS1_ADDRESS;

	//* Configure PIOC as peripheral (D16/D31)
	AT91F_SDRC_CfgPIO();
	
	//* Setup MEMC to support CS1=SDRAM
	AT91C_BASE_EBI->EBI_CSA |= AT91C_EBI_CS1A;
	AT91C_BASE_EBI->EBI_CFGR = (AT91C_EBI_DBPUC & 0x00) | (AT91C_EBI_EBSEN & 0x00);

	//* Init SDRAM

	//* 1. A minimum pause of 200us is provided to precede any signal toggle
	AT91C_BASE_SDRC->SDRC_CR = AT91C_SDRC_NC_9 | AT91C_SDRC_NR_12 | AT91C_SDRC_NB_4_BANKS | AT91C_SDRC_CAS_2
								| 0x100 | 0x4000 | 0x8000
								| 0x880000
								| 0x21000000;


	//* 2. A Precharge All command is issued to the SDRAM
	AT91C_BASE_SDRC->SDRC_MR = AT91C_SDRC_MODE_PRCGALL_CMD;
	*pSDRAM = 0;

	//* 3. Eight Auto-refresh are provided
	AT91C_BASE_SDRC->SDRC_MR = AT91C_SDRC_MODE_RFSH_CMD;
	for(i=0;i<8;i++)
		*pSDRAM = 0;

	//* 4. A mode register cycle is issued to program the SDRAM parameters
	AT91C_BASE_SDRC->SDRC_MR = AT91C_SDRC_MODE_LMR_CMD;
	*(pSDRAM+0x80) = 0;

	//* 5. Write refresh rate into SDRAMC refresh timer COUNT register
	AT91C_BASE_SDRC->SDRC_TR = (AT91C_SDRC_COUNT & 0x2E0);
	*pSDRAM = 0;

	//* 6. A Normal Mode Command is provided, 3 clocks after tMRD is set
	AT91C_BASE_SDRC->SDRC_MR = AT91C_SDRC_MODE_NORMAL_CMD;
	*pSDRAM = 0;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_InitFlash
//* \brief This function performs very low level HW initialization
//*----------------------------------------------------------------------------
void AT91F_InitFlash()
{
	AT91C_BASE_MC->MC_PUIA[0] = AT91C_MC_PROT_PNAUNA;
	AT91C_BASE_MC->MC_PUP = 0;
	AT91C_BASE_MC->MC_PUER = 0;	//* Memory controller protection unit disable
	AT91C_BASE_MC->MC_ASR = 0;  //* read only!
	AT91C_BASE_MC->MC_AASR = 0; //* read only!

	//* Setup MEMC to support CS0=Flash
	AT91C_BASE_EBI->EBI_CSA |= AT91C_EBI_CS0A_SMC;
	AT91C_BASE_EBI->EBI_CFGR = (AT91C_EBI_DBPUC & 0x00) | (AT91C_EBI_EBSEN & 0x00);

	//* Setup Flash
	AT91C_BASE_SMC2->SMC2_CSR[0] = (AT91C_SMC2_NWS & 0x4) | AT91C_SMC2_WSEN
									| (AT91C_SMC2_TDF & 0x200) | AT91C_SMC2_BAT | AT91C_SMC2_DBW_16;
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_DBGU_Printk
//* \brief This function is used to send a string through the DBGU channel (Very low level debugging)
//*----------------------------------------------------------------------------
void AT91F_DBGU_Printk(
	char *buffer) // \arg pointer to a string ending by \0
{
	while(*buffer != '\0') {
		while (!AT91F_US_TxReady((AT91PS_USART)AT91C_BASE_DBGU));
		AT91F_US_PutChar((AT91PS_USART)AT91C_BASE_DBGU, *buffer++);
	}
}

//*----------------------------------------------------------------------------
//* \fn    AT91F_LowLevelInit
//* \brief This function performs very low level HW initialization
//*----------------------------------------------------------------------------
void AT91F_LowLevelInit()
{
	unsigned char 	status;

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Step 2.
// Checking the Main Oscillator Frequency (Optional)
/////////////////////////////////////////////////////////////////////////////////////////////////////

	status = AT91F_WaitForMainClockFrequency();

/////////////////////////////////////////////////////////////////////////////////////////////////////
// Flash AT49BV1614 Initialisation : must be done before change the clocks -> Set correct Wait States
/////////////////////////////////////////////////////////////////////////////////////////////////////

	AT91F_InitFlash();
 
/////////////////////////////////////////////////////////////////////////////////////////////////////
// Step 3. to 5.
/////////////////////////////////////////////////////////////////////////////////////////////////////

	status = AT91F_InitClocks(PLLAR,PLLBR,MCKR);

/////////////////////////////////////////////////////////////////////////////////////////////////////
// SDRAM Initialisation
/////////////////////////////////////////////////////////////////////////////////////////////////////

	AT91F_InitSDRAM();
	
/////////////////////////////////////////////////////////////////////////////////////////////////////
// Test PMC Initialization.
/////////////////////////////////////////////////////////////////////////////////////////////////////

	// Open PIO for DBGU
	AT91F_DBGU_CfgPIO();

	// Configure DBGU
	AT91F_US_Configure (
		(AT91PS_USART) AT91C_BASE_DBGU,          			// DBGU base address
		60000000,                  							// 60 MHz
		AT91C_US_CHMODE_NORMAL | AT91C_US_PAR_NONE ,        // mode Register to be programmed
		115200 ,                   							// baudrate to be programmed
		0);                        							// timeguard to be programmed

	// Enable Transmitter
	AT91F_US_EnableTx((AT91PS_USART) AT91C_BASE_DBGU);

	AT91F_DBGU_Printk("\n\rAT91F_LowLevelInit() Complete!\n\r");

}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜片在线观看| 亚洲乱码一区二区三区在线观看| 欧美国产精品劲爆| 亚洲电影在线播放| 99视频超级精品| 欧美不卡一二三| 亚洲成人激情社区| 国产99一区视频免费| 69堂亚洲精品首页| 一区二区三区日韩精品视频| 国产精品夜夜嗨| 日韩欧美国产午夜精品| 亚洲自拍偷拍综合| 99re8在线精品视频免费播放| 精品免费国产二区三区| 性欧美大战久久久久久久久| 色综合久久久久| 国产精品丝袜黑色高跟| 国产在线精品一区二区不卡了| 欧美午夜精品久久久| 亚洲欧美日韩人成在线播放| 成人免费毛片aaaaa**| 久久综合久久综合久久综合| 日韩福利电影在线| 91精品国产综合久久精品| 亚洲国产成人av好男人在线观看| 91麻豆自制传媒国产之光| 中文字幕一区二区日韩精品绯色| 成人综合在线网站| 欧美国产欧美综合| 成人va在线观看| 国产精品久久免费看| 99久久夜色精品国产网站| 国产精品理论片| 99久久99精品久久久久久| 亚洲天堂福利av| 在线亚洲人成电影网站色www| 亚洲日韩欧美一区二区在线| 一本色道久久综合亚洲aⅴ蜜桃 | 丁香婷婷综合激情五月色| 2024国产精品视频| 国产福利一区二区三区| 中日韩av电影| 色婷婷av一区| 三级在线观看一区二区| 欧美电影免费观看高清完整版在线 | 国产精品1024久久| 久久久国产精华| av在线播放一区二区三区| 亚洲女爱视频在线| 在线91免费看| 韩国精品在线观看| 中文字幕日韩精品一区| 欧美四级电影网| 韩国一区二区视频| 成人欧美一区二区三区视频网页| 欧美在线观看你懂的| 免费精品视频在线| 欧美激情一二三区| 欧美视频中文一区二区三区在线观看| 日韩av在线免费观看不卡| 26uuu亚洲婷婷狠狠天堂| 99久久精品国产毛片| 视频在线观看一区| 欧美极品美女视频| 在线观看区一区二| 国产综合久久久久久鬼色| 亚洲日本va午夜在线影院| 日韩一区二区三区视频在线观看| 国产**成人网毛片九色| 亚洲1区2区3区视频| 久久久精品影视| 欧美日韩一区二区三区不卡| 国产一区二区三区四区五区美女 | 亚洲国产毛片aaaaa无费看| 亚洲精品在线免费观看视频| 91老师片黄在线观看| 国产一区二区三区四| 亚洲一区二区在线播放相泽| 欧美精品一区二区在线播放| 欧美性大战久久久久久久蜜臀| 狠狠色狠狠色综合系列| 亚洲成人免费视| 国产精品久久久久久久久快鸭| 91精品在线麻豆| 色88888久久久久久影院野外| 久久99久久99小草精品免视看| 亚洲一区中文在线| 中文字幕av不卡| 精品成人免费观看| 欧美一区二区观看视频| 欧美在线不卡一区| 成人av网址在线| 国产精品一卡二| 人人精品人人爱| 亚洲一二三区在线观看| 国产精品二区一区二区aⅴ污介绍| 日韩精品一区二区三区swag| 欧美久久久影院| 在线观看欧美精品| 91麻豆高清视频| 91免费小视频| 菠萝蜜视频在线观看一区| 国产精品亚洲午夜一区二区三区 | 国产成人亚洲综合a∨猫咪| 亚洲va天堂va国产va久| 一区二区三区四区亚洲| 日韩美女精品在线| 中文字幕中文在线不卡住| 国产欧美精品一区二区三区四区| 欧美xxx久久| 日韩三级视频在线看| 制服丝袜亚洲色图| 91精品国产综合久久久久久 | 欧美变态tickling挠脚心| 欧美一区二区三区在线电影| 制服丝袜av成人在线看| 欧美日本在线播放| 日韩一区二区三区四区五区六区| 91麻豆精品91久久久久久清纯 | 午夜精品成人在线| 婷婷丁香久久五月婷婷| 日韩国产在线观看| 久久99精品久久久久久| 狠狠色2019综合网| 精品视频免费在线| 91麻豆精品国产91久久久久久久久 | 日韩毛片精品高清免费| 中文字幕综合网| 亚洲一区在线视频| 日韩av一区二| 精品一区二区三区免费毛片爱| 国产伦精品一区二区三区视频青涩| 国产精品原创巨作av| www.综合网.com| 欧美性猛片xxxx免费看久爱| 777xxx欧美| 国产日产欧美精品一区二区三区| 亚洲国产高清在线观看视频| 亚洲精品少妇30p| 人人精品人人爱| 成人性生交大片免费看中文网站| 91视频免费看| 欧美一区二区三区四区在线观看 | 欧美日韩高清在线| 精品国产乱码久久久久久蜜臀| 国产精品午夜久久| 午夜精品久久久久久久| 国产乱码一区二区三区| 91美女精品福利| 精品嫩草影院久久| 亚洲日本在线观看| 久久99热狠狠色一区二区| 成人高清免费观看| 91.com在线观看| 国产精品乱人伦一区二区| 日本成人在线不卡视频| 不卡视频免费播放| 欧美一区二区在线视频| 中文字幕日韩一区| 久久99精品久久久久久久久久久久| 成人国产免费视频| 日韩欧美电影一二三| 日韩美女视频一区二区| 国产自产视频一区二区三区| 91麻豆视频网站| 国产欧美一区二区精品忘忧草| 亚洲国产精品天堂| 成人av网址在线观看| 欧美电影免费观看高清完整版在线观看 | 国产xxx精品视频大全| 欧美群妇大交群的观看方式| 国产精品女同一区二区三区| 日本欧美在线看| 色婷婷av一区二区三区gif| 日本一区二区三级电影在线观看 | 狠狠色综合播放一区二区| 精品视频一区二区不卡| 亚洲欧美一区二区三区久本道91| 国产一区亚洲一区| 日韩欧美在线1卡| 亚洲一区二区三区精品在线| 岛国精品在线播放| 久久久不卡影院| 国产亚洲制服色| 精品国产乱码久久久久久久久| 91精彩视频在线| 欧美精品一二三| 亚洲一区二区三区国产| 91丨九色丨尤物| 中文字幕亚洲电影| 成人免费视频播放| 欧美国产激情一区二区三区蜜月| 免费不卡在线视频| 欧美一区二区三区喷汁尤物| 午夜精品久久久久久久99水蜜桃 | 精品在线亚洲视频| 欧美大片顶级少妇| 精品一区二区三区久久| 精品噜噜噜噜久久久久久久久试看|