Toggle navigation
首页
问答
文章
话题
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
tcp
etx和erx线程作用
发布于 2021-09-01 08:36:15 浏览:427
etx和erx线程有什么作用,不使用者两个线程有什么区别和影响
查看更多
3
个回答
默认排序
按发布时间排序
fhqmcu
认证专家
2021-09-01
个人博客:https://blog.csdn.net/fhqlongteng
完成低层以太网数据的接收与发送,都不使用的话,会影响以太网接收数据的速度,这里使用了线程同时使用数据缓冲队列,增加了数据的缓冲能力
Jone
2021-09-01
写了还是懒
认同@fhqmcu 的解释 我从数据接收方向来阐述一下接收流程,首先是数据走向: > 1硬件Phy接口 -> 2erx -> 3LWIP -> 4APP 流程: > 1中接收到数据通过pbuf_malloc申请空间存放数据,然后通过邮箱把数据发给2,2把数据交给3、4,3、4处理完成后pbuf_free 如果3、4处理数据用时较长,2可以缓存1过来的数据并依次处理,没2的话数据堵在了1,而1的资源一般不会太大,就会出现overrun
出出啊
2021-09-01
It is Not the Mountain We Conquer, but Ourselves
我不同意楼上专家的观点,增加的俩线程并没有做任何缓存或者速度提升优化,反而,增加了处理逻辑复杂度。 以 etx 为例。`ethernetif_linkoutput` 函数主要操作如下: ```c if (rt_mb_send(ð_tx_thread_mb, (rt_uint32_t) &msg) == RT_EOK) { /* waiting for ack */ rt_sem_take(&(enetif->tx_ack), RT_WAITING_FOREVER); } ``` 仅仅发送一个邮箱,然后等待一个 信号量。这个信号量从哪儿来?看下面的 etx 线程入口函数。 ```c static void eth_tx_thread_entry(void* parameter) { struct eth_tx_msg* msg; while (1) { if (rt_mb_recv(ð_tx_thread_mb, (rt_ubase_t *)&msg, RT_WAITING_FOREVER) == RT_EOK) { struct eth_device* enetif; RT_ASSERT(msg->netif != RT_NULL); RT_ASSERT(msg->buf != RT_NULL); enetif = (struct eth_device*)msg->netif->state; if (enetif != RT_NULL) { /* call driver's interface */ if (enetif->eth_tx(&(enetif->parent), msg->buf) != RT_EOK) { /* transmit eth packet failed */ } } /* send ACK */ rt_sem_release(&(enetif->tx_ack)); } } } ``` etx 等待 `ethernetif_linkoutput` 的邮件消息,然后调用 eth 驱动接口函数,完成后释放信号量给 `ethernetif_linkoutput`一个应答。 从这里看,用上这个线程,需要额外增加两次 ipc 消息。 去掉 etx 之后呢? ```c static err_t ethernetif_linkoutput(struct netif *netif, struct pbuf *p) { struct eth_device* enetif; RT_ASSERT(netif != RT_NULL); enetif = (struct eth_device*)netif->state; if (enetif->eth_tx(&(enetif->parent), p) != RT_EOK) { return ERR_IF; } return ERR_OK; } ``` 唯一不同的是,使用线程后,收发操作 eth 驱动都在一个线程里进行的,如果去掉就有可能多个应用线程同时发送数据,导致多个线程竞争 eth 驱动的结果出现。 但是,这个可以经过优化应用层业务逻辑规避。
撰写答案
登录
注册新账号
关注者
0
被浏览
427
关于作者
cris8259
This guy hasn't written anything yet
提问
13
回答
20
被采纳
0
关注TA
发私信
相关问题
1
freemodbus tcp
2
stm32f103 LWIP 2.0.2 TCP收发问题
3
AT_DEVICE TCP 接收大文件失败!
4
RT thread freemobus tcp通讯问题
5
hard fault on thread: tcpip
6
RT系统TCP收数据速度慢
7
TCP Client 断线重连
8
TCP数据包多包重合的问题
9
rtthread simulator中能够使用WIN10中得TCP/IP服务吗
10
lwip 跨网段ping不通的问题
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
五分钟玩转RT-Thread新社区
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
国产MCU移植系列教程汇总,欢迎查看!
最新文章
1
MQTT协议栈的原理及交互流程图
2
LVGL例程学习——get_started
3
瑞萨RA6M4 SPI0 W5500
4
这才是优美的文件系统挂载方式,亲测有效
5
基于RT-Thread+RA6M4的智能安防系统
热门标签
RT-Thread Studio
串口
LWIP
FinSH
ART-Pi
Env
AT
SPI
Bootloader
USB
Hardfault
CAN
文件系统
studio
DMA
RT-Thread
线程
Nano
stm32
ota
MQTT
SCons
rtthread
ESP8266
freemodbus
I2C
UART
软件包
flash
cubemx
RTC
定时器
W5500
FAL
BSP
rt-smart
rtt
PWM
AB32VG1
ADC
编译报错
msh
socket
SDIO
C++
dfs
at_device
SFUD
MicroPython
RT-Studio
本月问答贡献
小小李sunny
38
个答案
10
次被采纳
出出啊
29
个答案
7
次被采纳
lchnu
11
个答案
5
次被采纳
红枫
22
个答案
4
次被采纳
rcp
14
个答案
4
次被采纳
本月文章贡献
张世争
11
篇文章
30
次点赞
吉利咕噜2022
4
篇文章
5
次点赞
crystal266
3
篇文章
7
次点赞
Liutao
3
篇文章
4
次点赞
RTT_逍遥
2
篇文章
11
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部