fsmc地址线问题

2019-07-20 16:53发布

FSMC控制外部SRAM时,地址线A0-A15与SRAM的A0-A15分别对应连接,那么我实际输出的地址其实是左移了一位的地址,如果我的FSMC的A0与某外设的A1相连,而外设的A0与FSMC的NBL0相连,这样地址需要偏移吗?另外如果设置数据宽度为16bit,那么NBL0和NBL1不应该都是输出高吗?有点乱。因为是确实看见有人讲外设的A0与FSMC的NBL0相连

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
23条回答
_tank_
1楼-- · 2019-07-20 19:54
首先 纠正一个问题 实际的输出地址是右移一位地址(16bit模式下)
1、如果我的FSMC的A0与某外设的A1相连,而外设的A0与FSMC的NBL0相连,这样地址需要偏移吗?
如果是16位模式 要的 地址偏移是FSMC内部的固化操作 如果你选择16位模式就会有地址偏移(稍后说明原因) 这样做是为了用户使用方便
2、另外如果设置数据宽度为16bit,那么NBL0和NBL1不应该都是输出高吗? 
不一定 偶字节读写时仅NBL0有效,奇字节读写时仅NBL1有效 字读写都有效(低电平有效)
3、有点乱。因为是确实看见有人讲外设的A0与FSMC的NBL0相连 
不知道 没见过

这里说一下我对FSMC地址操作的一点认识

首先说一个前提:STM32 单片机的一个地址(如:0x20000000)是一个字节 
也就是说如果定义一个16位数组 u16 temp[5]  如果temp对应的地址是0x00000000 那么temp+1对应的地址是0x00000002 (地址是加2)

假设此时我们有一个 64K*8bit 的sram
那很简单 stm32的A0~A15 与存储器A0~A15连接 大家很容易理解

若此时是 64K*16bit 的sram
也就是此时sram的一个地址对应两个字节 但是stm32是一个地址一个字节 这就出现了对准的问题
如果我们的地址线依然是stm32A0~A15 和 存储器的A0~A15 连接
如果stm32要从sram中读取前面提到数组中的temp[1]
stm32会给出0x0002(二进制地址0000000000000010b) 可是对于我们这个sram来说 读到却是temp[2],因为sram一个地址就是一个16位数据 
为了解决这个问题 我们只需要在给sram送地址时 右移一位 再送地址 即可(sram的一个地址对应stm32两个地址的数据)
比如读取0x0002 右移一位(即除2)为0x0001(0000000000000010b) 此时对应的就是temp[1]
而为了给用户提供方便 如果你选择的是16位宽度的sram FSMC会在你送地址的时候自动为你做右移一位的操作 
此时会有另外一个问题 每次都右移一位 A0没用吗 也即只能读写偶地址的数据吗?
这也就是NBL0和NBL1的作用了 如果你要进行字节操作
如stm32发送地址0x0001读取一个字节 右移一位对应的是sram地址0x0000处的16位数据 FSMC会根据AO 来控制NBLO和NBL1为10 读取高字节数据
所以呢  偶字节读写时仅NBL0有效,奇字节读写时仅NBL1有效 字读写都有效(低电平有效)



 
正点原子
2楼-- · 2019-07-20 21:58
 精彩回答 2  元偷偷看……
流水无意
3楼-- · 2019-07-21 03:19
我这真没图。
地址线的连线如下
MCU(管脚)                   外设
FSMC_NBL0        A0
FSMC_A0            A1
FSMC_A1            A2
FSMC_A2            A3
FSMC_A3            A4
FSMC_A4            A5
FSMC_A5            A6
FSMC_A6            A7
FSMC_A7            A8
FSMC_A8            A9
FSMC_A9            A10
FSMC_A10          A11
FSMC_A11          A12
FSMC_A12          A13
FSMC_A13          A14
FSMC_A14          A15
正点原子
4楼-- · 2019-07-21 07:38
这个连接有点怪异,呵呵。
流水无意
5楼-- · 2019-07-21 11:09
那么当fsmc设为16位数据宽度,NBL0和NBL1输出应该是高吗?
eling13
6楼-- · 2019-07-21 11:20
回复【6楼】_tank_:
---------------------------------
非常强大!!非常NICE!!外部16位SRAM就是如此了,配合D0-D15。

一周热门 更多>