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

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

?? init.c

?? at91rm9200測(cè)試lcd dispaly 的程序
?? 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");

}


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美一区二区久久婷婷| 日韩亚洲欧美一区| 国产成人av电影在线| 蜜臀va亚洲va欧美va天堂| 调教+趴+乳夹+国产+精品| 一区二区三区电影在线播| 亚洲蜜桃精久久久久久久| 亚洲日本丝袜连裤袜办公室| 国产精品色婷婷久久58| 综合自拍亚洲综合图不卡区| 国产精品久久久一本精品 | 99热精品一区二区| 成人短视频下载| 91视频观看免费| 在线一区二区观看| 欧美一区二区在线免费播放| 日韩精品一区在线| 国产农村妇女毛片精品久久麻豆| 国产精品无遮挡| 亚洲精品日产精品乱码不卡| 日韩电影免费一区| 国产麻豆视频精品| aaa亚洲精品| 3d动漫精品啪啪1区2区免费| 欧美va在线播放| 国产精品久久久久久户外露出| 亚洲精选在线视频| 麻豆精品久久久| 豆国产96在线|亚洲| 在线观看视频欧美| 日韩精品一区在线| 亚洲欧美激情在线| 麻豆国产精品777777在线| 成人美女在线观看| 欧美久久久久久久久中文字幕| 2021中文字幕一区亚洲| 一区二区三区四区激情| 精品在线观看免费| 色欧美88888久久久久久影院| 91精品国产91久久久久久最新毛片 | 国产成人一区在线| 欧美亚洲图片小说| 久久久精品日韩欧美| 一区二区三区自拍| 国产乱人伦偷精品视频不卡| 欧美在线色视频| 国产午夜精品久久久久久久| 五月婷婷久久综合| 91蜜桃免费观看视频| 日韩欧美精品三级| 亚洲一区二区三区中文字幕| 国产在线精品视频| 日韩一区二区在线播放| 亚洲人亚洲人成电影网站色| 激情综合一区二区三区| 欧美体内she精视频| 国产亚洲成av人在线观看导航 | 中文字幕高清不卡| 久久精品国产999大香线蕉| 91丝袜国产在线播放| 国产视频一区二区在线| 久久er99热精品一区二区| 欧美色图免费看| 亚洲精品国产一区二区精华液| 国产福利精品一区二区| 亚洲精品一区二区三区99| 日本特黄久久久高潮| 欧美在线一区二区三区| 亚洲女人****多毛耸耸8| www.在线欧美| 一区二区中文视频| 色综合色狠狠综合色| 亚洲视频精选在线| 94-欧美-setu| 亚洲免费大片在线观看| 色综合咪咪久久| 亚洲自拍偷拍av| 欧美日韩国产另类不卡| 午夜电影一区二区| 欧美一区二区三区系列电影| 日韩av中文字幕一区二区 | 国产一区久久久| 久久久精品欧美丰满| 国产精品一二三| 国产精品灌醉下药二区| 92国产精品观看| 亚洲一区二区偷拍精品| 555www色欧美视频| 经典三级一区二区| 国产精品久久久久婷婷| 色播五月激情综合网| 亚洲国产精品久久不卡毛片| 欧美一区午夜精品| 国产一区二区三区四 | 日本韩国欧美三级| 亚洲va欧美va人人爽午夜| 91精品免费在线观看| 国产美女娇喘av呻吟久久| 1区2区3区欧美| 欧美精品 国产精品| 国产在线一区二区综合免费视频| 国产婷婷色一区二区三区四区 | 91精品国产美女浴室洗澡无遮挡| 蜜臀av在线播放一区二区三区| 国产欧美一区视频| 色婷婷精品久久二区二区蜜臂av| 丝袜美腿高跟呻吟高潮一区| 亚洲精品在线观看视频| 99视频在线精品| 蜜臀久久99精品久久久久宅男 | 亚洲地区一二三色| 久久综合久久综合亚洲| 91免费精品国自产拍在线不卡| 亚洲一区免费在线观看| 久久女同精品一区二区| 欧洲精品中文字幕| 国产成人亚洲精品青草天美| 一区二区久久久久| 欧美大片国产精品| 欧洲一区二区三区在线| 国产乱淫av一区二区三区| 一区二区激情视频| 国产欧美久久久精品影院| 欧美精品三级日韩久久| 99国产精品一区| 国产乱国产乱300精品| 亚洲bt欧美bt精品| 成人免费在线视频| 国产日韩欧美精品在线| 欧美一级国产精品| 欧美午夜影院一区| 99r国产精品| 国产成人鲁色资源国产91色综| 天堂久久一区二区三区| 亚洲精品免费视频| 国产精品成人免费| 国产视频一区在线播放| 精品国产乱码久久久久久免费| 欧美片网站yy| 在线亚洲免费视频| 91亚洲大成网污www| 国产盗摄视频一区二区三区| 韩日av一区二区| 麻豆成人免费电影| 免费成人在线观看视频| 日韩国产欧美一区二区三区| 亚洲一区二区三区爽爽爽爽爽| 中文字幕一区二区视频| 中文在线资源观看网站视频免费不卡| 久久综合五月天婷婷伊人| 欧美sm美女调教| 久久综合九色综合欧美98| 欧美r级在线观看| 久久久久久久久久美女| 久久久久久久久久看片| 国产欧美一区二区精品仙草咪| 久久久久久97三级| 国产三级精品视频| 亚洲国产精品二十页| 国产精品乱码一区二区三区软件 | 在线不卡免费欧美| 欧美日本在线看| 91精品国产福利在线观看| 欧美一级视频精品观看| 日韩精品在线网站| 亚洲国产精品传媒在线观看| 中文字幕一区日韩精品欧美| 亚洲精品视频观看| 丝袜美腿成人在线| 国产美女主播视频一区| 99精品久久99久久久久| 欧美精品一卡两卡| 日本女人一区二区三区| 亚洲国产欧美在线人成| 日本中文字幕一区二区视频| 韩国三级电影一区二区| 国产在线不卡一区| www.亚洲人| 欧美三级日本三级少妇99| 日韩一区二区三区四区| 国产婷婷色一区二区三区在线| 综合色天天鬼久久鬼色| 日韩成人av影视| 国产成人免费网站| 欧美丝袜丝交足nylons| 精品少妇一区二区三区在线视频| 国产亚洲精品精华液| 一区二区在线观看免费| 久久不见久久见免费视频7| www.久久久久久久久| 欧美精品第1页| 国产精品久久久久桃色tv| 日韩成人免费看| 成人国产精品免费网站| 337p亚洲精品色噜噜噜| 中文字幕第一区第二区| 蜜桃一区二区三区在线| 94-欧美-setu| 久久久精品欧美丰满| 日韩成人午夜精品|