Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
网络
双网口_多网口_多IP
双网口调试出现bug(单网口调试无问题)
发布于 2023-04-10 20:57:41 浏览:753
订阅该版
cpu:stm32F407VE os:rt-thread 问题:现在已按照官方文档移植lan8720和ksz8851网络芯片成功,单独调试每一个网络芯片,通讯都正常;双网口同时通讯,大多数时候,在客户端连接时,导致板件死机,死机地方为ethernetif.c中的接收函数eth0_rx_thread_entry和eth1_rx_thread_entry(大多时候在此函数),报错地方为函数中的LWIP_ASSERT("Should not happen!\n",0),已知为线程报超时导致,具体原因不清楚,社区大神能给出一些建议吗? ```c int eth_system_device_init_private(void) { rt_err_t result = RT_EOK; /**********************************>>ksz8851<<**********************************/ /* initialize Rx thread. */ #ifndef LWIP_NO_RX_THREAD /* initialize mailbox and create Ethernet Rx thread */ result = rt_mb_init(ð0_rx_thread_mb, "e0rxmb", ð0_rx_thread_mb_pool[0], sizeof(eth0_rx_thread_mb_pool)/4, RT_IPC_FLAG_FIFO); RT_ASSERT(result == RT_EOK); result = rt_thread_init(ð0_rx_thread, "e0rx", eth0_rx_thread_entry, RT_NULL, ð0_rx_thread_stack[0], sizeof(eth0_rx_thread_stack), RT_ETHERNETIF_THREAD_PREORITY, 16); RT_ASSERT(result == RT_EOK); result = rt_thread_startup(ð0_rx_thread); RT_ASSERT(result == RT_EOK); #endif /* initialize Tx thread */ #ifndef LWIP_NO_TX_THREAD /* initialize mailbox and create Ethernet Tx thread */ result = rt_mb_init(ð0_tx_thread_mb, "e0txmb", ð0_tx_thread_mb_pool[0], sizeof(eth0_tx_thread_mb_pool)/4, RT_IPC_FLAG_FIFO); RT_ASSERT(result == RT_EOK); result = rt_thread_init(ð0_tx_thread, "e0tx", eth0_tx_thread_entry, RT_NULL, ð0_tx_thread_stack[0], sizeof(eth0_tx_thread_stack), RT_ETHERNETIF_THREAD_PREORITY, 16); RT_ASSERT(result == RT_EOK); result = rt_thread_startup(ð0_tx_thread); RT_ASSERT(result == RT_EOK); #endif /**********************************>>ksz8851<<**********************************/ /**********************************>>lan8720<<**********************************/ /* initialize Rx thread. */ #ifndef LWIP_NO_RX_THREAD /* initialize mailbox and create Ethernet Rx thread */ result = rt_mb_init(ð1_rx_thread_mb, "e1rxmb", ð1_rx_thread_mb_pool[0], sizeof(eth1_rx_thread_mb_pool)/4, RT_IPC_FLAG_FIFO); RT_ASSERT(result == RT_EOK); result = rt_thread_init(ð1_rx_thread, "e1rx", eth1_rx_thread_entry, RT_NULL, ð1_rx_thread_stack[0], sizeof(eth1_rx_thread_stack), RT_ETHERNETIF_THREAD_PREORITY, 16); RT_ASSERT(result == RT_EOK); result = rt_thread_startup(ð1_rx_thread); RT_ASSERT(result == RT_EOK); #endif /* initialize Tx thread */ #ifndef LWIP_NO_TX_THREAD /* initialize mailbox and create Ethernet Tx thread */ result = rt_mb_init(ð1_tx_thread_mb, "e1txmb", ð1_tx_thread_mb_pool[0], sizeof(eth1_tx_thread_mb_pool)/4, RT_IPC_FLAG_FIFO); RT_ASSERT(result == RT_EOK); result = rt_thread_init(ð1_tx_thread, "e1tx", eth1_tx_thread_entry, RT_NULL, ð1_tx_thread_stack[0], sizeof(eth1_tx_thread_stack), RT_ETHERNETIF_THREAD_PREORITY, 16); RT_ASSERT(result == RT_EOK); result = rt_thread_startup(ð1_tx_thread); RT_ASSERT(result == RT_EOK); #endif /**********************************>>lan8720<<**********************************/ return (int)result; } /* Ethernet Rx Thread */ static void eth0_rx_thread_entry(void* parameter) { struct eth_device* device; while (1) { extern int g_udtaskflag; g_udtaskflag = 3; if (rt_mb_recv(ð0_rx_thread_mb, (rt_ubase_t *)&device, RT_WAITING_FOREVER) == RT_EOK) { g_udtaskflag = 3*9; struct pbuf *p; /* check link status */ if (device->link_changed) { int status; rt_uint32_t level; level = rt_hw_interrupt_disable(); status = device->link_status; device->link_changed = 0x00; rt_hw_interrupt_enable(level); if (status) netifapi_netif_set_link_up(device->netif); else netifapi_netif_set_link_down(device->netif); g_udtaskflag = 3*10; } /* receive all of buffer */ while (1) { if(device->eth_rx == RT_NULL) break; p = device->eth_rx(&(device->parent)); g_udtaskflag = 3*11; if (p != RT_NULL) { #if 1 char *pbuf; pbuf = (char*)p->payload; uint16_t type = (pbuf[12]<<8)+(pbuf[13]<<0); switch (type) { case 0x0806: //ARP device->netif = &Mnetif0; break; case 0x0800: //IPV4 device->netif = &Mnetif0; break; } #endif /* notify to upper layer */ if( device->netif->input(p, device->netif) != ERR_OK ) { LWIP_DEBUGF(NETIF_DEBUG, ("ethernetif_input: Input error\n")); pbuf_free(p); p = NULL; } g_udtaskflag = 3*12; } else break; } } else { g_udtaskflag = 3*13; LWIP_ASSERT("Should not happen!\n",0); } } } ```
查看更多
3
个回答
默认排序
按发布时间排序
hancanglong
2023-04-10
这家伙很懒,什么也没写!
自己先占个沙发,跪求社区大神给解惑
aozima
2023-04-11
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
2个网卡驱动不是独立的么? 为什么会在 ethernetif.c 中添加 eth0_rx_thread_entry和eth1_rx_thread_entry? 正常多网卡是不需要动 ethernetif.c 的。 这块自己重新梳理移植吧,不然你贴个自己魔改的代码别人也没法看。
yc961213911
2023-04-11
这家伙很懒
不知道这个芯片和W5500差别,要不就自己用hal库做个驱动,不接入RTT的框架
撰写答案
登录
注册新账号
关注者
0
被浏览
753
关于作者
hancanglong
这家伙很懒,什么也没写!
提问
1
回答
2
被采纳
0
关注TA
发私信
相关问题
1
两个tcpclient同时通讯可以吗?
2
SO_BINDTODEVICE 未定义该如何解决
3
RTT是否支持注册多个网卡,随意切换?
4
如何在rtt上实现多网口通信
5
SAL框架添加多个同类型网卡问题?
6
多网卡时ifconfig只有一个网卡处于linkup状态
7
多网卡情况下如何判断是哪个网卡接收到的数据包
8
多网卡时网页服务器无法访问
9
多网卡同时使用的问题
10
多网卡情况下如果做到哪个网卡优先通信
推荐文章
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
GD32F450 片内 flash驱动适配
2
STM32H7R7运行CherryUSB
3
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
4
使用RC522软件包驱动FM1722
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
UART
WIZnet_W5500
ota在线升级
freemodbus
PWM
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
篇文章
5
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部