搜索
查看: 2481|回复: 11

[求助] stm32f103vet6外接铁电FM28V020发现的问题

[复制链接]

该用户从未签到

2

主题

8

帖子

0

蝴蝶豆

初级会员

最后登录
2019-12-19
发表于 2019-1-24 16:41:10 | 显示全部楼层 |阅读模式

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

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

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

FMSC初始化后,所有DA0-DA15,理论上引脚信号幅值应该是一样的,为什么PF11就不一样?,最后只有在PE11上上拉一个2K电阻,信号幅值就上去了,如果对PE11采用IO模式,Out_PP输出,信号幅值很正常
PCB原理图
1.jpg
ALE已经反向输出到573的
现在是用的什么都不挂接的实验板,信号还是一样,说明是F103VE自身的问题,这个怎么解释,如果FSMC初始化不正确,为什么0x100-0x1FF的内容写入和读出都是正确的?只是所有地址数据都是在0X100-0X1FF循环

FMSC程序
//初始化外部SRAM
void        FSMC_SRAM_Init(void)
{        
        GPIO_InitTypeDef  GPIO_InitStructure;
        FSMC_NORSRAMInitTypeDef  FSMC_NORSRAMInitStructure;
        FSMC_NORSRAMTimingInitTypeDef  p;

        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);  
                                                                                
}



回复

使用道具 举报

该用户从未签到

2

主题

8

帖子

0

蝴蝶豆

初级会员

最后登录
2019-12-19
 楼主| 发表于 2019-1-24 17:35:45 | 显示全部楼层
   哎,大家都能说说吗......
回复 支持 反对

使用道具 举报

  • TA的每日心情
    开心
    2017-12-6 11:47
  • 签到天数: 1 天

    [LV.1]初来乍到

    49

    主题

    3724

    帖子

    429

    蝴蝶豆

    论坛元老

    最后登录
    2021-8-7
    发表于 2019-1-25 09:44:47 | 显示全部楼层
    本帖最后由 toofree 于 2019-1-25 09:54 编辑

    还有没有别的板子了,换一块试试
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    2

    主题

    8

    帖子

    0

    蝴蝶豆

    初级会员

    最后登录
    2019-12-19
     楼主| 发表于 2019-1-25 22:40:56 | 显示全部楼层
    已经换了2种不同的实验板共3块板子,都一样的现象
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    2

    主题

    8

    帖子

    0

    蝴蝶豆

    初级会员

    最后登录
    2019-12-19
     楼主| 发表于 2019-1-25 22:42:17 | 显示全部楼层
      用来2种不同的实验板,一共3块(有一种2块),都是一样的现象
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    10

    主题

    802

    帖子

    271

    蝴蝶豆

    版主

    最后登录
    2020-12-15
    发表于 2019-2-12 12:06:57 | 显示全部楼层
    hi,

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

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

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

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

    评分

    参与人数 1蝴蝶豆 +3 收起 理由
    STMCU + 3

    查看全部评分

    回复 支持 反对

    使用道具 举报

    该用户从未签到

    19

    主题

    1734

    帖子

    7

    蝴蝶豆

    论坛元老

    最后登录
    2021-5-10
    发表于 2019-2-12 13:25:01 | 显示全部楼层
    到底是PE11还是PF11?用CUBEMX生成个FSMC的程序看看

    评分

    参与人数 1蝴蝶豆 +3 收起 理由
    STMCU + 3

    查看全部评分

    回复 支持 反对

    使用道具 举报

    该用户从未签到

    3

    主题

    1306

    帖子

    929

    蝴蝶豆

    版主

    最后登录
    2021-3-31
    发表于 2019-2-12 15:41:11 | 显示全部楼层
    没看明白接线图。 但是从故障现象看DA8(PE11)没器作用。
    建议在调试界面检查MUXEN是否设置。
    断开连接 看看是否能输出高。

    评分

    参与人数 1蝴蝶豆 +3 收起 理由
    STMCU + 3

    查看全部评分

    回复 支持 反对

    使用道具 举报

    该用户从未签到

    2

    主题

    8

    帖子

    0

    蝴蝶豆

    初级会员

    最后登录
    2019-12-19
     楼主| 发表于 2019-2-17 21:38:34 | 显示全部楼层
    谢谢大家,这个现象是用学习板,都没有带任何负载的(见上面的图),信号还是这样,采用的F103VET6,应该是PE11,另外使用LCD控制板(只用了A0/A1)地址,8位数据,操作都是正常的,液晶显示也正常,PE11加上拉电阻后,电平正常,但读写SRAM还是不正常,0-0xFF与0x100-0x1FF一样,往后的地址不停循序0-0xFF的内容
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    2

    主题

    8

    帖子

    0

    蝴蝶豆

    初级会员

    最后登录
    2019-12-19
     楼主| 发表于 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)的电平幅值很低的情况,
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 注册/登录

    本版积分规则

    关闭

    站长推荐上一条 /3 下一条

    Archiver|手机版|小黑屋|论坛-意法半导体STM32/STM8技术社区

    GMT+8, 2024-4-26 22:14 , Processed in 0.190627 second(s), 47 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2024, Tencent Cloud.

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