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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? init.c

?? AT91RM9200的USB host和USB device的代碼ADS1.2. USB-Device測(cè)試程序: 因?yàn)槌绦蜻\(yùn)行在SDRAM中
?? C
字號(hào):
//*----------------------------------------------------------------------------
//*         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
//*初始FLASH 、初始主時(shí)鐘60000000Hz、初始SDRAM、初始DEBUG端口
//*----------------------------------------------------------------------------

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

//#include <stdarg.h>
//#include <string.h>
//#include <stdlib.h>
//#include <stdio.h>
//#include <ctype.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

#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


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

//*----------------------------------------------------------------------------
//* \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)
/////////////////////////////////////////////////////////////////////////////////////////////////////

	//* Constraints of the Master Clock selection sequence
	//* Write in the MCKR dirty value concerning the clock selection CSS then overwrite it in a second sequence
	AT91C_BASE_PMC->PMC_MCKR = AT91C_PMC_CSS_SLOW_CLK;
	//* Wait until the master clock is established
	tmp = 0;
	while( !(AT91C_BASE_PMC->PMC_SR & AT91C_PMC_MCKRDY) && (tmp++ < DELAY_MAIN_FREQ) );

	//* Second sequence
	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 |= 0;
	AT91C_BASE_EBI->EBI_CFGR = 0;

	//* Setup Flash
	AT91C_BASE_SMC2->SMC2_CSR[0] = 0x6 | (1<<7) | (2<<8) | (1<<12) | (1<<13);

}

//*----------------------------------------------------------------------------
//* \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++);
	}
}
/*
//=====================================================================
//If you don't use vsprintf(), the code size is reduced very much.
void AT91F_DBGU_Printf(char *fmt,...)
{
    va_list ap;
    char string[256];

    va_start(ap,fmt);
    vsprintf(string,fmt,ap);
    AT91F_DBGU_Printk(string);
    va_end(ap);
}
*/
//-------------------------------------------------------------------------
//Input Char
char AT91F_DBGU_GetChar(void)
{

	while (!AT91F_US_RxReady((AT91PS_USART)AT91C_BASE_DBGU));
	return (char)((AT91F_US_GetChar((AT91PS_USART)AT91C_BASE_DBGU))&0xff);
	
}

//*----------------------------------------------------------------------------
//* \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_US_EnableRx((AT91PS_USART) AT91C_BASE_DBGU);

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

}


?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
夜夜爽夜夜爽精品视频| aaa欧美大片| 蜜臀av一区二区在线免费观看| 亚洲综合久久久久| 亚洲尤物在线视频观看| 一区二区不卡在线播放| 一区二区三区不卡视频| 亚洲高清不卡在线| 日韩中文字幕av电影| 日韩精品每日更新| 另类调教123区| 国产一区欧美一区| 国产mv日韩mv欧美| 成人ar影院免费观看视频| 99精品视频中文字幕| 91久久久免费一区二区| 欧美三日本三级三级在线播放| 欧美丝袜丝交足nylons图片| 91精品国产乱码| 精品国产乱码久久久久久牛牛 | 色94色欧美sute亚洲线路二 | 欧美高清性hdvideosex| 欧美一区二区在线免费播放| 日韩免费电影网站| 中文字幕av一区二区三区高| 亚洲三级电影网站| 日韩精品色哟哟| 国产麻豆视频一区| 色婷婷综合久久| 欧美一区二区三区的| xf在线a精品一区二区视频网站| 欧美激情一区二区三区蜜桃视频| 亚洲免费在线观看| 日本va欧美va精品发布| 国产精品一区二区免费不卡| 97久久超碰国产精品电影| 欧美久久久久免费| 久久女同精品一区二区| 亚洲蜜臀av乱码久久精品| 91在线视频免费观看| 91精品国产91热久久久做人人| 精品久久国产字幕高潮| ●精品国产综合乱码久久久久| 午夜在线电影亚洲一区| 国产一区二区三区美女| 欧美曰成人黄网| 久久九九国产精品| 亚洲成人综合网站| 成人午夜在线免费| 91精品婷婷国产综合久久性色| 国产亚洲欧美一区在线观看| 亚洲福利一区二区| 成人综合在线观看| 欧美高清视频www夜色资源网| 国产亚洲精品中文字幕| 亚洲成人www| 成人高清av在线| 日韩欧美激情在线| 亚洲男人天堂av网| 国产91在线看| 欧美一区午夜精品| 一区二区国产盗摄色噜噜| 国产在线一区二区| 欧美人妇做爰xxxⅹ性高电影| 日本一区二区三区国色天香| 日本美女一区二区三区视频| 色综合激情久久| 国产日韩欧美精品一区| 日本不卡高清视频| 欧美在线一区二区| 国产精品久久毛片a| 国产在线视视频有精品| 欧美疯狂性受xxxxx喷水图片| 国产精品五月天| 国产一区二区三区四区五区入口 | 欧美一区二区视频观看视频| 国产精品不卡一区| 国产精选一区二区三区| 日韩精品一区二区三区四区| 亚洲妇女屁股眼交7| 色噜噜狠狠成人中文综合| 国产精品毛片a∨一区二区三区| 极品尤物av久久免费看| 91精品国产色综合久久ai换脸| 一区二区三区四区高清精品免费观看 | 麻豆成人免费电影| 欧美裸体bbwbbwbbw| 亚洲国产va精品久久久不卡综合 | 日韩一区二区三区视频在线观看 | 国产福利一区在线| 精品国产乱码久久久久久久久| 日本视频免费一区| 91麻豆精品91久久久久同性| 亚洲一二三四区| 日本韩国精品一区二区在线观看| 中文字幕在线不卡| 成人av在线电影| 国产精品理论在线观看| 成人爱爱电影网址| 国产精品久久一级| 成人h精品动漫一区二区三区| 国产精品美女久久久久av爽李琼| 丁香五精品蜜臀久久久久99网站| 久久精品在这里| 国产成人在线观看免费网站| 久久久久久久久久久久电影| 国产一区二区主播在线| 国产午夜精品久久久久久免费视| 国产电影精品久久禁18| 中文字幕av免费专区久久| zzijzzij亚洲日本少妇熟睡| 亚洲欧美另类综合偷拍| 色999日韩国产欧美一区二区| 亚洲自拍偷拍九九九| 欧美人牲a欧美精品| 日韩不卡手机在线v区| 欧美tickling挠脚心丨vk| 韩国成人福利片在线播放| 国产日韩欧美高清在线| 91亚洲精品久久久蜜桃网站| 亚洲一区中文在线| 91精品国产一区二区三区香蕉| 美脚の诱脚舐め脚责91| 国产日本一区二区| 97se亚洲国产综合在线| 亚洲aaa精品| 26uuu久久天堂性欧美| www..com久久爱| 亚洲一区在线观看免费 | 欧美国产日韩a欧美在线观看 | 欧美激情一区二区三区| 91网站黄www| 日韩精品一级中文字幕精品视频免费观看| 欧美一区二区三区小说| 国产成人在线视频网站| 一级特黄大欧美久久久| 日韩欧美亚洲国产精品字幕久久久| 国产一区二区三区电影在线观看| 中文字幕在线不卡一区| 欧美日韩国产一级片| 国产美女视频91| 一个色在线综合| 精品1区2区在线观看| aaa亚洲精品一二三区| 青娱乐精品视频| 国产精品动漫网站| 欧美一区二区三级| 波多野结衣在线一区| 天天综合色天天| 国产精品入口麻豆九色| 欧美日韩电影在线| 大美女一区二区三区| 日韩激情中文字幕| 国产精品乱人伦中文| 欧美一区二区三区四区视频| 波多野结衣视频一区| 麻豆91小视频| 一区二区三区欧美亚洲| 久久综合久久综合亚洲| 欧美三级中文字幕在线观看| 国产成人综合亚洲91猫咪| 日韩高清不卡一区| 亚洲免费资源在线播放| 国产三级欧美三级日产三级99| 欧美手机在线视频| www.66久久| 国产麻豆午夜三级精品| 免费成人在线视频观看| 一区二区三区中文在线| 欧美精彩视频一区二区三区| 91精品国产91热久久久做人人| av中文一区二区三区| 国产一区二区免费看| 偷窥少妇高潮呻吟av久久免费| 国产精品电影一区二区| 久久午夜电影网| 日韩欧美国产综合在线一区二区三区| 91免费看视频| 成人的网站免费观看| 黑人巨大精品欧美一区| 日本中文一区二区三区| 亚洲一级二级三级| **性色生活片久久毛片| 国产女人18水真多18精品一级做 | 日本一二三不卡| 精品奇米国产一区二区三区| 欧美日韩一区二区三区高清| 91在线免费视频观看| 国产大陆a不卡| 国产精品一区免费在线观看| 久久精品久久久精品美女| 日韩电影在线观看网站| 亚洲高清免费观看| 亚洲国产另类av| 亚洲一区二区在线免费看| 亚洲精品福利视频网站| 亚洲免费色视频| 一区二区三区成人在线视频| 一区二区三区高清不卡| 一区二区三区日本|