Brew编译成mod之后 运行出错

luckwangjing 2010-03-22 02:44:27
先看一下伪代码:
int XXXXXX_create(void* pMe)
{
//此处代码省略 .....
DBGPRINTF("*********Log 01********");
DBGPRINTF("*********Log 02********");
DBGPRINTF("*********Log 03********");
//此处代码省略 .....
}

编译成mod文件,然后再真机上运行,用BREWLogger查看Log信息,
发现 输出了
*********Log 01********
*********Log 02********

Log 03还没输出来程序就挂掉了 报Data abort错误,不知道是什么原因,按道理Log 01,Log 02都能打印出来 为什么Log 03打印不出来,而且还报错呢?! ....
...全文
1694 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
visual4825 2010-03-25
  • 打赏
  • 举报
回复
基本上都是函数内,或者函数被调用周边代码出现不具合,和DBGPRINTF应该没啥关系
其log出力是非同期的
hhygcy 2010-03-25
  • 打赏
  • 举报
回复
建议自己写个文件来打log
这种dbgprint有字符数的限制 还有buffered IO的优化
往往不准确
路飞-总裁 2010-03-24
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 sxcnfly 的回复:]
引用 2 楼 luckwangjing 的回复:

引用 1 楼 sxcnfly 的回复:
你用Brew多线程了没有


没有 就是普通调用一个函数 只调用了一次

那就是你DBGPRINTF("*********Log 03********");之后有语句导致死机了,声明一下打印函数不是同步的。
[/Quote]


对就是这样,解决上面LOG打印问题可以将要打印的LOG写入文件中。
twoconk 2010-03-24
  • 打赏
  • 举报
回复
楼上正解~
bxk253387223 2010-03-23
  • 打赏
  • 举报
回复
DBGPRINTF("*********Log 01********");
DBGPRINTF("*********Log 02********");
DBGPRINTF("*********Log 03********");
实际上面这3条语句都已经正常执行过去,只是后面出现了问题,导致CPU挂起,LOG还没有来得及从缓冲区出来。
悠然红茶 2010-03-22
  • 打赏
  • 举报
回复
现象是这样,不过感觉上问题应该出在其他地方。可以把这3条DBGPRINTF注释掉,再试试。
sxcnfly 2010-03-22
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 luckwangjing 的回复:]

引用 1 楼 sxcnfly 的回复:
你用Brew多线程了没有


没有 就是普通调用一个函数 只调用了一次
[/Quote]
那就是你DBGPRINTF("*********Log 03********");之后有语句导致死机了,声明一下打印函数不是同步的。
nuist320 2010-03-22
  • 打赏
  • 举报
回复
顶一下~
luckwangjing 2010-03-22
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 sxcnfly 的回复:]
你用Brew多线程了没有
[/Quote]

没有 就是普通调用一个函数 只调用了一次
sxcnfly 2010-03-22
  • 打赏
  • 举报
回复
你用Brew多线程了没有

2,851

社区成员

发帖
与我相关
我的任务
社区描述
本论坛以AI、WoS 、XR、IoT、Auto、生成式AI等核心板块组成,为开发者提供便捷及高效的学习和交流平台。 高通开发者专区主页:https://qualcomm.csdn.net/
人工智能物联网机器学习 技术论坛(原bbs) 北京·东城区
社区管理员
  • csdnsqst0050
  • chipseeker
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧