全志T113芯片蓝牙音乐播放失败如何解决?

时间:2023-01-12 12:02:27

1.主题

T113-S3 蓝牙音乐播放失败问题

2.问题背景

硬件:T113 + XR829 软件:Linux(非Tina)

3.问题描述

3.1复现步骤

#驱动路径要根据固件实际路径
insmod /lib/modules/5.4.61±ab179/xradio_btlpm.ko

等驱动安装完再执行后续操作
echo 0 > /sys/class/rfkill/rfkill0/state
sleep 1
echo 1 > /sys/class/rfkill/rfkill0/state
sleep 1

hciattach -n ttyS1 xradio &

hciconfig hci0 up
hciconfig hci0 piscan

#启动蓝牙协议栈
bluetoothd -n &

#设定本机为播放源
bluealsa -p a2dp-source &

#进入蓝牙控制终端
bluetoothctl

#扫描周边蓝牙设备
scan on
#若例表中已找到设备则手动停止扫描
scan off
#连接蓝牙音箱
connect <蓝牙音箱MAC>

连接成功提示Device 30:21:23:6F:18:E2 Connected: yes

#退出bluetoothctl
exit

#播放音乐aplay -D bluealsa:DEV=音箱mac 音乐文件路径
aplay -D bluealsa:DEV=30:21:23:6F:18:E2 /a.wav &

3.2具体表现

蓝牙音乐播放失败,并且出现蓝牙设备断开现象

4.问题分析

1、对比R328等Tina平台,以上的验证方法没有问题,bluez 和 bluealsa版本也一致,因此判断不是操作或者版本本身的问题。 2、由于蓝牙已经断开,查看进程情况,通过PS命令,看出Bluetoothd进程还在,但是bluealsa进程已经退出。 3、加打印分析bluealsa退出点,经过验证是在SBC编码环节。 4、排查SBC编码的代码,发现程序在某个点会崩溃。 5、在网上查找相关案例,疑似与编译配置有关系。

5.根本原因

与SBC编译的配置有关系,在当前的编译工具链环境下,需要打开--enable-high-precision配置

6.解决办法

如下修改配置:

  • 修改sbc_primitives.h
diff --git a/sbc/sbc_primitives.h b/sbc/sbc_primitives.h
index e01c957..b060484 100644
--- a/sbc/sbc_primitives.h
+++ b/sbc/sbc_primitives.h
@@ -27,6 +27,10 @@
 #ifndef __SBC_PRIMITIVES_H
 #define __SBC_PRIMITIVES_H

+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
 #define SCALE_OUT_BITS 15
 #define SBC_X_BUFFER_SIZE 328
  • 在sbc.mk中增加
SBC_CONF_OPTS = --enable-high-precision