完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我已经编写了一个相当简单的测试用例,用于使用系统引导加载程序从 STM32F429ZIT6U(在 Nucleo F429ZI 板上开发)上的闪存组 2 引导。通过将 stdio 重定向到 UART,我可以将代码定向到:
查看反汇编,我可以看到一个“bx lr”跳到样板启动代码中间的点,所以我认为没有发生实际故障或重置;这更有可能是堆栈损坏的情况。但是,这种情况通过硬重置仍然存在;我只能通过使用 STProg 清除 BFB2 选项位来重新获得对芯片的控制权。 我不知所措。Bank 2 与 Bank 1 相同;我知道这一点是因为代码本身直接复制了它,我可以通过 STProg 下载和比较这两个银行,看看它们是相同的。那么为什么切换银行会导致代码跳到奇怪的地方呢? |
|
相关推荐
1个回答
|
|
基于我之前设法掩盖的 AN4767 中的这一短段:
“请注意 VTOR 重置值为零,如果 BFB2 选项处于活动状态,它将默认指向系统内存。” 所以是的,当然,如果设置了 BFB2 并且 VTOR 没有适当地重新指向,则在存储体切换之后出现的第一个中断会将执行发送回系统内存。这就是为什么我首先在 printf 的上下文中看到它,这导致了 UART 中断。 如果 main 中的第一条指令(或者,实际上,任何在中断之前发生的指令)正确地将 VTOR 指向 0x0800 0000,核心在应用程序代码中保持快乐。 |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2340 浏览 1 评论
3095 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1663 浏览 1 评论
3480 浏览 6 评论
5832 浏览 21 评论
823浏览 4评论
1199浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
467浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1182浏览 3评论
1233浏览 3评论
小黑屋| 手机版| Archiver| 德赢Vwin官网 ( 湘ICP备2023018690号 )
GMT+8, 2024-9-2 00:15 , Processed in 1.144854 second(s), Total 78, Slave 62 queries .
Powered by 德赢Vwin官网 网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
德赢Vwin官网 观察
版权所有 © 湖南华秋数字科技有限公司
德赢Vwin官网 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号