Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2022 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | #define LOG_TAG "DeviceHalAidl" |
| 18 | |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 19 | #include <aidl/android/hardware/audio/core/StreamDescriptor.h> |
| 20 | #include <error/expected_utils.h> |
| 21 | #include <media/AidlConversionCppNdk.h> |
| 22 | #include <media/AidlConversionUtil.h> |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 23 | #include <mediautils/TimeCheck.h> |
| 24 | #include <utils/Log.h> |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 25 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 26 | #include "DeviceHalAidl.h" |
| 27 | #include "StreamHalAidl.h" |
| 28 | |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 29 | using aidl::android::aidl_utils::statusTFromBinderStatus; |
| 30 | using aidl::android::media::audio::common::AudioMode; |
| 31 | using aidl::android::media::audio::common::Float; |
| 32 | using aidl::android::hardware::audio::core::IModule; |
| 33 | using aidl::android::hardware::audio::core::ITelephony; |
| 34 | using aidl::android::hardware::audio::core::StreamDescriptor; |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 35 | |
| 36 | namespace android { |
| 37 | |
| 38 | status_t DeviceHalAidl::getSupportedDevices(uint32_t*) { |
| 39 | // Obsolete. |
| 40 | return INVALID_OPERATION; |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 41 | } |
| 42 | |
| 43 | status_t DeviceHalAidl::initCheck() { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 44 | if (mModule == nullptr) return NO_INIT; |
| 45 | // HAL modules are already initialized by the time they are published to the SM. |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 46 | return OK; |
| 47 | } |
| 48 | |
| 49 | status_t DeviceHalAidl::setVoiceVolume(float volume) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 50 | TIME_CHECK(); |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 51 | if (!mModule) return NO_INIT; |
| 52 | std::shared_ptr<ITelephony> telephony; |
| 53 | if (ndk::ScopedAStatus status = mModule->getTelephony(&telephony); |
| 54 | status.isOk() && telephony != nullptr) { |
| 55 | ITelephony::TelecomConfig inConfig{ .voiceVolume = Float{volume} }, outConfig; |
| 56 | RETURN_STATUS_IF_ERROR( |
| 57 | statusTFromBinderStatus(telephony->setTelecomConfig(inConfig, &outConfig))); |
| 58 | ALOGW_IF(outConfig.voiceVolume.has_value() && volume != outConfig.voiceVolume.value().value, |
| 59 | "%s: the resulting voice volume %f is not the same as requested %f", |
| 60 | __func__, outConfig.voiceVolume.value().value, volume); |
| 61 | } |
| 62 | return INVALID_OPERATION; |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 63 | } |
| 64 | |
| 65 | status_t DeviceHalAidl::setMasterVolume(float volume) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 66 | TIME_CHECK(); |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 67 | if (!mModule) return NO_INIT; |
| 68 | return statusTFromBinderStatus(mModule->setMasterVolume(volume)); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 69 | } |
| 70 | |
| 71 | status_t DeviceHalAidl::getMasterVolume(float *volume) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 72 | TIME_CHECK(); |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 73 | if (!mModule) return NO_INIT; |
| 74 | return statusTFromBinderStatus(mModule->getMasterVolume(volume)); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 75 | } |
| 76 | |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 77 | status_t DeviceHalAidl::setMode(audio_mode_t mode) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 78 | TIME_CHECK(); |
| 79 | if (!mModule) return NO_INIT; |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 80 | AudioMode audioMode = VALUE_OR_FATAL(::aidl::android::legacy2aidl_audio_mode_t_AudioMode(mode)); |
| 81 | std::shared_ptr<ITelephony> telephony; |
| 82 | if (ndk::ScopedAStatus status = mModule->getTelephony(&telephony); |
| 83 | status.isOk() && telephony != nullptr) { |
| 84 | RETURN_STATUS_IF_ERROR(statusTFromBinderStatus(telephony->switchAudioMode(audioMode))); |
| 85 | } |
| 86 | return statusTFromBinderStatus(mModule->updateAudioMode(audioMode)); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 87 | } |
| 88 | |
| 89 | status_t DeviceHalAidl::setMicMute(bool state) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 90 | TIME_CHECK(); |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 91 | if (!mModule) return NO_INIT; |
| 92 | return statusTFromBinderStatus(mModule->setMicMute(state)); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 93 | } |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 94 | |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 95 | status_t DeviceHalAidl::getMicMute(bool *state) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 96 | TIME_CHECK(); |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 97 | if (!mModule) return NO_INIT; |
| 98 | return statusTFromBinderStatus(mModule->getMicMute(state)); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 99 | } |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 100 | |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 101 | status_t DeviceHalAidl::setMasterMute(bool state) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 102 | TIME_CHECK(); |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 103 | if (!mModule) return NO_INIT; |
| 104 | return statusTFromBinderStatus(mModule->setMasterMute(state)); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 105 | } |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 106 | |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 107 | status_t DeviceHalAidl::getMasterMute(bool *state) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 108 | TIME_CHECK(); |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 109 | if (!mModule) return NO_INIT; |
| 110 | return statusTFromBinderStatus(mModule->getMasterMute(state)); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 111 | } |
| 112 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 113 | status_t DeviceHalAidl::setParameters(const String8& kvPairs __unused) { |
| 114 | TIME_CHECK(); |
| 115 | if (!mModule) return NO_INIT; |
| 116 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 117 | return OK; |
| 118 | } |
| 119 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 120 | status_t DeviceHalAidl::getParameters(const String8& keys __unused, String8 *values) { |
| 121 | TIME_CHECK(); |
| 122 | values->clear(); |
| 123 | if (!mModule) return NO_INIT; |
| 124 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 125 | return OK; |
| 126 | } |
| 127 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 128 | status_t DeviceHalAidl::getInputBufferSize( |
| 129 | const struct audio_config* config __unused, size_t* size __unused) { |
| 130 | TIME_CHECK(); |
| 131 | if (!mModule) return NO_INIT; |
| 132 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 133 | return OK; |
| 134 | } |
| 135 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 136 | status_t DeviceHalAidl::openOutputStream( |
| 137 | audio_io_handle_t handle __unused, audio_devices_t devices __unused, |
| 138 | audio_output_flags_t flags __unused, struct audio_config* config, |
| 139 | const char* address __unused, |
| 140 | sp<StreamOutHalInterface>* outStream) { |
| 141 | if (!outStream || !config) { |
| 142 | return BAD_VALUE; |
| 143 | } |
| 144 | TIME_CHECK(); |
| 145 | if (!mModule) return NO_INIT; |
| 146 | config->sample_rate = 48000; |
| 147 | config->format = AUDIO_FORMAT_PCM_24_BIT_PACKED; |
| 148 | config->channel_mask = AUDIO_CHANNEL_OUT_STEREO; |
| 149 | StreamDescriptor descriptor; |
| 150 | descriptor.frameSizeBytes = audio_bytes_per_sample(config->format) * |
| 151 | audio_channel_count_from_out_mask(config->channel_mask); |
| 152 | descriptor.bufferSizeFrames = 600; |
| 153 | *outStream = sp<StreamOutHalAidl>::make(descriptor, nullptr); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 154 | return OK; |
| 155 | } |
| 156 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 157 | status_t DeviceHalAidl::openInputStream( |
| 158 | audio_io_handle_t handle __unused, audio_devices_t devices __unused, |
| 159 | struct audio_config* config, audio_input_flags_t flags __unused, |
| 160 | const char* address __unused, audio_source_t source __unused, |
| 161 | audio_devices_t outputDevice __unused, |
| 162 | const char* outputDeviceAddress __unused, |
| 163 | sp<StreamInHalInterface>* inStream) { |
| 164 | if (!inStream || !config) { |
| 165 | return BAD_VALUE; |
| 166 | } |
| 167 | TIME_CHECK(); |
| 168 | if (!mModule) return NO_INIT; |
| 169 | config->sample_rate = 48000; |
| 170 | config->format = AUDIO_FORMAT_PCM_24_BIT_PACKED; |
| 171 | config->channel_mask = AUDIO_CHANNEL_IN_STEREO; |
| 172 | StreamDescriptor descriptor; |
| 173 | descriptor.frameSizeBytes = audio_bytes_per_sample(config->format) * |
| 174 | audio_channel_count_from_out_mask(config->channel_mask); |
| 175 | descriptor.bufferSizeFrames = 600; |
| 176 | *inStream = sp<StreamInHalAidl>::make(descriptor, nullptr); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 177 | return OK; |
| 178 | } |
| 179 | |
| 180 | status_t DeviceHalAidl::supportsAudioPatches(bool* supportsPatches) { |
| 181 | *supportsPatches = true; |
| 182 | return OK; |
| 183 | } |
| 184 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 185 | status_t DeviceHalAidl::createAudioPatch(unsigned int num_sources __unused, |
| 186 | const struct audio_port_config* sources __unused, |
| 187 | unsigned int num_sinks __unused, |
| 188 | const struct audio_port_config* sinks __unused, |
| 189 | audio_patch_handle_t* patch __unused) { |
| 190 | TIME_CHECK(); |
| 191 | if (!mModule) return NO_INIT; |
| 192 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 193 | return OK; |
| 194 | } |
| 195 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 196 | status_t DeviceHalAidl::releaseAudioPatch(audio_patch_handle_t patch __unused) { |
| 197 | TIME_CHECK(); |
| 198 | if (!mModule) return NO_INIT; |
| 199 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 200 | return OK; |
| 201 | } |
| 202 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 203 | status_t DeviceHalAidl::getAudioPort(struct audio_port* port __unused) { |
| 204 | TIME_CHECK(); |
| 205 | ALOGE("%s not implemented yet", __func__); |
| 206 | return INVALID_OPERATION; |
| 207 | } |
| 208 | |
| 209 | status_t DeviceHalAidl::getAudioPort(struct audio_port_v7 *port __unused) { |
| 210 | TIME_CHECK(); |
| 211 | ALOGE("%s not implemented yet", __func__); |
| 212 | return INVALID_OPERATION; |
| 213 | } |
| 214 | |
| 215 | status_t DeviceHalAidl::setAudioPortConfig(const struct audio_port_config* config __unused) { |
| 216 | TIME_CHECK(); |
| 217 | if (!mModule) return NO_INIT; |
| 218 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 219 | return OK; |
| 220 | } |
| 221 | |
| 222 | status_t DeviceHalAidl::getMicrophones( |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 223 | std::vector<audio_microphone_characteristic_t>* microphones __unused) { |
| 224 | TIME_CHECK(); |
| 225 | if (!mModule) return NO_INIT; |
| 226 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 227 | return OK; |
| 228 | } |
| 229 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 230 | status_t DeviceHalAidl::addDeviceEffect(audio_port_handle_t device __unused, |
| 231 | sp<EffectHalInterface> effect) { |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 232 | if (!effect) { |
| 233 | return BAD_VALUE; |
| 234 | } |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 235 | TIME_CHECK(); |
| 236 | if (!mModule) return NO_INIT; |
| 237 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 238 | return OK; |
| 239 | } |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 240 | status_t DeviceHalAidl::removeDeviceEffect(audio_port_handle_t device __unused, |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 241 | sp<EffectHalInterface> effect) { |
| 242 | if (!effect) { |
| 243 | return BAD_VALUE; |
| 244 | } |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 245 | TIME_CHECK(); |
| 246 | if (!mModule) return NO_INIT; |
| 247 | ALOGE("%s not implemented yet", __func__); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 248 | return OK; |
| 249 | } |
| 250 | |
| 251 | status_t DeviceHalAidl::getMmapPolicyInfos( |
| 252 | media::audio::common::AudioMMapPolicyType policyType __unused, |
| 253 | std::vector<media::audio::common::AudioMMapPolicyInfo>* policyInfos __unused) { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 254 | TIME_CHECK(); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 255 | ALOGE("%s not implemented yet", __func__); |
| 256 | return OK; |
| 257 | } |
| 258 | |
| 259 | int32_t DeviceHalAidl::getAAudioMixerBurstCount() { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 260 | TIME_CHECK(); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 261 | ALOGE("%s not implemented yet", __func__); |
| 262 | return OK; |
| 263 | } |
| 264 | |
| 265 | int32_t DeviceHalAidl::getAAudioHardwareBurstMinUsec() { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 266 | TIME_CHECK(); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 267 | ALOGE("%s not implemented yet", __func__); |
| 268 | return OK; |
| 269 | } |
| 270 | |
| 271 | error::Result<audio_hw_sync_t> DeviceHalAidl::getHwAvSync() { |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 272 | TIME_CHECK(); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 273 | ALOGE("%s not implemented yet", __func__); |
| 274 | return base::unexpected(INVALID_OPERATION); |
| 275 | } |
| 276 | |
Mikhail Naganov | fab697c | 2023-01-11 19:33:13 +0000 | [diff] [blame^] | 277 | status_t DeviceHalAidl::dump(int fd, const Vector<String16>& args) { |
| 278 | TIME_CHECK(); |
| 279 | if (!mModule) return NO_INIT; |
| 280 | return mModule->dump(fd, Args(args).args(), args.size()); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 281 | }; |
| 282 | |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 283 | int32_t DeviceHalAidl::supportsBluetoothVariableLatency(bool* supports __unused) { |
| 284 | TIME_CHECK(); |
Shunkai Yao | 5120250 | 2022-12-12 06:11:46 +0000 | [diff] [blame] | 285 | ALOGE("%s not implemented yet", __func__); |
| 286 | return INVALID_OPERATION; |
| 287 | } |
Mikhail Naganov | 31d4665 | 2023-01-10 18:29:25 +0000 | [diff] [blame] | 288 | |
| 289 | } // namespace android |