标记当前处理的音频源类型

bash 复制代码
diff --git a/frameworks/av/services/audiopolicy/enginedefault/src/Engine.cpp b/frameworks/av/services/audiopolicy/enginedefault/src/Engine.cpp
index e50f81aca9c..1de19a5afec 100755
--- a/frameworks/av/services/audiopolicy/enginedefault/src/Engine.cpp
+++ b/frameworks/av/services/audiopolicy/enginedefault/src/Engine.cpp
@@ -16,8 +16,8 @@

 #define LOG_TAG "APM_AudioPolicyEngine"
 //#define LOG_NDEBUG 0
-
-//#define VERY_VERBOSE_LOGGING
+#define TRACE_CASE(source) ALOGD("zzz getDeviceForInputSource: selected %s", #source);
+#define VERY_VERBOSE_LOGGING
 #ifdef VERY_VERBOSE_LOGGING
 #define ALOGVV ALOGV
 #else
@@ -510,6 +510,7 @@ sp<DeviceDescriptor> Engine::getDeviceForInputSource(audio_source_t inputSource)
     switch (inputSource) {
     case AUDIO_SOURCE_DEFAULT:
     case AUDIO_SOURCE_MIC:
+     TRACE_CASE(AUDIO_SOURCE_MIC);
         device = availableDevices.getDevice(
                 AUDIO_DEVICE_IN_BLUETOOTH_A2DP, String8(""), AUDIO_FORMAT_DEFAULT);
         if (device != nullptr) break;
@@ -524,6 +525,7 @@ sp<DeviceDescriptor> Engine::getDeviceForInputSource(audio_source_t inputSource)
         break;

     case AUDIO_SOURCE_VOICE_COMMUNICATION:
+     TRACE_CASE(AUDIO_SOURCE_VOICE_COMMUNICATION);
         // Allow only use of devices on primary input if in call and HAL does not support routing
         // to voice call path.
         if ((getPhoneState() == AUDIO_MODE_IN_CALL) &&
@@ -559,6 +561,7 @@ sp<DeviceDescriptor> Engine::getDeviceForInputSource(audio_source_t inputSource)
     case AUDIO_SOURCE_VOICE_RECOGNITION:
     case AUDIO_SOURCE_UNPROCESSED:
     case AUDIO_SOURCE_HOTWORD:
+     TRACE_CASE(AUDIO_SOURCE_HOTWORD);
         if (inputSource == AUDIO_SOURCE_HOTWORD) {
             // We should not use primary output criteria for Hotword but rather limit
             // to devices attached to the same HW module as the build in mic
@@ -575,6 +578,7 @@ sp<DeviceDescriptor> Engine::getDeviceForInputSource(audio_source_t inputSource)
                 AUDIO_DEVICE_IN_USB_DEVICE, AUDIO_DEVICE_IN_BUILTIN_MIC});
         break;
     case AUDIO_SOURCE_CAMCORDER:
+     TRACE_CASE(AUDIO_SOURCE_CAMCORDER);
         // For a device without built-in mic, adding usb device
         device = availableDevices.getFirstExistingDevice({
                 AUDIO_DEVICE_IN_USB_DEVICE,
@@ -583,23 +587,32 @@ sp<DeviceDescriptor> Engine::getDeviceForInputSource(audio_source_t inputSource)
     case AUDIO_SOURCE_VOICE_DOWNLINK:
     case AUDIO_SOURCE_VOICE_CALL:
     case AUDIO_SOURCE_VOICE_UPLINK:
+        TRACE_CASE(AUDIO_SOURCE_VOICE_UPLINK);
+
         device = availableDevices.getDevice(
                 AUDIO_DEVICE_IN_VOICE_CALL, String8(""), AUDIO_FORMAT_DEFAULT);
         break;
     case AUDIO_SOURCE_VOICE_PERFORMANCE:
+            TRACE_CASE(AUDIO_SOURCE_VOICE_PERFORMANCE);
+
         device = availableDevices.getFirstExistingDevice({
                 AUDIO_DEVICE_IN_WIRED_HEADSET, AUDIO_DEVICE_IN_USB_HEADSET,
                 AUDIO_DEVICE_IN_USB_DEVICE, AUDIO_DEVICE_IN_BUILTIN_MIC});
         break;
     case AUDIO_SOURCE_REMOTE_SUBMIX:
+                TRACE_CASE(AUDIO_SOURCE_REMOTE_SUBMIX);
+
         device = availableDevices.getDevice(
                 AUDIO_DEVICE_IN_REMOTE_SUBMIX, String8(""), AUDIO_FORMAT_DEFAULT);
         break;
     case AUDIO_SOURCE_FM_TUNER:
+                    TRACE_CASE(AUDIO_SOURCE_FM_TUNER);
+
         device = availableDevices.getDevice(
                 AUDIO_DEVICE_IN_FM_TUNER, String8(""), AUDIO_FORMAT_DEFAULT);
         break;
     case AUDIO_SOURCE_ECHO_REFERENCE:
+                        TRACE_CASE(AUDIO_SOURCE_ECHO_REFERENCE);
         device = availableDevices.getDevice(
                 AUDIO_DEVICE_IN_ECHO_REFERENCE, String8(""), AUDIO_FORMAT_DEFAULT);
         break;
  • 帮助开发者跟踪音频策略引擎在为不同音频源选择输入设备时的执行路径

  • 可以清楚地看到系统处理了哪个音频源类型

  • 调试时可以验证是否进入了预期的 case 分支

  • 当有音频输入相关问题时,可以通过这些日志快速定位问题源头

相关推荐
TDengine (老段)21 小时前
TDengine 数学函数 DEGRESS 用户手册
大数据·数据库·sql·物联网·时序数据库·iot·tdengine
TDengine (老段)21 小时前
TDengine 数学函数 GREATEST 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
安当加密1 天前
云原生时代的数据库字段加密:在微服务与 Kubernetes 中实现合规与敏捷的统一
数据库·微服务·云原生
爱喝白开水a1 天前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
想ai抽1 天前
深入starrocks-多列联合统计一致性探查与策略(YY一下)
java·数据库·数据仓库
武子康1 天前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql
longgyy1 天前
5 分钟用火山引擎 DeepSeek 调用大模型生成小红书文案
java·数据库·火山引擎
ytttr8731 天前
C# 仿QQ聊天功能实现 (SQL Server数据库)
数据库·oracle·c#
盒马coding1 天前
第18节-索引-Partial-Indexes
数据库·postgresql