请教个FSMC 连接 SRAM的问题

2019-07-20 20:39发布

本帖最后由 电吹风 于 2016-6-28 21:29 编辑

最近在调FSMC和SRAM,遇到一个问题,请教各位1 单片机用的STM32F407ZET6, SRAM用的是IS62WV51216BLL,硬件连接如图
11.jpg
2 FSMC配置

[mw_shl_code=c,true]
void FsmcForSramConfig()
{
        GPIO_InitTypeDef  GPIO_InitStructure;
        FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure;
        FSMC_NORSRAMTimingInitTypeDef  writeTiming;
        
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD|RCC_AHB1Periph_GPIOE|RCC_AHB1Periph_GPIOF|RCC_AHB1Periph_GPIOG, ENABLE);//使能PD,PE,PF,PG时钟  
        RCC_AHB3PeriphClockCmd(RCC_AHB3Periph_FSMC,ENABLE);//使能FSMC时钟  
        
        GPIO_InitStructure.GPIO_Pin =
(GPIO_Pin_14|GPIO_Pin_15|GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_13);
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
        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_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
        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_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
        GPIO_Init(GPIOF, &GPIO_InitStructure);//初始化  
        
        GPIO_InitStructure.GPIO_Pin = (GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_0);
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
        GPIO_Init(GPIOG, &GPIO_InitStructure);//初始化  
        

        GPIO_PinAFConfig(GPIOF,GPIO_PinSource0,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource1,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource2,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource3,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource4,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource5,GPIO_AF_FSMC);        
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource12,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource13,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource14,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOF,GPIO_PinSource15,GPIO_AF_FSMC);


        GPIO_PinAFConfig(GPIOG,GPIO_PinSource0,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOG,GPIO_PinSource1,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOG,GPIO_PinSource2,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOG,GPIO_PinSource3,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOG,GPIO_PinSource4,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOG,GPIO_PinSource5,GPIO_AF_FSMC);        
        
        
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource0,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource1,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource7,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource8,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource9,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource10,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource11,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource12,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource13,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource14,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOE,GPIO_PinSource15,GPIO_AF_FSMC);
        
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource7,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource11,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource12,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource13,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource0,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource1,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource4,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource5,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource8,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource9,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource10,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource14,GPIO_AF_FSMC);
        GPIO_PinAFConfig(GPIOD,GPIO_PinSource15,GPIO_AF_FSMC);
        
        writeTiming.FSMC_AddressSetupTime = 15;              //地址建立时间(ADDSET)为15个HCLK
        writeTiming.FSMC_AddressHoldTime = 0;//0x00;         //地址保持时间
        writeTiming.FSMC_DataSetupTime = 15;                 //数据保存时间为15个HCLK
        writeTiming.FSMC_BusTurnAroundDuration = 0x00;
        writeTiming.FSMC_CLKDivision = 0x00;
        writeTiming.FSMC_DataLatency = 0x00;
        writeTiming.FSMC_AccessMode = FSMC_AccessMode_A;         //模式A
        
        FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1;//  这里我们使用NE1
        FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable; // 不复用数据地址
        FSMC_NORSRAMInitStructure.FSMC_MemoryType =FSMC_MemoryType_SRAM;// FSMC_MemoryType_SRAM;  //SRAM   
        FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;//存储器数据宽度为16bit   
        FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode =FSMC_BurstAccessMode_Disable;// 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;  
        FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;        //  存储器写使能
        FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;   
        FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; // 读写使用相同的时序
        FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
        FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &writeTiming;//&readWriteTiming; //读写时序
        FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &writeTiming;  //写时序

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

        FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE);  // 使能BANK1
}[/mw_shl_code]

3 读写函数

[mw_shl_code=c,true]#define Bank1_SRAM1_ADDR  ((uint32_t)0x60000000)

void SramWrite(uint32_t addr,uint16_t data)
{
        *( uint16_t *) (Bank1_SRAM1_ADDR + (addr)) = data;

}

uint16_t SramRead(uint32_t addr)
{
        uint16_t data;
        data = *(__IO uint16_t*) (Bank1_SRAM1_ADDR + (addr));
        return data;
}[/mw_shl_code]
4 问题
4.1 我在while(1)循环里面测试
while(1)
{
    SramWrite(1,0xffff);
    SramWrite(1,0x0000);
}
用示波器测NE1,NOE,NWE,FSMC_D0~D15,FSMC_A0都是有信号的,这样我觉得FSMC配置应该没问题
4.2然后我开始读写SRAM
uint16_t i;SramWrite(0,0x1234);i = SramRead(0);printf(“i=%04x ”,i);这样读出来的始终是0xFFFF,就好像SRAM没工作一样。控制板换过,SRAM芯片也换过,折腾一整天了,没调出来,哪位兄弟帮忙看看问题出在哪?



友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
3条回答
xuande
2019-07-20 22:53

首先,必须保证所有引脚都是可靠焊接。
要检查这一点,可以给0地址写0,1地址写1,2地址写2,。。。一直到最大地址,
然后分别检查数据线和地址线,低位频率最高,高一位则频率降一倍,每个管脚都测一遍。
硬件要扎实。

其次,示波器检查片选、读写、地址、数据之间的时间关系,
或者调整程序,把所有的延迟都加到最大,保证满足时序要求,
然后再实验。


一周热门 更多>