首页 > 其他 > 详细

DWM1000 巧用Status 快速Debug

时间:2018-11-29 22:54:06      阅读:250      评论:0      收藏:0      [点我收藏+]

在Debug DWM1000 的时候,可以巧用Status 加快Debug,例如如下代码

 1 if (status_reg & SYS_STATUS_RXFCG)
 2 {
 3   ……
 4 }
 5 else
 6  {
 7     sprintf(dist_str, "%08x",status_reg);
 8     OLED_ShowString(0, 2,"            "); 
 9     OLED_ShowString(0, 2,dist_str);
10     dwt_write32bitreg(SYS_STATUS_ID, SYS_STATUS_ALL_RX_ERR);
11 }

据正确只有一种可能,而数据接收出错,则有很多种可能,例如可能RX timeout,数据帧错误等等,不同问题Debug 出发点不一样,Rx timeout 可能是RX延时太短,或者对方没有发送数据,而帧错误可能环境差或者距离太远等等。

但是,在DWM1000 代码中,只有成功标志 SYS_STATUS_RXFCG  和错误标志集SYS_STATUS_ALL_RX_ERR

这里将status_reg 转换成16进制,然后放到OLED上显示,然后对应代码看到底是哪种错误

 

其它比较重要方法:LED灯光法,在不同代码中放置不同LED灯,通过LED灯指示来观察程序实际走向。

 

注意事项: 尽量不要将OLED显示以及串口发送数据(中断除外)放到DWM1000 主程序中,因为DWM1000 有着极高时间依赖特性,OLED 和串口发送数据会占用大量时间。 上面else 类似代码除外

 

蓝点DWM1000 模块已经打样测试完毕,有兴趣的可以申请购买了,更多信息参见 蓝点论坛 

技术分享图片

DWM1000 巧用Status 快速Debug

原文:https://www.cnblogs.com/tuzhuke/p/10041362.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!