系统卡在uxListRemove函数中的“pxItemToRemove-pxNext-pxPrevious = pxItemToRemove-pxPrevious”其中一个原因

好久不见,时隔一年又重新开始写文章了,今天分享的是在使用FreeRTOS时候遇到的一个BUG。话不多说,开门见山:

先看错误:错误是一开始发现系统一直在list.c中的uxListRemove任务下跑,不管怎么调试,一直在这里面;

该函数为:

UBaseType_t uxListRemove( ListItem_t * const pxItemToRemove )
{
/* The list item knows which list it is in.  Obtain the list from the list
item. */
List_t * const pxList = ( List_t * ) pxItemToRemove->pvContainer;

	pxItemToRemove->pxNext->pxPrevious = pxItemToRemove->pxPrevious;
	pxItemToRemove->pxPrevious->pxNext = pxItemToRemove->pxNext;

	/* Only used during decision coverage testing. */
	mtCOVERAGE_TEST_DELAY();

	/* Make sure the index is left pointing to a valid item. */
	if( pxList->pxIndex == pxItemToRemove )
	{
		pxList->pxIndex = pxItemToRemove->pxPrevious;
	}
	else
	{
		mtCOVERAGE_TEST_MARKER();
	}

	pxItemToRemove->pvContainer = NULL;
	( pxList->uxNumberOfItems )--;

	return pxList->uxNumberOfItems;
}

而上述这个任务是为了移除当前这个任务,而为什么会一直运行在这个函数,通过调试的call back发现,在进入这个函数前系统是先跑到了vTaskDelay函数,而为什么vTaskDelay调用uxListRemove无法成功呢?

是因为我发现自己一不小心在vTaskStartScheduler前调用了vTaskDelay,所以系统无法进行任务切换,所以才会卡在 uxListRemove中;

到了这里小伙伴应该发现了,vTaskDelay函数是非阻塞延时,调用这个会将任务加入等待队列,然后将任务从就绪任务队列中移除,而因为没有开启调度,所以无法成功进行,于是卡在了 uxListRemove中;

所以如果有出现这种情况的,可以尝试该解决方法解决:就是在任务调度(vTaskStartScheduler)开始前禁止调用Freertos提供的非阻塞延时函数vTaskDelay等。

好了今天的分享就到这里了,下期再见~

本人水平有限,上述信息仅供学习参考,如有错误和不妥之处,请多多指教。
另外创作不易,请勿抄袭,如果有帮助到大家的话希望大家可以点个赞和收藏,谢谢~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

OMGMac

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值