BLE协议栈 – HCI

2023-10-16 21:20
文章标签 协议 ble hci

本文主要是介绍BLE协议栈 – HCI,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

HCI(Host Controller Interface)层中文称为主机与控制器接口,它连接主机(Host)和控制器(Controller),将主机的操作转化成HCI指令传给控制器,BLE协议规定了HCI的指令集。

单芯片与双芯片

在BLE协议栈的层模型中,位于下部的物理层、链路层、DTM属于控制器,位于上部的L2Cap、ATT、GATT、GAP、SM层则属于主机,在主机之上用户自己的程序称为用户程序。因此BLE协议栈进一步可以抽象为三层:控制器、主机和用户程序。

BLE协议栈规划的芯片实现方案有单芯片方案,双芯片方案和三芯片方案。
单芯片方案即主机和控制器在同一颗芯片内,双芯片方案是主机和控制器分属两颗不同芯片,三芯片方案则是将用户程序也放在单独芯片内。单芯片放置协议栈全部内容,势必需要巨大Flash和SRAM,而早期主流的芯片资源可能并没有那么充裕,因而提出双芯片方案。

我们知道,BLE协议诞生于2010年推出的Bluetooth 4.0,当时ARM已经大行其道,说芯片没有资源是站不住脚的,但是为什么还是有这个双芯片方案的考虑呢?这需要用历史的眼光去看到BLE协议。BLE脱胎于蓝牙协议,在许多方面借鉴和集成了经典蓝牙的既有特征,在追求低功耗这个目标的路上,也尽量保持蓝牙协议栈核心架构的原始面貌。而经典蓝牙由来已久,所以我们可以猜测,这样的双芯片方案甚至三芯片方案的设计是从经典蓝牙那边继承过来的特性。

实际上,双芯片方案仍然可以在市面上寻到,比如ST的BLE协处理器,就是一颗单独的BLE控制器。使用时只要在任意一个ST的MCU中下载Host固件即可实现主机功能,两颗芯片通过SPI接口进行通信,组成双芯片方案。这样带来的好处也是显而易见,就是可以复用已有的MCU,实现各种资源配置的BLE主机。然而在单芯片方案中,HCI的地位是很尴尬的。我们观察协议栈,物理层属于硬件实现,一部分链路层的功能,比如校验、白化、导引字的识别等功能也是硬件实现,除此之外,协议栈的其他部分均是在固件中实现。所以协议栈其实可以被认做一个固件程序。在单芯片方案中,主机和控制器是写在同一个程序之中两个模块,还要增加一个HCI层来转发消息实属浪费。因此,在某些协议栈的实现代码中,HCI虽然存在,但是其功能已经十分模糊,不再承担主机和控制器之间完整的消息转发功能。

下图为Nordic的一个协议栈实现图,在右图中,HCI从逻辑已经被抹去。(从图上水印可知其来自FutureTek-2014微信公众号的文章: 链接 )

HCI的用途

就单芯片而言,HCI主要有两个用途。
一个是保持对BLE协议栈的兼容性,既然SPEC这样定义,那么协议栈IP供应商也就这么实现。另一个是用于BLE的RF测试。面向BLE的RF测试的设备,都会配备一个UART接口用于数据通信,而HCI在外部就表现为一个UART接口,这样在测试时,直接用UART线连接测试设备与芯片的UART管脚即可。软件层面,BLE SPEC提供一套HCI指令,测试设备自动收发处理,无需人工干预。结合上一期介绍的DTM层,我们可以简单理解,DTM和HCI就是为BLE的RF测试而存在的。DTM定义了测试内容和格式,HCI提供通信接口

使用HCI

假如安装了Cypress Kit 042-BLE的帮助文件,可以在安装目录下找到DTM的示例工程:PSoC_BLE_DTM。该工程演示了如何使用DTM和HCI进行BLE测试。
很遗憾,该工程过于简单,导致用户一脸懵懂,不知示例为何。其实正如前面所说,RF测试设备通常已经配备了自动发送命令,处理数据的能力,因此只要将BLE配置为DTM模式,并且指定HCI串口管脚即可,无需其他额外操作,所以我们看到工程的main文件中未添加任何操作代码。

 

[本文转自红旭论坛,看完之后获益良多,故联系大佬Wireless-tech转之。]

这篇关于BLE协议栈 – HCI的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/220870

相关文章

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines