jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 1 | /* |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 2 | * Copyright (C) 2019 The Android Open Source Project |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 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 | |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 17 | #define LOG_TAG "DeviceDescriptorBase" |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 18 | //#define LOG_NDEBUG 0 |
| 19 | |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 20 | #include <android-base/stringprintf.h> |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 21 | #include <audio_utils/string.h> |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 22 | #include <media/AidlConversion.h> |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 23 | #include <media/DeviceDescriptorBase.h> |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 24 | #include <media/TypeConverter.h> |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 25 | |
| 26 | namespace android { |
| 27 | |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 28 | DeviceDescriptorBase::DeviceDescriptorBase(audio_devices_t type) : |
jiabin | 36e2dea | 2019-11-07 15:47:01 -0800 | [diff] [blame] | 29 | DeviceDescriptorBase(type, "") |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 30 | { |
jiabin | 36e2dea | 2019-11-07 15:47:01 -0800 | [diff] [blame] | 31 | } |
| 32 | |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 33 | DeviceDescriptorBase::DeviceDescriptorBase( |
| 34 | audio_devices_t type, const std::string& address, |
| 35 | const FormatVector &encodedFormats) : |
| 36 | DeviceDescriptorBase(AudioDeviceTypeAddr(type, address), encodedFormats) |
jiabin | 36e2dea | 2019-11-07 15:47:01 -0800 | [diff] [blame] | 37 | { |
| 38 | } |
| 39 | |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 40 | DeviceDescriptorBase::DeviceDescriptorBase( |
| 41 | const AudioDeviceTypeAddr &deviceTypeAddr, const FormatVector &encodedFormats) : |
jiabin | 36e2dea | 2019-11-07 15:47:01 -0800 | [diff] [blame] | 42 | AudioPort("", AUDIO_PORT_TYPE_DEVICE, |
| 43 | audio_is_output_device(deviceTypeAddr.mType) ? AUDIO_PORT_ROLE_SINK : |
| 44 | AUDIO_PORT_ROLE_SOURCE), |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 45 | mDeviceTypeAddr(deviceTypeAddr), |
| 46 | mEncodedFormats(encodedFormats) |
jiabin | 36e2dea | 2019-11-07 15:47:01 -0800 | [diff] [blame] | 47 | { |
jiabin | 0a48893 | 2020-08-07 17:32:40 -0700 | [diff] [blame] | 48 | if (mDeviceTypeAddr.address().empty() && audio_is_remote_submix_device(mDeviceTypeAddr.mType)) { |
| 49 | mDeviceTypeAddr.setAddress("0"); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 50 | } |
jiabin | 827df1b | 2020-07-29 15:09:52 -0700 | [diff] [blame] | 51 | } |
| 52 | |
| 53 | void DeviceDescriptorBase::setAddress(const std::string &address) { |
jiabin | 0a48893 | 2020-08-07 17:32:40 -0700 | [diff] [blame] | 54 | mDeviceTypeAddr.setAddress(address); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 55 | } |
| 56 | |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 57 | void DeviceDescriptorBase::toAudioPortConfig(struct audio_port_config *dstConfig, |
| 58 | const struct audio_port_config *srcConfig) const |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 59 | { |
| 60 | dstConfig->config_mask = AUDIO_PORT_CONFIG_GAIN; |
| 61 | if (mSamplingRate != 0) { |
| 62 | dstConfig->config_mask |= AUDIO_PORT_CONFIG_SAMPLE_RATE; |
| 63 | } |
| 64 | if (mChannelMask != AUDIO_CHANNEL_NONE) { |
| 65 | dstConfig->config_mask |= AUDIO_PORT_CONFIG_CHANNEL_MASK; |
| 66 | } |
| 67 | if (mFormat != AUDIO_FORMAT_INVALID) { |
| 68 | dstConfig->config_mask |= AUDIO_PORT_CONFIG_FORMAT; |
| 69 | } |
| 70 | |
| 71 | if (srcConfig != NULL) { |
| 72 | dstConfig->config_mask |= srcConfig->config_mask; |
| 73 | } |
| 74 | |
| 75 | AudioPortConfig::toAudioPortConfig(dstConfig, srcConfig); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 76 | |
jiabin | 5d51ca9 | 2019-11-05 11:59:53 -0800 | [diff] [blame] | 77 | dstConfig->role = audio_is_output_device(mDeviceTypeAddr.mType) ? |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 78 | AUDIO_PORT_ROLE_SINK : AUDIO_PORT_ROLE_SOURCE; |
| 79 | dstConfig->type = AUDIO_PORT_TYPE_DEVICE; |
jiabin | 5d51ca9 | 2019-11-05 11:59:53 -0800 | [diff] [blame] | 80 | dstConfig->ext.device.type = mDeviceTypeAddr.mType; |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 81 | |
jiabin | 5d51ca9 | 2019-11-05 11:59:53 -0800 | [diff] [blame] | 82 | (void)audio_utils_strlcpy_zerofill(dstConfig->ext.device.address, mDeviceTypeAddr.getAddress()); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 83 | } |
| 84 | |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 85 | void DeviceDescriptorBase::toAudioPort(struct audio_port *port) const |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 86 | { |
jiabin | 5d51ca9 | 2019-11-05 11:59:53 -0800 | [diff] [blame] | 87 | ALOGV("DeviceDescriptorBase::toAudioPort() handle %d type %08x", mId, mDeviceTypeAddr.mType); |
jiabin | b4fed19 | 2020-09-22 14:45:40 -0700 | [diff] [blame] | 88 | toAudioPortInternal(port); |
| 89 | } |
| 90 | |
| 91 | void DeviceDescriptorBase::toAudioPort(struct audio_port_v7 *port) const { |
| 92 | ALOGV("DeviceDescriptorBase::toAudioPort() v7 handle %d type %08x", mId, mDeviceTypeAddr.mType); |
| 93 | toAudioPortInternal(port); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 94 | } |
| 95 | |
jiabin | 1c4794b | 2020-05-05 10:08:05 -0700 | [diff] [blame] | 96 | status_t DeviceDescriptorBase::setEncapsulationModes(uint32_t encapsulationModes) { |
| 97 | if ((encapsulationModes & ~AUDIO_ENCAPSULATION_MODE_ALL_POSITION_BITS) != 0) { |
| 98 | return BAD_VALUE; |
| 99 | } |
| 100 | mEncapsulationModes = encapsulationModes & ~(1 << AUDIO_ENCAPSULATION_MODE_NONE); |
| 101 | return NO_ERROR; |
| 102 | } |
| 103 | |
| 104 | status_t DeviceDescriptorBase::setEncapsulationMetadataTypes(uint32_t encapsulationMetadataTypes) { |
| 105 | if ((encapsulationMetadataTypes & ~AUDIO_ENCAPSULATION_METADATA_TYPE_ALL_POSITION_BITS) != 0) { |
| 106 | return BAD_VALUE; |
| 107 | } |
| 108 | mEncapsulationMetadataTypes = |
| 109 | encapsulationMetadataTypes & ~(1 << AUDIO_ENCAPSULATION_METADATA_TYPE_NONE); |
| 110 | return NO_ERROR; |
| 111 | } |
| 112 | |
Mikhail Naganov | 0f413b2 | 2021-12-02 05:29:27 +0000 | [diff] [blame] | 113 | void DeviceDescriptorBase::dump(std::string *dst, int spaces, |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 114 | const char* extraInfo, bool verbose) const |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 115 | { |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 116 | if (mId != 0) { |
Mikhail Naganov | 0dbe87b | 2021-12-01 02:03:31 +0000 | [diff] [blame] | 117 | dst->append(base::StringPrintf("Port ID: %d; ", mId)); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 118 | } |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 119 | if (extraInfo != nullptr) { |
Mikhail Naganov | 0dbe87b | 2021-12-01 02:03:31 +0000 | [diff] [blame] | 120 | dst->append(base::StringPrintf("%s; ", extraInfo)); |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 121 | } |
Mikhail Naganov | fcfb516 | 2021-12-02 01:35:15 +0000 | [diff] [blame] | 122 | dst->append(base::StringPrintf("{%s}\n", |
Mikhail Naganov | 0dbe87b | 2021-12-01 02:03:31 +0000 | [diff] [blame] | 123 | mDeviceTypeAddr.toString(true /*includeSensitiveInfo*/).c_str())); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 124 | |
jiabin | 1c4794b | 2020-05-05 10:08:05 -0700 | [diff] [blame] | 125 | dst->append(base::StringPrintf( |
Mikhail Naganov | 0f413b2 | 2021-12-02 05:29:27 +0000 | [diff] [blame] | 126 | "%*sEncapsulation modes: %u, metadata types: %u\n", spaces, "", |
Mikhail Naganov | 0dbe87b | 2021-12-01 02:03:31 +0000 | [diff] [blame] | 127 | mEncapsulationModes, mEncapsulationMetadataTypes)); |
jiabin | 1c4794b | 2020-05-05 10:08:05 -0700 | [diff] [blame] | 128 | |
Mikhail Naganov | 0f413b2 | 2021-12-02 05:29:27 +0000 | [diff] [blame] | 129 | AudioPort::dump(dst, spaces, nullptr, verbose); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 130 | } |
| 131 | |
jiabin | 827df1b | 2020-07-29 15:09:52 -0700 | [diff] [blame] | 132 | std::string DeviceDescriptorBase::toString(bool includeSensitiveInfo) const |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 133 | { |
jiabin | 0a48893 | 2020-08-07 17:32:40 -0700 | [diff] [blame] | 134 | return mDeviceTypeAddr.toString(includeSensitiveInfo); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 135 | } |
| 136 | |
jiabin | ce9f20e | 2019-09-12 16:29:15 -0700 | [diff] [blame] | 137 | void DeviceDescriptorBase::log() const |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 138 | { |
jiabin | 5d51ca9 | 2019-11-05 11:59:53 -0800 | [diff] [blame] | 139 | ALOGI("Device id:%d type:0x%08X:%s, addr:%s", mId, mDeviceTypeAddr.mType, |
| 140 | ::android::toString(mDeviceTypeAddr.mType).c_str(), |
| 141 | mDeviceTypeAddr.getAddress()); |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 142 | |
| 143 | AudioPort::log(" "); |
| 144 | } |
| 145 | |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 146 | template<typename T> |
| 147 | bool checkEqual(const T& f1, const T& f2) |
| 148 | { |
| 149 | std::set<typename T::value_type> s1(f1.begin(), f1.end()); |
| 150 | std::set<typename T::value_type> s2(f2.begin(), f2.end()); |
| 151 | return s1 == s2; |
| 152 | } |
| 153 | |
jiabin | 49e69a1 | 2019-10-15 16:04:13 -0700 | [diff] [blame] | 154 | bool DeviceDescriptorBase::equals(const sp<DeviceDescriptorBase> &other) const |
| 155 | { |
| 156 | return other != nullptr && |
| 157 | static_cast<const AudioPort*>(this)->equals(other) && |
Mikhail Naganov | 9980902 | 2021-11-04 00:00:29 +0000 | [diff] [blame] | 158 | static_cast<const AudioPortConfig*>(this)->equals(other, useInputChannelMask()) && |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 159 | mDeviceTypeAddr.equals(other->mDeviceTypeAddr) && |
| 160 | checkEqual(mEncodedFormats, other->mEncodedFormats); |
| 161 | } |
| 162 | |
| 163 | bool DeviceDescriptorBase::supportsFormat(audio_format_t format) |
| 164 | { |
| 165 | if (mEncodedFormats.empty()) { |
| 166 | return true; |
| 167 | } |
| 168 | |
| 169 | for (const auto& devFormat : mEncodedFormats) { |
| 170 | if (devFormat == format) { |
| 171 | return true; |
| 172 | } |
| 173 | } |
| 174 | return false; |
jiabin | 49e69a1 | 2019-10-15 16:04:13 -0700 | [diff] [blame] | 175 | } |
| 176 | |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 177 | status_t DeviceDescriptorBase::writeToParcelable(media::AudioPort* parcelable) const { |
| 178 | AudioPort::writeToParcelable(parcelable); |
Mikhail Naganov | 0078ee5 | 2021-09-30 23:06:20 +0000 | [diff] [blame] | 179 | AudioPortConfig::writeToParcelable(&parcelable->hal.activeConfig, useInputChannelMask()); |
| 180 | parcelable->hal.id = VALUE_OR_RETURN_STATUS(legacy2aidl_audio_port_handle_t_int32_t(mId)); |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 181 | |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 182 | media::audio::common::AudioPortDeviceExt deviceExt; |
| 183 | deviceExt.device = VALUE_OR_RETURN_STATUS( |
Mikhail Naganov | ceb8bf9 | 2021-09-23 21:29:39 +0000 | [diff] [blame] | 184 | legacy2aidl_AudioDeviceTypeAddress(mDeviceTypeAddr)); |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 185 | deviceExt.encodedFormats = VALUE_OR_RETURN_STATUS( |
| 186 | convertContainer<std::vector<media::audio::common::AudioFormatDescription>>( |
| 187 | mEncodedFormats, legacy2aidl_audio_format_t_AudioFormatDescription)); |
| 188 | UNION_SET(parcelable->hal.ext, device, deviceExt); |
Mikhail Naganov | ceb8bf9 | 2021-09-23 21:29:39 +0000 | [diff] [blame] | 189 | media::AudioPortDeviceExtSys deviceSys; |
| 190 | deviceSys.encapsulationModes = VALUE_OR_RETURN_STATUS( |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 191 | legacy2aidl_AudioEncapsulationMode_mask(mEncapsulationModes)); |
Mikhail Naganov | ceb8bf9 | 2021-09-23 21:29:39 +0000 | [diff] [blame] | 192 | deviceSys.encapsulationMetadataTypes = VALUE_OR_RETURN_STATUS( |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 193 | legacy2aidl_AudioEncapsulationMetadataType_mask(mEncapsulationMetadataTypes)); |
Mikhail Naganov | 0078ee5 | 2021-09-30 23:06:20 +0000 | [diff] [blame] | 194 | UNION_SET(parcelable->sys.ext, device, deviceSys); |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 195 | return OK; |
| 196 | } |
| 197 | |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 198 | status_t DeviceDescriptorBase::readFromParcelable(const media::AudioPort& parcelable) { |
Mikhail Naganov | 0078ee5 | 2021-09-30 23:06:20 +0000 | [diff] [blame] | 199 | if (parcelable.sys.type != media::AudioPortType::DEVICE) { |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 200 | return BAD_VALUE; |
| 201 | } |
| 202 | status_t status = AudioPort::readFromParcelable(parcelable) |
Mikhail Naganov | 0078ee5 | 2021-09-30 23:06:20 +0000 | [diff] [blame] | 203 | ?: AudioPortConfig::readFromParcelable( |
| 204 | parcelable.hal.activeConfig, useInputChannelMask()); |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 205 | if (status != OK) { |
| 206 | return status; |
| 207 | } |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 208 | |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 209 | media::audio::common::AudioPortDeviceExt deviceExt = VALUE_OR_RETURN_STATUS( |
Mikhail Naganov | 0078ee5 | 2021-09-30 23:06:20 +0000 | [diff] [blame] | 210 | UNION_GET(parcelable.hal.ext, device)); |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 211 | mDeviceTypeAddr = VALUE_OR_RETURN_STATUS( |
Mikhail Naganov | 1050612 | 2021-10-19 10:14:23 -0700 | [diff] [blame] | 212 | aidl2legacy_AudioDeviceTypeAddress(deviceExt.device)); |
| 213 | mEncodedFormats = VALUE_OR_RETURN_STATUS( |
| 214 | convertContainer<FormatVector>(deviceExt.encodedFormats, |
| 215 | aidl2legacy_AudioFormatDescription_audio_format_t)); |
Mikhail Naganov | ceb8bf9 | 2021-09-23 21:29:39 +0000 | [diff] [blame] | 216 | media::AudioPortDeviceExtSys deviceSys = VALUE_OR_RETURN_STATUS( |
Mikhail Naganov | 0078ee5 | 2021-09-30 23:06:20 +0000 | [diff] [blame] | 217 | UNION_GET(parcelable.sys.ext, device)); |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 218 | mEncapsulationModes = VALUE_OR_RETURN_STATUS( |
Mikhail Naganov | ceb8bf9 | 2021-09-23 21:29:39 +0000 | [diff] [blame] | 219 | aidl2legacy_AudioEncapsulationMode_mask(deviceSys.encapsulationModes)); |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 220 | mEncapsulationMetadataTypes = VALUE_OR_RETURN_STATUS( |
Mikhail Naganov | ceb8bf9 | 2021-09-23 21:29:39 +0000 | [diff] [blame] | 221 | aidl2legacy_AudioEncapsulationMetadataType_mask(deviceSys.encapsulationMetadataTypes)); |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 222 | return OK; |
jiabin | 17058fa | 2019-10-08 17:33:38 -0700 | [diff] [blame] | 223 | } |
| 224 | |
jiabin | c52b1ff | 2019-10-31 17:20:42 -0700 | [diff] [blame] | 225 | std::string toString(const DeviceDescriptorBaseVector& devices) |
| 226 | { |
| 227 | std::string ret; |
| 228 | for (const auto& device : devices) { |
| 229 | if (device != *devices.begin()) { |
| 230 | ret += ";"; |
| 231 | } |
| 232 | ret += device->toString(); |
| 233 | } |
| 234 | return ret; |
| 235 | } |
| 236 | |
| 237 | AudioDeviceTypeAddrVector deviceTypeAddrsFromDescriptors(const DeviceDescriptorBaseVector& devices) |
| 238 | { |
| 239 | AudioDeviceTypeAddrVector deviceTypeAddrs; |
| 240 | for (const auto& device : devices) { |
| 241 | deviceTypeAddrs.push_back(device->getDeviceTypeAddr()); |
| 242 | } |
| 243 | return deviceTypeAddrs; |
| 244 | } |
| 245 | |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 246 | ConversionResult<sp<DeviceDescriptorBase>> |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 247 | aidl2legacy_DeviceDescriptorBase(const media::AudioPort& aidl) { |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 248 | sp<DeviceDescriptorBase> result = new DeviceDescriptorBase(AUDIO_DEVICE_NONE); |
| 249 | status_t status = result->readFromParcelable(aidl); |
| 250 | if (status != OK) { |
| 251 | return base::unexpected(status); |
| 252 | } |
| 253 | return result; |
| 254 | } |
| 255 | |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 256 | ConversionResult<media::AudioPort> |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 257 | legacy2aidl_DeviceDescriptorBase(const sp<DeviceDescriptorBase>& legacy) { |
Ytai Ben-Tsvi | f9dd924 | 2020-11-23 15:44:10 -0800 | [diff] [blame] | 258 | media::AudioPort aidl; |
Ytai Ben-Tsvi | 50e016a | 2020-11-12 14:26:12 -0800 | [diff] [blame] | 259 | status_t status = legacy->writeToParcelable(&aidl); |
| 260 | if (status != OK) { |
| 261 | return base::unexpected(status); |
| 262 | } |
| 263 | return aidl; |
| 264 | } |
| 265 | |
jiabin | 6ae65d8 | 2019-09-11 10:16:33 -0700 | [diff] [blame] | 266 | } // namespace android |