第18.2节_地址类型与LL层设备过滤

一、地址类型

二、白名单和Resolving List

三、LL层设备过滤

一、地址类型

学习资料:官方手册

Vol 6: Core System Package [Low Energy Controller volume]

Part B: Link Layer Specification

1.3 Device Address

这篇文章总结得比较好:

蓝牙协议分析(6)_BLE地址类型

http://www.wowotech.net/bluetooth/ble_address_type.html

 

BLE地址分为2大类:

1. 公有地址(Public Device Address):

这需要向IEEE购买,并且容易被伪造。

2. 随机地址(Random Device Address):

这又分为这2类:静态地址、随机地址。

2.1 静态地址(Static address):

每次上电周期,设备都可以选择一个随机数作为地址,在该上电周期中地址保持不变。

下一次上电时,设备可以继续使用上次的地址,也可以选择新的随机地址。

该类地址的最高2位为0b11。

不用购买,也容易被伪造。

2.2 私有地址(Private address):

这类地址每隔几分钟交换一次,一般建议是15分钟。

这又分为这2类:不可解析私有地址、可解析私有地址。

2.2.1 不可解析私有地址(Non-resolvable private address):

除最高2位是0b00外,其他46位都是随机数。

其应用场景并不是很清晰,地址变来变去的,确实是迷惑了敌人,但自己人不也一样被迷惑了吗?因此,实际产品中,该地址类型并不常用。

2.2.2 可解析私有地址(Resolvable private address):

最高2位是0b01,其余部分见下图。

在上一节视频里讲解过该类地址。

随机地址这一类目下,有3种地址(看上图中的3个红色箭头),它们可以根据最高2位互相区分。

但是公有地址和随机地址之间,无法通过地址值来区分。

因此,在发送的数据中会有一位被用来标记地址类型。

比如广播数据包中,头部信息中有一位“TxAdd”或“RxAdd”,0表示公有地址,1表示随机地址:

之前我们说过为了防止被冒充、为了隐私,建议使用“可解析私有地址”。

一个设备,它可能有公有地址,但是它仍可同时使用“可解析私有地址”。

一个设备,它上电后使用了静态地址,但是它仍可同时使用“可解析私有地址”。

也就是说,一个设备它可以使用变来变去的“可解析私有地址”,但是我们要称呼它时需要一个相对固定的地址。这个相对固定的地址,就叫“Identity Address”,它是公有地址或静态地址。

白名单里保存的都是“Identity Address”,“Identity Address”可能是公有地址也可能是静态随机地址,所以还需要“Address Type”来分辨它是哪一类。

二、白名单和Resolving List

学习资料:官方手册

Vol 2: Core System Package [BR/EDR Controller volume]

Part E: Host Controller Interface Functional Specification

7 HCI Commands and Events

7.8 LE Controller Commands

 

这篇文章总结得比较好:

蓝牙协议分析(8)_BLE安全机制之白名单

http://www.wowotech.net/bluetooth/ble_white_list.html

LL层可以根据设备的地址,过滤掉一些设备,免得频繁打扰Host导致浪费电量。

过滤设备,要借助于白名单。

白名单是一个列表,每一个表项中含有“Device Identity Address”和“Address Type”:

Device Identity Address:设备的公有地址或静态地址;

Address Type:设备的地址类型

为了防止别的设备冒充白名单里的设备,可以使用“可解析地址”。Controller为了能够解析地址,需要有一个“Resolving List”。

白名单和“Resolving List”的作用在上一节视频里介绍过,Host可以通过命令在白名单和“Resolving List”中增加、删减项目。

1. 白名单操作命令:

2. “Resolving List”操作命令:

三、LL层设备过滤

学习资料:官方手册

Vol 6: Core System Package [Low Energy Controller volume]

Part B: Link Layer Specification

4.3 Link Layer Device Filtering

Vol 2: Core System Package [BR/EDR Controller volume]

Part E: Host Controller Interface Functional Specification

7 HCI Commands and Events

7.8 LE Controller Commands

7.8.5 LE Set Advertising Parameters Command

7.8.10 LE Set Scan Parameters Command

7.8.12 LE Create Connection Command

LL层可以根据设备的地址,过滤掉一些设备,免得频繁打扰Host导致浪费电量。

LL层过滤设备的策略有如下3种,它们都使用同一个白名单:

1. 广播过滤策略(Advertising Filter Policy)

该策略用来决定广播设备的链路层,如何处理其他设备发来的扫描请求、连接请求。

Host可以发出下面的命令设置Controller的Advertising Filter Policy:

Advertising_Filter_Policy的含义如下:

0x00,禁用白名单机制,允许任何设备连接和扫描。

0x01,允许任何设备连接,但只允许白名单中的设备扫描。

0x02,允许任何设备扫描,但只允许白名单中的设备连接。

0x03,只允许白名单中的设备扫描和连接。

2. 扫描过滤策略(Scanner Filter Policy)

该策略用来决定处于扫描态的设备的链路层,如何处理其他设备发来的广播包。

Host可以发出下面的命令设置Controller的Scanner Filter Policy:

Scanning_Filter_Policy的含义如下:

0x00,禁用白名单机制,接受所有的广播包(除了那些目的地址不是该设备的directed advertising packets)。

0x01,只接受在白名单中的那些设备发送的广播包(除了那些目的地址不是该设备的directed advertising packets)。

0x02,Extended Scanner Filter policies相关,暂时不介绍。

0x03,Extended Scanner Filter policies相关,暂时不介绍。

3. 发起者过滤策略(Initiator Filter Policy)

该策略用来决定怎么去连接对端设备:要Host指定,还是自动连接白名单中的设备。

Host可以发出下面的命令设置Controller的Initiator Filter Policy:

Initiator_Filter_Policy的含义如下:

0x00,禁用白名单机制,使用Host提供的Peer_Address_Type and Peer_Address指定需要连接的设备。

0x01,连接那些在白名单中的设备,不需要Host提供Peer_Address_Type and Peer_Address参数。

原文地址:https://www.cnblogs.com/-glb/p/11669148.html

时间: 2024-11-20 22:53:28

第18.2节_地址类型与LL层设备过滤的相关文章

基本_移动类型轮播效果_框架

一.基本元素: D:display window;用户浏览的窗口: S:scroll window;存放内容的大容器:通过移动来改变显示的内容: C:content;内容信息: B:button;按钮,多种样式,可选: 二.思路: 通过移动S 的位置,由于C位于S中,所有的C将会同时跟随S而移动. 在D中显示的内容将会被改变. 三.html结构: 1 <div class=”D”> 2 <div class=”S”> 3 <div class=”C”>content&l

Java网络编程从入门到精通 (9):使用isXxx方法判断地址类型

IP地址分为普通地址和特殊地址.在前面的文章中所使用的大多数都是普通的IP地址,在本文中将介绍如何利用InetAddress类提供的十个方法来确定一个IP地址是否是一个特殊的IP地址. 一.isAnyLocalAddress方法 当IP地址是通配符地址时返回true,否则返回false.这个通配符地址对于拥有多个网络接口(如两块网卡)的计算机非常拥有.使用通配符地址可以允许在服务器主机接受来自任何网络接口的客户端连接.IPv4的通配符地址是0.0.0.0.IPv6的通配符地址是0:0:0:0:0

结构体_枚举类型

namespace 结构体_枚举类型{    class Program    {        struct jiegouti        {            public int fenshu;            public string name;            public string kecheng;        }        static void Main(string[] args)        {            jiegouti a =

【翻译】【linux设备驱动】linux地址类型

Linux中使用的地址类型列表: 用户虚拟地址(User virtual addresses) 用户空间程序可见的普通地址.用户虚拟地址的长度为32位或64位,依赖于底层的硬件体系架构,每个进程有它自己的虚拟地址空间. 物理地址(Physical addresses) 处理器和系统内存之间使用的地址.物理地址的长度为32位或64位:32位操作系统上有时也可以使用大于32位的物理地址(PAE) 总线地址(Bus addresses) 外部总线和系统内存之间使用的地址.通常总线地址和物理地址是等同的

Ubuntu 18.04 LTS IP 地址设置

和之前的版本不太一样, Ubuntu 18.04 的 ip地址设置是用netplan管理的 配置文件在: /etc/netplan/50-cloud-init.yaml 示例文件如下: # This file is generated from information provided by # the datasource. Changes to it will not persist across an instance. # To disable cloud-init's network

阶段1 语言基础+高级_1-3-Java语言高级_03-常用API第二部分_第6节 基本类型包装类_4_包装类_基本类型与字符串类型之间

integer里面有toString的方法,可以integer转换为String类型 String类里面有valueOf可以,把int转换为String类型 int加上空的字符串就是,字符串 字符串变为基本类型 异常数据 以上就是基本类型和字符串的相互转换. 原文地址:https://www.cnblogs.com/wangjunwei/p/11229028.html

Java应该拥有对象地址类型

我认为现在的Java需要一种类型:对象地址.这在C++中是有的.理由是: 如果把数据内容当作一箱苹果或者其它什么东西,那么对象引用就是一个箱子,那么在方法间调用时,在现在的Java系统中就不得不每次都要重新使用一个新的箱子来包装这些内容,这是一个额外的消耗.你知道,这个对象引用并不是像一个指针那样有固定大小的地址记录内存块,而是足够大到能包含具体对象类型的所有内容.这样的额外消耗在某些特定目的的执行过程中将会使程序崩溃,如果想要避免它又会失去面向对象的特性从而无法实现API. 举例我看见的这个缺

第七节:将类型序列化为不同的类型以及将类型反序列化为不同的对象

.NET Framework的序列化架构相当全面,本节要讨论如何设计一个类型,本节要讨论如何设计一个类型,它能将自己的序列化或反序列化成一个不同的类型或对象.下面列举一些有趣的例子. 1.         有的类型(比如System.DBNull和System.Reflection.Missing)设计成每个AppDomain一个实例.我们经常把这些类型称为单实例类型.给定一个DBNull对象引用,序列化和反序列化它不应造成在AppDomain中创建一个DBNull对象.序列化后,返回的引用应指

postgresql----网络地址类型和函数

本人对网络这块实在是搞不清楚,要是能有人推荐一下资料就好了!不知道有没有跟我一样呢?!所以在这里先贴一点从其他地方搞来的一些IPv4的东东. IPv4主要包括一下5类地址 A类: 0 7位 网络号 24位 主机号 B类: 1 0 14位 网络号 16位 主机号 C类: 1 1 0 21位 网络号 8位 主机号 D类: 1 1 1 0 28位 多播组号 E类: 1 1 1 1 0 27位 留待后用 由上表可以看出一个IPv4地址使用32位二进制表示,使用时写成4个十进制数,每个十进制占用8位,每个