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

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

?? lpc177x_8x_emc.c

?? 優龍LPC1788開發板資料
?? C
?? 第 1 頁 / 共 2 頁
字號:
/***********************************************************************//**
 * @file		lpc177x_8x_emc.c
 * @brief		Contains all functions support for EMC firmware library on
 * 				LPC177x_8x
 * @version		1.0
 * @date		13. Dec. 2010
 * @author		NXP MCU SW Application Team
 **************************************************************************
 * Software that is described herein is for illustrative purposes only
 * which provides customers with programming information regarding the
 * products. This software is supplied "AS IS" without any warranties.
 * NXP Semiconductors assumes no responsibility or liability for the
 * use of the software, conveys no license or title under any patent,
 * copyright, or mask work right to the product. NXP Semiconductors
 * reserves the right to make changes in the software without
 * notification. NXP Semiconductors also make no representation or
 * warranty that such application will be suitable for the specified
 * use without further testing or modification.
 **********************************************************************/

#include "lpc177x_8x_emc.h"
#include "lpc177x_8x_clkpwr.h"
#include "lpc177x_8x_pinsel.h"


/*********************************************************************//**
 * @brief 		EMC initialize
 * @param[in]	None
 * @return 		None
 **********************************************************************/
void EMC_Init(void)
{
	uint8_t i;

	/* Enable clock for EMC */
//	CLKPWR_ConfigPPWR(CLKPWR_PCONP_PCEMC, ENABLE);
//	LPC_EMC->Control 	= 0x00000001;
// 	LPC_EMC->Config  	= 0x00000000;

	  LPC_SC->PCONP   	|= 0x00000800;
	  LPC_SC->EMCDLYCTL   = 0x00001010;
	  LPC_EMC->Control 	= 0x00000001;
	  LPC_EMC->Config  	= 0x00000000;

  /* Pin configuration:
   * P2.14 - /EMC_CS2
   * P2.15 - /EMC_CS3
   *
   * P2.16 - /EMC_CAS
   * P2.17 - /EMC_RAS
   * P2.18 - EMC_CLK[0]
   * P2.19 - EMC_CLK[1]
   *
   * P2.20 - EMC_DYCS0
   * P2.21 - EMC_DYCS1
   * P2.22 - EMC_DYCS2
   * P2.23 - EMC_DYCS3
   *
   * P2.24 - EMC_CKE0
   * P2.25 - EMC_CKE1
   * P2.26 - EMC_CKE2
   * P2.27 - EMC_CKE3
   *
   * P2.28 - EMC_DQM0
   * P2.29 - EMC_DQM1
   * P2.30 - EMC_DQM2
   * P2.31 - EMC_DQM3
   *
   * P3.0-P3.31 - EMC_D[0-31]
   * P4.0-P4.23 - EMC_A[0-23]
   *
   * P4.24 - /EMC_OE
   * P4.25 - /EMC_WE
   *
   * P4.30 - /EMC_CS0
   * P4.31 - /EMC_CS1   */
//	PINSEL_ConfigPin(2,14,1);
//	PINSEL_ConfigPin(2,15,1);
	PINSEL_ConfigPin(2,16,1);
	PINSEL_ConfigPin(2,17,1);
	PINSEL_ConfigPin(2,18,1);
	PINSEL_ConfigPin(2,20,1);
	PINSEL_ConfigPin(2,24,1);

	PINSEL_ConfigPin(2,28,1);
	PINSEL_ConfigPin(2,29,1);
	PINSEL_ConfigPin(2,30,1);
	PINSEL_ConfigPin(2,31,1);

	for(i = 0; i < 32; i++)
	{
		PINSEL_ConfigPin(3,i,1);
		PINSEL_ConfigPin(4,i,1);
	}
}
/*********************************************************************//**
 * @brief 		Configure Little Endian/Big Endian mode for EMC
 * @param[in]	endia_mode	Endian mode, should be:
 * 				- EMC_LITTLE_ENDIAN_MODE:	Little-endian mode
 * 				- EMC_BIG_ENDIAN_MODE	:	Big-endian mode
 * @return 		None
 **********************************************************************/
void EMC_ConfigEndianMode(uint32_t endian_mode)
{
   LPC_EMC->Config = ((LPC_EMC->Config & 0x01)|endian_mode) & EMC_Config_MASK;
}

/****************** Group of Dynamic control functions************************/
/*********************************************************************//**
 * @brief 		Set the value for dynamic clock enable bit
 * @param[in]	clock_enable	clock enable mode, should be:
 * 					- 0: Clock enable of idle devices are deasserted to
 * 						save power
 * 					- 1: All clock enables are driven HIGH continuously
 * @return 		None
 **********************************************************************/
void EMC_DynCtrlClockEnable(uint32_t clock_enable)
{
   LPC_EMC->DynamicControl = ((LPC_EMC->DynamicControl) |clock_enable);
}

/*********************************************************************//**
 * @brief 		Set the value for dynamic memory clock control:
 * 				stops or runs continuously
 * @param[in]	clock_control	clock control mode, should be:
 * 					- 0: CLKOUT stops when all SDRAMs are idle and
 * 						during self-refresh mode
 * 					- 1: CLKOUT runs continuously
 * @return 		None
 **********************************************************************/
void EMC_DynCtrlClockControl(int32_t clock_control)
{
   uint32_t mask = ~(uint32_t)(2);
   LPC_EMC->DynamicControl = ((LPC_EMC->DynamicControl & mask) |clock_control);
}

/*********************************************************************//**
 * @brief 		Switch the Self-refresh mode between normal and self-refresh mode
 * @param[in]	self_refresh_mode	self refresh mode, should be:
 * 					- 0: Normal mode
 * 					- 1: Enter self-refresh mode
 * @return 		None
 **********************************************************************/
void EMC_DynCtrlSelfRefresh(uint32_t self_refresh_mode)
{
   uint32_t mask = ~(uint32_t)(4);
   LPC_EMC->DynamicControl = ((LPC_EMC->DynamicControl & mask) |self_refresh_mode);
}

/*********************************************************************//**
 * @brief 		Enable/disable CLKOUT
 * @param[in]	MMC_val	Memory clock control mode, should be:
 * 					- 0: CLKOUT enabled
 * 					- 1: CLKOUT disabled
 * @return 		None
 **********************************************************************/
void EMC_DynCtrlMMC(uint32_t MMC_val)
{
   uint32_t mask = ~(uint32_t)(_BIT(5));
   LPC_EMC->DynamicControl = ((LPC_EMC->DynamicControl & mask) |MMC_val);
}

/*********************************************************************//**
 * @brief 		Issue SDRAM command
 * @param[in]	SDRAM_command	Command mode, should be:
 * 					- 0x00: Issue SDRAM NORMAL operation command
 * 					- 0x01: Issue SDRAM MODE command
 * 					- 0x02: Issue SDRAM PALL (precharge all) command
 * 					- 0x03: Issue SRAM NOP (no operation) command
 * @return 		None
 **********************************************************************/
void EMC_DynCtrlSDRAMInit(uint32_t SDRAM_command)
{
   uint32_t mask = ~(uint32_t)(_SBF(7,0x03));
   LPC_EMC->DynamicControl = ((LPC_EMC->DynamicControl & mask)|SDRAM_command);
}

/*********************************************************************//**
 * @brief 		Switch between Normal operation and deep sleep power mode
 * @param[in]	Power_command	Low-power SDRAM deep-sleep mode, should be:
 *					- 0: Normal operation
 *					- 1: Enter deep-sleep mode
 * @return 		None
 **********************************************************************/
void EMC_DynCtrlPowerDownMode(uint32_t Power_command)
{
   uint32_t mask = ~(uint32_t)(_BIT(13));
   LPC_EMC->DynamicControl = ((LPC_EMC->DynamicControl & mask)|Power_command);
}

/*********************************************************************//**
 * @brief 		Set the value of EMC dynamic memory registers
 * @param[in]	par	EMC register that will set value, should be:
 *					- EMC_DYN_MEM_REFRESH_TIMER: Dynamic Refresh register
 *					- EMC_DYN_MEM_READ_CONFIG: Dynamic Read Config register
 *					- EMC_DYN_MEM_TRP: Dynamic RP register
 *					- EMC_DYN_MEM_TRAS: Dynamic RAS register
 *					- EMC_DYN_MEM_TSREX: Dynamic SREX register
 *					- EMC_DYN_MEM_TAPR: Dynamic APR register
 *					- EMC_DYN_MEM_TDAL: Dynamic DAL register
 *					- EMC_DYN_MEM_TWR: Dynamic WR register
 *					- EMC_DYN_MEM_TRC: Dynamic RC register
 *					- EMC_DYN_MEM_TRFC: Dynamic RFC register
 *					- EMC_DYN_MEM_TXSR: Dynamic XSR register
 *					- EMC_DYN_MEM_TRRD: Dynamic RRD register
 *					- EMC_DYN_MEM_TMRD: Dynamic MRD register
 * @return 		None
 **********************************************************************/
void EMC_SetDynMemoryParameter(EMC_DYN_MEM_PAR par, uint32_t val)
{
   switch ( par)
   {
      case EMC_DYN_MEM_REFRESH_TIMER:
         LPC_EMC->DynamicRefresh = val;
         break;
      case EMC_DYN_MEM_READ_CONFIG:
         LPC_EMC->DynamicReadConfig = val;
         break;
      case EMC_DYN_MEM_TRP:
         LPC_EMC->DynamicRP = val;
         break;
      case EMC_DYN_MEM_TRAS:
         LPC_EMC->DynamicRAS = val;
         break;
      case EMC_DYN_MEM_TSREX:
         LPC_EMC->DynamicSREX = val;
         break;
      case EMC_DYN_MEM_TAPR:
         LPC_EMC->DynamicAPR = val;
         break;
      case EMC_DYN_MEM_TDAL:
         LPC_EMC->DynamicDAL = val;
         break;
      case EMC_DYN_MEM_TWR:
         LPC_EMC->DynamicWR = val;
         break;
      case EMC_DYN_MEM_TRC:
         LPC_EMC->DynamicRC = val;
         break;
      case EMC_DYN_MEM_TRFC:
         LPC_EMC->DynamicRFC = val;
         break;
      case EMC_DYN_MEM_TXSR:
         LPC_EMC->DynamicXSR = val;
         break;
      case EMC_DYN_MEM_TRRD:
         LPC_EMC->DynamicRRD = val;
         break;
      case EMC_DYN_MEM_TMRD:
         LPC_EMC->DynamicMRD = val;
         break;
   }
}

/*********************************************************************//**
 * @brief 		Set extended wait time out for accessing static memory
 * @param[in]	Extended_wait_time_out timeout value that will be set
 * @return 		None
 **********************************************************************/
void EMC_StaticExtendedWait(uint32_t Extended_wait_time_out)
{
   LPC_EMC->StaticExtendedWait = Extended_wait_time_out;
}

/*********************************************************************//**
 * @brief 		Configure the memory device
 * @param[in]	index index number, should be from 0 to 3
 * @param[in]	mem_dev Memory device, should be:
 *					- 0x00: SDRAM
 *					- 0x01: Low-power SDRAM
 *					- 0x02: Micron Syncflash
 * @return 		None
 **********************************************************************/
void EMC_DynMemConfigMD(uint32_t index , uint32_t mem_dev)
{
   uint32_t mask = ~(uint32_t)(_SBF(3, 0x03));
   switch ( index)
   {
      case 0:
         LPC_EMC->DynamicConfig0 = (LPC_EMC->DynamicConfig0 & mask) | mem_dev;
	   break;
      case 1:
         LPC_EMC->DynamicConfig1 = (LPC_EMC->DynamicConfig1 & mask) | mem_dev;
	   break;
      case 2:
         LPC_EMC->DynamicConfig2 =(LPC_EMC->DynamicConfig2 & mask) | mem_dev;
	   break;
      case 3:
         LPC_EMC->DynamicConfig3 = (LPC_EMC->DynamicConfig3 & mask) | mem_dev;
	   break;
   }
}

/*********************************************************************//**
 * @brief 		Map the address for the memory device
 * @param[in]	index index number, should be from 0 to 3
 * @param[in] 	add_mapped address where the memory will be mapped
 * @return 		None
 **********************************************************************/
void EMC_DynMemConfigAM(uint32_t index , uint32_t add_mapped)
{
   uint32_t mask = ~(uint32_t)(_SBF(7, 0x3f)) | ~(uint32_t)(_BIT(14))  ;

   switch ( index)
   {
      case 0:
         LPC_EMC->DynamicConfig0 = ( LPC_EMC->DynamicConfig0 & mask) | add_mapped;
	   break;
      case 1:
         LPC_EMC->DynamicConfig1 = (LPC_EMC->DynamicConfig1 & mask) | add_mapped;
	   break;
      case 2:
         LPC_EMC->DynamicConfig2 = (LPC_EMC->DynamicConfig2 & mask) | add_mapped;
	   break;
      case 3:
         LPC_EMC->DynamicConfig3 = (LPC_EMC->DynamicConfig3 & mask) | add_mapped;
	   break;
   }
}

/*********************************************************************//**
 * @brief 		Enable/disable the buffer
 * @param[in]	index index number, should be from 0 to 3
 * @param[in] 	buff_control buffer control mode, should be:
 * 					- ENABLE
 * 					- DISABLE
 * @return 		None
 **********************************************************************/
void EMC_DynMemConfigB(uint32_t index , uint32_t buff_control)
{
   uint32_t mask =  ~(uint32_t)(_BIT(19))  ;
   switch ( index)
   {
      case 0:
         LPC_EMC->DynamicConfig0 = (LPC_EMC->DynamicConfig0 & mask) | buff_control;
	   break;
      case 1:
         LPC_EMC->DynamicConfig1 = ( LPC_EMC->DynamicConfig1 & mask) | buff_control;
	   break;
      case 2:
         LPC_EMC->DynamicConfig2 = (LPC_EMC->DynamicConfig2 & mask)| buff_control;
	   break;
      case 3:
         LPC_EMC->DynamicConfig3 = (LPC_EMC->DynamicConfig3 & mask) | buff_control;
	   break;
   }
}


/*********************************************************************//**
 * @brief 		Configure write permission: protect or not
 * @param[in]	index index number, should be from 0 to 3
 * @param[in] 	permission  permission mode, should be:
 * 					- ENABLE: protect
 * 					- DISABLE: not protect
 * @return 		None
 **********************************************************************/
void EMC_DynMemConfigP(uint32_t index , uint32_t permission)
{
   uint32_t mask =  ~(uint32_t)(_BIT(20))  ;
   switch ( index)
   {
      case 0:
         LPC_EMC->DynamicConfig0 = (LPC_EMC->DynamicConfig0 & mask) | permission;
	   break;
      case 1:
         LPC_EMC->DynamicConfig1 = (LPC_EMC->DynamicConfig1 & mask) | permission;
	   break;
      case 2:
         LPC_EMC->DynamicConfig2 = ( LPC_EMC->DynamicConfig2 & mask) | permission;
	   break;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线影院国内精品| 欧美亚洲禁片免费| 欧美日本一区二区在线观看| 久久久美女艺术照精彩视频福利播放| 欧美激情在线一区二区三区| 婷婷一区二区三区| 色欲综合视频天天天| 国产亚洲精品资源在线26u| 亚洲国产一区在线观看| 成人性色生活片免费看爆迷你毛片| 91.成人天堂一区| 亚洲精品欧美在线| 成人av网站免费观看| 日韩欧美一区电影| 日韩黄色片在线观看| 91九色02白丝porn| 综合欧美亚洲日本| 成人久久久精品乱码一区二区三区| 日韩欧美国产一区二区三区| 亚洲图片欧美视频| 精品视频资源站| 夜夜爽夜夜爽精品视频| 日本高清无吗v一区| 亚洲日本在线看| 91色综合久久久久婷婷| 国产精品理伦片| 成人免费福利片| 亚洲国产精品t66y| 成人美女在线观看| 国产日韩欧美精品在线| 豆国产96在线|亚洲| 国产精品污www在线观看| 大美女一区二区三区| 国产精品蜜臀av| av电影在线观看完整版一区二区| 国产精品久久久久天堂| aaa亚洲精品一二三区| 亚洲天堂成人网| 欧美综合亚洲图片综合区| 亚洲一区二区视频在线| 制服丝袜成人动漫| 激情综合五月天| 国产色爱av资源综合区| 99麻豆久久久国产精品免费优播| 国产精品美女久久久久久久久| 91在线小视频| 亚洲国产日韩a在线播放性色| 欧美日韩精品专区| 久久精工是国产品牌吗| 久久精品夜色噜噜亚洲aⅴ| 成人性生交大片免费看中文网站| 中文字幕日韩精品一区| 欧美色爱综合网| 激情综合色综合久久| 国产欧美va欧美不卡在线| 99精品久久只有精品| 丝袜亚洲另类欧美| 久久久久国产精品人| 91视频免费播放| 日本午夜精品视频在线观看| 久久久久亚洲蜜桃| caoporn国产精品| 水蜜桃久久夜色精品一区的特点| 精品久久久久久久人人人人传媒 | 美国av一区二区| 久久久国产综合精品女国产盗摄| 91亚洲精品乱码久久久久久蜜桃| 天堂va蜜桃一区二区三区漫画版| 久久蜜桃一区二区| 欧美午夜不卡视频| 国产经典欧美精品| 婷婷夜色潮精品综合在线| 国产日韩三级在线| 欧美日韩在线播放三区四区| 国产一区视频网站| 一区二区三区欧美日| 久久久久久久久久久久电影| 欧美日韩精品专区| 成人黄色小视频在线观看| 免费一级片91| 一区二区三区在线影院| 久久免费美女视频| 日韩欧美一卡二卡| 欧美视频一区在线| 91女厕偷拍女厕偷拍高清| 久久99精品国产91久久来源| 亚洲久本草在线中文字幕| 精品电影一区二区| 91精品欧美综合在线观看最新| 91在线观看高清| 国产精品一区在线观看乱码| 青青草视频一区| 亚洲午夜免费电影| 成人免费在线播放视频| 久久嫩草精品久久久久| 欧美一区欧美二区| 欧美日韩亚洲综合一区二区三区 | 国产精品一区二区免费不卡| 日韩电影网1区2区| 午夜在线电影亚洲一区| 亚洲精品日韩专区silk| 成人欧美一区二区三区黑人麻豆 | 色94色欧美sute亚洲线路一ni| 国产乱码一区二区三区| 看国产成人h片视频| 蜜桃视频一区二区三区| 天天色综合天天| 亚洲五月六月丁香激情| 亚洲精品国久久99热| 国产精品护士白丝一区av| 中文字幕第一区第二区| 国产日韩影视精品| 国产精品无码永久免费888| 久久久91精品国产一区二区三区| 精品久久一区二区三区| 久久综合色天天久久综合图片| 日韩欧美在线一区二区三区| 欧美一区二区女人| 精品免费视频一区二区| 精品福利一二区| 国产精品无码永久免费888| 国产日本一区二区| **网站欧美大片在线观看| 中文字幕亚洲精品在线观看| 日韩理论片中文av| 亚洲一级二级三级在线免费观看| 亚洲综合小说图片| 蜜臀av一区二区在线免费观看| 麻豆一区二区99久久久久| 韩国女主播一区二区三区| 国产福利91精品一区二区三区| 国产高清精品久久久久| 91麻豆国产自产在线观看| 色av一区二区| 欧美一区二区视频在线观看2022| 日韩欧美国产麻豆| 国产精品天干天干在观线| 亚洲蜜臀av乱码久久精品 | 国产成人午夜高潮毛片| av中文字幕在线不卡| 欧美亚洲国产一区二区三区 | 欧美日韩高清一区二区不卡| 欧美一区二区在线视频| 精品粉嫩超白一线天av| 亚洲摸摸操操av| 日本中文在线一区| 成人久久视频在线观看| 欧美日韩免费一区二区三区 | 亚洲精品成人精品456| 视频一区二区三区在线| 国产剧情一区二区| 欧美亚洲精品一区| 久久久精品tv| 亚洲高清免费一级二级三级| 久久疯狂做爰流白浆xx| 99久久精品免费看国产| 欧美一级xxx| 亚洲色图制服丝袜| 狠狠色丁香久久婷婷综| 欧美综合久久久| 国产欧美一区视频| 亚洲成av人片在线| 成人a免费在线看| 日韩一区二区三区视频在线| 亚洲视频 欧洲视频| 国产一区二区在线电影| 欧美日韩视频在线观看一区二区三区| 久久久久久一二三区| 五月婷婷激情综合| 99久久精品费精品国产一区二区| 欧美成人精品1314www| 亚洲一区二区三区在线播放| 国产老肥熟一区二区三区| 欧美一区二区三区啪啪| 亚洲精品欧美在线| 99国产精品久久久久| 久久亚洲影视婷婷| 青青国产91久久久久久| 欧美三级资源在线| 亚洲精品福利视频网站| 国产91对白在线观看九色| 日韩欧美亚洲另类制服综合在线| 亚洲午夜免费电影| 日本电影欧美片| 亚洲人成影院在线观看| 不卡的av在线| 国产精品丝袜91| 岛国一区二区在线观看| 国产人妖乱国产精品人妖| 国产尤物一区二区在线| 欧美成人精品二区三区99精品| 日本成人中文字幕| 欧美日韩在线播放三区四区| 亚洲高清免费一级二级三级| 欧美性生活久久| 亚洲国产欧美另类丝袜| 精品视频1区2区| 日本午夜一区二区| 日韩免费一区二区| 久久爱www久久做|