×
单片机 > 单片机程序设计 > 详情

STM32 外部 SRAM

发布时间:2020-06-16 发布时间:
|
STM32F103ZET6 自带了 64K 字节的 SRAM,对一般应用来说,已经足够了,不过在一些对内存要求高的场合,STM32 自带的这些内存就不够用了。比如跑算法或者跑 GUI 等,就可能不太够用

IS62WV51216 简介

IS62WV51216 是 ISSI(Integrated  Silicon  Solution,  Inc)公司生产的一颗 16 位宽 512K(512*16,即 1M 字节)容量的 CMOS 静态内存芯片。该芯片具有如下几个特点:

l 高速。具有 45ns/55ns 访问速度。

l 低功耗。

l TTL 电平兼容。

l 全静态操作。不需要刷新和时钟电路。

l 三态输出。

l 字节控制功能。支持高/低字节控制。

看看实现 IS62WV51216 的访问,需要对 FSMC进行哪些配置。 这里就做一个概括性的讲解。步骤如下: 

1)使能 FSMC 时钟,并配置 FSMC 相关的 IO 及其时钟使能。

要使用 FSMC,当然首先得开启其时钟。然后需要把 FSMC_D0~15,FSMCA0~18 等相关IO 口,全部配置为复用输出,并使能各 IO 组的时钟。 

使能 FSMC 时钟的方法:

RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC,ENABLE); 

对于其他 IO 口设置的方法前面讲解很详细,这里不做过多的讲解。

2)设置 FSMC BANK1 区域 3。

此部分包括设置区域 3 的存储器的工作模式、位宽和读写时序等。我们使用模式 A、16 位宽,读写共用一个时序寄存器。使用的函数是:

void FSMC_NORSRAMInit(FSMC_NORSRAMInitTypeDef* FSMC_NORSRAMInitStruct)

3)使能 BANK1 区域 3。

使能 BANK 的方法跟前面 LCD 实验也是一样的,这里也不做详细讲解,函数是:

void FSMC_NORSRAMCmd(uint32_t FSMC_Bank, FunctionalState NewState);

通过以上几个步骤,我们就完成了 FSMC 的配置,可以访问 IS62WV51216 了,这里还需要注意,因为我们使用的是 BANK1 的区域 3,所以 HADDR[27:26]=10,故外部内存的首地址为 0X68000000。 

  1. //使用NOR/SRAM的 Bank1.sector3,地址位HADDR[27,26]=10 
  2. //对IS61LV25616/IS62WV25616,地址线范围为A0~A17 
  3. //对IS61LV51216/IS62WV51216,地址线范围为A0~A18
  4. #define Bank1_SRAM3_ADDR ((u32)(0x68000000))        
  5.                            
  6. //初始化外部SRAM
  7. void FSMC_SRAM_Init(void)
  8. {    
  9.     FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;
  10.     FSMC_NORSRAMTimingInitTypeDef readWriteTiming;
  11.     GPIO_InitTypeDef GPIO_InitStructure;
  12.  
  13.      RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_GPIOE|RCC_APB2Periph_GPIOF|RCC_APB2Periph_GPIOG,ENABLE);
  14.       RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC,ENABLE);
  15.   
  16.     GPIO_InitStructure.GPIO_Pin = 0xFF33;                  //PORTD复用推挽输出 
  17.      GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;          //复用推挽输出
  18.      GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  19.      GPIO_Init(GPIOD, &GPIO_InitStructure);
  20.  
  21.  
  22.     GPIO_InitStructure.GPIO_Pin = 0xFF83;                  //PORTE复用推挽输出 
  23.      GPIO_Init(GPIOE, &GPIO_InitStructure);
  24.  
  25.      GPIO_InitStructure.GPIO_Pin = 0xF03F;                  //PORTD复用推挽输出 
  26.      GPIO_Init(GPIOF, &GPIO_InitStructure);
  27.  
  28.     GPIO_InitStructure.GPIO_Pin = 0x043F;                  //PORTD复用推挽输出 
  29.      GPIO_Init(GPIOG, &GPIO_InitStructure);
  30.  
  31.                        
  32.      readWriteTiming.FSMC_AddressSetupTime = 0x00;     //地址建立时间(ADDSET)为1个HCLK 1/36M=27ns
  33.     readWriteTiming.FSMC_AddressHoldTime = 0x00;     //地址保持时间(ADDHLD)模式A未用到    
  34.     readWriteTiming.FSMC_DataSetupTime = 0x03;         //数据保持时间(DATAST)为3个HCLK 4/72M=55ns(对EM的SRAM芯片)     
  35.     readWriteTiming.FSMC_BusTurnAroundDuration = 0x00;
  36.     readWriteTiming.FSMC_CLKDivision = 0x00;
  37.     readWriteTiming.FSMC_DataLatency = 0x00;
  38.     readWriteTiming.FSMC_AccessMode = FSMC_AccessMode_A;     //模式A 
  39.     
  40.  
  41.  
  42.     FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3;// 这里我们使用NE3 ,也就对应BTCR[4],[5]。
  43.     FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable; 
  44.     FSMC_NORSRAMInitStructure.FSMC_MemoryType =FSMC_MemoryType_SRAM;// FSMC_MemoryType_SRAM; //SRAM 
  45.     FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;//存储器数据宽度为16bit 
  46.     FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode =FSMC_BurstAccessMode_Disable;// FSMC_BurstAccessMode_Disable; 
  47.     FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
  48.     FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait=FSMC_AsynchronousWait_Disable;
  49.     FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable; 
  50.     FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState; 
  51.     FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;    //存储器写使能 
  52.     FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable; 
  53.     FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; // 读写使用相同的时序
  54.     FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable; 
  55.     FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &readWriteTiming;
  56.     FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &readWriteTiming; //读写同样时序
  57.  
  58.     FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure); //初始化FSMC配置
  59.  
  60.        FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE); // 使能BANK3                                         
  61.                                             
  62. }
  63.                                                               
  64. //在指定地址开始,连续写入n个字节.
  65. //pBuffer:字节指针
  66. //WriteAddr:要写入的地址
  67. //n:要写入的字节数
  68. void FSMC_SRAM_WriteBuffer(u8* pBuffer,u32 WriteAddr,u32 n)
  69. {
  70.     for(;n!=0;n--) 
  71.     {                                         
  72.         *(vu8*)(Bank1_SRAM3_ADDR+WriteAddr)=*pBuffer;     
  73.         WriteAddr+=2;//这里需要加2,是因为STM32的FSMC地址右移一位对其.加2相当于加1.
  74.         pBuffer++;
  75.     } 
  76. }                                                                             
  77. //在指定地址开始,连续读出n个字节.
  78. //pBuffer:字节指针
  79. //ReadAddr:要读出的起始地址
  80. //n:要写入的字节数
  81. void FSMC_SRAM_ReadBuffer(u8* pBuffer,u32 ReadAddr,u32 n)
  82. {
  83.     for(;n!=0;n--) 
  84.     {                                             
  85.         *pBuffer++=*(vu8*)(Bank1_SRAM3_ADDR+ReadAddr); 
  86.         ReadAddr+=2;//这里需要加2,是因为STM32的FSMC地址右移一位对其.加2相当于加1.
  87.     } 
  88. ////////////////////////////////////////////////////////////////////////////////////////
  89. //测试函数
  90. //在指定地址写入1个字节
  91. //addr:地址
  92. //data:要写入的数据
  93. void fsmc_sram_test_write(u8 data,u32 addr)
  94. {             
  95.     FSMC_SRAM_WriteBuffer(&data,addr,1);//写入1个字节
  96. }
  97. //读取1个字节
  98. //addr:要读取的地址
  99. //返回值:读取到的数据
  100. u8 fsmc_sram_test_read(u32 addr)
  101. {
  102.     u8 data;
  103.     FSMC_SRAM_ReadBuffer(&data,addr,1);
  104.     return data;
  105. }
  106.  

关键字:STM32  外部SRAM 

『本文转载自网络,版权归原作者所有,如有侵权请联系删除』

热门文章 更多
C51 特殊功能寄存器SFR的名称和地址