历史上的今天
返回首页

历史上的今天

今天是:2025年03月07日(星期五)

正在发生

2019年03月07日 | STM32之FSMC-SRAM例程

2019-03-07 来源:eefocus

SRAM使用的是55ns的IS62WV51216,需要先分析IS62WV51216对读写的时序要求。


读时序


 

分析时序图,可以提取如下信息(不分析高低字节位和使能位,因为FSMC访问模式是一直保持的):整个读周期大于55ns、地址建立时间55ns且读使能25ns才能确保输出数据


写时序



分析时序图,可以提取如下信息(不分析高低字节位和使能位,因为FSMC访问模式是一直保持的):整个写周期大于55ns、写使能时间大于45ns(tHZWE+tSD)才能保证数据写入


 


FSMC时序配置

根据手册模式1和模式A一般用于SRAM操作。注意:根据手册,模式1具有相同的读写时序,而模式A则是独立的读写时序。


下面分别结合两种模式进行时序分析:


模式1



根据提取出来的要求:整个读周期大于55ns、地址建立时间55ns且读使能25ns才能确保输出数据、整个写周期大于55ns、写使能时间大于45ns(tHZWE+tSD)才能保证数据写入。


得出:


tHCLK * ((ADDSET + 1) + (DATAST + 1) + 2) >= 55ns


tHCLK * ((ADDSET + 1) + (DATAST + 1) ) >= 55ns(不应包括2周期存储时间)


tHCLK * ((ADDSET + 1) + (DATAST + 1) ) >= 25ns(不应包括2周期存储时间)


tHCLK * ((ADDSET + 1) + (DATAST + 1) ) >= 55ns


tHCLK * DATAST >= 45ns


STM32F103的HCLK配置为72MHz,则tHCLK=13.8ns。因此,DATAST >= 4且ADDSET >= 0。


 模式A


根据提取出来的要求:整个读周期大于55ns、地址建立时间55ns且读使能25ns才能确保输出数据


得出:


tHCLK * ((ADDSET + 1) + (DATAST + 1) + 2) >= 55ns


tHCLK * ((ADDSET + 1) + (DATAST + 1) ) >= 55ns(不应包括2周期存储时间)


tHCLK * (DATAST + 1) >= 25ns(不应包括2周期存储时间)


STM32F103的HCLK配置为72MHz,则tHCLK=13.8ns。因此,DATAST = 1且ADDSET >= 1,DATAST >= 2且ADDSET >= 0。



根据提取出来的要求:整个写周期大于55ns、写使能时间大于45ns(tHZWE+tSD)才能保证数据写入


tHCLK * ((ADDSET + 1) + (DATAST + 1) ) >= 55ns


tHCLK * DATAST >= 45ns


STM32F103的HCLK配置为72MHz,则tHCLK=13.8ns。因此,DATAST >= 4且ADDSET >= 0。


 


源码例程

以模式A为例


#include "stm32f10x.h"

 

/* RCC时钟配置 */

void RCC_config()

ErrorStatus HSEStartUpStatus;

 

/* RCC寄存器设置为默认配置 */

RCC_DeInit();

/* 打开外部高速时钟 */

RCC_HSEConfig(RCC_HSE_ON);

/* 等待外部高速时钟稳定 */

HSEStartUpStatus = RCC_WaitForHSEStartUp();

if(HSEStartUpStatus == SUCCESS) 

/* 设置HCLK = SYSCLK */

RCC_HCLKConfig(RCC_SYSCLK_Div1);

/* 设置PCLK2 = HCLK */

RCC_PCLK2Config(RCC_HCLK_Div1);

/* 设置PCLK1 = HCLK / 2 */

RCC_PCLK1Config(RCC_HCLK_Div2);

/* 设置FLASH代码延时 */

FLASH_SetLatency(FLASH_Latency_2);

/* 使能预取址缓存 */

FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);

/* 设置PLL时钟源为HSE倍频9 72MHz */

RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);

/* 使能PLL */

RCC_PLLCmd(ENABLE);

/* 等待PLL稳定 */

while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);

/* 设置PLL为系统时钟源 */

RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

/* 等待系统时钟源切换到PLL */

while(RCC_GetSYSCLKSource() != 0x08);

}

}

 

/* GPIO配置 */

void GPIO_config(void)

{

GPIO_InitTypeDef GPIO_InitStructure;


RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE | RCC_APB2Periph_GPIOF | RCC_APB2Periph_GPIOG, ENABLE);

  

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_4 | GPIO_Pin_5 | 

GPIO_Pin_8| GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_11 | 

GPIO_Pin_12 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15;

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  GPIO_Init(GPIOD, &GPIO_InitStructure);

 

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_7 | GPIO_Pin_8 | 

GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_11 | GPIO_Pin_12 | 

GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15;

  GPIO_Init(GPIOE, &GPIO_InitStructure);


  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | 

GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_12 | GPIO_Pin_13 | 

GPIO_Pin_14 | GPIO_Pin_15;

  GPIO_Init(GPIOF, &GPIO_InitStructure);

 

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3 | 

GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_10;

  GPIO_Init(GPIOG, &GPIO_InitStructure);

}

 

/* FSMC配置 */

void FSMC_SRAM_Init(void)

{

FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;

FSMC_NORSRAMTimingInitTypeDef readTiming;

FSMC_NORSRAMTimingInitTypeDef WriteTiming;


RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);


FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3; //Bank

FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable; //数据和地址线是否复用

FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM; //存储器类型

FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b; //存储器数据宽度  

FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable; //是否进行突发模式访问

FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low; //等待信号极性(突发模式下)

FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable; //保留位

FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;    //是否支持非对齐操作(突发模式下)

FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;  //WAIT信号有效时机(突发模式下)

FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable; //是否允许写操作

FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;  //是否使用WAIT信号(突发模式下)

FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Enable; //是否使用读写不同时序

FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable; //是否允许突发写操作

 

readTiming.FSMC_AddressSetupTime = 0x00; //地址建立时间

readTiming.FSMC_AddressHoldTime = 0x00; //地址保持时间

readTiming.FSMC_DataSetupTime = 0x02; //数据保持时间

readTiming.FSMC_BusTurnAroundDuration = 0x00;

readTiming.FSMC_CLKDivision = 0x00;

readTiming.FSMC_DataLatency = 0x00;

readTiming.FSMC_AccessMode = FSMC_AccessMode_A; //模式A


WriteTiming.FSMC_AddressSetupTime = 0x00; //地址建立时间

WriteTiming.FSMC_AddressHoldTime = 0x00; //地址保持时间

WriteTiming.FSMC_DataSetupTime = 0x04; //数据保持时间

WriteTiming.FSMC_BusTurnAroundDuration = 0x00;

WriteTiming.FSMC_CLKDivision = 0x00;

WriteTiming.FSMC_DataLatency = 0x00;

WriteTiming.FSMC_AccessMode = FSMC_AccessMode_A; //模式A

 

FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &readTiming;

FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &WriteTiming;

 

FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);

FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE);

}

 

uint8_t testsram[1000000] __attribute__((at(0x68000000)));

uint8_t test;

 

int main(void)

{

uint8_t count = 0;


/* 时钟配置 */

RCC_config();


/* GPIO配置 */

GPIO_config();


/* FSMC配置 */

FSMC_SRAM_Init();


for(uint32_t ts = 0; ts < 1000000; ts++)

testsram[ts] = count++;


for(uint32_t ts = 0; ts < 1000000; ts++)

test = testsram[ts];


while(1)

{

 

}

}

 


推荐阅读

史海拾趣

GSME Electronics公司的发展小趣事

GSME Electronics的起点可以追溯到2001年,当时公司在广西桂林市成立,作为桂林国家高新区的高新技术企业。初期,公司面临着技术设备落后的挑战,但管理层高瞻远瞩,决定从日本、韩国、欧美等国家引进具有国际先进水平的自动化生产设备。这一决策为公司后续的发展奠定了坚实的基础,使得公司能够快速进入半导体器件的生产领域,并不断提升产品质量和生产效率。

Gespac Inc公司的发展小趣事

随着公司业务的不断拓展和市场竞争的日益激烈,GSME Electronics开始实施国际化战略。公司积极参与国际市场竞争,加强与国外客户的合作与交流,不断提升产品的国际竞争力。同时,公司还注重品牌建设,通过提升产品质量和服务水平,树立了良好的品牌形象。如今,“桂微牌”产品已经在国内外市场上赢得了广泛的认可度和美誉度,为公司未来的发展奠定了坚实的基础。

Cramer公司的发展小趣事

随着可穿戴设备的兴起,Cramer公司迅速捕捉到了市场机遇。他们推出了一款智能手表,该手表不仅具备基本的时间显示功能,还集成了健康监测、运动追踪等多项实用功能。为了提升产品的竞争力,Cramer公司与多家科技公司合作,共同研发新技术。这款智能手表在市场上获得了广泛认可,进一步提升了Cramer公司的品牌知名度和市场份额。

Frolyt Condensers & Elements GmbH公司的发展小趣事

随着业务规模的扩大,Frolyt Condensers & Elements GmbH意识到全球化布局的重要性。2010年,公司制定了全球化战略,首先在亚洲设立了生产基地,以利用当地丰富的资源和低廉的劳动力成本。随后几年间,Frolyt还通过一系列并购活动,收购了多家在特定市场具有影响力的电容器制造商,进一步巩固了其在全球市场的地位。这些并购不仅扩大了Frolyt的产品线,还增强了其技术研发能力和市场服务能力。

中电熊猫(CEC)公司的发展小趣事

2007年,中电熊猫母公司中国电子信息集团公司(CEC)对熊猫电子进行了重组,全面推进平板显示全产业链发展。2015年,中电熊猫投资291.5亿元建设的8.5代液晶面板生产线投产,成为全球首条应用金属氧化物IGZO技术的超高分辨率液晶面板生产线。这一举措标志着中电熊猫在液晶面板产业中占据了重要地位,为后续的发展奠定了坚实基础。

Barkston Plastics Engineering Ltd.公司的发展小趣事

随着环保意识的日益增强,Barkston Plastics Engineering Ltd.积极响应行业趋势,致力于研发和生产环保型塑料电子元件。公司投入大量资源研发可降解和可回收的塑料材料,并将其应用于产品中。这一举措不仅赢得了客户的认可,也提升了公司的品牌形象,使其在竞争激烈的电子行业中脱颖而出。

问答坊 | AI 解惑

基于HT48单片机的笔段型液晶显示的简易驱动

1 笔段型液晶显示器件 笔段型液晶显示器件是指以长条状显示像素组成一位显示类型的液晶显示器件,简称段型液晶显示器件。段型显示器件主要是显示数字,或围绕数字显示。在形状中总是围绕\"8\"的结构变化。其中以七段显示最为常用。段型液晶显示器 ...…

查看全部问答>

求助

马上要毕业了,我是学通信的女生,工作很难找啊,我想好好做一下毕业设计,我的毕业设计的题目是射频技术的研究与应用,看似简单的题目,我却犯难了,不是想网上找些资料随便拼凑一下了事,真的很喜欢这个专业,所以想好好的做,希望各位同仁能够给 ...…

查看全部问答>

运放电路的增益小于1时会怎样?

当用运算放大器组成放大倍数绝对值小于1的回路时电路会怎么样? 内部补偿的恒定GBP的运放在放大倍数大于等于1时可以保证电路稳定,但当组成小于1的电路时会否引起电路稳定性问题??…

查看全部问答>

谁用过wavecom的gprs模块,可靠性怎么样?

谁用过wavecom的gprs模块,可靠性怎么样,听说可靠性不太好。…

查看全部问答>

请问S3C2440+WinCE5.0串口通讯实时性的问题

S3C2440+WinCE5.0平台上,用EVC开发串口接收程序,请问串口能每隔1ms收到1字节的数据吗? 我编的应用程序实时性很差, …

查看全部问答>

食人鱼LED的封装

食人鱼LED产品有很多优点,由于食人鱼LED所用的支架是铜制的,面积较大,因此传热和散热快。LED点亮后,pn结产生的热量很快就可以由支架的四个支脚导出到PCB的铜带上。这种LED食人鱼管子比φ3mm、φ5mm引脚式的管子传热快,从而可以延长器件的使用寿命。 ...…

查看全部问答>

逐次逼近型ADC工作原理----Flash动态演示

https://bbs.eeworld.com.cn/upfiles/img/20096/2009630164127921.rar 相关链接:https://bbs.eeworld.com.cn/upfiles/img/20096/2009630164127921.rar…

查看全部问答>

菜鸟若问:msp430f169和PC机怎么通讯啊?

用uart? 我的想法是在pc机上向单片机发送一个信息,然后单片机作出相应反应(一个I/O口输出高电平),可是在pc机上有输入的界面吗?我该怎么做 在线等…… 刚开始,但很着急 万谢…

查看全部问答>

工业级16位ADC芯片型号?

请大家推荐一下,工业级16位ADC芯片,单电源5V左右,串行通信方式,单通道;比如:凌力尔特LTC2451;…

查看全部问答>