加密
4 E8 ^5 K# B' l7 ]. `3 u4 c
" U; C. \2 n4 M# i1 G) A" I
蓝牙设备中采用加密的方法来保证连接的保密性。但在数据加密之前,需要存在一条经过认证的已建立连接。蓝牙加密采用8位至128位的密钥对蓝牙分组中的数据载荷进行加密,但不对蓝牙接入码和分组头进行加密。载荷加密的具体细节依赖于所需要的加密强度以及产品最终应用国家的地区性法规要求。 * v- a1 M& K4 e; W4 ]
1 S' a6 [$ E) f 蓝牙系统采用称为E0的序列加密算法对数据进行加密。对每一数据载荷(payload)E0算法都进行重新同步。E0序列加密包含三个部分:
, Q! g- P1 y" I5 n0 N# ]
8 D7 H, [4 }" N# E' q+ q6 ] j●初始化部分,生成载荷密钥; - N( X8 L* F' Q- |. @; k m& M
6 u: i9 g3 E3 _7 N
●密钥流比特生成器;
, K0 t0 l. g, T& E4 f3 T
$ o7 _, m; t& m0 \
●加密与解密硬件电路。 & D% ]: _. \( n8 t
1 M, K0 ^ {, T ^0 x0 K
有三种加密模式: + J; j$ s/ l6 ?1 r; o! w. w
, B/ t+ j- Y+ ~ z! A
● 加密模式1:不对任何数据进行加密; ! D; c! w- a8 E7 U8 U' \/ e
6 G; r% }+ Y& j$ b& {9 r7 j" R
● 加密模式2:点对多点(广播)数据流不加密,点对点数据流进行加密; 9 q4 m# ~4 l) Y
9 _9 h2 v7 S: P& ^8 B0 {
● 加密模式3:所有数据流均进行加密。 ' B! z9 C; n+ c, J% X
" |# f4 H: @" T2 O' S7 }- c
物理层数据安全性-跳频扩展频谱
4 N* V: A, a: q v: C3 m Y% U F; I" f3 ]$ j* s9 J
除了蓝牙标准所采取的其它安全手段以外,蓝牙通信所采取的跳频通信这一机制也使窃听变得极困难。
- Y2 z. e+ z2 h 4 i8 A8 I% U3 f0 F" T1 l
如前所述,蓝牙射频工作在2.4GHz频段。在北美和欧洲的大部分,蓝牙设备工作于从2.402至2.480GHz的频带,整个频带被分成 79个1MHz带宽的子信道。在跳频通信中,数据信号被窄带载波信号调制,而这些窄带载波信号则做为时间的函数不断从一个频率跳到另一个频率。蓝牙标准采用的是每秒跳跃1600次的跳频序列。
3 k, o7 o9 P+ Z2 O! H# E% V + v8 E F4 a: N( b. |) P s# y
收发双方都知道的跳频码决定了射频载波的频率以及跳频的顺序。为正确地进行信号接收,接收器必须设置成与发送方一样的跳频码,并在恰当的时间和正确的频率点监听载波信号。只有正确同步时,才能维持一个逻辑信道。其它接收器看到的FHSS信号仅是持续时间极短的脉冲噪声。
8 x; J8 y- |5 c' y- y & f4 m/ @# E. m* D1 P1 f
FHSS依靠频率的变化来对抗干扰。如果射频单元在某个频率遇到干扰,则会在下一步跳到另一频率点时重传受到干扰的信号。因此总的干扰可变得很低,位错误很少或几乎没有。 $ x1 n. [4 l9 ^1 w- g) z* B) s
5 d( W' X& e6 r$ Z
蓝牙数据完整性 * }2 n& D: T+ ^- }
0 ~/ C$ ?9 K7 y2 O3 M5 l
前向纠错(FEC)
" @' ~- g- O# S2 g$ \
6 h6 r. ^6 W6 [6 W& {/ @
蓝牙采用的错误校正有三种类型:
C+ f: O9 Q8 l6 s# R" Y3 C0 c3 n( x% P/ a4 Y0 a' C
●1/3编码率FEC
+ G% Z0 m0 m# V5 h/ X
1 F( ?- ^% t0 q; d5 M' k& d* z6 k
●2/3 编码率 FEC
/ c8 y, g5 ~ g6 f& R! z3 c, u9 i7 O4 A1 }, n, N$ e0 O7 Q0 m7 t
●数据的自动重发请求(ARQ)方案 7 ?( F. H, B! @. q; N
. u- s p( z/ S# U- ?
FEC(前向纠错)的目的是为了减少数据载荷重发的次数。但是,采用FEC的缺点是会明显地降低可达到的实际数据传输速率。 ' Y" c6 s9 c b$ V# K+ I2 d9 w
, {3 P1 d. { i( o/ c
数据白化 - G8 E& D2 S# f) `' B
1 E7 @" o* ?2 s' F
所有的分组头和载荷信息在发送前都要利用数据白化位进行白化处理。这主要是为了避免在传输过程中出现过长的连续0或1的位流模式。基带处理器需要从接收到的模拟数据信号中判断数据是0还是1,但过长的连续0或1位流会造成问题。因为在接收到的模拟数据信号中并不存在象直流信号中那样的参考点,因此必须依靠接收到的最后几个传输信号进行校正。任何连续的0或1的长序列位流串都可能导致校正失败。因此需要采用数据白化技术对信号进行扰码处理,以大大降低出现长序列0或1位流串的可能性。: [3 c3 X N( y% n( ~- W
0 M: |+ N! N: c$ S, ]" ? _
用于高级数据安全可编程解决方案 . [ E7 N7 O% n i' p
5 V# }0 s, q+ h" o: c5 r
对于大多数需要将保密放在首位来考虑的应用来说,蓝牙所提供的数据安全性是不够的。总的来说,就蓝牙安全性来说,还存在一些问题需要解决。蓝牙所提供的数据安全性措施对小型应用来说看起来已足够了,但任何敏感数据或会产生问题的数据都不应直接通过蓝牙传输。例如,蓝牙所采用的加密方案本身就有某些弱点。128位密钥长度的E0序列加密在某些情况下可通过O(2^64)方式破解。 8 u J8 K. E+ [ ^
% D0 H+ k1 o: U* `$ j
设想一种可能的情况,攻击者设法获取了用来保证两个设备间通信的加密密钥,然后即可窃听这两个设备间互相发送的消息。而且,攻击者还可以冒充其中的某个设备插入错误的信息。朗讯公司认为,避免这一问题的一个方法是用户采用较长的个人识别码(PIN码)而不是用短的PIN码,从而增加攻击者获取加密密钥的难度。而这又意味着要人工输入PIN号码。这实在令人觉得非常不方便,因为每次建立安全连接都需要输入PIN码。
: s+ x) `+ s$ Y3 I
. z% p) n# ]. f3 w" a3 S7 x 克服这种安全性问题的另一个方法是采用更强健的加密算法,如数字加密标准(DES),甚至三次DES来代替E0序列加密算法。DES是一种块加密方法,这意味着加密过程是针对一个数据块一个数据块地进行的。在DES算法中,原始信息被分成64位的固定长度数据块,然后利用56位的加密密钥通过置换和组合方法生成64位的加密信息。图2示出的是DES加密处理的框图。 ' N: {; V( O: F$ p
& b" S+ Z$ F! p% M8 q9 q
与蓝牙序列加密算法不同,数学上可以证明块加密算法是完全安全的。DES块密码是高度随机的、非线性的,生成的加密密文与明文和密钥的每一位都相关。DES的可用加密密钥数量多达72 x 1015个。应用于每一 明文信息的密钥都是从这一巨大数量的密钥中随机产生的。DES算法已被广泛采用并被认为是非常可靠的,而且现在出现了一种更为安全的DES算法变种--称为三次DES(TDES),它采用不同的密钥对信息连续进行三次DES加密处理。 0 f3 r9 i! W5 w' j
; {) q- y$ |% z. L+ \- I. u. q( Q 所有这些加密算法都可以采用低成本的可编程逻辑器件和现成可用的用于高级加密处理的智力产权(IP)产品实现。如图2所示的DES功能,仅需要2美元成本的芯片逻辑资源即可实现。目前,大批量时只用10美元即可购买到10万系统门的可编程逻辑器件,而且是现货,立即可以使用。这些器件还允许在设计中增加其它功能,如高级错误纠正。因此可编程逻辑器件可大幅度降低系统级的成本。 / e: I$ T6 k0 u; u$ U4 Z
5 l9 Y5 D2 z0 k8 V) v
基于软件的加密解决方案具有极好的灵活性,然而性能较低。另一方面,基于硬件的加密解决方案性能很高,但一旦设计完成后灵活性很差。而基于可编程逻辑的加密解决方案则可同时提供前述两种方案的优点,即具有很高水平的灵活性也具有很高的性能。 ; X5 m5 ^2 a9 a S* B2 U" Y
" e$ D2 {# t. ? 采用一个更强键的加密算法允许蓝牙技术安全地应用到范围广泛的安全性具有最重要地位的应用中去。这些应用包括:金融电子交易:ATM、智能卡;安全电子商务交易;安全办公通信;安全视频监视系统;数字机顶盒;高清晰度电视(HDTV)及其它消费电子设备。
d2 a# O; @) o/ V l* N3 I8 s+ v" Q; R6 L6 j
用于高级数据完整性可编程解决方案
4 O) \ K( P1 g4 U0 e+ J
+ o2 H5 A; w( r
蓝牙标准定义了可有效防止随机错误的方法,即采用数据白化和错误校验方法进行数据传输。然而,从理论上仍然存在这样的特定数据流,它可能会持续地造成蓝牙传输错误,虽然这种情况在通常的蓝牙传输中很难碰到。
4 n" ~* D9 L' ^
5 a6 m! K7 [" @$ I6 I; \! P 而且在更为恶劣的环境,如工业环境、办公大楼、机场和城市公共交通厂所等,仍然存在传输过程中产生差错的危险。在这些地方,来自其它多种蓝牙设备、无线网络、手机系统或其它工作在相同频段的电子设备的噪声和干扰都会导致问题。针对这些情况,可以再次采用可编程逻辑和高级纠错IP来实现无错通信。对恶劣的通信环境,可以采用一种更为强大的前向纠错技术,如Turbo卷积编码。 ! X0 V$ h0 s8 ~/ T1 |- J% U
% o! d5 G4 ^8 O" W0 S
urbo编码是一种高级前向纠错算法,它是第三代无线通信系统(如WCDMA中实现的)的标准纠错算法。Turbo编码的原理是由编码器生成包含两上独立编码比特序列和一个未编码比特序列的数据流。由于经过交织处理,两组校验比特序列是弱相关的。在Turbo解码器中,两组校验比特序列分别利用称为外部信息的软判决输出进行解码。Turbo解码的效率来自一系列译码循环过程中对外部信息的共享。外部信息从一个校验解码步骤传递到另一个,从一个循环传递到另一个。已经有此类Turbo卷积码的现成IP可用,并且可容易地采用低成本可编程逻辑实现。这一解决方案可以在恶劣和容易出错的环境中保证蓝牙数据完整性。
3 C" Q |" k Z1 y/ g9 ?6 W/ d
4 l2 S9 A5 F# j D! E
蓝牙应用中的可编程逻辑解决方案+ Q, `6 T1 R. s7 q& E3 I: p3 q
$ b' c5 R0 r7 D- |! U: ^' R8 V* e
目前,实现这一美好前景所面临的挑战集中于如何将蓝牙应用到下一代产品中。这可能是一个困难的任务,特别是当面对现有的产品结构时。如何集成蓝牙子系统?如何最小化软件开发开销和对系统的影响?如何创造针对特定应用的设备配置? : P6 s& d* F% {: D2 x
; C6 L3 h2 T2 r: h5 Q 可编程逻辑的一个巨大优点是可以根据特殊的要求调整系统配置。例如,目前提供的蓝牙器件最大性能仅721Kbps,并且仅能同时支持几个并发的网络(微微网)。对公共厂所的接入点(如机场休息室或企业会议室等),可能需要汇接大量的此类设备,以支持大量用户的高带宽连接。
4 x) }* u, S! \# k0 @8 q' C ' e' E9 P& G4 K4 m: V2 |* i$ z; J
可编程逻辑可以许多方式为设计提供灵活性,无论是连接一个不同的射频部分到所选择的基带控制器,还是象上面的例子一样集成更多的用户接口外设,或如图3那样实现数据安全性和完整性等增值功能。在所有情况下,您都会发现硬件设计会更快,并且可以多次进行设计修正,从而保证系统可以在更短的时间内达到正常工作,而所有这一切都没有采用ASIC时的NRE费用。