Firefly开源社区

打印 上一主题 下一主题

FireBlue QN9021 QN902x Proximity Reportor profile(防丢器) 之源码分析 (四)连接

25

积分

0

威望

0

贡献

游客

积分
25

FireBlue QN9021 QN902x Proximity Reportor profile(防丢器) 之源码分析 (四)连接

发表于 2015-4-3 17:58:12      浏览:11057 | 回复:4        打印      只看该作者   [复制链接] 楼主
本帖最后由 dezhi 于 2015-4-7 09:18 编辑

     BLE 的连接都是由主机在前篇所描述的广播扫描响应后主动发起连接请求去连接从设备。      
     做为从机的防丢器端,会被动地等待主机的连接,当系统初始化并开启广播后就开始等待主机的连接,如果主机发送连接请求过来,GAP 层会做相应的处理,如果接受该连接请求,就会向APP 层发送 GAP_LE_CREATE_CONN_REQ_CMP_EVT 消息,

  1. {GAP_LE_CREATE_CONN_REQ_CMP_EVT,(ke_msg_func_t) app_gap_le_create_conn_req_cmp_evt_handler}
复制代码
     app_gap_le_create_conn_req_cmp_evt_handler 里设置 TASK_APP 的任务状态为IDLE,环境角色为PERIPHERAL,并保存主机的相关信息
然后启用从机服务器的服务,关键代码如下:
  1.     if (APP_ADV == ke_state_get(TASK_APP))
  2.     {    //设置 TASK_APP 的任务状态为IDLE,环境角色为PERIPHERAL
  3.         ke_state_set(TASK_APP, APP_IDLE);
  4.         app_set_role(GAP_PERIPHERAL_SLV);
  5.     }
  6.     else
  7.     {
  8.         app_set_role(GAP_CENTRAL_MST);
  9.     }

  10.     if (param->conn_info.status == CO_ERROR_NO_ERROR)
  11.     {    //保存主机的相关信息
  12.         app_set_link_status_by_conhdl(param->conn_info.conhdl, ¶m->conn_info, true);

  13.         // 使能从机服务器的服务
  14. #if (BLE_PERIPHERAL)
  15.         app_enable_server_service(true, param->conn_info.conhdl);
  16. #endif
  17.     }

  18.     app_task_msg_hdl(msgid, param);
复制代码

最后还调用了 app_task_msg_hdl ,

  1. case GAP_LE_CREATE_CONN_REQ_CMP_EVT:
  2.         if(((struct gap_le_create_conn_req_cmp_evt *)param)->conn_info.status == CO_ERROR_NO_ERROR)
  3.         {
  4.                 if(GAP_PERIPHERAL_SLV == app_get_role())
  5.                 {
  6.                         //清除APP_ADV_INTV_UPDATE_TIMER 定时器,该定时器用意为开始广播30S 后变为慢速广播
  7.                         //避免长时间无主机连接,而又一直频繁广播,浪费不必要的功耗
  8.                         ke_timer_clear(APP_ADV_INTV_UPDATE_TIMER, TASK_APP);
  9.                         //主机已连接上从机,设置LED1为常亮
  10.                         usr_led1_set(LED_ON_DUR_CON, LED_OFF_DUR_CON);
  11.                         //如果主机的连接时间过于频密,更新连接时间
  12.                         if (((struct gap_le_create_conn_req_cmp_evt *)param)->conn_info.con_interval < GAP_PPCP_CONN_INTV_MIN)
  13.                         {
  14.                                 // Update connection parameters here
  15.                                 struct gap_conn_param_update conn_par;
  16.                                 /// Connection interval minimum
  17.                                 conn_par.intv_min = GAP_PPCP_CONN_INTV_MIN;
  18.                                 /// Connection interval maximum
  19.                                 conn_par.intv_max = GAP_PPCP_CONN_INTV_MAX;
  20.                                 /// Latency
  21.                                 conn_par.latency = GAP_PPCP_SLAVE_LATENCY;
  22.                                 /// Supervision timeout, Time = N * 10 msec
  23.                                 conn_par.time_out = GAP_PPCP_STO_MULT;
  24.                                 app_gap_param_update_req(((struct gap_le_create_conn_req_cmp_evt *)param)->conn_info.conhdl, &conn_par);
  25.                         }
  26.                 }
  27.         }
  28.         break;
复制代码


     至此 主机和从机连接成功,主机可以对从机进行操作,比如,查找从机Profiles Server UUID ,读写characteristic  等操作。

     在struct gap_le_create_conn_req_cmp_evt 里面我们得知BLE 的连接参数如下
  1. struct gap_link_info
  2. {
  3.     /// 确认状态:0x00表示连接成功,其他表示连接失败
  4.     uint8_t status;
  5.     /// 连接句柄
  6.     uint16_t conhdl;
  7.     /// 对方设备的地址类型:0x00(Public) 0x01(Random)
  8.     uint8_t peer_addr_type;
  9.     /// 对方设备的地址
  10.     struct bd_addr peer_addr;
  11.     ///连接的时间间隔
  12.     uint16_t con_interval;
  13.     /// 连接的潜伏期
  14.     uint16_t con_latency;
  15.     ///链接超时
  16.     uint16_t sup_to;
  17.     /// Master 的时钟精度
  18.     uint8_t clk_accuracy;
  19. };
复制代码

    这里比较重要的是     
     1. con_interval; ///连接的时间间隔
连接事件的时间间隙为1.25ms 的倍数  在7.5ms~4S 之间
     2.con_latency;  /// 连接的潜伏期
          连接的潜伏也是为1.25ms 的倍数  在7.5ms~4S 之间,
    3.sup_to          ///链接超时
          链接超时时间为10ms 的倍数,在100ms~32S 之间

     BLE 的连接事件
          连接建立后所有的通信都在两个设备的连接事件 ,连接事件周期地发生,按照连接参数的时间间隙发生连接通信,如下图



     con_interval 时间间隔设定小时,两设备都会以较高功耗运行,通信频密,数据吞吐量高,数据延时小;反之,时间间隔设定大时,两设备都会以较低功耗运行,通信疏密,数据吞吐量低,数据延时大。
     con_latency  潜伏期设定小,功耗相对提高,但设备可以快速收到主设备发来的数据。反之,设定较大,从设备在没有数据发送的情况下,可以与较低的功耗运行,从设备不能无法及时收到主设备发来的数据,主设备能及时收到从设备的数据。

欢迎关注小弟博客http://blog.csdn.net/q562359345










回复

使用道具 举报

18

积分

0

威望

0

贡献

游客

积分
18
发表于 2015-8-2 18:51:41        只看该作者  沙发
至此 主机和从机连接成功,主机可以对从机进行操作,比如,查找从机Profiles Server UUID ,读写characteristic  等操作。
大师可否继续往下写“比如”的内容?
回复

使用道具 举报

124

积分

0

威望

0

贡献

技术达人

Rank: 2

积分
124
发表于 2015-8-28 14:37:08        只看该作者  板凳
请问如何将从机端的数据发到APP端显示
回复

使用道具 举报

151

积分

0

威望

0

贡献

技术小白

积分
151
发表于 2015-8-29 09:21:16        只看该作者  地板
卜道翁先生 发表于 2015-8-28 14:37
请问如何将从机端的数据发到APP端显示

1.首先得了解特征值的属性
2.参考各例程
3.利用LightBlue 等调试工具调试例程,总结规律
4.自己编写属于自己的server

以上是小弟的学习过程;P,一步一个脚印,基本都是:看->抄->懂->改->写
回复

使用道具 举报

124

积分

0

威望

0

贡献

技术达人

Rank: 2

积分
124
发表于 2015-8-29 10:21:54        只看该作者  5#
OK、3Q:handshake
回复

使用道具 举报

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

本版积分规则

友情链接 : 爱板网 电子发烧友论坛 云汉电子社区 粤ICP备14022046号-2
快速回复 返回顶部 返回列表