Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
dhcp
WIZnet_W5500
W5500 IP 续约会重新 DHCP_init() 的问题
发布于 2022-01-13 19:35:07 浏览:1062
订阅该版
发现设备偶尔会有丢帧的问题,用 Wireshark 抓包发现了以下的问题  正好我的路由器的租约时间也是1小时,感觉每次续约的过程中会重新 DHCP 看了下源码,感觉这里是有BUG 排查过程: 工作流初始化:将 wiz_dhcp_work 加入到工作流中,time时间一到,就会自动调用  同时此函数包含 DHCP_run()  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 续约逻辑  不知道为什么进入到 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();` 不知道是不是请求的过程没经过电脑的网卡所以抓不到? 
查看更多
1
个回答
默认排序
按发布时间排序
aingsu
2022-01-13
这家伙很懒,什么也没写!
请移步 [bug:w5500 DHCP续租逻辑问题](https://club.rt-thread.org/ask/question/435491.html)
撰写答案
登录
注册新账号
关注者
0
被浏览
1.1k
关于作者
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
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
五分钟玩转RT-Thread新社区
5
国产MCU移植系列教程汇总,欢迎查看!
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
寻找大牛移植rt-smart到milk-v
2
【2023RT-Thread全球技术峰会】解决物联网终端应用多样化难题的软件架构:xiotman (文末送书)
3
【Matter】Nordic-Mattter开发大纲
4
rt-thread on risc-v相关汇总(截止2023-5-31)
5
【GITHUB】快速入门教程分享(面向github小白)
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
AT
FinSH
ART-Pi
Bootloader
CAN总线
Hardfault
文件系统
USB
DMA
RT-Thread
线程
SCons
RT-Thread Nano
stm32
MQTT
ESP8266
ota
WIZnet_W5500
RTC
rt-smart
UART
flash
rtthread
packages_软件包
freemodbus
潘多拉开发板_Pandora
I2C
cubemx
FAL
定时器
PWM
BSP
AB32VG1
ADC
中断
消息队列_msg_queue
SDIO
msh
keil
Debug
编译报错
socket
LVGL
SFUD
C++_cpp
本月问答贡献
RTT_逍遥
5
个答案
2
次被采纳
小小李sunny
6
个答案
1
次被采纳
xiaorui
3
个答案
1
次被采纳
JonasWen
3
个答案
1
次被采纳
rcp
3
个答案
1
次被采纳
本月文章贡献
燕十三
2
篇文章
7
次点赞
jaffer
1
篇文章
8
次点赞
kurisaW
1
篇文章
5
次点赞
小权一句两句
1
篇文章
4
次点赞
喵小黑
1
篇文章
4
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部