中国安防论坛

 找回密码
 注册
查看: 30412|回复: 0

[心得] Realtek蓝牙Android10.0移植结束后的基本测试和常见问题分析

[复制链接]

安防知名大师

Rank: 7Rank: 7Rank: 7

积分
1247
QQ
发表于 2023-11-27 15:06:35 | 显示全部楼层 |阅读模式
基本测试主要包括配置检查和BT测试两大部分  A2 l) @1 e8 G$ W
配置检查:- F; `2 J6 I% P3 x  t
  为了进一步确保 porting 没有问题,在测试之前先确认 fw 以及 config 文件是否存在。1 C8 q( M% q5 o( Y1 X* y
  adb shell 到测试平台的根目录,检查测试平台的 vendor/firmware/目录中 rtlxxxx_fw 以及 rtlxxxx_config文件是否存在(xxxx 为 BT Chip 型号)。检查 Release 包中的 rtkbt/下的文件是否都已经安装到对应的目录.1 @' u2 S, R3 W
BT 测试:+ K1 ^! Y% I9 R. ?' J9 F  U- k2 l2 j
  本测试是 porting 结束后对 BT 基本和常用功能的一个快速测试,旨在快速验证一些基本问题,不代表BT完整的测试 , 测试结果也非正式test report 。 如果使用的是非Realtek BT chip ,该项测试可能没有意义。! K; X. J" M2 j3 l0 g/ N7 W
基本功能测试如下:
  d* {) x$ w8 ]  _7 V8 C2 g  1) 打开/关闭 BT 无失败现象。
0 U/ W3 h- P: C, j* Q+ a, D; }  2) 能够搜索到近处 BT 设备。
' x7 @8 O6 N9 z1 G& q  3) 和搜索到的蓝牙耳机或其他设备配对。
+ Z: L0 ?0 p8 d' H  ?1 b  4) 连接上蓝牙耳机,使用 BT A2DP 听音乐(sdcard 确保存在)。
& T! g; L. @+ X1 J# U  5) 连接上蓝牙耳机,使用 BT HFP/HSP 打电话(确保用蓝牙时能够正常通话)。
) M, `: q; K* L8 }  6) 传输文件到远端支持蓝牙 OPP Server 的设备,从远端支持蓝牙 OPP client 的设备传送文件到本地(sdcard 确保存在)。& K9 A" g! S9 Q; N* @5 v
  7) 连接上蓝牙键盘,打开需要输入的应用,通过蓝牙键盘输入。7 l' s% w/ w; H& M( S- r
( [" U5 ^) s; i: W% `$ i2 }* W( p
' O% k6 o# `0 s$ s, ?/ }: V
  当发现蓝牙有问题的时候,需要同时提供对应蓝牙问题报告下面的 log,否则可能会因为 log信息不足无法定位问题.所以请务必学会抓取下列蓝牙 log 的方法.3 w7 Q( d# y5 O( V6 I: Y
蓝牙 Log 相关的配置文件:
7 p4 e0 o7 P% e9 {  蓝牙相关的配置文件存放在设备的/system/etc/bluetooth/bt_stack.conf .可以通过 adb 方式进行修改.默认的配置文件如下:7 e  ~, l! m8 W- j/ ^% X6 a& Y  f
    # Enable trace level reconfiguration function
# z; M6 ~9 L3 z. m/ `2 Y/ s    # Must be present before any TRC_ trace level settings. W7 }9 T' I& X$ _
    TraceConf=true
- l1 z7 a. V/ @, o) W
/ f6 d( b) r! u  k    # Trace level configuration1 S; L0 h) w8 \: `
    # BT_TRACE_LEVEL_NONE 0 ( No trace messages to be generated )
+ V/ S6 j' D$ d9 t' ?    # BT_TRACE_LEVEL_ERROR 1 ( Error condition trace messages )% s& ~4 W, L0 v, \, H6 ~5 E) C
    # BT_TRACE_LEVEL_WARNING 2 ( Warning condition trace messages ); J1 M' T6 k3 f! e! o" \) e
    # BT_TRACE_LEVEL_API 3 ( API traces )  `+ f% [9 a" e' ?' w4 T6 E) S& g
    # BT_TRACE_LEVEL_EVENT 4 ( Debug messages for events )5 A1 V, c3 k8 G. M4 P  ~! X
    # BT_TRACE_LEVEL_DEBUG 5 ( Full debug messages )+ p2 m9 y$ z% z) i$ w
    # BT_TRACE_LEVEL_VERBOSE 6 ( Verbose messages ) - Currently supported for  @* q4 Q7 P( i
TRC_BTAPP only./ r. i9 t1 M8 T. Q
    TRC_BTM=2
0 g/ K; F3 L3 A    TRC_HCI=2
9 l0 D/ I( t5 R  y- x: f* p9 n8 C( f    TRC_L2CAP=2
5 U2 e; u  y5 Y2 g/ a    TRC_RFCOMM=2% O+ o) j2 C# M" G6 `% e
    TRC_OBEX=2
! \$ o. t$ S& i1 P: u. f5 [. T    TRC_AVCT=2
5 M) _7 R2 {( D3 A! g    TRC_AVDT=2; K) N6 K* {# [; V+ b
    TRC_AVRC=2- S/ K! h/ F; W# Y/ }+ D
    TRC_AVDT_SCB=2
3 Y4 H9 ?; q0 q    TRC_AVDT_CCB=2# A  k- C4 `. T. [. x/ m
    TRC_A2D=2
9 u8 \# K' G) S7 c3 ~. \, W    TRC_SDP=2
* R; n, Z2 _9 T# ?    TRC_GATT=2
5 R' _) u) n# D2 A* g    TRC_SMP=25 r! Q8 U3 C9 Y9 _5 C; [
    TRC_BTAPP=2( i* U5 J6 _5 ~; q0 u
    TRC_BTIF=2
5 j/ g& K4 ~, C  T( G! x* z    TRC_GAP=2( @# t7 H9 @5 Z/ b4 q* r+ g% u' ?
    TRC_BNEP=2
* i3 g; d9 r0 y1 ~4 @6 X3 h1 y. g    TRC_PAN=2
1 t2 |) r$ D! z+ p) _" G3 X    TRC_HID_HOST=2
& H# x/ w7 x6 q- d4 @: H    TRC_HID_DEV=2' n+ e6 ^9 M* f+ c' c

% q9 \# k7 Z1 C1 O% Y6 v2 M0 f; p
Logcat –v time
1 U; m3 ?* @: ~  F  在抓取 log 的时候,必须添加”-v time”选项.否则没法将 log 和出现问题的时间点对应起来,给分析 log 会带来很大的麻烦.3 R) Q1 a; {; M3 B: S
  测试前,可以打开 log 并将 log 导入到设备的某个分区,待测试完成后再通过 adb, sdcard 等方式导出 log.
; a4 g8 D+ P2 I- P
6 d# \1 s. h; O- u) F2 EBtSnoop
" W2 _& |4 N4 n4 D# ?9 Z+ C  打开 btsnoop 录制 功能 设置 persist.bluetooth.btsnooplogmode 属 性为 full, 设 置保 存路 径persist.bluetooth.btsnooppath。然后开关一次蓝牙生效.9 [0 J8 C: U1 e# O
  在蓝牙打开时,这个文件会自动被覆盖一次,所以重现到问题后,需要尽快采用 adb 或者 sdcard 将 btsoop文件导出.切勿重新开关蓝牙或者重启设备.! F( {& q& {' F- q
6 g& ^0 H/ q) B2 @
获取 Bluetooth 进程相关信息. ^, G' ]1 I& M
  输入 adb shell dumpsys bluetooth_manager > xxx.log, 获取 bt 进程相关信息
1 J* ~. R7 n; s1 F- ?- k
7 L; {) y' v& b0 e注意事项3 {5 m9 p, j+ r
  报告蓝牙问题 至少 需要 提供 下列信息:
" m0 x) |$ c; |2 g4 y6 N! [1 j   logcat –v time
& E, O$ y5 X5 Q% |+ x   btsnoop* O( w* Q7 e) G. ?4 P
   Bluetooth 进程信息2 y" d( e5 ~, ]5 O! k" H6 P
  出现问题的时间点( 以设备时间为准)
( S9 z9 M  u( X( L6 {6 t% I  重现步骤.
( }/ s) `2 H& N) i( c% b# r! l5 e2 V/ c8 h
- L0 q) {# Z& u; U6 I: E
常见问题分析
$ J3 J# ?/ i; [, fBT 打开失败(UART)/ y' H3 l9 j4 G
    打开 H5 UART Driver Log, 使用 logcat 抓取 log,看 H5 SYNC 过程时候成功,如果 H5 SYNC 失败,那么需要首先检查硬件电路是否正确(Power Supply, BT Reset PIN, UART TX/RX,CTS/RTS),然后检查卡片 efuse,用示波器量测 UART 波形,看 Host 是否把数据正确的发送到 Controller。
2 w( {" {' N+ ?7 }7 l. M& X    如果 H5 SYNC 成功,那么下一步就是 Change Baudrate,判断 Change Baudrate 是否成功。如果 Change Baudrate 失败,那么需要确定 Host 是否支持该波特率,config 文件是否正确设定了波特率。, B8 h1 h/ V. A! ~' N  S
    如果 Change Baudrate 成功,下一步是下载 fw 以及 config 文件,如果下载完毕之后,收不到 Controller回复的 Command Complete Event,那么需要检查 fw 以及 config 文件是否正确,BT Reset PIN 是否为高电平。) j( R$ t3 k3 E
    如果下载 fw 以及 config 文件成功,那么下一步就是根据 config 文件的设定修改 HW Flowcontrol 的设置。设置成功之后,bluedroid stack 会下第一个 HCI Comamnd。
# @! R. ], R0 b4 t    如果第一个 HCI Command 一直 H5 重传,那么说明可能 HW flowcontrol 有问题,需要检查 Host 的UART driver 是否支持 HW Flowcontrol。, U( o/ Q1 g2 g' g' m/ c

- k" K, P1 T" W/ o. K& ~BT 打开失败(USB)) S0 R; k6 b( L! v! f
    用 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是不是对应当前使用的蓝牙芯片。如果没有则是没有识别蓝牙卡片,需要首先检查硬件电路是否正确.
+ E# C  i& j. H% D( N. N9 w! S    查看 USB 的驱动是否正常加载。登陆到平台里(adb shell),然后使用命令 lsmod 来查看是否有rtk_btusb.ko 的存在。0 w7 k2 o8 a* C: z1 f  J1 Z

1 J# U) d2 N7 u3 [0 J以上观点纳拓科技提供,请勿随意复制、编辑转用/ ?5 p. N2 ~2 X2 M7 O( g

# Y. |& x7 S) A. D6 V  j9 T" g" g( v- ^+ L1 [

1 \8 z) n, \: f' u5 E/ }
WiFi模块/无线路由/无线中继/交换机方案PCBA模块QQ:42142951
您需要登录后才可以回帖 登录 | 注册

本版积分规则

安豆网|Archiver|手机版|中国安防论坛 ( 粤ICP备09063021号 )

GMT+8, 2025-5-23 21:03 , Processed in 0.094835 second(s), 20 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表