
01蓝牙设备地址的类型 所有蓝牙设备都应具有一个蓝牙设备地址 (BD_ADDR),该地址(及其地址类型)可以唯一地(一定范围内唯一)标识该设备。使用者如果不了解其概念,看上去可能会有很多疑惑,甚至容易造成侵权问题。 . ^1 t" z) m( h 蓝牙的设备地址分为两大类,一类是 Public,一类是 Random 的。其中 Random 类地址里面又分为静态地址和私有地址。私有地址又分为不可解析的私有地址和可以解析的私有地址。这些地址类型列举如下: • Public Bluetooth address // 1% C7 J( Q$ N6 q: J9 x • Random Bluetooth address! C; j. A* i+ ~ o Static address // 2 o Private address$ g4 F0 g8 M. [( G j) { ▪ Non-resolvable private address // 3: B4 U% E: M3 J2 t* W; f ▪ Resolvable private address // 4 " R* a# J _6 ^$ K3 q$ | 上述 4 种地址类型都使用 48bit 的地址长度。地址类型不同,48bit 地址的格式也会不同;设备地址类型和设备地址共同用于唯一标识该设备。另外需要注意以下几点: • Public 或者 Random 地址类型的标识在链路层的广播包 PDU Header 中,不在48bit 地址的内容中。 • Random 类型下的三种地址类型,使用 48bit 地址的高 2bit 进行标识。" q) a u- C& x7 {) P! q7 o • 48bit 地址都相同的两个设备,如果它们分别属于 Public 或者 Random 地址类型,则它们是两个不同身份的蓝牙设备。 6 I8 F1 T" i: m/ H% c 设备应至少使用一种类型的设备地址,也可以同时使用两种。该设备可以通过它使用的任何设备地址来寻址。设备的身份地址是它在传输的数据包中使用的 Public 设备地址或Random 静态设备地址。如果一个设备使用可解析的私有地址,它也应该有一个身份地址。每当比较两个设备地址时,比较应包括设备地址类型(即如果两个地址的类型不同,即使两个 48 位地址相同,它们也不同)。 如果公司有购买 Public 地址,则建议用 Public。如果没有购买地址,又没有设备地址隐私需求,则建议使用 Random Static Device Address。 1.1. Public Bluetooth Address2 M% R9 [& e% q. c 在传统蓝牙和 BLE 中,原则上来说,使用 Public 地址需要向 IEEE 申请购买,使用未授权的 Public 地址如果和已授权的 Public 地址发生地址冲突,可能会面临法律纠纷。使用Public 地址还需要涉及到地址的管理、购买等流程。本文的后面举例描述了购买 Public 地址的流程。 + R% x3 e2 t# y) Y, x+ ^+ p; R5 V- I 1.2. Random Static Device Address 蓝牙更新到了 BLE 版本之后,为了让设备厂商可以节省购买 Public 地址授权的费用,引入了 Random 类型的地址。从前文可知,Random 地址类型又分为静态(Static)类型和隐私(Private)类型。静态类型的地址格式如下: % u0 K/ Q4 w0 q' W! v ![]() # w& L* R: D3 U. ^ G 静态地址是随机生成的48位地址,应满足以下要求 :4 N7 |) U: z+ @. o • 地址的随机部分至少有一位应为 0 • 地址的随机部分至少有一位应为 1: E8 ?1 n- I. C) ? N# z 0 I. Z6 L W; V+ T# o: w4 X 设备可以选择在每次电源循环后将其静态地址初始化为新值。设备在初始化后不得更改其静态地址值,直到设备重新上电。 % d* o/ ^6 n5 q 注意:如果设备的静态地址发生更改,则存储在对端设备中的地址将无效,并且将失去使用旧地址重新连接的能力。 2 k. n+ K3 y; ^ s1 I( w0 m; L$ Q- d 1.3. Random Non-Resolvable Private Address& A* J/ _3 u* n! o 隐私地址主要是为了解决隐私问题。根据其是否可解析,又分成不可解析地址类型和可解析地址类型,不可解析地址类型的地址格式如下: $ ~" M6 A( h& e) m* }3 k, f3 r* r$ | ![]() 4 N# G4 M" Z" c • 地址的随机部分至少有一位应为 1 • 地址的随机部分至少有一位应为 07 g4 z1 R2 w6 t3 B* Q0 X • 地址不得等于 Public 地址 不可解析地址会周期更新(建议值是 15 分钟),这类地址在实际应用中比较少用。 % J1 P7 g; P6 G9 m* L+ h 1.4. Random Resolvable Private Address1 M4 t- M- r9 g 所谓可解析地址(RPA),是指可以把一个周期变化的地址解析为唯一的身份地址。使用随机可解析地址类型的设备应具备两个地址,一个地址用于标识该设备,称为身份地址(Identity Address),另一个则为随机可解析地址(RPA)。一般情况下,设备会广播RPA,身份地址保存在本地。对端设备可通过解析 PRA 进一步获得其身份地址。 要生成可解析的私有地址,设备必须具有本地身份解析密钥 (IRK) 或对端身份解析密钥 (IRK)。可解析的私有地址应使用 IRK 和随机生成的 24 位数字生成。随机数称为prand,应满足以下要求:( P9 w6 K3 ?0 E$ p* t3 a- z • prand 的随机部分至少有一位为 07 r( Y& o+ z7 X9 p; U • prand 的随机部分至少有一位为 1 ![]() 特征如下: 1)由两部分组成: 高位 24bits 是随机数部分,其中最高两个 bit 为“10”,用于标识地址类型;0 T& P* n8 L- J( E8 \ 低位 24bits 是随机数和 IRK 经过 hash 运算得到的 hash 值,运算的公式为 hash = ah(IRK, prand)。. q7 c( h: A0 o( ~0 \8 J7 d 2)当对端 BLE 设备扫描到该类型的蓝牙地址后,会使用保存在本机的 IRK,和该地址中的 prand,进行同样的 hash 运算,并将运算结果和地址中的 hash 字段比较,相同的时候,才进行后续的操作。这个过程称作 resolve(解析),这也是 Non-Resolvable Private Address/Resolvable Private Address 命名的由来。# o. g3 V& K4 g6 B: y' x 3)以 T_GAP(private_addr_int)为周期,定时更新。哪怕在广播、扫描、已连接等过程中,也可能改变。 4)Resolvable Private Address 不能单独使用,因此需要使用该类型的地址的话,设备要选择 Public Device Address 或者 Static Device Address 中的一种作为其身份地址。) V2 P( @. n8 u. D& ] 5 e* ?3 t/ G5 } ]7 X2 b 02MAC 地址相关函数$ _4 i7 m$ p/ {2 n. X! h; C! Z4 h 下面介绍两个比较重要的和 MAC 设置相关的函数。 , s' o, ]! w; Q' U( X2 g0 x # a: R$ O; ]9 N+ |3 \4 C) v // 配置 MAC 地址的函数3 S3 W* q9 E& l- ~. c8 M2 S% W , C) B$ o" A. J/ [3 D ![]() % w: y5 K( l; k/ S* ~ 其中不同的 offset 设置的数值不一样,和 MAC 地址相关的主要是这两个:8 @- n: @: N9 A6 C) q+ o' V e2 d g • 0x00: CONFIG_DATA_PUBADDR_OFFSET+ d( c: I) g, ?- r4 E • 0x2E: CONFIG_DATA_STATIC_RANDOM_ADDRESS& B% ?* V0 D9 q8 w. l; c 4 H5 j1 w) c- u Q //配置使用哪种 MAC 地址的函数: ![]() Identity_Address_Type : • 0x00: Public Address& v) K& I! b7 y' V0 f3 x • 0x01: Static Random Address& v Z7 |, H4 B% G 03蓝牙 Random 静态设备地址的生成与设置参考方法 为了方便一些客户生成免费的相对唯一的 MAC 地址,下面列举一个使用芯片出厂唯一的 UID 来生成 MAC 地址的参考方法。基本原理是通过读取芯片的 UID,然后再进行 Hash计算,截取需要的 46bit 作为随机部分的静态地址。理论上这种方法生成的 MAC 地址重复的几率很小,在 2 的 40 多次方分之一的几率重复,因此实际工程应用中可以认为它相对比较唯一。9 h: R% E( T" V/ D5 L. @/ m# L$ H sha256.c这个库文件在当前开发平台上需要修改前面一个头文件包含: 将 “#include” 更改为 “#include”2 w3 X9 i- q8 n% p" M" ]6 w 以下部分伪代码适用于 BlueNRG 系列和 STM32WB 系列 5 ~7 P7 S% g" v0 ^0 o/ I: Q/ W // 生成静态 MAC 地址参考函数, P3 N/ ?& Z/ z) b 1 l1 X8 ]' n u. \5 r# D. E$ y ![]() 8 j$ W$ e$ l4 V) T/ B; b( `' _4 v6 a 04蓝牙 Public 设备地址的购买流程 全球唯一设备号,标准化组织是 IEEE,以前的网卡 Ma 地址、PC,现在蓝牙设备、BLE 设备若需要认证的,官方的唯一设备标识,即蓝牙地址,也是 Mac 地址,需向 IEEE申请,并登记付费。即可获得授权。' O5 @1 e# H: C8 ?9 n* f 4.1. OUI 介绍 Organizationally Unique Identifier(OUI) 被称作“组织唯一标识符”,在任何一块网卡中烧录的 6 字节 MAC 地址中,前三个字节就体现了 OUI,通常情况下,该标识符是唯一的。因此,OUI 可以用来创建 MAC 地址、蓝牙设备地址或以太网地址。另外,OUI 也可作为一个公司的 SNAP 协议标识符使用。; t( D' T6 O \$ w) p 通常情况下,IEEE 标准协会将前 24 位组织唯一标识符(OUI)分配给生产企业,剩下的 24 位由厂家自行分配代码。+ P P) ^) X }* ? X 目前,OUI 只能通过 IEEE 标准协会直接购买,其总价格大概在 3500 美元左右。! L5 M1 o7 {, P' O& j: j" v" Q . j7 h8 H2 Q+ Z# `+ z 如果如果没有保密需求,支付$3500 就可获得一个 OUI(可生成 1600 万个地址),即上述所指的 publicly registered MA-L,也就是说此类公司的名称和地址是公开的,公众可以访问 输入公司名称查询该公司拥有的 MA-L,或者输入 MA-L查询公司的名称和地址。7 J7 B% v3 ^! B6 I6 N! P6 l; Q' x 如果生产厂商希望对以上信息保密,可以选择 Privately registered MA-L,价格会贵很多,且每年需要支付保密费用大概几千美元。 4.2. 购买流程( W7 q8 |" E" Z& | 如果需要购买 Public 地址,需要先申请一个 IEEE 账号。登入后点击如下入口开始申请。$ `3 [, J' C; V+ [) J& j . _2 @% I! ?3 A3 R 图1.申请购买 public 地址入口. f- K; V7 n9 ^* A6 z, m) [; b. \ ![]() 图2. 选择购买的 MAC 地址数量和类型+ J! D. m( d* i3 C* a0 f* ?2 K & D0 j8 Q' Q- ^0 Y% d ![]() 如果申请的类型是 MA-L 大概有 1677 万个地址,MA-M 大概有 100 多万个。7 R6 G' w: X7 A5 U. O 图3.申请过程中的 4 个步骤 ( B6 b8 A4 Q; w l5 k& I9 x ![]() 3 X- n U6 g/ d/ r 主要填写:申请人信息,包括姓名、职位、公司名称、地址及邮箱电话等;$ T$ {, P; c$ S H - A8 w& n* L8 F* O1 g 公司信息,如果贵公司为首次申请,initial corporate assignment request 后选择YES,如果不是首次申请 OUI,一定要确保现有的 MAC 地址使用率已达到 95%,否则不予申请,选择 No 之后需要在方框内填写上次申请 OUI 的公司名称并提供再次申请的理由,同时还需提供公司类型,是母公司还是子公司,还是两者皆否 ( z' S; F: v+ {8 b7 K7 w' h 如果公司类型选择了母公司或者是子公司,需要填写至少 3 家联营公司的具体信息,如果公司类型选择了 neither,该部分可不填;为保密信息,如果选择购买的是 publicly registered MA-L,该部分选择 No,反之选择 Yes 并提供理由;目前 IEEE 标准协会接受的付款方式包括邮寄美国银行汇票、美元电汇及信用卡在线支付。如果需要提供形式发票,请选择 please send a proforma invoice 之前的复选框。" E8 p+ G0 M/ G$ r 7 ]! H) E$ P, v" l U' c' q 完成以上内容后在线提交即可。 + w% t2 |7 w: b- N' F7 L+ i 4.3. 购买后检查确认( G& `. G6 F( c/ r' ] 如果需要购买 public 地址,需要先申请一个 IEEE 账号。登入后点击如下入口开始申请。通常 IEEE 收到款后的第二天,即可邮件收到一个 Mac 地址的生成软件,填上日期等信息后,会生成一个 6BYTE(48bits)的地址段,前 3BYTE 数据为公司名,后面 3BYTE是序号。 ![]() 图4.在更新的列表中检查申请的地址 7 G* `: Y0 a7 r8 ` 8 t8 _0 B- P" t# e 05小结 本文介绍了 BLE MAC 地址的类型,基于芯片 ID 生成静态随机 MAC 地址,以及购买Public MAC 地址的流程。) C" e; P$ P0 c7 P! C0 s3 g ! {! `! H7 Q7 y; \0 r- q1 s " _ ~8 }6 I+ X) O% g! s 转载自: STM32单片机 如有侵权请联系删除, ^. x/ r$ V; P$ v# k : K+ |/ L# c1 K: f2 }3 q |
【2025·STM32峰会】GUI解决方案实训分享1-对LVGL咖啡机例程的牛刀小试以及问题排查
OpenBLT移植到STM32F405开发板
为什么要先开启STM32外设时钟?
【STM32MP157】从ST官方例程中分析RPMsg-TTY/SDB核间通信的使用方法
【经验分享】STM32实例-RTC实时时钟实验④-获取RTC时间函数与中断服务函数
STM32 以太网 MAC Loopback 的实现
STM32功能安全设计包,助力产品功能安全认证
基于STM32启动过程startup_xxxx.s文件经验分享
HRTIM 指南
ST 微控制器电磁兼容性 (EMC) 设计指南