RK3326 android10.0(Q) 音频通道 tinyalsa_hal层 bug 记录

简介: RK3326 android10.0(Q) 音频通道 tinyalsa_hal层 bug 记录

Platform: Rk3329

OS: Android 10.0

Kernel: v4.19.111


问题现象


在开发完音频驱动 rk817 后,上层APP调用通道切换接口 mAudioManager.setSpeakerphoneOn(), 发现无效,

一直未切换成功,通道始终在麦克风上。


问题排查


开始先从 setSpeakerphoneOn 入手,跟踪


frameworks/base/services/core/java/com/android/server/audio/AudioService.java


frameworks/base/services/core/java/com/android/server/audio/AudioDeviceBroker.java


日志打印 framework 层是ok的,向jni传递通道数据正常。


system_process D/cck: on=true eventSource=setSpeakerphoneOn(true) from u/pid:1000/2841

system_process D/cck: mForcedUseForComm=1

system_process I/cck: time=847700

system_process D/cck: time=847700

system_process E/cck: MSG_IIL_SET_FORCE_USE arr

system_process D/cck: useCase=0 config=1

system_process D/cck: eventSource=setSpeakerphoneOn(true) from u/pid:1000/2841


system_process I/cck: time=852780

system_process D/cck: time=852780

system_process D/cck: on=false eventSource=setSpeakerphoneOn(false) from u/pid:1000/2841

system_process D/cck: mForcedUseForComm=0

system_process I/cck: time=852782

system_process D/cck: time=852782

system_process E/cck: MSG_IIL_SET_FORCE_USE arr

system_process D/cck: useCase=0 config=0

system_process D/cck: eventSource=setSpeakerphoneOn(false) from u/pid:1000/2841


向下寻找到hal层,hardware/rockchip/audio/tinyalsa_hal/


日志打印如下


听筒


start_output_stream:873 out = 0xf75a8000,device = 0x2,outputs[OUTPUT_HDMI_MULTI] = 0x0

AudioHardwareTiny: out->Device : 0x2

alsa_route: route_pcm_card_open(card 0, route 0)

D/alsa_route: route_info->sound_card 0, route_info->devices 0

D/alsa_route: route_pcm_card_open() INCALL_OFF_ROUTE 26

D/alsa_route: route_set_controls() set route 0

D/AudioHardwareTiny: start_output_stream:968, out = 0xf75a8000

D/alsa_route: route_set_controls() set route 24


免提


start_output_stream:873 out = 0xf75a8000,device = 0x2,outputs[OUTPUT_HDMI_MULTI] = 0x0

/AudioHardwareTiny: out->Device : 0x2

alsa_route: route_pcm_card_open(card 0, route 24)

D/alsa_route: route_info->sound_card 0, route_info->devices 0

D/alsa_route: route_pcm_card_open() INCALL_OFF_ROUTE 26

D/alsa_route: route_set_controls() set route 24

D/AudioHardwareTiny: start_output_stream:968, out = 0xf75a8000


耳机


start_output_stream:873 out = 0xf75a8000,device = 0x4,outputs[OUTPUT_HDMI_MULTI] = 0x0

AudioHardwareTiny: out->Device : 0x4

alsa_route: route_pcm_card_open(card 0, route 14)

D/alsa_route: route_info->sound_card 0, route_info->devices 0

D/alsa_route: route_pcm_card_open() INCALL_OFF_ROUTE 26

D/alsa_route: route_set_controls() set route 14

D/AudioHardwareTiny: start_output_stream:968, out = 0xf75a8000


发现耳机 device 类型是正确的,听筒和免提切换时 device 并未改变,alsa route 打印 只找到 set route 0 和 route 24


AUDIO_DEVICE_OUT_EARPIECE = 0x1, // 听筒


AUDIO_DEVICE_OUT_SPEAKER = 0x2, // 扬声器


AUDIO_DEVICE_OUT_WIRED_HEADSET = 0x4, // 线控耳机


据此推测节点配置不对,pull 出设备中 vendor/etc/audio_policy_configuration.xml 查看,其中并


不包含 AUDIO_DEVICE_OUT_EARPIECE 节点,破案了


解决方案


device\rockchip\common\audio_policy_configuration.xml


     <modules>
         <module name="primary" halVersion="2.0">
             <attachedDevices>
+                <item>Earpiece</item>
                 <item>Speaker</item>
             <devicePorts>
+                <devicePort tagName="Earpiece" type="AUDIO_DEVICE_OUT_EARPIECE" role="sink">
+                </devicePort>
                 <devicePort tagName="Speaker" type="AUDIO_DEVICE_OUT_SPEAKER" role="sink">
                 </devicePort>
             <routes>
+                <route type="mix" sink="Earpiece"
+                       sources="primary output"/>
                 <route type="mix" sink="Speaker"
                        sources="primary output"/>



hardware\libhardware_legacy\audio\audio_policy.conf

 # as well as the output device selected by default.
 # Devices are designated by a string that corresponds to the enum in audio.h
 global_configuration {
-  attached_output_devices AUDIO_DEVICE_OUT_SPEAKER
+  attached_output_devices AUDIO_DEVICE_OUT_EARPIECE|AUDIO_DEVICE_OUT_SPEAKER
   default_output_device AUDIO_DEVICE_OUT_SPEAKER
   attached_input_devices AUDIO_DEVICE_IN_BUILTIN_MIC|AUDIO_DEVICE_IN_REMOTE_SUBMIX
 }

hardware\rockchip\audio\tinyalsa_hal\audio_hw.c

unsigned getOutputRouteFromDevice(uint32_t device)
{
    /*if (mMode != AudioSystem::MODE_RINGTONE && mMode != AudioSystem::MODE_NORMAL)
        return PLAYBACK_OFF_ROUTE;
    */
    ALOGD("%s:%d, device = 0x%x",__FUNCTION__,__LINE__, device);
    switch (device) {
+    case AUDIO_DEVICE_OUT_EARPIECE:
+        return EARPIECE_NORMAL_ROUTE; 
     case AUDIO_DEVICE_OUT_SPEAKER:
         return SPEAKER_NORMAL_ROUTE;
static int start_output_stream(struct stream_out *out)
{
    struct audio_device *adev = out->dev;
    int ret = 0;
    int card = (int)SND_OUT_SOUND_CARD_UNKNOWN;
    int device = 0;
   if (out->device & (
+             AUDIO_DEVICE_OUT_EARPIECE |
                      AUDIO_DEVICE_OUT_SPEAKER |
                      AUDIO_DEVICE_OUT_WIRED_HEADSET |
                      AUDIO_DEVICE_OUT_WIRED_HEADPHONE |
                      AUDIO_DEVICE_OUT_ALL_SCO)) {
        card = adev->dev_out[SND_OUT_SOUND_CARD_SPEAKER].card;

参考文章


Android音频底层调试-基于tinyalsa

Android 音频tinyalsa开发

目录
相关文章
|
7月前
|
存储 缓存 Android开发
安卓Jetpack Compose+Kotlin, 使用ExoPlayer播放多个【远程url】音频,搭配Okhttp库进行下载和缓存,播放完随机播放下一首
这是一个Kotlin项目,使用Jetpack Compose和ExoPlayer框架开发Android应用,功能是播放远程URL音频列表。应用会检查本地缓存,如果文件存在且大小与远程文件一致则使用缓存,否则下载文件并播放。播放完成后或遇到异常,会随机播放下一首音频,并在播放前随机设置播放速度(0.9到1.2倍速)。代码包括ViewModel,负责音频管理和播放逻辑,以及UI层,包含播放和停止按钮。
|
编解码 监控 API
Android平台GB28181设备接入侧音频采集推送示例
GB/T28181是广泛应用于视频监控行业的标准协议规范,可以在不同设备之间实现互联互通。今天我们主要探讨Android平台的Audio采集部分。
135 1
|
8月前
|
Android开发
【Android App】蓝牙的设备配对、音频传输、点对点通信的讲解及实战(附源码和演示 超详细)
【Android App】蓝牙的设备配对、音频传输、点对点通信的讲解及实战(附源码和演示 超详细)
1578 0
|
编解码 开发工具 Android开发
Android平台RTSP轻量级服务|RTMP推送摄像头或屏幕之音频接口设计
好多开发者在做Android平台录像或者RTSP轻量级服务、RTMP推送相关模块时,对需要设计哪些常用接口会心存疑惑,本文主要以大牛直播SDK(官方)为例,简单介绍下Android平台直播推送SDK所有音频相关的接口,感兴趣的开发者可以看看。
108 0
|
8月前
|
XML Java Android开发
Android Studio App开发中使用录音机、MediaRecorder录制音频和MediaPlayer播放音频讲解及实战(附源码)
Android Studio App开发中使用录音机、MediaRecorder录制音频和MediaPlayer播放音频讲解及实战(附源码)
317 0
|
7月前
|
存储 数据库 Android开发
安卓Jetpack Compose+Kotlin,支持从本地添加音频文件到播放列表,支持删除,使用ExoPlayer播放音乐
为了在UI界面添加用于添加和删除本地音乐文件的按钮,以及相关的播放功能,你需要实现以下几个步骤: 1. **集成用户选择本地音乐**:允许用户从设备中选择音乐文件。 2. **创建UI按钮**:在界面中创建添加和删除按钮。 3. **数据库功能**:使用Room数据库来存储音频文件信息。 4. **更新ViewModel**:处理添加、删除和播放音频文件的逻辑。 5. **UI实现**:在UI层支持添加、删除音乐以及播放功能。
|
8月前
|
XML 开发工具 Android开发
|
5月前
|
编解码 监控 API
惊艳登场!揭秘如何在Android平台上轻松玩转GB28181标准,实现多视频通道接入的超实用指南!
【8月更文挑战第14天】GB28181是公共安全视频监控联网的技术标准。本文介绍如何在Android平台上实现该标准下的多视频通道接入。首先准备开发环境,接着引入GB28181 SDK依赖并初始化SDK。实现设备注册与登录后,通过指定不同通道号请求多路视频流。最后,处理接收到的数据并显示给用户。此过程涉及视频解码,需确保应用稳定及良好的用户体验。
112 0
|
7月前
|
缓存 Android开发 Kotlin
【安卓app开发】kotlin Jetpack Compose框架 | 先用OKhttp下载远程音频文件再使用ExoPlayer播放
使用 Kotlin 的 Jetpack Compose 开发安卓应用时,可以结合 OkHttp 下载远程音频文件和 ExoPlayer 进行播放。在 `build.gradle` 添加相关依赖后,示例代码展示了如何下载音频并用 ExoPlayer 播放。代码包括添加依赖、下载文件、播放文件及简单的 Compose UI。注意,示例未包含完整错误处理和资源释放,实际应用需补充这些内容。
|
7月前
|
存储 Android开发 Kotlin
开发安卓app OKhttp下载后使用MediaPlayer播放
在Android Jetpack Compose应用程序中,要使用OkHttp下载远程音频文件并在本地播放,你需要完成以下几个步骤: 1. **添加依赖**:确保`build.gradle`文件包含OkHttp和Jetpack Compose的相关依赖。 2. **下载逻辑**:创建一个`suspend`函数,使用OkHttp发起网络请求下载音频文件到本地。 3. **播放逻辑**:利用`MediaPlayer`管理音频播放状态。 4. **Compose UI**:构建用户界面,包含下载和播放音频的按钮。