|
基本测试主要包括配置检查和BT测试两大部分2 z: B* }9 Y d! B6 c/ W
配置检查:4 f. D' ]" S& G8 j
为了进一步确保 porting 没有问题,在测试之前先确认 fw 以及 config 文件是否存在。
W! e- Z5 W8 E9 c4 t adb shell 到测试平台的根目录,检查测试平台的 vendor/firmware/目录中 rtlxxxx_fw 以及 rtlxxxx_config文件是否存在(xxxx 为 BT Chip 型号)。检查 Release 包中的 rtkbt/下的文件是否都已经安装到对应的目录.8 P+ b: s# b5 @, K2 c1 y! s
BT 测试:
% ?! }/ }/ W8 M: [/ N 本测试是 porting 结束后对 BT 基本和常用功能的一个快速测试,旨在快速验证一些基本问题,不代表BT完整的测试 , 测试结果也非正式test report 。 如果使用的是非Realtek BT chip ,该项测试可能没有意义。+ r% {, }% [" D# o0 c. c
基本功能测试如下:
' R: l- S4 z8 ]; [" N1 F0 F. x( W8 L: q, Y 1) 打开/关闭 BT 无失败现象。
1 }& ^( U1 ~% S! E 2) 能够搜索到近处 BT 设备。
& b" t1 Z @8 M, b7 Z) y/ H 3) 和搜索到的蓝牙耳机或其他设备配对。7 c8 Y2 L4 x' j6 f
4) 连接上蓝牙耳机,使用 BT A2DP 听音乐(sdcard 确保存在)。( t; Z* \ [9 w4 ?, G& g
5) 连接上蓝牙耳机,使用 BT HFP/HSP 打电话(确保用蓝牙时能够正常通话)。+ ?8 m1 H5 S1 u, k
6) 传输文件到远端支持蓝牙 OPP Server 的设备,从远端支持蓝牙 OPP client 的设备传送文件到本地(sdcard 确保存在)。
8 @1 u$ p N2 ^ 7) 连接上蓝牙键盘,打开需要输入的应用,通过蓝牙键盘输入。6 O: A7 E- k1 ^+ V4 P8 f, W
. v0 h, T$ J; e7 v. n: ]
: u4 w Z# F: Z& y$ c6 G 当发现蓝牙有问题的时候,需要同时提供对应蓝牙问题报告下面的 log,否则可能会因为 log信息不足无法定位问题.所以请务必学会抓取下列蓝牙 log 的方法.
- b/ _3 r5 R( R/ B" t7 f蓝牙 Log 相关的配置文件:) E/ g$ d8 G! b) y/ E
蓝牙相关的配置文件存放在设备的/system/etc/bluetooth/bt_stack.conf .可以通过 adb 方式进行修改.默认的配置文件如下:
. {1 V8 Y* D+ C( F& \ # Enable trace level reconfiguration function
* U5 S3 h0 O: f, ^: b # Must be present before any TRC_ trace level settings
& o% `$ O+ U/ Z1 Q6 E' \ TraceConf=true
3 M% l! A* b& G" @7 t o3 O3 {# x4 Z8 Y' r' y
# Trace level configuration& D2 C2 R Y/ R6 G
# BT_TRACE_LEVEL_NONE 0 ( No trace messages to be generated )
$ S+ S0 h" D1 U- O4 z3 M- ^ # BT_TRACE_LEVEL_ERROR 1 ( Error condition trace messages )% L+ C9 _% y% P* Y% |: R" x
# BT_TRACE_LEVEL_WARNING 2 ( Warning condition trace messages )3 B* U% p) m) G, B+ ~
# BT_TRACE_LEVEL_API 3 ( API traces )
; p) }7 \3 q' C6 V # BT_TRACE_LEVEL_EVENT 4 ( Debug messages for events )3 C1 @ x0 M6 q
# BT_TRACE_LEVEL_DEBUG 5 ( Full debug messages )
% {- j+ O9 r) T2 O0 I7 O& y C& _ # BT_TRACE_LEVEL_VERBOSE 6 ( Verbose messages ) - Currently supported for
" L, s e4 A; S+ e. b2 Q! P6 W3 {$ RTRC_BTAPP only.3 {, Z; w- p$ X5 V0 n4 _5 S7 P
TRC_BTM=2
; L% I7 Y* x$ [& _1 Q3 H/ H6 s TRC_HCI=24 |) O: ^0 b, s3 G
TRC_L2CAP=2
% H/ V' F5 M0 l TRC_RFCOMM=2
9 c; g8 K7 ?6 w$ k TRC_OBEX=20 H# V* R3 W3 J+ k2 \, F p: t
TRC_AVCT=2
X4 W* P2 U1 ] TRC_AVDT=2
3 U+ Q. w4 B8 p. E" M9 r- U. B TRC_AVRC=2
$ \+ j# b! e6 P# g0 {. B7 M$ T TRC_AVDT_SCB=2
/ G+ Z. A6 p! \9 \" o" A2 ? TRC_AVDT_CCB=2* m( p; V0 {0 `4 {6 C
TRC_A2D=2
- {# y Q p/ E) v2 T0 Y/ R, T TRC_SDP=2
9 N# n- Q. i, [ TRC_GATT=2+ V6 i! P# V8 t6 X/ k7 R; K
TRC_SMP=2
7 z. z5 K8 p' w. _1 V X TRC_BTAPP=23 N4 Y( M6 c2 i$ f! O% R
TRC_BTIF=2
1 ?- T. H k( C* N: r7 X TRC_GAP=2
% T6 F }$ A& H7 P1 k) R) _ TRC_BNEP=2
! j9 g( L" O& L9 J7 C TRC_PAN=24 w6 o5 F" D$ t( L& O: j
TRC_HID_HOST=2
# ~: Z$ g" W4 y9 K8 y/ } TRC_HID_DEV=2
9 m7 n' |* D' v4 {% @9 k6 {: U' g: i1 r0 e' V
! G$ {/ X. Z4 e+ K+ F, r7 E; w
Logcat –v time. q7 [3 R* T" i% I" c2 U! Q
在抓取 log 的时候,必须添加”-v time”选项.否则没法将 log 和出现问题的时间点对应起来,给分析 log 会带来很大的麻烦.
3 v$ X7 G8 Z0 [ 测试前,可以打开 log 并将 log 导入到设备的某个分区,待测试完成后再通过 adb, sdcard 等方式导出 log.
n- _4 [6 v, L
. E" ?4 Z, _& b2 ~BtSnoop+ N# E# u8 V8 n6 k& d5 Q
打开 btsnoop 录制 功能 设置 persist.bluetooth.btsnooplogmode 属 性为 full, 设 置保 存路 径persist.bluetooth.btsnooppath。然后开关一次蓝牙生效.
M6 c% h7 L- h6 A# D 在蓝牙打开时,这个文件会自动被覆盖一次,所以重现到问题后,需要尽快采用 adb 或者 sdcard 将 btsoop文件导出.切勿重新开关蓝牙或者重启设备.
F u7 ~- x/ M% D/ s
# o. x' n6 C# s0 S4 g+ ~% M1 l& I获取 Bluetooth 进程相关信息
6 _ h+ d; l" m0 g2 h) t) H/ z! n& U6 c 输入 adb shell dumpsys bluetooth_manager > xxx.log, 获取 bt 进程相关信息
& D* j, G# L9 r5 B& v P3 x% E; I" q, z) ~" E- `! k" `3 o
注意事项
F7 j) u/ a2 O! D2 l" F I 报告蓝牙问题 至少 需要 提供 下列信息:% W6 A6 U9 ~. z* _( p
logcat –v time# ~# l; |1 b- g" L% Q0 `
btsnoop
r( `% r/ V& x; F0 U Bluetooth 进程信息
6 \4 p% Z) Z& F" D 出现问题的时间点( 以设备时间为准)
1 E$ W* p! F, ~- p! m- \8 i 重现步骤.
3 R `7 T; V7 l. d9 H
% ?2 V- O' P z, B& n7 j+ t3 L4 P
常见问题分析2 S" f4 X8 z$ e4 V4 j0 F, Y& z
BT 打开失败(UART)2 e* F& U3 j7 n, b( R5 d0 c
打开 H5 UART Driver Log, 使用 logcat 抓取 log,看 H5 SYNC 过程时候成功,如果 H5 SYNC 失败,那么需要首先检查硬件电路是否正确(Power Supply, BT Reset PIN, UART TX/RX,CTS/RTS),然后检查卡片 efuse,用示波器量测 UART 波形,看 Host 是否把数据正确的发送到 Controller。( d0 @8 ^9 {6 x& ~2 p2 s \
如果 H5 SYNC 成功,那么下一步就是 Change Baudrate,判断 Change Baudrate 是否成功。如果 Change Baudrate 失败,那么需要确定 Host 是否支持该波特率,config 文件是否正确设定了波特率。$ i4 l6 R! c' Y4 J; g, F
如果 Change Baudrate 成功,下一步是下载 fw 以及 config 文件,如果下载完毕之后,收不到 Controller回复的 Command Complete Event,那么需要检查 fw 以及 config 文件是否正确,BT Reset PIN 是否为高电平。3 l9 t2 s3 y* g# r
如果下载 fw 以及 config 文件成功,那么下一步就是根据 config 文件的设定修改 HW Flowcontrol 的设置。设置成功之后,bluedroid stack 会下第一个 HCI Comamnd。
! }' |0 _$ u8 M/ s) F 如果第一个 HCI Command 一直 H5 重传,那么说明可能 HW flowcontrol 有问题,需要检查 Host 的UART driver 是否支持 HW Flowcontrol。# G# U0 [7 q* P6 d, C$ f7 r
( j; y D$ k9 x- I; w9 Y
BT 打开失败(USB)! U3 Y. D1 N( ~9 P ?) ]
用 logcat 抓取打开蓝牙打开的 log,搜索“dev/bus/usb”字样看是否有这样的 log:Added device UsbDevice[mName=/dev/bus/usb/002/002,mVendorId=3034,mProductId=46880,mClass=239,mSubclass=2. 如果有,检查下 mVendorId和mProductId是不是对应当前使用的蓝牙芯片。如果没有则是没有识别蓝牙卡片,需要首先检查硬件电路是否正确.
3 O1 o( ^' i5 F* F" s 查看 USB 的驱动是否正常加载。登陆到平台里(adb shell),然后使用命令 lsmod 来查看是否有rtk_btusb.ko 的存在。% v m6 J/ v6 G6 C& |+ e7 |9 N6 _& |
- C- H/ |! C# @7 ?6 x
以上观点纳拓科技提供,请勿随意复制、编辑转用5 j6 F. I t& L9 r3 P! F
$ x8 ^8 B3 X* u% j$ }9 k
1 O3 T/ `( H9 t( b
( `( u5 V# s& x/ N9 B# J. W9 ` |
|