foer 发表于 2019-1-24 16:41:10

stm32f103vet6外接铁电FM28V020发现的问题


   以前用单片机做的,正常工作很长时间,现在想转到stm32,采用fsmc,外接32K铁电FM28V020,一直不正常,现象是只能读出0x100-0x1FF的内容(正确),0x0-0xff也是0x100-0x1ff的内容,然后所有的地址内容不停循环0x100-0x1ff,NADV已经反向给74HC573,初始化程序在后面,

最后,直接用一个F103VET6实验板,什么都不接,只是下载这个程序,用示波器观察,发现如下问题


1. PE11(DA8),信号幅值明显与其他DA0-DA15的幅值低很多 (这个是2V档)

PE13的信号(1V档)


FMSC初始化后,所有DA0-DA15,理论上引脚信号幅值应该是一样的,为什么PF11就不一样?,最后只有在PE11上上拉一个2K电阻,信号幅值就上去了,如果对PE11采用IO模式,Out_PP输出,信号幅值很正常
PCB原理图

ALE已经反向输出到573的
现在是用的什么都不挂接的实验板,信号还是一样,说明是F103VE自身的问题,这个怎么解释,如果FSMC初始化不正确,为什么0x100-0x1FF的内容写入和读出都是正确的?只是所有地址数据都是在0X100-0X1FF循环

FMSC程序
//初始化外部SRAM
void      FSMC_SRAM_Init(void)
{      
      GPIO_InitTypeDefGPIO_InitStructure;
      FSMC_NORSRAMInitTypeDefFSMC_NORSRAMInitStructure;
      FSMC_NORSRAMTimingInitTypeDefp;

      RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD | RCC_APB2Periph_GPIOE | RCC_APB2Periph_GPIOB| RCC_APB2Periph_AFIO, ENABLE);
      /* Enable FSMC, GPIOD, GPIOE, GPIOF, GPIOG and AFIO clocks */
      RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);

      GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;
      GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;      
      GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
      GPIO_Init(GPIOB, &GPIO_InitStructure);

      /* Set PD.00(D2), PD.01(D3), PD.04(NOE), PD.05(NWE), PD.07(NE1) PD.08(D13), PD.09(D14),
         PD.10(D15), PD.14(D0), PD.15(D1) as alternate function push pull */
      GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_7 | GPIO_Pin_11 |
                                    GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10| GPIO_Pin_14 | GPIO_Pin_15 ;

      GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
      GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
      GPIO_Init(GPIOD, &GPIO_InitStructure);

      /* Set PE.07(D4), PE.08(D5), PE.09(D6), PE.10(D7), PE.11(D8), PE.12(D9), PE.13(D10),
         PE.14(D11), PE.15(D12) as alternate function push pull */

      GPIO_InitStructure.GPIO_Pin = 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_Speed = GPIO_Speed_50MHz;
      GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
      GPIO_Init(GPIOE, &GPIO_InitStructure);

      p.FSMC_AddressSetupTime = 5;
      p.FSMC_AddressHoldTime = 5;
      p.FSMC_DataSetupTime = 15;
      p.FSMC_BusTurnAroundDuration = 5;
      p.FSMC_CLKDivision = 0;
      p.FSMC_DataLatency = 0;
      p.FSMC_AccessMode = FSMC_AccessMode_B;(改过D,一样现象)
      
      FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1;
      FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Enable;
      FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_NOR;(改过PSRAM,一样现象)
      FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b;
      FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;
      FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable;
      FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
      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 = &p;
      FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &p;
      

      FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);
      /* Enable FSMC Bank4_SRAM Bank */
      FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE);
                                                                              
}



foer 发表于 2019-1-24 17:35:45

   哎,大家都能说说吗......

toofree 发表于 2019-1-25 09:44:47

本帖最后由 toofree 于 2019-1-25 09:54 编辑

还有没有别的板子了,换一块试试

foer 发表于 2019-1-25 22:40:56

已经换了2种不同的实验板共3块板子,都一样的现象

foer 发表于 2019-1-25 22:42:17

用来2种不同的实验板,一共3块(有一种2块),都是一样的现象

xmshao 发表于 2019-2-12 12:06:57

hi,

还是建议你先检查下硬件连接以及电源供应情况。
可以先不管这个功能,试试别的外设工作是否正常。

另外, 基于你上面配置代码尝试调整后验证下:

   p.FSMC_AccessMode = FSMC_AccessMode_A;
   
FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM;

还有,注意NE1片选对应的起始地址别弄错了,

五哥1 发表于 2019-2-12 13:25:01

到底是PE11还是PF11?用CUBEMX生成个FSMC的程序看看

butterflyspring 发表于 2019-2-12 15:41:11

没看明白接线图。 但是从故障现象看DA8(PE11)没器作用。
建议在调试界面检查MUXEN是否设置。
断开连接 看看是否能输出高。

foer 发表于 2019-2-17 21:38:34

谢谢大家,这个现象是用学习板,都没有带任何负载的(见上面的图),信号还是这样,采用的F103VET6,应该是PE11,另外使用LCD控制板(只用了A0/A1)地址,8位数据,操作都是正常的,液晶显示也正常,PE11加上拉电阻后,电平正常,但读写SRAM还是不正常,0-0xFF与0x100-0x1FF一样,往后的地址不停循序0-0xFF的内容

foer 发表于 2019-2-17 21:50:00

这个是原来51单片机的原理图,工作是正常的,读写铁电存储器也是正常,我只是用stm32开发板通过跳线到这个PCB上,读写SRAM就不正常,8位地址数据共用的部分是正常,只使用A0/A1挂LCD液晶控制板(8位数据,800*600)的显示也正常,那说明stm32的初始化是正确的,就是高8位地址数据不正确,直接用stm32开发板,什么都不挂接,PE11的现象是一样的,那说明与我的PCB无关,从道理上讲A8-A15的权限是一样的,不应该出现A8(PE11)的电平幅值很低的情况,
页: [1] 2
查看完整版本: stm32f103vet6外接铁电FM28V020发现的问题