完善资料让更多小伙伴认识你,还能领取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的选项
2644 浏览 1 评论
3209 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1784 浏览 1 评论
3613 浏览 6 评论
5990 浏览 21 评论
940浏览 4评论
1317浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
585浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1304浏览 3评论
1362浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-25 22:10 , Processed in 1.170591 second(s), Total 79, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号