Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
qboot
STM32H750VB
Bootloader
H750VB原子开发板, 使用qboot软件包时有时候跳转卡死。
发布于 2023-03-01 11:39:27 浏览:643
订阅该版
首先我按照art-pi的例子进行qboot的移植,移植后跳转一直不怎么正常,检查过内存映射的数据读取是正常的,大多时候都不能正常跳转,偶尔会跳转成功。 ~~然后我以为是中断的问题, 我将开中断的函数注释掉了, 然后app的rtthread初始化的时候应该会开这个中断,现在的话大多时候都是能够正常跳转的, 但是还是偶尔出现卡死的情况。~~(后来发现是错觉) 同样的步骤我在另一个工程里面,没有添加fal sfud qboot相关组件包, 直接main里面做跳转是100%成功的, 但是想着qboot这个方案比较完整,想直接拿过来用。 代码如下: ```c void qbt_jump_to_app(void) { typedef void (*app_func_t)(void); app_func_t app_func; struct rt_qspi_device *device = NULL; u32 stk_addr = 0; u32 reset_handler = 0; const u8 send[4] = {0x03, 0x00, 0x00, 0x00}; u8 recv[8] = {0}; device = (struct rt_qspi_device *)rt_device_find(QBOOT_QSPI_FLASH_DEVICE_NAME); if(device == RT_NULL) { LOG_E("no found qspi flash."); return; } rt_qspi_send_then_recv(device, send, sizeof(send), recv, sizeof(recv)); stk_addr = recv[0]; stk_addr += ((u32)recv[1] << 8); stk_addr += ((u32)recv[2] << 16); stk_addr += ((u32)recv[3] << 24); reset_handler = recv[4]; reset_handler += ((u32)recv[5] << 8); reset_handler += ((u32)recv[6] << 16); reset_handler += ((u32)recv[7] << 24); LOG_I("stk_addr :\t\t0x%08X", stk_addr); LOG_I("reset_handler :\t0x%08X",reset_handler); stk_addr &= 0x3FF00000; if(((reset_handler & 0xff000000) != QSPI_BASE) || (stk_addr != 0x20000000 && stk_addr != 0x24000000 && stk_addr != 0x30000000 && stk_addr != 0x38000000)) { LOG_E("No legitimate application."); return; } W25QXX_Reset(); W25QXX_Init(); W25Q_Memory_Mapped_Enable(); rt_thread_delay(100); LOG_I("Jump to application running ... 0x%#X, 0x%#X\n", *(uint32_t *)(QSPI_BASE), *(uint32_t *)(QSPI_BASE + 4)); #if (__MPU_PRESENT == 1) HAL_MPU_Disable(); #endif SCB_DisableICache(); SCB_DisableDCache(); __set_PRIMASK(1); SysTick->CTRL = 0; SysTick->LOAD = 0; SysTick->VAL = 0; for(int i = 0; i < 8; i++) { NVIC->ICER[i] = 0xffffffff; NVIC->ICPR[i] = 0xffffffff; } //__set_PRIMASK(0); __set_MSP(stk_addr); __set_CONTROL(0); app_func = (app_func_t) (reset_handler); app_func(); LOG_I("Qboot jump to application fail."); } ``` 下面是两次的启动日志, 第二次直接卡死, 我debug调试也不知道从哪下手,求助下大佬! ``` \ | / - RT - Thread Operating System / | \ 4.1.1 build Mar 1 2023 10:27:57 2006 - 2022 Copyright by RT-Thread team [D/main] Hello RT-Thread! msh >[D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! \ | / - RT - Thread Operating System / | \ 4.1.1 build Mar 1 2023 11:10:40 2006 - 2022 Copyright by RT-Thread team [1] D/drv.qspi: qspi init success! [5] I/SFUD: Warning: Read SFDP parameter header information failed. The W25Q128 is not support JEDEC SFDP. [15] I/SFUD: Find a flash chip. Size is 16777216 bytes. [21] I/SFUD: W25Q128 flash device is initialize success. [27] D/drv.qspi: qspi init success! [30] I/SFUD: Probe SPI flash W25Q128 by SPI device qspi10 success. [D/FAL] (fal_flash_init:47) Flash device | stm32_onchip | addr: 0x08000000 | len: 0x00020000 | blk_size: 0x00020000 |initialized finish. [D/FAL] (fal_flash_init:47) Flash device | W25Q128 | addr: 0x00000000 | len: 0x01000000 | blk_size: 0x00001000 |initialized finish. [I/FAL] ==================== FAL partition table ==================== [I/FAL] | name | flash_dev | offset | length | [I/FAL] ------------------------------------------------------------- [I/FAL] | bl | stm32_onchip | 0x00000000 | 0x00020000 | [I/FAL] | app | W25Q128 | 0x00000000 | 0x00100000 | [I/FAL] | factory | W25Q128 | 0x00100000 | 0x00700000 | [I/FAL] | download | W25Q128 | 0x00800000 | 0x00800000 | [I/FAL] ============================================================= [I/FAL] RT-Thread Flash Abstraction Layer initialize success. msh > Qboot startup ... Qboot version : V1.0.5 2020.10.05 Product name : Qboot Logo Product version : v1.00 2023.02.23 Product mcu : stm32H750VB Press [Enter] key into shell in 5 s : [5172] I/Qboot: stk_addr : 0x240009F4 [5176] I/Qboot: reset_handler : 0x9000E6B9 [5281] I/Qboot: Jump to application running ... 0x240009F4, 0x9000E6B9 \ | / - RT - Thread Operating System / | \ 4.1.1 build Mar 1 2023 10:27:57 2006 - 2022 Copyright by RT-Thread team [D/main] Hello RT-Thread! msh >[D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! [D/main] Hello RT-Thread! \ | / - RT - Thread Operating System / | \ 4.1.1 build Mar 1 2023 11:10:40 2006 - 2022 Copyright by RT-Thread team [1] D/drv.qspi: qspi init success! [5] I/SFUD: Warning: Read SFDP parameter header information failed. The W25Q128 is not support JEDEC SFDP. [15] I/SFUD: Find a flash chip. Size is 16777216 bytes. [21] I/SFUD: W25Q128 flash device is initialize success. [27] D/drv.qspi: qspi init success! [30] I/SFUD: Probe SPI flash W25Q128 by SPI device qspi10 success. [D/FAL] (fal_flash_init:47) Flash device | stm32_onchip | addr: 0x08000000 | len: 0x00020000 | blk_size: 0x00020000 |initialized finish. [D/FAL] (fal_flash_init:47) Flash device | W25Q128 | addr: 0x00000000 | len: 0x01000000 | blk_size: 0x00001000 |initialized finish. [I/FAL] ==================== FAL partition table ==================== [I/FAL] | name | flash_dev | offset | length | [I/FAL] ------------------------------------------------------------- [I/FAL] | bl | stm32_onchip | 0x00000000 | 0x00020000 | [I/FAL] | app | W25Q128 | 0x00000000 | 0x00100000 | [I/FAL] | factory | W25Q128 | 0x00100000 | 0x00700000 | [I/FAL] | download | W25Q128 | 0x00800000 | 0x00800000 | [I/FAL] ============================================================= [I/FAL] RT-Thread Flash Abstraction Layer initialize success. msh > Qboot startup ... Qboot version : V1.0.5 2020.10.05 Product name : Qboot Logo Product version : v1.00 2023.02.23 Product mcu : stm32H750VB Press [Enter] key into shell in 5 s : [5172] I/Qboot: stk_addr : 0x240009F4 [5176] I/Qboot: reset_handler : 0x9000E6B9 [5281] I/Qboot: Jump to application running ... 0x240009F4, 0x9000E6B9 ```
查看更多
mii
2023-03-01
这家伙很懒,什么也没写!
你把QBOOT时钟初始化跟APP程序弄得一致试试,跳转前确保跟APP一致
3
个回答
默认排序
按发布时间排序
zx970204
2023-03-01
这家伙很懒,什么也没写!
在另一个项目中重新构建qboot,莫名奇妙好了。。。
Dev_XH
2023-08-02
每天进步一点点,发际线后移一点点
我跟您的配置是一样,但是遇到了跳转无响应的问题,写一个文档,求助您帮我看一下,感谢🤞 https://club.rt-thread.org/ask/question/2c54845fa7148ef6.html
撰写答案
登录
注册新账号
关注者
0
被浏览
643
关于作者
zx970204
这家伙很懒,什么也没写!
提问
2
回答
1
被采纳
0
关注TA
发私信
相关问题
1
Linux下通过USBTinyISP为Arduino开发板烧?写Bootloader
2
请教修改NVIC后RTT调度函数失效的问题[已解决 bootloader中打开了不必要的中断]
3
进入bootloader的方式探讨
4
求助:IAP里的APP使用的RTT,跳转后出错。[已解决]
5
有没有人在STM32F103上用UART IAP跑过RT-Thread?
6
想做网口的IAP远程升级,不知可不可行
7
IAP问题
8
[已解决]请教基于RTT的IAP程序切换到应用程序不成功的问题(基于STM32F4)?
9
stm32f4xx-----IAP移植APP程序需要注意的地方
10
在调试IAP网络升级遇到跳转之后bootloader程序网络不通
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
at_device
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
张世争
8
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
KunYi
6
个答案
1
次被采纳
本月文章贡献
程序员阿伟
6
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部