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

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

?? at91sam9xeek.c

?? ATMEL AT91SAM926x bootstrap 程序
?? C
字號:
/* ---------------------------------------------------------------------------- *         ATMEL Microcontroller Software Support  -  ROUSSET  - * ---------------------------------------------------------------------------- * Copyright (c) 2007, Atmel Corporation * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * - Redistributions of source code must retain the above copyright notice, * this list of conditions and the disclaiimer below. * * - Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the disclaimer below in the documentation and/or * other materials provided with the distribution. * * Atmel's name may not be used to endorse or promote products derived from * this software without specific prior written permission. * * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE * DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ---------------------------------------------------------------------------- * File Name           : at91sam9xeek.c * Object              : * Creation            : NFe Feb 2nd 2007 *----------------------------------------------------------------------------- */#include "../../include/part.h"#include "../../include/gpio.h"#include "../../include/pmc.h"#include "../../include/debug.h"#include "../../include/sdramc.h"#include "../../include/main.h"#ifdef CFG_NANDFLASH#include "../../include/nandflash.h"#endif#ifdef CFG_DATAFLASH#include "../../include/dataflash.h"#endifstatic inline unsigned int get_cp15(void){	unsigned int value;	__asm__("mrc p15, 0, %0, c1, c0, 0" : "=r" (value));	return value;}static inline void set_cp15(unsigned int value){	__asm__("mcr p15, 0, %0, c1, c0, 0" : : "r" (value));}#ifdef CFG_HW_INIT/*----------------------------------------------------------------------------*//* \fn    hw_init							      *//* \brief This function performs very low level HW initialization	      *//* This function is invoked as soon as possible during the c_startup	      *//* The bss segment must be initialized					      *//*----------------------------------------------------------------------------*/void hw_init(void){	unsigned int cp15;		/* Configure PIOs */	const struct pio_desc hw_pio[] = {#ifdef CFG_DEBUG		{"RXD", AT91C_PIN_PB(14), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"TXD", AT91C_PIN_PB(15), 0, PIO_DEFAULT, PIO_PERIPH_A},#endif		{(char *) 0, 0, 0, PIO_DEFAULT, PIO_PERIPH_A},	};	/* Disable watchdog */	writel(AT91C_WDTC_WDDIS, AT91C_BASE_WDTC + WDTC_WDMR);	/* At this stage the main oscillator is supposed to be enabled	 * PCK = MCK = MOSC */	/* Adjust waitstates to access internal flash */	writel(AT91C_EFC_FWS_6WS, AT91C_BASE_EFC + EFC_FMR);	/* Configure PLLA = MOSC * (PLL_MULA + 1) / PLL_DIVA */	pmc_cfg_plla(PLLA_SETTINGS, PLL_LOCK_TIMEOUT);	/* Switch MCK on PLLA output PCK = PLLA = 2 * MCK */	pmc_cfg_mck(MCKR_SETTINGS, PLL_LOCK_TIMEOUT);	/* Configure PLLB */	pmc_cfg_pllb(PLLB_SETTINGS, PLL_LOCK_TIMEOUT);	/* Configure CP15 */	cp15 = get_cp15();	cp15 |= I_CACHE;	set_cp15(cp15);	/* Configure the PIO controller */	pio_setup(hw_pio);#ifdef CFG_DEBUG	/* Enable Debug messages on the DBGU */	dbg_init(BAUDRATE(MASTER_CLOCK, 115200));	dbg_print("Start AT91Bootstrap...\n\r");#endif /* CFG_DEBUG */#ifdef CFG_SDRAM	/* Initialize the matrix */	writel(readl(AT91C_BASE_CCFG + CCFG_EBICSA) | AT91C_EBI_CS1A_SDRAMC, AT91C_BASE_CCFG + CCFG_EBICSA);	/* Configure SDRAM Controller */	sdram_init(	AT91C_SDRAMC_NC_9  |				AT91C_SDRAMC_NR_13 |				AT91C_SDRAMC_CAS_2 |				AT91C_SDRAMC_NB_4_BANKS |				AT91C_SDRAMC_DBW_32_BITS |				AT91C_SDRAMC_TWR_2 |				AT91C_SDRAMC_TRC_7 |				AT91C_SDRAMC_TRP_2 |				AT91C_SDRAMC_TRCD_2 |				AT91C_SDRAMC_TRAS_5 |				AT91C_SDRAMC_TXSR_8,		/* Control Register */				(MASTER_CLOCK * 7)/1000000);	/* Refresh Timer Register */#endif /* CFG_SDRAM */}#endif /* CFG_HW_INIT */#ifdef CFG_SDRAM/*------------------------------------------------------------------------------*//* \fn    sdramc_hw_init							*//* \brief This function performs SDRAMC HW initialization			*//*------------------------------------------------------------------------------*/void sdramc_hw_init(void){	/* Configure PIOs *//*	const struct pio_desc sdramc_pio[] = {		{"D16", AT91C_PIN_PC(16), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D17", AT91C_PIN_PC(17), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D18", AT91C_PIN_PC(18), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D19", AT91C_PIN_PC(19), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D20", AT91C_PIN_PC(20), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D21", AT91C_PIN_PC(21), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D22", AT91C_PIN_PC(22), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D23", AT91C_PIN_PC(23), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D24", AT91C_PIN_PC(24), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D25", AT91C_PIN_PC(25), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D26", AT91C_PIN_PC(26), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D27", AT91C_PIN_PC(27), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D28", AT91C_PIN_PC(28), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D29", AT91C_PIN_PC(29), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D30", AT91C_PIN_PC(30), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"D31", AT91C_PIN_PC(31), 0, PIO_DEFAULT, PIO_PERIPH_A},		{(char *) 0, 0, 0, PIO_DEFAULT, PIO_PERIPH_A},	};*/	/* Configure the SDRAMC PIO controller to output PCK0 *//*	pio_setup(sdramc_pio); */	writel(0xFFFF0000, AT91C_BASE_PIOC + PIO_ASR(0));	writel(0xFFFF0000, AT91C_BASE_PIOC + PIO_PDR(0));}#endif /* CFG_SDRAM */#ifdef CFG_DATAFLASH/*------------------------------------------------------------------------------*//* \fn    df_recovery								*//* \brief This function erases DataFlash Page 0 if BP4 is pressed 		*//*        during boot sequence							*//*------------------------------------------------------------------------------*/void df_recovery(AT91PS_DF pDf){#if (AT91C_SPI_PCS_DATAFLASH == AT91C_SPI_PCS1_DATAFLASH)	/* Configure PIOs */	const struct pio_desc bp4_pio[] = {		{"BP4", AT91C_PIN_PA(31), 0, PIO_PULLUP, PIO_INPUT},		{(char *) 0, 0, 0, PIO_DEFAULT, PIO_PERIPH_A},	};	/* Configure the PIO controller */	writel((1 << AT91C_ID_PIOA), PMC_PCER + AT91C_BASE_PMC);	pio_setup(bp4_pio);		/* If BP4 is pressed during Boot sequence */	/* Erase NandFlash block 0*/	if ( !pio_get_value(AT91C_PIN_PA(31)) )		df_page_erase(pDf, 0);#endif}/*------------------------------------------------------------------------------*//* \fn    df_hw_init								*//* \brief This function performs DataFlash HW initialization			*//*------------------------------------------------------------------------------*/void df_hw_init(void){	/* Configure PIOs */	const struct pio_desc df_pio[] = {		{"MISO",  AT91C_PIN_PA(0), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"MOSI",  AT91C_PIN_PA(1), 0, PIO_DEFAULT, PIO_PERIPH_A},		{"SPCK",  AT91C_PIN_PA(2), 0, PIO_DEFAULT, PIO_PERIPH_A},#if (AT91C_SPI_PCS_DATAFLASH == AT91C_SPI_PCS0_DATAFLASH)		{"NPCS0", AT91C_PIN_PA(3), 0, PIO_DEFAULT, PIO_PERIPH_A},#endif#if (AT91C_SPI_PCS_DATAFLASH == AT91C_SPI_PCS1_DATAFLASH)		{"NPCS1", AT91C_PIN_PC(11), 0, PIO_DEFAULT, PIO_PERIPH_B},#endif		{(char *) 0, 0, 0, PIO_DEFAULT, PIO_PERIPH_A},	};	/* Configure the PIO controller */	pio_setup(df_pio);}#endif /* CFG_DATAFLASH */#ifdef CFG_NANDFLASH/*------------------------------------------------------------------------------*//* \fn    nand_recovery						*//* \brief This function erases NandFlash Block 0 if BP4 is pressed 		*//*        during boot sequence							*//*------------------------------------------------------------------------------*/static void nand_recovery(void){	/* Configure PIOs */	const struct pio_desc bp4_pio[] = {		{"BP4", AT91C_PIN_PA(31), 0, PIO_PULLUP, PIO_INPUT},		{(char *) 0, 0, 0, PIO_DEFAULT, PIO_PERIPH_A},	};	/* Configure the PIO controller */	writel((1 << AT91C_ID_PIOA), PMC_PCER + AT91C_BASE_PMC);	pio_setup(bp4_pio);		/* If BP4 is pressed during Boot sequence */	/* Erase NandFlash block 0*/	if (!pio_get_value(AT91C_PIN_PA(31)) )		AT91F_NandEraseBlock0();}/*------------------------------------------------------------------------------*//* \fn    nandflash_hw_init							*//* \brief NandFlash HW init							*//*------------------------------------------------------------------------------*/void nandflash_hw_init(void){	/* Configure PIOs */	const struct pio_desc nand_pio[] = {		{"RDY_BSY", AT91C_PIN_PC(13), 0, PIO_PULLUP, PIO_INPUT},		{"NANDCS",  AT91C_PIN_PC(14), 0, PIO_PULLUP, PIO_OUTPUT},		{(char *) 0, 0, 0,  PIO_DEFAULT, PIO_PERIPH_A},	};	/* Setup Smart Media, first enable the address range of CS3 in HMATRIX user interface */	writel(readl(AT91C_BASE_CCFG + CCFG_EBICSA) | AT91C_EBI_CS3A_SM, AT91C_BASE_CCFG + CCFG_EBICSA);		    	/* Configure SMC CS3 */ 	writel((AT91C_SM_NWE_SETUP | AT91C_SM_NCS_WR_SETUP | AT91C_SM_NRD_SETUP | AT91C_SM_NCS_RD_SETUP), AT91C_BASE_SMC0 + SMC_SETUP3);  	writel((AT91C_SM_NWE_PULSE | AT91C_SM_NCS_WR_PULSE | AT91C_SM_NRD_PULSE | AT91C_SM_NCS_RD_PULSE), AT91C_BASE_SMC0 + SMC_PULSE3);	writel((AT91C_SM_NWE_CYCLE | AT91C_SM_NRD_CYCLE)						, AT91C_BASE_SMC0 + SMC_CYCLE3);	writel((AT91C_SMC_READMODE | AT91C_SMC_WRITEMODE | AT91C_SMC_NWAITM_NWAIT_DISABLE |   		AT91C_SMC_DBW_WIDTH_EIGTH_BITS | AT91C_SM_TDF)						, AT91C_BASE_SMC0 + SMC_CTRL3);	/* Configure the PIO controller */	writel((1 << AT91C_ID_PIOC), PMC_PCER + AT91C_BASE_PMC);	pio_setup(nand_pio);		nand_recovery();}/*------------------------------------------------------------------------------*//* \fn    nandflash_cfg_16bits_dbw_init						*//* \brief Configure SMC in 16 bits mode						*//*------------------------------------------------------------------------------*/void nandflash_cfg_16bits_dbw_init(void){	writel(readl(AT91C_BASE_SMC0 + SMC_CTRL3) | AT91C_SMC_DBW_WIDTH_SIXTEEN_BITS, AT91C_BASE_SMC0 + SMC_CTRL3);}#endif /* #ifdef CFG_NANDFLASH */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品一区二区综合| 欧美一级二级三级乱码| 欧美男生操女生| 国产女人18水真多18精品一级做| 亚洲欧美日韩在线不卡| 精品写真视频在线观看| 欧美日韩在线播放三区| 日本一区二区视频在线| 日本中文在线一区| 在线视频国内一区二区| 国产嫩草影院久久久久| 蜜桃91丨九色丨蝌蚪91桃色| 在线观看av一区| 17c精品麻豆一区二区免费| 国产在线精品一区二区夜色| 欧美另类z0zxhd电影| 一区二区三区日韩欧美| 成人精品在线视频观看| 久久日韩精品一区二区五区| 午夜激情综合网| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 亚洲午夜在线电影| 成人av网站在线观看| 精品日韩一区二区三区| 日本特黄久久久高潮| 欧美午夜精品久久久| 亚洲人123区| 91免费看视频| 亚洲视频资源在线| 91一区二区三区在线观看| 中文字幕成人av| 国产大陆精品国产| 欧美国产禁国产网站cc| 国产高清精品久久久久| 国产日韩精品一区二区三区在线| 精品在线一区二区三区| 久久久一区二区三区| 黑人巨大精品欧美一区| 久久精品免视看| 成人激情免费电影网址| 中文字幕在线观看一区| av亚洲精华国产精华精| 亚洲美女视频在线| 在线亚洲人成电影网站色www| 一区二区视频在线| 精品视频在线免费看| 日韩福利视频导航| 日韩精品一区二区三区swag| 极品美女销魂一区二区三区免费| 久久综合色婷婷| 成人精品亚洲人成在线| 一区二区三区精品视频| 69精品人人人人| 久久av中文字幕片| 国产精品久久久久精k8| 欧美综合欧美视频| 精品在线播放免费| 国产精品福利影院| 欧美午夜精品一区二区三区 | 在线日韩国产精品| 爽好多水快深点欧美视频| 欧美成人官网二区| av午夜精品一区二区三区| 亚洲电影在线免费观看| 欧美变态tickle挠乳网站| av电影一区二区| 图片区日韩欧美亚洲| 久久先锋影音av| 在线欧美小视频| 国产麻豆精品久久一二三| 亚洲一区视频在线| 久久久国产午夜精品| 欧美日韩国产高清一区| 国产精品一级在线| 婷婷亚洲久悠悠色悠在线播放| 2023国产精品自拍| 欧美性感一区二区三区| 国产精品一区免费在线观看| 亚洲电影第三页| 国产精品久久久久一区二区三区| 91精品国产欧美一区二区 | 亚洲电影视频在线| 国产女主播在线一区二区| 欧美日韩精品一区二区在线播放| 国产精品一区二区你懂的| 午夜精品久久久久久久99水蜜桃| 国产精品国产自产拍高清av王其 | 亚洲人妖av一区二区| 欧美大胆一级视频| 欧美性猛交xxxx乱大交退制版| 国产精品888| 日本亚洲三级在线| 亚洲国产成人高清精品| 综合欧美一区二区三区| 国产欧美综合在线| 欧美成人欧美edvon| 欧美日韩三级在线| 91色视频在线| 成人网在线播放| 国产精品中文字幕日韩精品| 日本午夜一区二区| 图片区小说区区亚洲影院| 亚洲三级在线观看| 国产精品不卡在线| 欧美国产精品v| 26uuu另类欧美| 精品久久久久久最新网址| 欧美日本国产视频| 在线视频你懂得一区二区三区| 99久久综合国产精品| 成人黄色大片在线观看| 成人亚洲精品久久久久软件| 国产成人欧美日韩在线电影| 久久99热狠狠色一区二区| 日韩高清中文字幕一区| 日韩高清欧美激情| 日韩黄色免费电影| 蜜桃久久久久久| 蜜桃一区二区三区在线| 九色综合狠狠综合久久| 国内精品伊人久久久久av影院| 久草中文综合在线| 国产中文字幕一区| 国产成人欧美日韩在线电影| 成人午夜电影久久影院| av一区二区不卡| 欧美主播一区二区三区美女| 欧美精品少妇一区二区三区| 欧美一区午夜精品| 精品国产91亚洲一区二区三区婷婷| 欧美精品一区二区三区高清aⅴ| 久久久久久免费网| 国产精品免费aⅴ片在线观看| 国产精品传媒视频| 亚洲永久精品国产| 肉色丝袜一区二区| 久久99精品国产91久久来源| 粉嫩av亚洲一区二区图片| av电影一区二区| 欧美猛男男办公室激情| 日韩免费高清av| 欧美经典一区二区| 亚洲综合男人的天堂| 日日骚欧美日韩| 国产一区二区三区久久悠悠色av | 亚洲精品一区二区三区蜜桃下载 | 久久一区二区视频| 国产精品美女久久久久av爽李琼 | 91色乱码一区二区三区| 欧美日韩中文字幕精品| 日韩一区二区三区电影 | 欧美岛国在线观看| 中文字幕欧美国产| 视频在线观看一区二区三区| 国产麻豆视频一区二区| 欧美体内she精高潮| 久久综合色一综合色88| 亚洲va天堂va国产va久| 国产成人精品免费在线| 欧美色涩在线第一页| 久久久久久久久免费| 亚洲国产成人高清精品| 国产精品88888| 欧美久久久久久久久| 国产欧美日韩不卡| 视频一区在线播放| 99热在这里有精品免费| 欧美成人精品福利| 亚洲国产一二三| 国产ts人妖一区二区| 欧美一区二区免费观在线| 国产精品高潮呻吟久久| 极品少妇一区二区三区精品视频| 色婷婷综合激情| 国产精品情趣视频| 精品一区二区在线观看| 欧美色综合天天久久综合精品| 国产精品久久久久久福利一牛影视| 看片的网站亚洲| 欧美日韩第一区日日骚| 亚洲视频电影在线| 9久草视频在线视频精品| 精品国产乱码久久久久久蜜臀| 悠悠色在线精品| av爱爱亚洲一区| 国产精品欧美极品| 丁香六月久久综合狠狠色| 中文字幕亚洲在| 国产精品一二三| 国产午夜精品一区二区三区嫩草| 日韩黄色小视频| 日韩写真欧美这视频| 首页国产欧美日韩丝袜| 欧美日韩国产美女| 亚洲综合小说图片| 欧美在线影院一区二区| 亚洲一区免费在线观看| 欧美性猛片aaaaaaa做受| 一个色综合av| 欧美亚洲综合在线|