lwip 开发 sntp 与 tcp 不能同时工作的奇怪问题
生活随笔
收集整理的這篇文章主要介紹了
lwip 开发 sntp 与 tcp 不能同时工作的奇怪问题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
最近基于 stm32f107??做lwip 網絡開發,?開啟?dhcp?和?sntp?服務,?一個udp?并且是多播 和?一個tcp,開發是基于 stm32cube 工具生成的代碼,LWIP 配置如下:
工作時出現了很奇怪的問題:
?如果先開?sntp?? ?( 執行sntp_init()?)?那么 后面的?tcp?過一段時間后會無法主動發送數據,
如果先開?tcp ,?則?sntp?只能執行一次,不根據設置的?SNTP_UPDATE_DELAY?定時同步時間。
仿真發現 ,如果先開 sntp ,則后面tcp 的 tcp_poll 回調函數無法回調,如果先開 tcp 則 sntp 的回調函數無法被執行。
問題很奇怪,總之誰先初始化,誰就能正常工作,誰后初始化,誰就有異常!
懷疑過??很多東西,曾把?tcp?與?udp?的數量增加到?5,5,或,5,6?,都還是有一樣的問題。?
最后懷疑是回調定時器的個數可能不夠用,找了上圖配置界面沒找到相關的設置參數,最后在?lwip 源碼中的 opt.h 中找到
#if !defined MEMP_NUM_SYS_TIMEOUT || defined __DOXYGEN__ #define MEMP_NUM_SYS_TIMEOUT ? ? ? ? ? ?(LWIP_TCP + IP_REASSEMBLY + LWIP_ARP + (2*LWIP_DHCP) + LWIP_AUTOIP + LWIP_IGMP + LWIP_DNS + (PPP_SUPPORT*6*MEMP_NUM_PPP_PCB) + (LWIP_IPV6 ? (1 + LWIP_IPV6_REASS + LWIP_IPV6_MLD) : 0)) #endif發現沒有 LWIP_SNTP 項,果斷加上 LWIP_SNTP? :
#if !defined MEMP_NUM_SYS_TIMEOUT || defined __DOXYGEN__ #define MEMP_NUM_SYS_TIMEOUT (LWIP_TCP + IP_REASSEMBLY + LWIP_ARP + (2*LWIP_DHCP) + LWIP_AUTOIP + LWIP_SNTP + LWIP_IGMP + LWIP_DNS + (PPP_SUPPORT*6*MEMP_NUM_PPP_PCB) + (LWIP_IPV6 ? (1 + LWIP_IPV6_REASS + LWIP_IPV6_MLD) : 0)) #endif重新編譯工程,問題完美解決!!SNTP 與 TCP 均能正常工作,回調任務都能正常回調。
?
?
?
總結
以上是生活随笔為你收集整理的lwip 开发 sntp 与 tcp 不能同时工作的奇怪问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: keil 5 出现 error: #6
- 下一篇: 基于stm32f107 stm32cu