MCU_STM32CUBEMX v5.5.0的一个BUG:ethernetif_input引起进入HardFault_Handler

STM32CUBEMX v5.5.0 配置FreeRTOS + LWIP,在MX_LWIP_Init()中的倒数第二句,

osThreadNew(ethernetif_input, &link_arg, &attributes);

这里是错误的,link_arg显然不能是ethernetif_input的参数,

正确的用法是

osThreadNew(ethernetif_set_link, &link_arg, &attributes);

不过,如果你下载最新版STM32CUBEMX的话,这个BUG已经修复了。

顺便说两句,发现这个BUG的原因,是仿真调试时会在ethernetif_input中因为指针错误而直接进入HardFault_Handler。好奇在网上查找了一下,发现有不少在启动FreeRTOS+LWIP时在prvStartFirstTask中调用“svc 0"这条指令时会进入HardFault,当然本质上是SVC中断进入vPortSVCHandler中断服务,中断服务调用第一个最近的Task就是这个ethernetif_set_link,这个Task也是MX_LWIP_Init()中最后加入的那个,也是用户创建的Task的前一个(使用默认优先级的情况)。

不过貌似现在最新版已经把MX_LWIP_INIT移到第一个任务里去了。

 

posted @ 2020-05-07 19:54  SpaceVision  阅读(167)  评论(0编辑  收藏  举报