完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
这是程序源码:int main(void)
{ mainInit(); delay_ms(2000); delay_ms(2000); OSInit(); OSTaskCreate(start_task, (void *) 0,(OS_STK *) &START_TASK_STK[START_STK_SIZE - 1], START_TASK_PRIO); OSStart(); } void start_task(void *pdata) { u8 *sta; DEBUG("PC_process", " enter start_task function !!!"); OSStatInit(); while (1) { delay_ms(2000); DEBUG("PC_process", " sta = %d",*sta); } } 下面是用cmBackTrace 工具 定位出来的错误信息: E:工作MCU 资料STM32 资料cmBacktrack_project_testcmbackTraceonline_gprsObjects>addr2line -e charger.axf -a -f 08000352 0800252b 0800428f 080002ff 0x08000352 OSStartHighRdy E:工作MCU 资料stm32 资料cmBacktrack_project_testcmbackTraceonline_gprs/..src_commonucosiiport/os_cpu_a.asm:110 0x0800252b OSStart E:宸ヤ綔MCU 璧勬枡stm32 璧勬枡cmBacktrack_project_testcmbackTraceonline_gprs/..src_commonucosiicore/os_core.c:830 0x0800428f main E:宸ヤ綔MCU 璧勬枡stm32 璧勬枡cmBacktrack_project_testcmbackTraceonline_gprs/srcmain.c:52 0x080002ff __rt_entry_main 通过 工具定位出来的是 main.c 中 的 第 52 行有问题, 52 行对应的是 OSStart(); 但是程序的错误 应该在 DEBUG("PC_process", " sta = %d",*sta); 为什么定位的 不正确啊??? 这是什么原因??? |
|
相关推荐
3个回答
|
|
|
|
|
|
难道是你指针使用的有问题?那你这个指针指到哪里去了 或者你强行换一换这个变量类型 别用指针了试试
|
|
|
|
空指针错误
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
hal库中i2c卡死在HAL_I2C_Master_Transmit
815 浏览 1 评论
LL库F030进行3个串口收发,2个串口为232,一个为485,长时间后,会出现串口1停止运行,另外两个正常,只有重启复原
1360 浏览 1 评论
506 浏览 0 评论
992 浏览 0 评论
1119 浏览 1 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-2 10:18 , Processed in 1.340369 second(s), Total 75, Slave 59 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号