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

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

?? start_up.c

?? AD芯片TLC3544在ADS下的調(diào)試程序
?? 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
//*
//*----------------------------------------------------------------------------

#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)
/////////////////////////////////////////////////////////////////////////////////////////////////////

	//* 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 |= 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");

}


?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩高清在线观看| 亚洲国产一区二区在线播放| 色婷婷综合久久久中文一区二区 | 天天影视网天天综合色在线播放| 日韩你懂的在线观看| 色综合久久中文字幕| 黄一区二区三区| 亚洲国产三级在线| 国产女主播在线一区二区| 精品视频一区二区三区免费| 国产成人在线网站| 日产欧产美韩系列久久99| 综合久久一区二区三区| 久久品道一品道久久精品| 欧美性受xxxx黑人xyx| 成人午夜av电影| 玖玖九九国产精品| 午夜精品久久一牛影视| 亚洲少妇最新在线视频| 日本一区二区综合亚洲| 日韩免费福利电影在线观看| 欧美日韩精品免费| 色嗨嗨av一区二区三区| 不卡一卡二卡三乱码免费网站| 久久国产福利国产秒拍| 天天av天天翘天天综合网 | 日韩一区二区三区在线观看 | 91精品在线麻豆| 91福利资源站| 91碰在线视频| caoporen国产精品视频| 国产高清精品在线| 国产一区二区三区免费看| 久久99精品久久久久| 免费一级片91| 日本伊人色综合网| 成人免费视频一区二区| 国产精品白丝jk白祙喷水网站| 精品国产污污免费网站入口 | 日韩黄色免费电影| 亚洲美腿欧美偷拍| 亚洲欧美中日韩| 一区二区中文字幕在线| 国产欧美一区二区在线| 国产欧美日韩在线观看| 日本一区二区三区四区在线视频| 精品久久久久久久久久久久久久久久久| 欧美日韩国产在线播放网站| 欧美日韩激情一区二区三区| 欧美亚洲动漫制服丝袜| 欧美在线免费观看视频| 欧美视频第二页| 欧美精品1区2区| 日韩免费电影一区| 欧美电视剧在线看免费| 精品国产免费一区二区三区四区| 欧美xxxx在线观看| 久久久久久久网| 中文字幕视频一区| 亚洲综合在线观看视频| 亚洲综合色丁香婷婷六月图片| 亚洲成人激情社区| 男女男精品视频| 国产麻豆91精品| 91免费版在线| 91精品国产高清一区二区三区| 日韩视频一区在线观看| 国产欧美综合在线观看第十页| 日韩一区中文字幕| 婷婷中文字幕一区三区| 国产精品综合一区二区| av亚洲精华国产精华精华| 欧美无砖砖区免费| 欧美成人精精品一区二区频| 国产精品蜜臀av| 香蕉加勒比综合久久| 精品在线播放免费| 91麻豆国产福利在线观看| 欧美区视频在线观看| 国产午夜精品在线观看| 亚洲电影中文字幕在线观看| 国产在线精品一区二区三区不卡 | 亚洲精品在线观| 亚洲三级小视频| 精品一区在线看| 99久久亚洲一区二区三区青草| 666欧美在线视频| 中文字幕欧美区| 亚洲va欧美va人人爽| 成人午夜视频网站| 91精品国产综合久久精品图片| 欧美激情在线一区二区三区| 夜夜嗨av一区二区三区四季av| 国产自产2019最新不卡| 欧美日韩在线播放一区| 国产三级一区二区| 丝袜诱惑亚洲看片| 成人av午夜影院| 欧美高清dvd| 亚洲精品国产一区二区三区四区在线| 日本成人在线网站| 91污片在线观看| 久久精品一区四区| 奇米影视一区二区三区小说| 色综合网色综合| 久久久久久久久久久久久女国产乱| 亚洲一区二区三区免费视频| 国产成人av影院| 日韩无一区二区| 五月天中文字幕一区二区| av电影在线观看完整版一区二区| 精品人在线二区三区| 亚洲午夜精品网| www.66久久| 亚洲综合久久av| 在线观看91精品国产入口| 视频一区视频二区在线观看| 欧美日韩免费视频| 亚洲成人av在线电影| 成人不卡免费av| 国产女主播视频一区二区| 91丨porny丨中文| 国产精品久久久久久久久免费樱桃 | 国产麻豆成人传媒免费观看| 欧美人牲a欧美精品| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 精品一区二区三区欧美| 欧美嫩在线观看| 五月综合激情日本mⅴ| 91成人免费电影| 一区二区三区在线观看动漫 | 欧美一区二区三区四区高清| 亚洲午夜久久久久久久久久久| 色综合天天综合给合国产| 中文欧美字幕免费| 国产精品一二三四区| 国产日产亚洲精品系列| 韩国一区二区在线观看| 337p日本欧洲亚洲大胆精品| 韩国精品免费视频| 久久精品人人做| 成人激情av网| 自拍偷拍国产亚洲| 91国产成人在线| 天堂影院一区二区| 日韩亚洲电影在线| 国产在线一区二区| 中文一区二区在线观看 | 亚洲欧美一区二区三区极速播放| 中文欧美字幕免费| 一区二区三区.www| 亚洲1区2区3区4区| 免费欧美在线视频| 热久久一区二区| 久久精品久久99精品久久| 亚洲综合精品自拍| 亚洲综合丁香婷婷六月香| 国产在线精品一区二区夜色| 美美哒免费高清在线观看视频一区二区| 久久精品人人做人人综合| 国产欧美日韩久久| 日韩电影一区二区三区四区| 精品少妇一区二区三区免费观看 | 精品播放一区二区| 国产传媒久久文化传媒| 国产精品久久久久久一区二区三区| 成人高清视频免费观看| 一区二区免费视频| 69堂国产成人免费视频| 国产不卡在线一区| 亚洲一区二区三区四区五区黄| 日韩一区二区免费电影| 国产91精品久久久久久久网曝门 | 欧美久久久久久蜜桃| 国产在线精品国自产拍免费| 国产精品久久久久久久岛一牛影视| 91福利国产精品| 另类小说综合欧美亚洲| 日本一区二区三区在线观看| 欧美性生活一区| 国产一区二区三区久久悠悠色av | 国产精品久久免费看| 色94色欧美sute亚洲线路二 | 99久久国产免费看| 日韩电影免费一区| 国产精品国产a| 3751色影院一区二区三区| 成人小视频免费观看| 日本va欧美va瓶| 综合久久久久综合| 欧美va亚洲va在线观看蝴蝶网| 色综合久久天天| 国产一区二区三区蝌蚪| 午夜精品久久久久影视| 国产欧美精品区一区二区三区| 欧美精品少妇一区二区三区| 成人午夜电影久久影院| 蓝色福利精品导航| 亚洲国产精品久久久男人的天堂| 久久久久久久久久久久电影|