野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 19301|回复: 2

霸道板子,关于SRAM 时序及寄存器的困惑,请大师帮忙缕缕我哪个地方理解错了

[复制链接]
发表于 2019-5-16 16:42:45 | 显示全部楼层 |阅读模式
霸道板子

以读时序为例
模式A 读时序
          ________________
NOE                                \__________________________________
                                      |                              |                   |
                                      |                              |                   |
            (ADDSET+1)          (DATAST+1)         2HCLK            
        |<--------------------> <----------------------->| <----------->|
            地址建立时间           数据保持时间    从这里数据有效后就可以读取了  
我的理解:
(ADDSET+1) :地址建立时间  与IS62芯片时序同样,在OE为高期间为地址建立时间
(DATAST+1): 数据保持时间                                  在OE拉低直到DATA VALID有效才可以读取数据


我又看寄存器:
SRAM/NOR闪存片选时序寄存器 1…4 (FSMC_BTR1…4)
DATAST:数据保持时间 (Data-phase duration)
0000 0000:保留
0000 0001:DATAST保持时间=2个HCLK时钟周期
ADDSET:地址建立时间 (Address setup phase duration)
0000:ADDSET建立时间=1个HCLK时钟周期
1111:ADDSET建立时间=16个HCLK时钟周期(这是复位后的默认数值)。

我的理解:
ADDSET设置为1 时,其实是2个HCLK时钟周期
ADDSET设置为3 时,其实是4个HCLK时钟周期   

DATAST设置为1时,其实是2个HCLK时钟周期
ADDSET设置为3 时,其实是4个HCLK时钟周期   

我看库函数里面是这样的
FSMC_Bank1->BTCR[FSMC_NORSRAMInitStruct->FSMC_Bank+1] =
            (uint32_t)FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressSetupTime |
            (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AddressHoldTime << 4) |
            (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataSetupTime << 8) |
            (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_BusTurnAroundDuration << 16) |
            (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_CLKDivision << 20) |
            (FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_DataLatency << 24) |
             FSMC_NORSRAMInitStruct->FSMC_ReadWriteTimingStruct->FSMC_AccessMode;

是直接把我们写的ADDSET值写进FSMC_BTR1的 位3:0  ADDSET:地址建立时间

那么在计算的时候:                                                                       ADDSET  = 0
(ADDSET+1) :地址建立时间   -------------    ADDSET +  1   > 0ns   =====>    ( 0 + 1)  + 1 =   2HCLK  = 27.6 ns  > 0ns

                                                                                                   DATAST = 1
(DATAST+1): 数据保持时间      -----------    DATAST + 1  > 25ns   =====>   ( 1 + 1 ) + 1 =   3HCLK   = 41.4 ns  > 25ns

我 在 (ADDSET+1)地址建立阶段, ADDSET的值设置为1时,在计算时需要加1,因为
ADDSET:地址建立时间 (Address setup phase duration)
0000:ADDSET建立时间=1个HCLK时钟周期
1111:ADDSET建立时间=16个HCLK时钟周期(这是复位后的默认数值)。

这个地方我感觉我理解的对呀,懵逼了,请大师帮我缕缕思路吧


老师写的
//1.  ADDSET+1+DATAST+1 +2 >55ns
//2.  DATAST+1  > 25ns
//3.  ADDSET+1 > 0ns  












回复

使用道具 举报

发表于 2019-5-17 09:24:48 | 显示全部楼层
这个好复杂,我直接用火哥的算了,没有想
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-17 09:45:37 | 显示全部楼层
雍蕴美 发表于 2019-5-17 09:24
这个好复杂,我直接用火哥的算了,没有想

我跟着视频学的,到这里有点困惑,想弄明白
回复 支持 反对

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2025-12-6 22:10 , Processed in 0.049878 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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