Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
关于rt_ringbuffer_put_force的问题讨论
发布于 2018-05-24 14:16:35 浏览:2419
订阅该版
* 本帖最后由 geniusgogo 于 2018-5-24 14:18 编辑 * 最近要用到ringbuffer功能,所以review了一下rt_ringbuffer的实现,发现rt_ringbuffer_put_force的实现存在问题。 先看其实现: ```/** * put a block of data into ring buffer * * When the buffer is full, it will discard the old data. */ rt_size_t rt_ringbuffer_put_force(struct rt_ringbuffer *rb, const rt_uint8_t *ptr, rt_uint16_t length) { rt_uint16_t space_length; RT_ASSERT(rb != RT_NULL); space_length = rt_ringbuffer_space_len(rb); if (length > space_length) length = rb->buffer_size; if (rb->buffer_size - rb->write_index > length) { /* read_index - write_index = empty space */ memcpy(&rb->buffer_ptr[rb->write_index], ptr, length); /* this should not cause overflow because there is enough space for * length of data in current mirror */ rb->write_index += length; if (length > space_length) rb->read_index = rb->write_index; return length; } memcpy(&rb->buffer_ptr[rb->write_index], &ptr[0], rb->buffer_size - rb->write_index); memcpy(&rb->buffer_ptr[0], &ptr[rb->buffer_size - rb->write_index], length - (rb->buffer_size - rb->write_index)); /* we are going into the other side of the mirror */ rb->write_mirror = ~rb->write_mirror; rb->write_index = length - (rb->buffer_size - rb->write_index); if (length > space_length) { rb->read_mirror = ~rb->read_mirror; rb->read_index = rb->write_index; } return length; } RTM_EXPORT(rt_ringbuffer_put_force);``` 按理说如果put的数据大于ringbuffer的size或者剩余空间时,将会丢弃最老的数据。 而这里的实现首先将put的length给截短了,这就导致put的数据被丢弃了后面的,只 put进最前面的那段数据,而其实是尽可能put进后面那段数据。 举例:假如ringbuff的buffer size是5。put_force是1 2 3 4 5 6 7 8 9 10这10个数据。 那么应该是put 6 7 8 9 10而不是put 1 2 3 4 5.
查看更多
4
个回答
默认排序
按发布时间排序
geniusgogo
认证专家
2018-05-25
这家伙很懒,什么也没写!
另外发现一个内存错误的BUG。 if (length > space_length) length = rb->buffer_size; 看是这一句。 这里当需要put的长度大于剩余的空间则将length等于ringbuffer的buffer_size。 而这个length也许是小于buffer_size的。这就导致后续的put反而比ptr的实际数据长。
geniusgogo
认证专家
2018-05-25
这家伙很懒,什么也没写!
[i=s] 本帖最后由 geniusgogo 于 2018-5-25 09:48 编辑 [/i] >另外发现一个内存错误的BUG。 >if (length > space_length) > length = rb->buffer_size; --- 提供修复代码: ``` if (length > rb->buffer_size) { ptr += length - rb->buffer_size; length = rb->buffer_size; } ```
geniusgogo
认证专家
2018-05-25
这家伙很懒,什么也没写!
原来是我的branch没更新,草,好几个月了!
bondxie
2018-05-27
这家伙很懒,什么也没写!
我也发现这个问题了。 我在网盘下载的就有bug, 在github上下载的就正常, 对比了一下, 确实有修改。 建议大家在github上下载。
撰写答案
登录
注册新账号
关注者
1
被浏览
2.4k
关于作者
geniusgogo
这家伙很懒,什么也没写!
提问
42
回答
157
被采纳
7
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
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
CherryUSB的bootuf2配置
2
在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
3
GD32F450 片内 flash驱动适配
4
STM32H7R7运行CherryUSB
5
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
热门标签
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
UART
WIZnet_W5500
ota在线升级
PWM
freemodbus
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
6
次点赞
YZRD
2
篇文章
5
次点赞
lizimu
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部