OpenEdv-开源电子网

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

奇怪了 STM32 FMC NWAIT功能无效

[复制链接]

13

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
98
金钱
98
注册时间
2016-8-10
在线时间
23 小时
发表于 2017-9-11 09:22:21 | 显示全部楼层 |阅读模式
大家好,STM32单片机FMC接口,初始化为SRAM,使能了异步通信NWAIT功能,同步通信NWAIT禁止,低电平有效,设置为等待周期前一个数据有效。NWAIT接有上拉电阻,所以默认状态高电平。这些配置都配置完毕后,由于NWAIT是高电平,STM32应该是读不到数据的,但是实际上并不影响STM32读到数据,很奇怪,请教一个大家,谢谢大家。        SRAM_HandleTypeDef  CPLD_sram;
        FMC_NORSRAM_TimingTypeDef Timing;
       
        CPLD_sram.Init.NSBank = FMC_NORSRAM_BANK1;
        CPLD_sram.Init.DataAddressMux = FMC_DATA_ADDRESS_MUX_DISABLE;
        CPLD_sram.Init.MemoryType = FMC_MEMORY_TYPE_SRAM;
        CPLD_sram.Init.MemoryDataWidth = FMC_NORSRAM_MEM_BUS_WIDTH_16;
        CPLD_sram.Init.BurstAccessMode = FMC_BURST_ACCESS_MODE_DISABLE;
        CPLD_sram.Init.WaitSignalPolarity = FMC_WAIT_SIGNAL_POLARITY_LOW;  
        CPLD_sram.Init.WaitSignalActive = FMC_WAIT_TIMING_BEFORE_WS;      
        CPLD_sram.Init.WriteOperation = FMC_WRITE_OPERATION_ENABLE;
        CPLD_sram.Init.WaitSignal = FMC_WAIT_SIGNAL_DISABLE;               
        CPLD_sram.Init.ExtendedMode = FMC_EXTENDED_MODE_DISABLE;
        CPLD_sram.Init.AsynchronousWait = FMC_ASYNCHRONOUS_WAIT_ENABLE;
        CPLD_sram.Init.WriteBurst = FMC_WRITE_BURST_DISABLE;
        CPLD_sram.Init.ContinuousClock = FMC_CONTINUOUS_CLOCK_SYNC_ONLY;
        CPLD_sram.Init.WriteFifo = 0;
        CPLD_sram.Init.PageSize = 0;       
        CPLD_sram.Instance = FMC_NORSRAM_DEVICE;
        CPLD_sram.Extended = FMC_NORSRAM_EXTENDED_DEVICE;       
        Timing.AddressSetupTime = 0;
        Timing.AddressHoldTime = 0;
        Timing.DataSetupTime = 3;
        Timing.BusTurnAroundDuration = 1;
        Timing.CLKDivision = 0;
        Timing.DataLatency = 0;
        Timing.AccessMode = FMC_ACCESS_MODE_A;       
        HAL_SRAM_DeInit(&CPLD_sram);
        HAL_SRAM_Init(&CPLD_sram, &Timing, &Timing);


NWAIT时序图.jpg
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11553
金钱
11553
注册时间
2014-4-1
在线时间
1317 小时
发表于 2017-9-11 09:22:22 | 显示全部楼层

如果存储器有这个管脚,NWAIT线必须接存储器的对应管脚,才会起作用,
如果没有这个管脚,NWAIT设置只起到改变时间长度的作用。


回复 支持 反对

使用道具 举报

13

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
98
金钱
98
注册时间
2016-8-10
在线时间
23 小时
 楼主| 发表于 2017-9-12 15:53:13 | 显示全部楼层
xuande 发表于 2017-9-11 09:22
如果存储器有这个管脚,NWAIT线必须接存储器的对应管脚,才会起作用,
如果没有这个管脚,NWAIT设置只起 ...

谢谢!存储器有这个引脚,并且已经链接。我的NWAIT初始化代码对吧,第一次用NWAIT功能,不太确定。
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-18 20:20

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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