msm8974-common: Add custom audio service
with reverts of: LineageOS/android_hardware_interfaces@3f8f599 LineageOS/android_hardware_interfaces@d90c474 Fixed bluetooth audio
This commit is contained in:
parent
4e8c9b2b08
commit
6850a3ff78
7 changed files with 175 additions and 1 deletions
33
audio_service/Android.bp
Normal file
33
audio_service/Android.bp
Normal file
|
@ -0,0 +1,33 @@
|
|||
//
|
||||
// Copyright (C) 2022 The LineageOS-UL Project
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
//
|
||||
|
||||
cc_binary {
|
||||
name: "android.hardware.audio.service.samsung8974",
|
||||
|
||||
init_rc: ["android.hardware.audio.service.samsung8974.rc"],
|
||||
relative_install_path: "hw",
|
||||
vendor: true,
|
||||
|
||||
srcs: ["service.cpp"],
|
||||
|
||||
cflags: [
|
||||
"-Wall",
|
||||
"-Wextra",
|
||||
"-Werror",
|
||||
],
|
||||
|
||||
shared_libs: [
|
||||
"libcutils",
|
||||
"libbinder",
|
||||
"libhidlbase",
|
||||
"liblog",
|
||||
"libutils",
|
||||
"libhardware",
|
||||
],
|
||||
|
||||
defaults: [
|
||||
"android_hardware_audio_config_defaults",
|
||||
],
|
||||
}
|
|
@ -0,0 +1,9 @@
|
|||
service vendor.audio-hal /vendor/bin/hw/android.hardware.audio.service.samsung8974
|
||||
class hal
|
||||
user audioserver
|
||||
# media gid needed for /dev/fm (radio) and for /data/misc/media (tee)
|
||||
group audio camera drmrpc inet media mediadrm net_bt net_bt_admin net_bw_acct wakelock context_hub
|
||||
capabilities BLOCK_SUSPEND
|
||||
ioprio rt 4
|
||||
task_profiles ProcessCapacityHigh HighPerformance
|
||||
onrestart restart audioserver
|
122
audio_service/service.cpp
Normal file
122
audio_service/service.cpp
Normal file
|
@ -0,0 +1,122 @@
|
|||
/*
|
||||
* Copyright (C) 2016 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#define LOG_TAG "audiohalservice"
|
||||
|
||||
#include <signal.h>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
#include <binder/ProcessState.h>
|
||||
#include <cutils/properties.h>
|
||||
#include <hidl/HidlTransportSupport.h>
|
||||
#include <hidl/LegacySupport.h>
|
||||
#include <hwbinder/ProcessState.h>
|
||||
|
||||
using namespace android::hardware;
|
||||
using android::OK;
|
||||
|
||||
using InterfacesList = std::vector<std::string>;
|
||||
|
||||
/** Try to register the provided factories in the provided order.
|
||||
* If any registers successfully, do not register any other and return true.
|
||||
* If all fail, return false.
|
||||
*/
|
||||
template <class Iter>
|
||||
static bool registerPassthroughServiceImplementations(Iter first, Iter last) {
|
||||
for (; first != last; ++first) {
|
||||
if (registerPassthroughServiceImplementation(*first) == OK) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
int main(int /* argc */, char* /* argv */ []) {
|
||||
signal(SIGPIPE, SIG_IGN);
|
||||
|
||||
::android::ProcessState::initWithDriver("/dev/vndbinder");
|
||||
// start a threadpool for vndbinder interactions
|
||||
::android::ProcessState::self()->startThreadPool();
|
||||
|
||||
const int32_t defaultValue = -1;
|
||||
int32_t value =
|
||||
property_get_int32("persist.vendor.audio.service.hwbinder.size_kbyte", defaultValue);
|
||||
if (value != defaultValue) {
|
||||
ALOGD("Configuring hwbinder with mmap size %d KBytes", value);
|
||||
ProcessState::initWithMmapSize(static_cast<size_t>(value) * 1024);
|
||||
}
|
||||
configureRpcThreadpool(16, true /*callerWillJoin*/);
|
||||
|
||||
// Automatic formatting tries to compact the lines, making them less readable
|
||||
// clang-format off
|
||||
const std::vector<InterfacesList> mandatoryInterfaces = {
|
||||
{
|
||||
"Audio Core API",
|
||||
"android.hardware.audio@7.1::IDevicesFactory",
|
||||
"android.hardware.audio@7.0::IDevicesFactory",
|
||||
"android.hardware.audio@6.0::IDevicesFactory",
|
||||
"android.hardware.audio@5.0::IDevicesFactory",
|
||||
"android.hardware.audio@4.0::IDevicesFactory",
|
||||
},
|
||||
{
|
||||
"Audio Effect API",
|
||||
"android.hardware.audio.effect@7.0::IEffectsFactory",
|
||||
"android.hardware.audio.effect@6.0::IEffectsFactory",
|
||||
"android.hardware.audio.effect@5.0::IEffectsFactory",
|
||||
"android.hardware.audio.effect@4.0::IEffectsFactory",
|
||||
}
|
||||
};
|
||||
|
||||
const std::vector<InterfacesList> optionalInterfaces = {
|
||||
{
|
||||
"Soundtrigger API",
|
||||
"android.hardware.soundtrigger@2.3::ISoundTriggerHw",
|
||||
"android.hardware.soundtrigger@2.2::ISoundTriggerHw",
|
||||
"android.hardware.soundtrigger@2.1::ISoundTriggerHw",
|
||||
"android.hardware.soundtrigger@2.0::ISoundTriggerHw",
|
||||
},
|
||||
{
|
||||
"Bluetooth Audio API",
|
||||
"android.hardware.bluetooth.audio@2.2::IBluetoothAudioProvidersFactory",
|
||||
"android.hardware.bluetooth.audio@2.1::IBluetoothAudioProvidersFactory",
|
||||
"android.hardware.bluetooth.audio@2.0::IBluetoothAudioProvidersFactory",
|
||||
},
|
||||
// remove the old HIDL when Bluetooth Audio Hal V2 has offloading supported
|
||||
{
|
||||
"Bluetooth Audio Offload API",
|
||||
"android.hardware.bluetooth.a2dp@1.0::IBluetoothAudioOffload"
|
||||
}
|
||||
};
|
||||
// clang-format on
|
||||
|
||||
for (const auto& listIter : mandatoryInterfaces) {
|
||||
auto iter = listIter.begin();
|
||||
const std::string& interfaceFamilyName = *iter++;
|
||||
LOG_ALWAYS_FATAL_IF(!registerPassthroughServiceImplementations(iter, listIter.end()),
|
||||
"Could not register %s", interfaceFamilyName.c_str());
|
||||
}
|
||||
|
||||
for (const auto& listIter : optionalInterfaces) {
|
||||
auto iter = listIter.begin();
|
||||
const std::string& interfaceFamilyName = *iter++;
|
||||
ALOGW_IF(!registerPassthroughServiceImplementations(iter, listIter.end()),
|
||||
"Could not register %s", interfaceFamilyName.c_str());
|
||||
}
|
||||
|
||||
joinRpcThreadpool();
|
||||
}
|
||||
|
|
@ -26,6 +26,11 @@
|
|||
<instance>default</instance>
|
||||
</interface>
|
||||
</hal>
|
||||
<hal format="hidl">
|
||||
<name>android.hardware.bluetooth.audio</name>
|
||||
<transport>hwbinder</transport>
|
||||
<fqname>@2.0::IBluetoothAudioProvidersFactory/default</fqname>
|
||||
</hal>
|
||||
<hal format="hidl">
|
||||
<name>android.hardware.camera.provider</name>
|
||||
<transport arch="32">passthrough</transport>
|
||||
|
|
|
@ -47,7 +47,7 @@ PRODUCT_COPY_FILES += \
|
|||
|
||||
# Audio
|
||||
PRODUCT_PACKAGES += \
|
||||
android.hardware.audio.service \
|
||||
android.hardware.audio.service.samsung8974 \
|
||||
android.hardware.audio@7.0-impl:32 \
|
||||
android.hardware.audio.effect@7.0-impl:32 \
|
||||
audio.bluetooth.default \
|
||||
|
@ -61,6 +61,8 @@ PRODUCT_PACKAGES += \
|
|||
|
||||
# Bluetooth
|
||||
PRODUCT_PACKAGES += \
|
||||
audio.bluetooth.default \
|
||||
android.hardware.bluetooth.audio@2.0-impl \
|
||||
android.hardware.bluetooth@1.0-impl \
|
||||
android.hardware.bluetooth@1.0-service \
|
||||
libbt-vendor
|
||||
|
|
|
@ -23,6 +23,7 @@
|
|||
|
||||
# executeables
|
||||
/system/vendor/bin/macloader u:object_r:macloader_exec:s0
|
||||
/(vendor|system/vendor)/bin/hw/android\.hardware\.audio\.service\.samsung8974 u:object_r:hal_audio_default_exec:s0
|
||||
/(vendor|system/vendor)/bin/hw/android\.hardware\.gatekeeper@1\.0-service\.software u:object_r:hal_gatekeeper_default_exec:s0
|
||||
/(vendor|system/vendor)/bin/hw/android\.hardware\.ir@1\.0-service\.samsung u:object_r:hal_ir_default_exec:s0
|
||||
/(vendor|system/vendor)/bin/hw/android\.hardware\.light@2\.0-service\.samsung u:object_r:hal_light_default_exec:s0
|
||||
|
|
2
sepolicy/common/hal_audio_default.te
Normal file
2
sepolicy/common/hal_audio_default.te
Normal file
|
@ -0,0 +1,2 @@
|
|||
get_prop(hal_audio_default, audio_prop)
|
||||
allow hal_audio_default default_android_vndservice:service_manager { find };
|
Loading…
Add table
Reference in a new issue