搜索
bottom↓
回复: 10

stm32h743的sct文件加入sdram地址后,仿真连接失败

[复制链接]

出0入0汤圆

发表于 2019-10-24 14:30:15 | 显示全部楼层 |阅读模式
刚刚使用stm32h743系列发现个问题,之前买的成品核心板 208个脚的也有一样的问题,一开始以为是板子问题,我自己重新画了个四层板,用的176脚的743,结果也是一样的问题,表现为
在指定自己的sct文件之前,使用系统自定义的内存分配,可以仿真加载,但是每次都不是到main函数,而是跑到一开始的汇编代码,你要按3次f5run才能跑起来,前面两次f5没什么反应,这样还好,而且程序下载进去后脱离仿真器,必须要按2次硬件复位按钮才能跑起来,每次上电第一次肯定跑不起来,后来因为用到sdram,所以吧sct文件加入了外部sdram空间,sdram程序部分已经完全没问题了,校验都通过,连仿真器都连不上了,看图片,但是因为自己设计的电路板,所以和429是完全可以替换的,焊了一块429的板子却一点问题都没有,但是有个问题是共同 的,那就是每次上电不会运行,需要连续按复位才能跑起来,之前从未碰倒过这样的现象,不知道谁知道该怎么处理,万分感谢了

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!

出0入0汤圆

发表于 2019-10-24 14:43:46 | 显示全部楼层
你这表现像是SDRAM里存放了已初始化变量,在未初始化接口的时候启动代码去访问了SDRAM;
试试把SDRAM的ZI去掉,启动的时候不加载;

出0入0汤圆

 楼主| 发表于 2019-10-24 14:48:08 | 显示全部楼层
jueenkay 发表于 2019-10-24 14:43
你这表现像是SDRAM里存放了已初始化变量,在未初始化接口的时候启动代码去访问了SDRAM;
试试把SDRAM的ZI去 ...

LR_IROM1 0x08000000 0x00200000  {    ; load region size_region
  ER_IROM1 0x08000000 0x00200000  {  ; load address = execution address
   *.o (RESET, +First)
   *(InRoot$$Sections)
   .ANY (+RO)
   .ANY (+RO)
  }
  RW_IRAM2 0x24000000 0x00080000  {  ; RW data
   *.o (STACK,+RW +ZI)
   *.o (HEAP,+RW +ZI)
  }
  RW_RAM1 0xD0500000 0x00100000  {  ; RW data
   .ANY (+RW)
  }
}

改成这样还是老样子,你们没有碰到过这样的问题吗,还有那个下载进去不运行怎么回事,要复位按钮按几下才可以

出0入0汤圆

发表于 2019-10-24 15:11:01 来自手机 | 显示全部楼层
自动分配到SDRAM比较容易出问题,最好是系统启动后手动分配变量

出0入0汤圆

发表于 2019-10-24 15:23:56 | 显示全部楼层
在启动文件中找sys_init函数的位置,在它后面把你SDRAM的初始化函数添加进去,sct里改回带ZI;
在加载完RAM后添加加载SDRAM的代码(这个我也不会了..你网上找找);

出140入158汤圆

发表于 2019-10-24 15:57:56 | 显示全部楼层
上电没初始化SDRAM当然不行,MDK的启动结构是:第一步初始化堆栈指针,然后跑SystemInit,再跳到__main,在__main里会把所有RAM清空,以及加载全局和静态变量,您没在__main前初始化,又在sct里指定了外部SDRAM空间,当然会出事。

出140入158汤圆

发表于 2019-10-24 16:07:44 | 显示全部楼层
H7的性能不错,可惜就是没有NEON,可惜

出0入0汤圆

 楼主| 发表于 2019-10-24 16:23:14 | 显示全部楼层
amigenius 发表于 2019-10-24 15:57
上电没初始化SDRAM当然不行,MDK的启动结构是:第一步初始化堆栈指针,然后跑SystemInit,再跳到__main,在 ...

奇怪的是,429可以啊,难道429流程不一样?

出140入158汤圆

发表于 2019-10-24 17:18:05 | 显示全部楼层
smilepppp 发表于 2019-10-24 16:23
奇怪的是,429可以啊,难道429流程不一样?

您都说429也是上电不运行,复位后才能运行。

出140入158汤圆

发表于 2019-10-24 17:24:29 | 显示全部楼层
smilepppp 发表于 2019-10-24 16:23
奇怪的是,429可以啊,难道429流程不一样?

另外,现在H7批量上线,质量还不是很稳定,一批下来总有一些有问题,这个原厂FAE已经承认了,后面会陆续解决。

出0入0汤圆

 楼主| 发表于 2019-10-24 18:48:16 | 显示全部楼层
amigenius 发表于 2019-10-24 17:24
另外,现在H7批量上线,质量还不是很稳定,一批下来总有一些有问题,这个原厂FAE已经承认了,后面会陆续 ...

谢谢指点,我按照你的说法,在s函数里面加了sdram初始化,在sct文件去掉sdram部分仿真发现在main之前sdram 的内存观察窗口已经可以访问了,数据也是对的,但是sct里面一加入sdram部分,仿真器就连不上,和图上一样显示cannnot access target
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-24 22:17

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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