3752|6

69

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

一个vxworks的问题,请大家帮帮忙 [复制链接]

 我在调试单板的时候发现了一个问题请大家帮忙看看怎么解决。

单板上的应用程序是一个大循环,由于需要死机重启的功能,还设置了看门狗,定时4秒。单板在测试的时候会不断的输出调试信息,而且信息量很大。如果打开了telnet连接,此时telnet就是标准输出了,单板跑几天都没有问题。但是如果在输出调试信息的时候关闭了telnet,单板跑一会儿就死掉重启了。重启的原因应该就是看门狗超时了。
于是我怀疑是打印信息的关系,在一条printf()语句的前后添加了时间计数,显示的结果是:打开telnet时,printf语句的执行时间不超过1ms,但是如果关闭了telnet(没有任何标准输出了),printf语句的执行时间超过了20ms。显然在里面有超时机制在起作用。我想问的是,怎样不让printf语句等待而直接返回?

最新回复

问题解决了。把标准IO重新定向就可以了。 多谢楼上各位的帮助。 回复nanjingzg:     用的是硬件看门狗,使用CTLD做的,具体怎么做的是硬件人员完成的,我也不太清楚。应该是把一个CPLD引脚连接到了控制器的复位引脚上。  详情 回复 发表于 2007-11-5 08:14
点赞 关注
 

回复
举报

76

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
没人知道怎么解决吗?
 
 
 

回复

68

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
用logMsgDAYIN
 
 
 

回复

80

帖子

0

TA的资源

一粒金砂(初级)

4
 
logMsg不会阻塞,或者自己写打印函数
 
 
 

回复

63

帖子

0

TA的资源

一粒金砂(初级)

5
 
把 printf 换掉,自己定义 dbg 消息输出

#ifdef DBG
#define dbgMsg(...) printf
#else
#define dbgMsg()
#endif
 
 
 

回复

78

帖子

0

TA的资源

一粒金砂(初级)

6
 
请问楼主用的是硬件的看门狗,还是VxWorks的看门狗啊?
我也想来实现死机重启,不知道该怎么做?先谢谢了!
 
 
 

回复

64

帖子

0

TA的资源

一粒金砂(初级)

7
 
问题解决了。把标准IO重新定向就可以了。

多谢楼上各位的帮助。

回复nanjingzg:
    用的是硬件看门狗,使用CTLD做的,具体怎么做的是硬件人员完成的,我也不太清楚。应该是把一个CPLD引脚连接到了控制器的复位引脚上。
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/7 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表