3231|1

25

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

stm32 fsmc总线操作nor flash时候的地址移位问题 [复制链接]

#define ADDR_SHIFT(A) (Bank1_NOR2_ADDR + (2 * (A)))

#define NOR_WRITE(Address, Data)  (*(vu16 *)(Address) = (Data))

NOR_Status FSMC_NOR_EraseBlock(u32 BlockAddr)
{
  NOR_WRITE(ADDR_SHIFT(0x05555), 0x00AA);第一步
  NOR_WRITE(ADDR_SHIFT(0x02AAA), 0x0055);第二步
  NOR_WRITE(ADDR_SHIFT(0x05555), 0x0080);第三步
  NOR_WRITE(ADDR_SHIFT(0x05555), 0x00AA);第四步
  NOR_WRITE(ADDR_SHIFT(0x02AAA), 0x0055);第五步
  NOR_WRITE((Bank1_NOR2_ADDR + BlockAddr), 0x30);第六步

  return (FSMC_NOR_GetStatus(BlockErase_Timeout));
}

NOR_Status FSMC_NOR_WriteHalfWord(uint32_t WriteAddr, uint16_t Data)
{
    NOR_WRITE(ADDR_SHIFT(0x05555),0x00aa);  第七步
NOR_WRITE(ADDR_SHIFT(0x02aaa),0x0055);   八
NOR_WRITE(ADDR_SHIFT(0x05555),0x00a0); 九
NOR_WRITE((Bank1_Nor2_ADDR+WriteAddr),Data);  十
return(FSMC_NOR_GetStatus(Program_Timeout));
}

想问问,在第六步和第十步里面的地址,为什么不像前五步那样,偏移地址往左移一位呢?谢啦!

flash操作指令的地址左移一位我知道。因为16位数据位宽时,内部HADDR[25:1]和产生外部存储器地址的FSMC_A[24:0]相连,而FSMC_A的最低位始终和存储器的地址线最低位相连。但是flash操作指令地址,是针对flash的 所以MCU产生的时候要左移一位后,发出,flash接受到的才是正确的地址指令。

但是到第六步和第十步的时候 为什么又不移位了呢?
此帖出自stm32/stm8论坛
点赞 关注
 

回复
举报

25

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
第一个函数为擦除函数,第二个函数为写函数
此帖出自stm32/stm8论坛
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表