上面我们的代码分析到ANCHOR 调用了一次testapprun_s,但是后面退出后发现还是满足while 条件,逼不得已还得再次调用testapprun_s。testapprun_s 也就是这样一点一点被消磨殆尽(分析完)(大部分代码也是本人第一次看,分析的不妥的地方大家多担待,后续发现问题我会及时更新)

好了,我们再看run 部分的代码

while(done == INST_NOT_DONE_YET)
{
//int state = instance_data[instance].testAppState;
done = instance_localdata[instance].testapprun_fn(&instance_data[instance], message) ; // run the communications application
//we've processed message
message = 0;
}

其实这个就是DWM1000 定位代码的core(加上上下几句),此时调用testapprun_s 传入的参数A 依然是结构体instace, B message, 此时message为0,我猜测估计还是用不到message。

我们再次进入testapprun_s 看看吧。

int testapprun_s(instance_data_t *inst, int message)
{
switch (inst->testAppState)
{

ANCHOR在上次进入testapprun_s 的最后设定了testAppState

inst->testAppState = TA_RXE_WAIT ;

那我们直接找到这部分代码

case TA_RXE_WAIT :  //enable rx,and  wait to recive a message
// printf("TA_RXE_WAIT") ;
{
if(inst->wait4ack == 0) //if this is set the RX will turn on automatically after TX
{
//turn RX on
instancerxon(inst, 0, 0) ; // turn RX on, with/without delay
}
else
{
inst->wait4ack = 0 ; //clear the flag, the next time we want to turn the RX on it might not be auto
}
if (inst->mode != LISTENER)
{
//we are going to use anchor/tag timeout
inst->done = INST_DONE_WAIT_FOR_NEXT_EVENT; //using RX FWTO
}
inst->testAppState = TA_RX_WAIT_DATA; // let this state handle it
// end case TA_RXE_WAIT, don't break, but fall through into the TA_RX_WAIT_DATA state to process it immediately.
if(message == 0) break;
}

看标注为蓝色的代码,我们在初始化的时候有动过这个家伙

  uint8         wait4ack ;         instance_init 0                                      // if this is set to

那么就是打开接受器,具体代码我们不看了,也是寄存器级别的代码。

后面接着判断

  if (inst->mode != LISTENER)

是的,我们目前分析的流程是ANCHOR,满足这个情况,那么接着执行

inst->done = INST_DONE_WAIT_FOR_NEXT_EVENT; //using RX FWTO

上一次最后遇到done这个变量打的我们措手不及,最后我们假定他是初始化值0,现在终于有个新值了,我记住你了!

if(message == 0) break;

失策了,以为message还不会用,但是这里用到了,我们传入的确实是0, break了。 由上一节分析,后面return done,这次返回的是INST_DONE_WAIT_FOR_NEXT_EVENT;。

总结一下ANCHOR 二进宫的工作: 开启接受器,没错,就这一件事。

这也就意味着等待其它设备发送数据了,我们估计后面要分析TAG了。 不过我们先返回去看看情况吧。 返回到int instance_run(void),可以知道不满足while 条件了,我们可以往后执行了。

 if(done == INST_DONE_WAIT_FOR_NEXT_EVENT_TO)
//we are in RX and need to timeout (Tag needs to send another poll if no Rx frame)
{
……
}

不满足条件,接着后面的代码,有种int instance_run也能执行完的感觉

if((instance_data[instance].instancetimer_en == 1) && (instance_data[instance].stoptimer == 0))
{
}

我们在看看这两个家伙初始化是否有赋值,我们从刚才代码分析中可以知道,至少在testapprun_s没有修改过这两个家伙

搜索初始化代码,没有发现修改过这两个家伙,或者漏掉了,我们暂且认为初始化没有修改过,那么两个值应该都是0,所以不满足,直接执行int instance_run(void)最后的return 0,高高兴兴的返回啦

【DWM1000】 code 解密4一 ANCHOR 二进宫testapprun_s的更多相关文章

  1. 【DWM1000】 code 解密7一ANCHOR接收到BLINK

    接着之前ANCHOR的代码分析,但接收到无线数据,应该执行如下代码 case TA_RX_WAIT_DATA :   //already recive a message                ...

  2. 【DWM1000】 code 解密9一 ANCHOR response poll message

    根据上面TAG发送的代码,我直接找到如下代码 case RTLS_DEMO_MSG_TAG_POLL: { if(inst->mode == LISTENER)                  ...

  3. 【DWM1000】 code 解密3一ANCHOR RUN起来

    int done = INST_NOT_DONE_YET; #define INST_DONE_WAIT_FOR_NEXT_EVENT 1 //this signifies that the curr ...

  4. 【DWM1000】 code 解密2一 工程初始化代码分析

    instance_init 函数追下去,绝大多数的代码都在初始化如下结构体 typedef struct { INST_MODE mode; instance_init -ANCHOR //insta ...

  5. 【DWM1000】 code 解密8一 TAG接收blink response 信号

    在分析这个部分前,目前我看到DWM1000 的资料,data可以分为blink和一般无线数据,后面有内容我们再扩充, 上面我们已经看到接收到blink触发的事件为 case SIG_RX_BLINK ...

  6. 【DWM1000】 code 解密6一TAG 状态机第一步

    我们前面分析过,不论ANCHOR 还是TAG,前面变量的初始化基本都是一样的,只是状态机必须明确区分不同的设备类型.我们从开始看TAG.由于初始化TAG的 testAppState一样初始化为TA_I ...

  7. 【DWM1000】 code 解密5一ACHOR 第一次回家Main 函数

    instance_run(); if((instance_data[0].monitor == 1) && ((portGetTickCnt() - instance_data[0]. ...

  8. 【DWM1000】 code 解密1一 去掉Main 函数多余内容

    蓝点DWM1000 模块已经打样测试完毕,有兴趣的可以申请购买了,更多信息参见 蓝点论坛 正文: 室内定位兴起,DWM1000 作为超宽带UWB的代表,在国内用的越来越多,但是可见资料非常少. 一方面 ...

  9. 【DWM1000】 code 解密10 一 TAG 发送最后一个消息

    更上面ANCHOR发送信息时的RTLS_DEMO_MSG_ANCH_RESP, 我们很快就可以找到如下代码 case RTLS_DEMO_MSG_ANCH_RESP: { 这里面一部分是设置重要变量, ...

随机推荐

  1. Atom插件下载失败解决办法

    转自:http://www.cnblogs.com/20145221GQ/p/5334762.html#正题 一般方法(Atom自动安装) 打开Atom >> Packages >& ...

  2. 基本 TCP 的回射服务器

    实验一 代码:链接[01项目] 1. 先启动服务器,如图: 2. 然后启动客户端,如图: 3. 输出结果: [注意]:在服务器终止时,给父进程发送了一个SIGCHILD信号,这一点本例发生了,但是我们 ...

  3. nginx 日志 cron任务切割日志

    #vim cut_nginx_log.sh #cd /usr/local/nginx/logs/ #/bin/mv access.log access_$(date +%F).log #/usr/lo ...

  4. 一次BurpSuite无法抓https包定位

  5. 通过java代码进行impala和kudu的对接

    对于impala而言,开发人员是可以通过JDBC连接impala的,有了JDBC,开发人员可以通过impala来间接操作kudu: maven导包: <!-- https://mvnreposi ...

  6. Spring AOP中args()、arg-names、argNames

    先小结一下: args()是用来匹配并且接收目标方法的参数的. argNames(用在注解中)与arg-names(用在XML中),他们是同一个东西. argNames用来接收AspectJ表达式中的 ...

  7. Codeforces 1139F Dish Shopping 树状数组套平衡树 || 平衡树

    Dish Shopping 将每个物品拆成p 和 s 再加上人排序. 然后问题就变成了, 对于一个线段(L - R), 问有多少个(li, ri)满足  L >= li && R ...

  8. 51Nod1577 异或凑数 线性基

    原文链接https://www.cnblogs.com/zhouzhendong/p/51Nod1577.html 题意 给定一个长度为 n 的序列. 有 m 组询问,每一组询问给出 L,R,k ,询 ...

  9. Codeforces 177G2 Fibonacci Strings KMP 矩阵

    原文链接https://www.cnblogs.com/zhouzhendong/p/CF117G2.html 题目传送门 - CF177G2 题意 定义斐波那契字符串如下: $s_1="a ...

  10. 给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。

    示例 1: 输入: [1,2,3,4,5,6,7] 和 k = 3 输出: [5,6,7,1,2,3,4] 解释: 向右旋转 1 步: [7,1,2,3,4,5,6] 向右旋转 2 步: [6,7,1 ...