OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3975|回复: 2

在探索者+NANO3.1.3上面添加外部sram作为动态内存池报错

[复制链接]

11

主题

30

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
394
金钱
394
注册时间
2018-8-28
在线时间
69 小时
发表于 2020-4-16 17:12:13 | 显示全部楼层 |阅读模式
1金钱
NANO3.1.3默认是用4K的数组作为动态内存池的,,单片机是STM32F407ZGT6我先把它改成使用片内剩余SRAM空间作为动态内存池成功了。但是使用片外IS62WV51216时失败报错了,单独把片外SRAM拿来读写测试了一下是正常的,但是一用做动态内存池就不行了,是什么原因呢?:

3种方式的首尾地址设置

3种方式的首尾地址设置

3种方式的堆初始化

3种方式的堆初始化

默认数组方式结果

默认数组方式结果

使用片内剩余SRAM方式结果

使用片内剩余SRAM方式结果

使用外部SRAM方式结果

使用外部SRAM方式结果

SRAM的初始化及读写测试代码就是原子的原来的测试代码,我只是加到rtthread nano里面跑了一下:
  1. #include "sram.h"          
  2. #include "usart.h"       
  3. #include <rtthread.h>

  4. //使用NOR/SRAM的 Bank1.sector3,地址位HADDR[27,26]=10
  5. //对IS61LV25616/IS62WV25616,地址线范围为A0~A17
  6. //对IS61LV51216/IS62WV51216,地址线范围为A0~A18

  7. #define Bank1_SRAM3_ADDR    ((u32)(0x68000000))       
  8.                                                     
  9. //初始化外部SRAM
  10. static int FSMC_SRAM_Init(void)
  11. {       
  12.         GPIO_InitTypeDef  GPIO_InitStructure;
  13.         FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure;
  14.   FSMC_NORSRAMTimingInitTypeDef  readWriteTiming;
  15.        
  16.         RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB|RCC_AHB1Periph_GPIOD|RCC_AHB1Periph_GPIOE|RCC_AHB1Periph_GPIOF|RCC_AHB1Periph_GPIOG, ENABLE);//使能PD,PE,PF,PG时钟  
  17.   RCC_AHB3PeriphClockCmd(RCC_AHB3Periph_FSMC,ENABLE);//使能FSMC时钟  
  18.    
  19.        
  20.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_15;//PB15 推挽输出,控制背光
  21.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;//普通输出模式
  22.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  23.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;//100MHz
  24.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  25.   GPIO_Init(GPIOB, &GPIO_InitStructure);//初始化 //PB15 推挽输出,控制背光

  26.         GPIO_InitStructure.GPIO_Pin = (3<<0)|(3<<4)|(0XFF<<8);//PD0,1,4,5,8~15 AF OUT
  27.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
  28.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  29.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
  30.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  31.   GPIO_Init(GPIOD, &GPIO_InitStructure);//初始化  
  32.        
  33.   GPIO_InitStructure.GPIO_Pin = (3<<0)|(0X1FF<<7);//PE0,1,7~15,AF OUT
  34.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
  35.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  36.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
  37.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  38.   GPIO_Init(GPIOE, &GPIO_InitStructure);//初始化  
  39.        
  40.         GPIO_InitStructure.GPIO_Pin = (0X3F<<0)|(0XF<<12);         //PF0~5,12~15
  41.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
  42.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  43.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
  44.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  45.   GPIO_Init(GPIOF, &GPIO_InitStructure);//初始化  

  46.         GPIO_InitStructure.GPIO_Pin =(0X3F<<0)| GPIO_Pin_10;//PG0~5,10
  47.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
  48.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  49.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
  50.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  51.   GPIO_Init(GPIOG, &GPIO_InitStructure);//初始化


  52.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource0,GPIO_AF_FSMC);//PD0,AF12
  53.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource1,GPIO_AF_FSMC);//PD1,AF12
  54.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource4,GPIO_AF_FSMC);
  55.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource5,GPIO_AF_FSMC);
  56.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource8,GPIO_AF_FSMC);
  57.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource9,GPIO_AF_FSMC);
  58.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource10,GPIO_AF_FSMC);
  59.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource11,GPIO_AF_FSMC);
  60.         GPIO_PinAFConfig(GPIOD,GPIO_PinSource12,GPIO_AF_FSMC);
  61.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource13,GPIO_AF_FSMC);
  62.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource14,GPIO_AF_FSMC);
  63.   GPIO_PinAFConfig(GPIOD,GPIO_PinSource15,GPIO_AF_FSMC);//PD15,AF12

  64.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource0,GPIO_AF_FSMC);
  65.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource1,GPIO_AF_FSMC);
  66.         GPIO_PinAFConfig(GPIOE,GPIO_PinSource7,GPIO_AF_FSMC);//PE7,AF12
  67.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource8,GPIO_AF_FSMC);
  68.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource9,GPIO_AF_FSMC);
  69.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource10,GPIO_AF_FSMC);
  70.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource11,GPIO_AF_FSMC);
  71.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource12,GPIO_AF_FSMC);
  72.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource13,GPIO_AF_FSMC);
  73.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource14,GPIO_AF_FSMC);
  74.   GPIO_PinAFConfig(GPIOE,GPIO_PinSource15,GPIO_AF_FSMC);//PE15,AF12

  75.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource0,GPIO_AF_FSMC);//PF0,AF12
  76.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource1,GPIO_AF_FSMC);//PF1,AF12
  77.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource2,GPIO_AF_FSMC);//PF2,AF12
  78.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource3,GPIO_AF_FSMC);//PF3,AF12
  79.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource4,GPIO_AF_FSMC);//PF4,AF12
  80.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource5,GPIO_AF_FSMC);//PF5,AF12
  81.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource12,GPIO_AF_FSMC);//PF12,AF12
  82.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource13,GPIO_AF_FSMC);//PF13,AF12
  83.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource14,GPIO_AF_FSMC);//PF14,AF12
  84.   GPIO_PinAFConfig(GPIOF,GPIO_PinSource15,GPIO_AF_FSMC);//PF15,AF12
  85.        
  86.   GPIO_PinAFConfig(GPIOG,GPIO_PinSource0,GPIO_AF_FSMC);
  87.   GPIO_PinAFConfig(GPIOG,GPIO_PinSource1,GPIO_AF_FSMC);
  88.   GPIO_PinAFConfig(GPIOG,GPIO_PinSource2,GPIO_AF_FSMC);
  89.   GPIO_PinAFConfig(GPIOG,GPIO_PinSource3,GPIO_AF_FSMC);
  90.   GPIO_PinAFConfig(GPIOG,GPIO_PinSource4,GPIO_AF_FSMC);
  91.   GPIO_PinAFConfig(GPIOG,GPIO_PinSource5,GPIO_AF_FSMC);
  92.   GPIO_PinAFConfig(GPIOG,GPIO_PinSource10,GPIO_AF_FSMC);
  93.        
  94.           
  95.   readWriteTiming.FSMC_AddressSetupTime = 0x00;         //地址建立时间(ADDSET)
  96.   readWriteTiming.FSMC_AddressHoldTime = 0x00;         //地址保持时间(ADDHLD)模式A未用到       
  97.   readWriteTiming.FSMC_DataSetupTime = 0x08;                 ////数据保持时间(DATAST)为9个HCLK 6*9=54ns                  
  98.   readWriteTiming.FSMC_BusTurnAroundDuration = 0x00;
  99.   readWriteTiming.FSMC_CLKDivision = 0x00;
  100.   readWriteTiming.FSMC_DataLatency = 0x00;
  101.   readWriteTiming.FSMC_AccessMode = FSMC_AccessMode_A;         //模式A
  102.    


  103.   FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3;//  这里我们使用NE3 ,也就对应BTCR[4],[5]。
  104.   FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;
  105.   FSMC_NORSRAMInitStructure.FSMC_MemoryType =FSMC_MemoryType_SRAM;// FSMC_MemoryType_SRAM;  //SRAM   
  106.   FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;//存储器数据宽度为16bit  
  107.   FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode =FSMC_BurstAccessMode_Disable;// FSMC_BurstAccessMode_Disable;
  108.   FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
  109.         FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait=FSMC_AsynchronousWait_Disable;
  110.   FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;   
  111.   FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;  
  112.   FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;        //存储器写使能
  113.   FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;  
  114.   FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; // 读写使用相同的时序
  115.   FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;  
  116.   FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &readWriteTiming;
  117.   FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &readWriteTiming; //读写同样时序

  118.   FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);  //初始化FSMC配置

  119.         FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE);  // 使能BANK1区域3       
  120.         return 0;
  121. }
  122. INIT_BOARD_EXPORT(FSMC_SRAM_Init);                                                                                                                   
  123. //在指定地址(WriteAddr+Bank1_SRAM3_ADDR)开始,连续写入n个字节.
  124. //pBuffer:字节指针
  125. //WriteAddr:要写入的地址
  126. //n:要写入的字节数
  127. void FSMC_SRAM_WriteBuffer(u8* pBuffer,u32 WriteAddr,u32 n)
  128. {
  129.         for(;n!=0;n--)  
  130.         {                                                                                    
  131.                 *(vu8*)(Bank1_SRAM3_ADDR+WriteAddr)=*pBuffer;          
  132.                 WriteAddr++;
  133.                 pBuffer++;
  134.         }   
  135. }                                                                                                                                                            
  136. //在指定地址((WriteAddr+Bank1_SRAM3_ADDR))开始,连续读出n个字节.
  137. //pBuffer:字节指针
  138. //ReadAddr:要读出的起始地址
  139. //n:要写入的字节数
  140. void FSMC_SRAM_ReadBuffer(u8* pBuffer,u32 ReadAddr,u32 n)
  141. {
  142.         for(;n!=0;n--)  
  143.         {                                                                                            
  144.                 *pBuffer++=*(vu8*)(Bank1_SRAM3_ADDR+ReadAddr);   
  145.                 ReadAddr++;
  146.         }  
  147. }

  148. //外部内存测试(最大支持1M字节内存测试)            
  149. void fsmc_sram_test(u16 x,u16 y)
  150. {  
  151.         u32 i=0;            
  152.         u8 temp=0;          
  153.         u8 sval=0;        //在地址0读到的数据                                            
  154.         //每隔4K字节,写入一个数据,总共写入256个数据,刚好是1M字节
  155.         for(i=0;i<1024*1024;i+=4096)
  156.         {
  157.                 FSMC_SRAM_WriteBuffer(&temp,i,1);
  158.                 temp++;
  159.         }
  160.         //依次读出之前写入的数据,进行校验                  
  161.         for(i=0;i<1024*1024;i+=4096)
  162.         {
  163.                   FSMC_SRAM_ReadBuffer(&temp,i,1);
  164.                 if(i==0)sval=temp;
  165.                 else if(temp<=sval)break;//后面读出的数据一定要比第一次读到的数据大.                                
  166.                 rt_kprintf("Ex Memory Test: %dKB\n", (temp-sval+1)*4);   
  167.         }                                         
  168. }       
  169. MSH_CMD_EXPORT(fsmc_sram_test, fsmc_sram_test);
复制代码


片外SRAM读写正常测试

片外SRAM读写正常测试


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

109

主题

5562

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
10528
金钱
10528
注册时间
2017-2-18
在线时间
1906 小时
发表于 2020-4-16 21:37:13 | 显示全部楼层
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165225
金钱
165225
注册时间
2010-12-1
在线时间
2107 小时
发表于 2020-4-17 01:08:40 | 显示全部楼层
仿真看看你初始化外部SRAM是否完全正常
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-1 07:57

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表