Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
ymodem_ota
rtthread通用bootloader踩坑分享
发布于 2020-08-25 15:02:19 浏览:2608
订阅该版
stm32f407vgt6采用通用bootloader+app模式,采用ymodem_ota进行固件升级, 在未编写任何功能性代码前均能正常升级,但是加入一个串口线程,一个按键处理线程,一个1秒周期性软件定时器之后, 升级固件就会卡在升级中,仿真发现错误返回值一直为-116(-0x74 RYM_ERR_DSZ 未收到足够数据), 采用排除法去掉串口线程和软件定时器之后,能正常升级,然后加入串口线程也能正常升级, 经排查得知软件定时器干扰了ymodem正常升级,软件定时器线程默认优先级为4调整为30后仍无法正常升级(优先级低于tshell),最后采用线程方式定时发送心跳可以正常升级(不采用软件定时器周期性回调发送数据)。 不太理解的是难道是因为软件定时器线程影响到了ymodem数据的正常接收? 哪位遇到过同样的问题解答下,谢谢!
查看更多
6
个回答
默认排序
按发布时间排序
红枫
认证专家
2020-08-25
这家伙很懒,什么也没写!
定时器回调处理耗时过长或mcu处理不够快,造成串口接收丢数据,就会出问题。解决办法主要是解决串口丢数据问题。如提高mcu主频,增大串口接收缓存等。
zyk6271
2020-08-25
这家伙很懒,什么也没写!
尝试将软件定时器调整为softtimer,同时并开启bsp的softtimer宏
aozima
2020-08-25
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
欢迎分享!
dancingzhang
2021-02-02
这家伙很懒,什么也没写!
今天也遇到这个问题,原因是串口缓存数据溢出导致,可以增加缓存或者提高shell进程优先级
07lhluo
2021-10-12
这家伙很懒,什么也没写!
这个问题我稍微深入查了一下,通过发送端和接收端的对比,证实发送端数据是OK的,只是接收端偶尔少了几个字节。我个人猜测是硬件上的问题,尤其是高波特率情况下,加上传输线等传输环境不佳,对数据有较大的干扰,导致接收端不能准确识别某些数据的电平信号,所以接收失败。 ![微信图片_20211012172239.png](https://oss-club.rt-thread.org/uploads/20211012/36ec2e377b1451530758a11dadd88dbe.png.webp) 这个问题首先可以降低波特率来解决。但如果在软件层面修复问题更加。我的做法是通过回应NAK来迫使对方从发数据来解决问题。有两个地方需要修改,1是开始握手接收第1帧(文件大小、文件名)的阶段;2是传输固件数据的过程中。目前我这边也多次重现同样问题,经过修复,现在波特率改大至230400,监视是有重发错误包的,目前功能稳定,但未做更多极限和长期测试。
diskwu
2021-03-15
这家伙很懒,什么也没写!
由于传输数据中途是有可能出错的,所以我改了一下下面的函数: ``` static rt_err_t _rym_do_trans(struct rym_ctx *ctx) { _rym_putchar(ctx, RYM_CODE_ACK); _rym_putchar(ctx, RYM_CODE_C); ctx->stage = RYM_STAGE_ESTABLISHED; while (1) { rt_err_t err; enum rym_code code; rt_size_t data_sz, i; code = _rym_read_code(ctx, RYM_WAIT_PKG_TICK); switch (code) { case RYM_CODE_SOH: data_sz = 128; break; case RYM_CODE_STX: data_sz = 1024; break; case RYM_CODE_EOT: return RT_EOK; default: return -RYM_ERR_CODE; }; err = _rym_trans_data(ctx, data_sz, &code); if (err != RT_EOK) { //return err; _rym_putchar(ctx, RYM_CODE_NAK); } else { switch (code) { case RYM_CODE_CAN: /* the spec require multiple CAN */ for (i = 0; i < RYM_END_SESSION_SEND_CAN_NUM; i++) { _rym_putchar(ctx, RYM_CODE_CAN); } return -RYM_ERR_CAN; case RYM_CODE_ACK: _rym_putchar(ctx, RYM_CODE_ACK); break; default: // wrong code break; }; } } } ``` 目的是,接受超时后,回复NAK,然后让上位机重发当前数据。因为我用的是128BYTE的方式,固件传输期间难免有问题,修改后,基本都可以OTA升级了。
撰写答案
登录
注册新账号
关注者
0
被浏览
2.6k
关于作者
Hunt
这家伙很懒,什么也没写!
提问
1
回答
1
被采纳
0
关注TA
发私信
相关问题
1
ymodem 升级失败
2
通过BootLoader升级固件失败,用的是stm32f407zgt6
3
qboot ymodem上传固件后release失败
4
ymodem传输 用什么工具呢?
5
ymodem_ota接收数据大小问题
6
Ymodem升级过程中丢包
7
H743的bootloader,在使用ymodem升级固件,无法写入app分区
8
求助 RT-Thread Studio 中 Ymodem 升级问题
9
YMODEM OTA 擦除download分区不完全
10
为什么电脑与板子直连着网线的时候,用ymodem_ota升级经常在中途卡住?
推荐文章
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
【RT-Thread】【ci】【scons】将ci.attachconfig.yml和scons结合使用
2
Rt-thread中OTA下载后,bootloader不搬程序
3
ulog 日志 LOG_HEX 输出时间改为本地日期时间
4
在RT-Thread Studio中构建前执行python命令
5
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
热门标签
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
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
cubemx
PWM
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
8
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
9
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
RTT_逍遥
3
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
4
次点赞
Ghost_Girls
1
篇文章
7
次点赞
xiaorui
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部