Сравнение AIDL и HIDL Audio HAL

Начиная с Android 14, партнерам и поставщикам SoC рекомендуется заменить текущую реализацию HIDL HAL на реализацию AIDL HAL.

Для облегчения перехода с HIDL Audio HAL на AIDL Audio HAL на этой странице выделены некоторые ключевые различия. Здесь также показано соответствие интерфейсов AIDL и HIDL для Audio HAL.

Разница между реализациями AIDL и HIDL Audio HAL

Основные различия между структурой HIDL и структурой AIDL заключаются в следующем:

  • В AIDL Audio Core HAL интерфейс IConfig представлен в качестве замены общесистемным параметрам в XML-файлах HIDL HAL. Фреймворк считывает эти параметры из Core HAL, а не из файла конфигурации поставщика. Например, список форматов объемного звука, доступных для управления пользователем, предоставляется методом IConfig.getSurroundSoundConfig в Core HAL.

    В AIDL Audio Effects HAL логика effectProxy , определённая в XML-файлах HIDL Effects HAL, перенесена в аудиофреймворк. Аудиофреймворк запрашивает все экземпляры эффектов в системе с помощью IFactory.queryEffects , а все обработки эффектов — с помощью IFactory.queryProcessing .

  • Чтобы избежать путаницы с использованием термина «устройство» для типов аудиоустройств, IDevice в HIDL Audio HAL переименован в IModule в AIDL Audio HAL.

  • Интерфейс AIDL Audio HAL заменяет IPrimaryDevice . Фреймворк отправляет обновления текущего аудиорежима и поворота экрана каждому экземпляру IModule . Выделенный интерфейс IBluetooth обрабатывает параметры, связанные с ориентированным на синхронное соединение Bluetooth (BT SCO) и профилем Hands-Free (HFP). Выделенный интерфейс ITelephony предоставляет элементы управления, специфичные для телефонии. Экземпляры обоих этих интерфейсов можно получить из основного экземпляра интерфейса IModule . Подробнее см. в сравнительных таблицах по основным HAL и функциональным возможностям .

  • IDevicesFactory удалена из AIDL Audio HAL для предотвращения избыточности. Модули HAL (то есть экземпляры интерфейса IModule ) теперь регистрируются непосредственно в диспетчере служб, используя имена экземпляров модулей, например, bluetooth или r_submix . Единственным исключением является primary модуль, который регистрируется под именем экземпляра default .

Сопоставление AIDL и HIDL Audio HAL

В таблицах в следующих разделах показано соответствие интерфейсов HIDL и AIDL Audio HAL. Подробнее о структуре каталогов см. в разделе «Audio HAL» .

Ядро HAL

Все интерфейсы HIDL находятся в пакете android.hardware.audio@NM , где NM обозначает версию Major.Minor . Все интерфейсы AIDL находятся в пакете android.hardware.audio.core .

Интерфейсы API HIDL и файлы конфигурации Интерфейсы API AIDL
IDevicesFactory Регистрация IModule в ServiceManager .
IDevice IModule
IPrimaryDevice ITelephony
IBluetooth
IStream
IStreamIn
IStreamOut
StreamDescriptor
IStreamIn
IStreamCommon
IStreamOut
audio_policy_configuration.xml
audio_policy_engine_configuration.xml
IConfig
IModule
Настраиваемые файлы аудиополитики Используйте реализацию HIDL для Android 14.

Аудиопорты, динамические профили, маршруты и патчи

В этой таблице элементы XML-файлов обозначены с помощью угловых скобок.

Методы интерфейса API HIDL и элементы файлов конфигурации Методы интерфейса API AIDL
<attachedDevices>
<defaultOutputDevice>
<mixPorts>
<devicePorts>
IModule.getAudioPorts
IDevice.getAudioPort
IDevice.setConnectedState
IModule.getAudioPort
IModule.connectExternalDevice
IModule.disconnectExternalDevice
IStream.getSupportedProfiles IModule.connectExternalDevice
< routes > IModule.getAudioRoutes
IDevice.createAudioPatch
IDevice.updateAudioPatch
IDevice.releaseAudioPatch
IStream.getDevices
IStream.setDevices
Спецификация устройства в IDevice.openInputStream
IDevice.openOutputStream
IModule.setAudioPatch
IModule.setAudioPortConfig
IModule.resetAudioPatch

Конфигурации аудиопортов и потоки

Методы интерфейса API HIDL Методы интерфейса API AIDL
IStream.getAudioProperties
IStream.setAudioProperties
IStreamIn.getAudioSource
IModule.getAudioPortConfigs
IModule.setAudioPortConfig
IDevice.openInputStream
IDevice.openOutputStream
IStreamIn.prepareForReading
IStreamOut.prepareForWriting
IStream.createMmapBuffer
IModule.openInputStream
IModule.openOutputStream
IStream.close IStreamCommon.close
IStreamIn.updateSinkMetadata
IStreamOut.updateSourceMetadata
IStreamIn.updateMetadata
IStreamOut.updateMetadata
IStream.standby StreamDescriptor.Command.standby
IStream.pause
IStream.resume
StreamDescriptor.Command.pause
.start
IStream.start
IStream.stop
(Трансляции MMAP)
StreamDescriptor.Command.start или .burst
.pause (вход) и/или .flush (выход)
IStreamOut.drain
IStreamOut.flush
StreamDescriptor.Command.drain
.flush
IStreamOut.setCallback
IStreamOut.clearCallback
IModule.openOutputStream
IStreamCommon.close
IStreamOut.getPresentationPosition и IStreamIn.getCapturePosition
IStreamOut.getLatency
IStream.getMmapPosition
IStreamIn.getInputFramesLost
StreamDescriptor.Reply.observable
StreamDescriptor.Reply.latencyMs
StreamDescriptor.Reply.hardware
StreamDescriptor.Reply.xrunFrames
IDevice.getInputBufferSize
IStreamOut.getLatency
IStream.getBufferSize
IStream.getFrameSize
IStream.getFrameCount
IModule.setAudioPatch , номинальная задержка и минимальный размер буфера являются частью структуры AudioPatch , возвращаемой HAL. Фактический размер буфера в кадрах, как и размер кадра в байтах, является частью структуры StreamDescriptor . Размер буфера в байтах можно рассчитать, умножив эти два числа.

Подключение аудиоэффектов

Методы интерфейса API HIDL Методы интерфейса API AIDL
IDevice.addDeviceEffect
IDevice.removeDeviceEffect
IModule.addDeviceEffect
IModule.removeDeviceEffect
IStream.addEffect
IStream.removeEffect
IStreamCommon.addEffect
IStreamCommon.removeEffect

Общесистемная конфигурация

Общесистемная конфигурация, ранее определённая в XML-файлах конфигурации аудиополитики (а именно, audio_policy_configuration.xml и audio_policy_engine_configuration.xml ), должна быть предоставлена ​​через IConfig . Однако для упрощения перехода на AIDL поставщики по-прежнему могут использовать те же XML-файлы, которые они использовали ранее для настройки общесистемной конфигурации. Эталонная реализация IConfig содержит код, необходимый для представления информации из XML-файла с использованием типов данных AIDL, что упрощает преобразование из XML в AIDL.

Элементы файла конфигурации HIDL Методы интерфейса API AIDL
<globalConfiguration>
<speaker_drc_enabled> 1

<call_screen_mode_supported>
<engine_library>
Разделено на два разных метода:
ITelephony.getSupportedAudioModes
IConfig.getEngineConfig
<volumes> , ИЛИ
<volumeGroups> , <ProductStrategies>
IConfig.getEngineConfig
<surroundSound> IConfig.getSurroundSoundConfig

  1. speaker_drc_enabled удалён из файла конфигурации, поскольку он не используется в системе. На всех устройствах DRC должен быть включён.

Функциональность, связанная с функциями

Методы интерфейса API HIDL API-интерфейс AIDL
IDevice.setMasterVolume
IDevice.getMasterVolume
IDevice.setMicMute
IDevice.getMicMute
IDevice.setMasterMute
IDevice.getMasterMute
IModule.\*
IPrimaryDevice.getTtyMode
IPrimaryDevice.setTtyMode
IPrimaryDevice.getHacEnabled
IPrimaryDevice.setHacEnabled
IPrimaryDevice.setVoiceVolume
ITelephony.TelecomConfig.\*
IPrimaryDevice.setBtScoHeadsetDebugName
IPrimaryDevice.getBtScoNrecEnabled
IPrimaryDevice.setBtScoNrecEnabled
IPrimaryDevice.getBtScoWidebandEnabled
IPrimaryDevice.setBtScoWidebandEnabled,
IPrimaryDevice.getBtHfpEnabled
IPrimaryDevice.setBtHfpEnabled
IPrimaryDevice.setBtHfpSampleRate
IPrimaryDevice.setBtHfpVolume
IBluetooth.ScoConfig.\*
IBluetooth.HfpConfig.\*
IPrimaryDevice.setMode
IPrimaryDevice.updateRotation
ITelephony.switchAudioMode
IModule.updateAudioMode
IModule.updateScreenRotation
IDevice.setScreenState
IDevice.getMicrophones
IModule.updateScreenState
IModule.getMicrophones
IDevice.getHwAvSync
IStream.setHwAvSync
IModule.generateHwAvSyncId
IStreamCommon.updateHwAvSyncId
IStreamIn.setGain
IStreamIn.setMicrophoneDirection
IStreamIn.setMicrophoneFieldDimension
IStreamIn.setHwGain
IStreamIn.setMicrophoneDirection
IStreamIn.setMicrophoneFieldDimension
IStreamOut.getDualMonoMode
IStreamOut.setDualMonoMode
IStreamOut.getPlaybackRateParameters
IStreamOut.setPlaybackRateParameters
IStreamOut.selectPresentation
IStreamOut.getAudioDescriptionMixLevel
IStreamOut.setAudioDescriptionMixLevel
IStreamOut.setLatencyMode
IStreamOut.getRecommendedLatencyModes
IStreamOut.\*
IStreamOut.setEventCallback
IStreamOut.setLatencyModeCallback
IModule.openOutputStream (обратные вызовы объединены в IStreamOutEventCallback )
IDevice.get/setParameters
IStream.get/setParameters
IModule.get/setVendorParameters
IStreamCommon.get/setVendorParameters

Устаревшие методы

Методы интерфейса API HIDL Комментарии
IDevice.initCheck
IDevice.close
Модуль HAL публикуется в ServiceManager только после успешной инициализации. С этого момента он считается постоянным и не может быть закрыт.
IDevice.supportsAudioPatches
IStreamOut.supportsPauseAndResume
IStreamOut.supportsDrain
Поддержка исправлений, паузы, возобновления и слива обязательна.
IStreamOut.getRenderPosition
IStreamOut.getNextWriteTimestamp
Устаревший.

Расширения поставщиков

В API HIDL расширения вендоров реализуются с помощью методов getParameters или setParameters из интерфейсов IDevice и IStream . Эти методы принимают произвольные строки. В API AIDL существуют соответствующие методы, такие как getVendorParameters или setVendorParameters , которые принимают произвольные экземпляры Parcelable , используя инкапсуляцию в ParcelableHolders .

Другие изменения

Другие общие изменения таковы:

  • Для улучшения тестируемости API HAL в версии AIDL мы добавили возможности отладки, используемые тестами VTS и доступные через пакет ModuleDebug . Эти возможности предписывают HAL эмулировать определённую функциональность (например, подключение внешних устройств), которая в противном случае потребовала бы ручного вмешательства и использования внешнего тестового оборудования.

  • Когда фреймворк или тест VTS устанавливает системное свойство sys.audio.restart.hal в 1 , службы HAL должны перезапуститься. Перезапуск выполняется в файле audioserver.rc . При реализации HAL используйте соответствующее имя службы HAL, указанное в файле audioserver.rc . В Android 14 имя vendor.audio-hal-aidl добавлено специально для версии HAL AIDL.

Эффекты HAL

Все интерфейсы HIDL находятся в пакете android.hardware.audio.effect@NM* , где NM — версия Major.Minor . Все интерфейсы AIDL находятся в пакете android.hardware.audio.effect .

Интерфейсы API HIDL и файлы конфигурации Интерфейсы API AIDL
IEffectsFactory IFactory
IEffect IEffect
audio_effects.xml IEffect

Фабрика эффектов

Интерфейсы API HIDL
(android.hardware.audio.effect@XX)
Интерфейсы API AIDL
(android.hardware.audio.effect)
IEffectsFactory.getAllDescriptors IFactory.queryEffects с нулевым параметром UUID
IEffectsFactory.getDescriptor IFactory.queryEffects с параметром UUID
IEffectsFactory.createEffect IFactory.createEffect
audio_effects.xml IFactory.queryProcessing
IFactory.queryEffects

Интерфейсы эффектов

Интерфейсы API HIDL
(android.hardware.audio.effect@XX)
Интерфейсы API AIDL
(android.hardware.audio.effect)
IEffect.init IEffect.open
IEffect.setConfig IEffect.setParameter
IEffect.enable IEffect.command(CommandId::START)
IEffect.disable IEffect.command(CommandId::STOP)
IEffect.reset IEffect.command(CommandId::RESET)
IEffect.getDescriptor IEffect.getDescriptor
IEffect.command Карта для IEffect.command ,
IEffect.setParameter или
IEffect.getParameter на основе типа устаревшей команды HIDL
Н/Д IEffect.getState
IEffect.setParameter IEffect.setParameter
IEffect.getParameter IEffect.getParameter

Команды эффектов

Интерфейсы API HIDL
(android.hardware.audio.effect@XX)
Интерфейсы API AIDL
(android.hardware.audio.effect)
EFFECT_CMD_INIT IEffect.open
EFFECT_CMD_RESET CommandId.RESET
EFFECT_CMD_ENABLE IEffect.command(CommandId::START)
EFFECT_CMD_DISABLE IEffect.command(CommandId::STOP)
EFFECT_CMD_SET_PARAM_DEFERRED Устаревшее в Effects AIDL HAL
EFFECT_CMD_SET_PARAM_COMMIT Устаревшее в Effects AIDL HAL
EFFECT_CMD_SET_CONFIG
EFFECT_CMD_SET_PARAM
EFFECT_CMD_SET_DEVICE
EFFECT_CMD_SET_VOLUME
EFFECT_CMD_SET_AUDIO_MODE
EFFECT_CMD_SET_CONFIG_REVERSE
EFFECT_CMD_SET_INPUT_DEVICE
EFFECT_CMD_SET_FEATURE_CONFIG
EFFECT_CMD_SET_AUDIO_SOURCE
IEffect.setParameter
EFFECT_CMD_GET_PARAM
EFFECT_CMD_GET_CONFIG
EFFECT_CMD_GET_CONFIG_REVERSE
EFFECT_CMD_GET_FEATURE_SUPPORTED_CONFIGS
EFFECT_CMD_GET_FEATURE_CONFIG
VISUALIZER_CMD_MEASURE
EFFECT_CMD_FIRST_PROPRIETARY
(то же самое, что и VISUALIZER_CMD_CAPTURE )
IEffect.getParameter
EFFECT_CMD_OFFLOAD Устарело.
В AIDL переключение режимов разгрузки и без разгрузки осуществляется в фреймворке.
EFFECT_CMD_DUMP Обрабатывается встроенной транзакцией-связкой AIBinder_dump .

Определение параметров общего эффекта

Определение HIDL
(android.hardware.audio.effect@XX)
Определение AIDL
Types.hal Flags.aidl
Parameter.aidl

Определение специфических эффектов

Интерфейсы API HIDL
(android.hardware.audio.effect@XX)
Интерфейсы API AIDL
(android.hardware.audio.effect)
I $EffectType$ .hal $EffectType$ .aidl