lwip 开发 sntp 与 tcp 不能同时工作的奇怪问题
最近基于 stm32f107??做lwip 網(wǎng)絡(luò)開發(fā),?開啟?dhcp?和?sntp?服務(wù),?一個(gè)udp?并且是多播 和?一個(gè)tcp,開發(fā)是基于 stm32cube 工具生成的代碼,LWIP 配置如下:
工作時(shí)出現(xiàn)了很奇怪的問題:
?如果先開?sntp?? ?( 執(zhí)行sntp_init()?)?那么 后面的?tcp?過一段時(shí)間后會(huì)無(wú)法主動(dòng)發(fā)送數(shù)據(jù),
如果先開?tcp ,?則?sntp?只能執(zhí)行一次,不根據(jù)設(shè)置的?SNTP_UPDATE_DELAY?定時(shí)同步時(shí)間。
仿真發(fā)現(xiàn) ,如果先開 sntp ,則后面tcp 的 tcp_poll 回調(diào)函數(shù)無(wú)法回調(diào),如果先開 tcp 則 sntp 的回調(diào)函數(shù)無(wú)法被執(zhí)行。
問題很奇怪,總之誰(shuí)先初始化,誰(shuí)就能正常工作,誰(shuí)后初始化,誰(shuí)就有異常!
懷疑過??很多東西,曾把?tcp?與?udp?的數(shù)量增加到?5,5,或,5,6?,都還是有一樣的問題。?
最后懷疑是回調(diào)定時(shí)器的個(gè)數(shù)可能不夠用,找了上圖配置界面沒找到相關(guān)的設(shè)置參數(shù),最后在?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發(fā)現(xiàn)沒有 LWIP_SNTP 項(xiàng),果斷加上 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 均能正常工作,回調(diào)任務(wù)都能正常回調(diào)。
?
?
?
總結(jié)
以上是生活随笔為你收集整理的lwip 开发 sntp 与 tcp 不能同时工作的奇怪问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: keil 5 出现 error: #6
- 下一篇: 基于stm32f107 stm32cu