产生原因:使用库里的printf函数在输出结束后会调用__used void _mutex_acquire (OS_ID *mutex)这个方法,但是传入的参数mutex并未进行初始化,所有内存访问地址出错。造成hardfault
解决方案:
1.修改RTX_Lib.c文件中的__used void _mutex_acquire (OS_ID *mutex)函数,在函数开始部分手动初始化互斥量。
[mw_shl_code=c,true]__used void _mutex_acquire (OS_ID *mutex) {
/* Acquire a system mutex, lock stdlib resources. */
static int initialized = 0;
if (initialized == 0)
{ /* initialize the mutex */
_mutex_initialize(mutex);
initialized = 1;
}//printf使用进入硬件中断的解决方法
if (runtask_id ()) {
/* RTX running, acquire a mutex. */
mutex_wait (*mutex);
}
}[/mw_shl_code]
2.重定义ferror函数,因为此函数是被库中的ferro函数调用的。
[mw_shl_code=c,true]int ferror(FILE *f)
{
return EOF;
}[/mw_shl_code]
两个方法都可以解决该问题。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
微库的标准库很多函数不支持多线程,具体可以看帮助文档
我在amo那里也有这个问题的论述,我记得楼主位的做法是英文网页里有人的给出的方案,不过其实是有bug的
一周热门 更多>