Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
dhcp获取IP地址
WIZnet_W5500
W5500 IP 续约会重新 DHCP_init() 的问题
发布于 2022-01-13 19:35:07 浏览:1804
订阅该版
发现设备偶尔会有丢帧的问题,用 Wireshark 抓包发现了以下的问题 ![image.png](https://oss-club.rt-thread.org/uploads/20220113/281ed1622a0ac990029eeb4aa118fcd4.png.webp) 正好我的路由器的租约时间也是1小时,感觉每次续约的过程中会重新 DHCP 看了下源码,感觉这里是有BUG 排查过程: 工作流初始化:将 wiz_dhcp_work 加入到工作流中,time时间一到,就会自动调用 ![image.png](https://oss-club.rt-thread.org/uploads/20220113/a4009350a26eb367c87f2b19081d6f1a.png) 同时此函数包含 DHCP_run() ![image.png](https://oss-club.rt-thread.org/uploads/20220113/27126e04cbf8d9e0f6b022d60e7e93f8.png) DHCP_run()中的 dhcp_state 分支源头:`INIT -> DISCOVER -> REQUEST -> LEASED -> REREQUEST -> CHANGED` 但是 DHCP_run() 中 一旦进入到 LEASED 分支,就会返回 DHCP_IP_LEASED, 从而在 wiz_dhcp_work 的 LEASED分支中关闭 DHCP定时器,退出当前任务 等待1/2租约时间,又重启该任务,然后又重新 DHCP_init() , 最终导致掐断了正常的 ip 续约逻辑 ![image.png](https://oss-club.rt-thread.org/uploads/20220113/386bf167bbceaf195834a4f544f558a2.png) 不知道为什么进入到 LEASED 中需要关闭 DHCP的定时器 和 DHCP_stop()? 但是可以看出,应该是希望等到 1/2租约时间到后,重新进入 DHCP_run() 中 跳到 REREQUEST 过程中 续约ip ,当然这里还需要对 DHCP_init() 进行条件约束 避免重新DHCP。 **以下是修改后的代码** ```c static void wiz_dhcp_work(struct rt_work *dhcp_work, void *dhcp_work_data) { #define WIZ_DHCP_WORK_RETRY 3 /* DHCP will have 3 times handshake */ #define WIZ_DHCP_WORK_RETRY_TIME (2 * RT_TICK_PER_SECOND) static int wiz_dhcp_retry_times = WIZ_DHCP_WORK_RETRY * 20; RT_ASSERT(dhcp_work_data != RT_NULL); struct netdev *netdev = (struct netdev *)dhcp_work_data; uint8_t dhcp_times = 0; static uint8_t data_buffer[1024]; static uint32_t dhcp_status = 0; if(dhcp_status == 0) { rt_timer_start(dhcp_timer); DHCP_init(WIZ_DHCP_SOCKET, data_buffer); } while (1) { /* DHCP start, return DHCP_IP_LEASED is success. */ dhcp_status = DHCP_run(); switch (dhcp_status) { case DHCP_IP_ASSIGN: case DHCP_IP_CHANGED: { /* to update netdev information */ wiz_netdev_info_update(netdev, RT_FALSE); break; } case DHCP_IP_LEASED: { int hour, min; // DHCP_stop(); // rt_timer_stop(dhcp_timer); /* to update netdev information */ wiz_netdev_info_update(netdev, RT_FALSE); /* reset the previous work configure */ rt_work_cancel(dhcp_work); /* according to the DHCP leaset time, config next DHCP produce */ rt_work_submit(dhcp_work, (getDHCPLeasetime() / 2) * RT_TICK_PER_SECOND); hour = getDHCPLeasetime() / 3600; min = (getDHCPLeasetime() % 3600) / 60; LOG_D("DHCP countdown to lease renewal [%dH: %dMin], retry time[%04d]", hour, min, dhcp_times); //wiz_dhcp_retry_times = dhcp_times; wiz_dhcp_retry_times = 3; return; } case DHCP_STOPPED: DHCP_stop(); rt_timer_stop(dhcp_timer); return; case DHCP_FAILED: { dhcp_times = wiz_dhcp_retry_times; LOG_E("dhcp handshake failed!"); break; } default: { dhcp_times++; /* DHCP_RUNNING status, include don't receive data */ rt_thread_mdelay(10); break; } } if (dhcp_times >= wiz_dhcp_retry_times) { LOG_D("DHCP work in %d seconds, [%03d|%03d]", WIZ_DHCP_WORK_RETRY_TIME / RT_TICK_PER_SECOND, dhcp_times, wiz_dhcp_retry_times); /* if dhcp service is too busy to manger IP, increase retry times */ wiz_dhcp_retry_times = wiz_dhcp_retry_times + WIZ_DHCP_WORK_RETRY; dhcp_status = 0; DHCP_stop(); rt_timer_stop(dhcp_timer); rt_work_cancel(dhcp_work); /* according to WIZ_DHCP_WORK_RETRY_TIME, reconfigure in 2 seconds */ rt_work_submit(dhcp_work, WIZ_DHCP_WORK_RETRY_TIME); break; } } } ``` **测试结果:** 可以看出确实不会 再重新DHCP 来续约ip,但是没有抓到请求的过程,但是打断点又确实有进入`send_DHCP_REQUEST();` 不知道是不是请求的过程没经过电脑的网卡所以抓不到? ![image.png](https://oss-club.rt-thread.org/uploads/20220113/deaa0b2bf831100c601c1e74b4f52fab.png)
查看更多
1
个回答
默认排序
按发布时间排序
aingsu
2022-01-13
这家伙很懒,什么也没写!
请移步 [bug:w5500 DHCP续租逻辑问题](https://club.rt-thread.org/ask/question/435491.html)
撰写答案
登录
注册新账号
关注者
0
被浏览
1.8k
关于作者
aingsu
这家伙很懒,什么也没写!
提问
5
回答
3
被采纳
0
关注TA
发私信
相关问题
1
W5500软件包开机无法解析link.rt-thread.org
2
W5500 如何实现断开重连?
3
W5500初始化全部都OK,电脑能ping板子,板子ping不通电脑
4
w5500 编译错误
5
求个SPI上挂W5500、Max6675两个设备的驱动例子
6
TFTP与W5500配合能传文件但无内容
7
wiznet(W5500) 设置MAC
8
SPI总线挂接2个W5500以太网芯片
9
多网卡建立链路问题,求官方解答
10
为什么W5500一直显示无法挂载
推荐文章
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
次被采纳
a1012112796
13
个答案
1
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
6
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部