Nate Jiang | 7a7fd84 | 2022-12-06 17:11:13 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2008 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 | #ifndef ANDROID_AUDIOSYSTEM_LEGACY_H_ |
| 18 | #define ANDROID_AUDIOSYSTEM_LEGACY_H_ |
| 19 | |
| 20 | #include <cutils/bitops.h> |
| 21 | #include <media/AudioParameter.h> |
| 22 | #include <utils/Errors.h> |
| 23 | |
| 24 | #include <system/audio.h> |
| 25 | #include <system/audio_policy.h> |
| 26 | |
| 27 | namespace android_audio_legacy { |
| 28 | |
| 29 | using android::AudioParameter; |
| 30 | using android::status_t; |
| 31 | |
| 32 | enum { |
| 33 | OK = android::OK, |
| 34 | NO_ERROR = android::NO_ERROR, |
| 35 | |
| 36 | UNKNOWN_ERROR = android::UNKNOWN_ERROR, |
| 37 | |
| 38 | NO_MEMORY = android::NO_MEMORY, |
| 39 | INVALID_OPERATION = android::INVALID_OPERATION, |
| 40 | BAD_VALUE = android::BAD_VALUE, |
| 41 | BAD_TYPE = android::BAD_TYPE, |
| 42 | NAME_NOT_FOUND = android::NAME_NOT_FOUND, |
| 43 | PERMISSION_DENIED = android::PERMISSION_DENIED, |
| 44 | NO_INIT = android::NO_INIT, |
| 45 | ALREADY_EXISTS = android::ALREADY_EXISTS, |
| 46 | DEAD_OBJECT = android::DEAD_OBJECT, |
| 47 | FAILED_TRANSACTION = android::FAILED_TRANSACTION, |
| 48 | BAD_INDEX = android::BAD_INDEX, |
| 49 | NOT_ENOUGH_DATA = android::NOT_ENOUGH_DATA, |
| 50 | WOULD_BLOCK = android::WOULD_BLOCK, |
| 51 | TIMED_OUT = android::TIMED_OUT, |
| 52 | UNKNOWN_TRANSACTION = android::UNKNOWN_TRANSACTION, |
| 53 | }; |
| 54 | |
| 55 | enum audio_source { |
| 56 | AUDIO_SOURCE_DEFAULT = 0, |
| 57 | AUDIO_SOURCE_MIC = 1, |
| 58 | AUDIO_SOURCE_VOICE_UPLINK = 2, |
| 59 | AUDIO_SOURCE_VOICE_DOWNLINK = 3, |
| 60 | AUDIO_SOURCE_VOICE_CALL = 4, |
| 61 | AUDIO_SOURCE_CAMCORDER = 5, |
| 62 | AUDIO_SOURCE_VOICE_RECOGNITION = 6, |
| 63 | AUDIO_SOURCE_VOICE_COMMUNICATION = 7, |
| 64 | AUDIO_SOURCE_MAX = AUDIO_SOURCE_VOICE_COMMUNICATION, |
| 65 | |
| 66 | AUDIO_SOURCE_LIST_END // must be last - used to validate audio source type |
| 67 | }; |
| 68 | |
| 69 | class AudioSystem { |
| 70 | public: |
| 71 | #if 1 |
| 72 | enum stream_type { |
| 73 | DEFAULT = -1, |
| 74 | VOICE_CALL = 0, |
| 75 | SYSTEM = 1, |
| 76 | RING = 2, |
| 77 | MUSIC = 3, |
| 78 | ALARM = 4, |
| 79 | NOTIFICATION = 5, |
| 80 | BLUETOOTH_SCO = 6, |
| 81 | ENFORCED_AUDIBLE = 7, // Sounds that cannot be muted by user and must be routed to speaker |
| 82 | DTMF = 8, |
| 83 | TTS = 9, |
| 84 | NUM_STREAM_TYPES |
| 85 | }; |
| 86 | |
| 87 | // Audio sub formats (see AudioSystem::audio_format). |
| 88 | enum pcm_sub_format { |
| 89 | PCM_SUB_16_BIT = 0x1, // must be 1 for backward compatibility |
| 90 | PCM_SUB_8_BIT = 0x2, // must be 2 for backward compatibility |
| 91 | }; |
| 92 | |
| 93 | enum audio_sessions { |
| 94 | SESSION_OUTPUT_STAGE = AUDIO_SESSION_OUTPUT_STAGE, |
| 95 | SESSION_OUTPUT_MIX = AUDIO_SESSION_OUTPUT_MIX, |
| 96 | }; |
| 97 | |
| 98 | // MP3 sub format field definition : can use 11 LSBs in the same way as MP3 frame header to |
| 99 | // specify bit rate, stereo mode, version... |
| 100 | enum mp3_sub_format { |
| 101 | // TODO |
| 102 | }; |
| 103 | |
| 104 | // AMR NB/WB sub format field definition: specify frame block interleaving, bandwidth efficient |
| 105 | // or octet aligned, encoding mode for recording... |
| 106 | enum amr_sub_format { |
| 107 | // TODO |
| 108 | }; |
| 109 | |
| 110 | // AAC sub format field definition: specify profile or bitrate for recording... |
| 111 | enum aac_sub_format { |
| 112 | // TODO |
| 113 | }; |
| 114 | |
| 115 | // VORBIS sub format field definition: specify quality for recording... |
| 116 | enum vorbis_sub_format { |
| 117 | // TODO |
| 118 | }; |
| 119 | |
| 120 | // Audio format consists in a main format field (upper 8 bits) and a sub format field (lower 24 |
| 121 | // bits). The main format indicates the main codec type. The sub format field indicates options |
| 122 | // and parameters for each format. The sub format is mainly used for record to indicate for |
| 123 | // instance the requested bitrate or profile. It can also be used for certain formats to give |
| 124 | // informations not present in the encoded audio stream (e.g. octet alignement for AMR). |
| 125 | enum audio_format { |
| 126 | INVALID_FORMAT = -1, |
| 127 | FORMAT_DEFAULT = 0, |
| 128 | PCM = 0x00000000, // must be 0 for backward compatibility |
| 129 | MP3 = 0x01000000, |
| 130 | AMR_NB = 0x02000000, |
| 131 | AMR_WB = 0x03000000, |
| 132 | AAC = 0x04000000, |
| 133 | HE_AAC_V1 = 0x05000000, |
| 134 | HE_AAC_V2 = 0x06000000, |
| 135 | VORBIS = 0x07000000, |
| 136 | MAIN_FORMAT_MASK = 0xFF000000, |
| 137 | SUB_FORMAT_MASK = 0x00FFFFFF, |
| 138 | // Aliases |
| 139 | PCM_16_BIT = (PCM | PCM_SUB_16_BIT), |
| 140 | PCM_8_BIT = (PCM | PCM_SUB_8_BIT) |
| 141 | }; |
| 142 | |
| 143 | enum audio_channels { |
| 144 | // output channels |
| 145 | CHANNEL_OUT_FRONT_LEFT = 0x1, |
| 146 | CHANNEL_OUT_FRONT_RIGHT = 0x2, |
| 147 | CHANNEL_OUT_FRONT_CENTER = 0x4, |
| 148 | CHANNEL_OUT_LOW_FREQUENCY = 0x8, |
| 149 | CHANNEL_OUT_BACK_LEFT = 0x10, |
| 150 | CHANNEL_OUT_BACK_RIGHT = 0x20, |
| 151 | CHANNEL_OUT_FRONT_LEFT_OF_CENTER = 0x40, |
| 152 | CHANNEL_OUT_FRONT_RIGHT_OF_CENTER = 0x80, |
| 153 | CHANNEL_OUT_BACK_CENTER = 0x100, |
| 154 | CHANNEL_OUT_SIDE_LEFT = 0x200, |
| 155 | CHANNEL_OUT_SIDE_RIGHT = 0x400, |
| 156 | CHANNEL_OUT_TOP_CENTER = 0x800, |
| 157 | CHANNEL_OUT_TOP_FRONT_LEFT = 0x1000, |
| 158 | CHANNEL_OUT_TOP_FRONT_CENTER = 0x2000, |
| 159 | CHANNEL_OUT_TOP_FRONT_RIGHT = 0x4000, |
| 160 | CHANNEL_OUT_TOP_BACK_LEFT = 0x8000, |
| 161 | CHANNEL_OUT_TOP_BACK_CENTER = 0x10000, |
| 162 | CHANNEL_OUT_TOP_BACK_RIGHT = 0x20000, |
| 163 | |
| 164 | CHANNEL_OUT_MONO = CHANNEL_OUT_FRONT_LEFT, |
| 165 | CHANNEL_OUT_STEREO = (CHANNEL_OUT_FRONT_LEFT | CHANNEL_OUT_FRONT_RIGHT), |
| 166 | CHANNEL_OUT_QUAD = (CHANNEL_OUT_FRONT_LEFT | CHANNEL_OUT_FRONT_RIGHT | |
| 167 | CHANNEL_OUT_BACK_LEFT | CHANNEL_OUT_BACK_RIGHT), |
| 168 | CHANNEL_OUT_SURROUND = (CHANNEL_OUT_FRONT_LEFT | CHANNEL_OUT_FRONT_RIGHT | |
| 169 | CHANNEL_OUT_FRONT_CENTER | CHANNEL_OUT_BACK_CENTER), |
| 170 | CHANNEL_OUT_5POINT1 = |
| 171 | (CHANNEL_OUT_FRONT_LEFT | CHANNEL_OUT_FRONT_RIGHT | CHANNEL_OUT_FRONT_CENTER | |
| 172 | CHANNEL_OUT_LOW_FREQUENCY | CHANNEL_OUT_BACK_LEFT | CHANNEL_OUT_BACK_RIGHT), |
| 173 | // matches the correct AudioFormat.CHANNEL_OUT_7POINT1_SURROUND definition for 7.1 |
| 174 | CHANNEL_OUT_7POINT1 = |
| 175 | (CHANNEL_OUT_FRONT_LEFT | CHANNEL_OUT_FRONT_RIGHT | CHANNEL_OUT_FRONT_CENTER | |
| 176 | CHANNEL_OUT_LOW_FREQUENCY | CHANNEL_OUT_BACK_LEFT | CHANNEL_OUT_BACK_RIGHT | |
| 177 | CHANNEL_OUT_SIDE_LEFT | CHANNEL_OUT_SIDE_RIGHT), |
| 178 | CHANNEL_OUT_ALL = |
| 179 | (CHANNEL_OUT_FRONT_LEFT | CHANNEL_OUT_FRONT_RIGHT | CHANNEL_OUT_FRONT_CENTER | |
| 180 | CHANNEL_OUT_LOW_FREQUENCY | CHANNEL_OUT_BACK_LEFT | CHANNEL_OUT_BACK_RIGHT | |
| 181 | CHANNEL_OUT_FRONT_LEFT_OF_CENTER | CHANNEL_OUT_FRONT_RIGHT_OF_CENTER | |
| 182 | CHANNEL_OUT_BACK_CENTER | CHANNEL_OUT_SIDE_LEFT | CHANNEL_OUT_SIDE_RIGHT | |
| 183 | CHANNEL_OUT_TOP_CENTER | CHANNEL_OUT_TOP_FRONT_LEFT | |
| 184 | CHANNEL_OUT_TOP_FRONT_CENTER | CHANNEL_OUT_TOP_FRONT_RIGHT | |
| 185 | CHANNEL_OUT_TOP_BACK_LEFT | CHANNEL_OUT_TOP_BACK_CENTER | |
| 186 | CHANNEL_OUT_TOP_BACK_RIGHT), |
| 187 | |
| 188 | // input channels |
| 189 | CHANNEL_IN_LEFT = 0x4, |
| 190 | CHANNEL_IN_RIGHT = 0x8, |
| 191 | CHANNEL_IN_FRONT = 0x10, |
| 192 | CHANNEL_IN_BACK = 0x20, |
| 193 | CHANNEL_IN_LEFT_PROCESSED = 0x40, |
| 194 | CHANNEL_IN_RIGHT_PROCESSED = 0x80, |
| 195 | CHANNEL_IN_FRONT_PROCESSED = 0x100, |
| 196 | CHANNEL_IN_BACK_PROCESSED = 0x200, |
| 197 | CHANNEL_IN_PRESSURE = 0x400, |
| 198 | CHANNEL_IN_X_AXIS = 0x800, |
| 199 | CHANNEL_IN_Y_AXIS = 0x1000, |
| 200 | CHANNEL_IN_Z_AXIS = 0x2000, |
| 201 | CHANNEL_IN_VOICE_UPLINK = 0x4000, |
| 202 | CHANNEL_IN_VOICE_DNLINK = 0x8000, |
| 203 | CHANNEL_IN_MONO = CHANNEL_IN_FRONT, |
| 204 | CHANNEL_IN_STEREO = (CHANNEL_IN_LEFT | CHANNEL_IN_RIGHT), |
| 205 | CHANNEL_IN_ALL = (CHANNEL_IN_LEFT | CHANNEL_IN_RIGHT | CHANNEL_IN_FRONT | CHANNEL_IN_BACK | |
| 206 | CHANNEL_IN_LEFT_PROCESSED | CHANNEL_IN_RIGHT_PROCESSED | |
| 207 | CHANNEL_IN_FRONT_PROCESSED | CHANNEL_IN_BACK_PROCESSED | |
| 208 | CHANNEL_IN_PRESSURE | CHANNEL_IN_X_AXIS | CHANNEL_IN_Y_AXIS | |
| 209 | CHANNEL_IN_Z_AXIS | CHANNEL_IN_VOICE_UPLINK | CHANNEL_IN_VOICE_DNLINK) |
| 210 | }; |
| 211 | |
| 212 | enum audio_mode { |
| 213 | MODE_INVALID = -2, |
| 214 | MODE_CURRENT = -1, |
| 215 | MODE_NORMAL = 0, |
| 216 | MODE_RINGTONE, |
| 217 | MODE_IN_CALL, |
| 218 | MODE_IN_COMMUNICATION, |
| 219 | NUM_MODES // not a valid entry, denotes end-of-list |
| 220 | }; |
| 221 | |
| 222 | enum audio_in_acoustics { |
| 223 | AGC_ENABLE = 0x0001, |
| 224 | AGC_DISABLE = 0, |
| 225 | NS_ENABLE = 0x0002, |
| 226 | NS_DISABLE = 0, |
| 227 | TX_IIR_ENABLE = 0x0004, |
| 228 | TX_DISABLE = 0 |
| 229 | }; |
| 230 | |
| 231 | // DO NOT USE: the "audio_devices" enumeration below is obsolete, use type "audio_devices_t" and |
| 232 | // audio device enumeration from system/audio.h instead. |
| 233 | enum audio_devices { |
| 234 | // output devices |
| 235 | DEVICE_OUT_EARPIECE = 0x1, |
| 236 | DEVICE_OUT_SPEAKER = 0x2, |
| 237 | DEVICE_OUT_WIRED_HEADSET = 0x4, |
| 238 | DEVICE_OUT_WIRED_HEADPHONE = 0x8, |
| 239 | DEVICE_OUT_BLUETOOTH_SCO = 0x10, |
| 240 | DEVICE_OUT_BLUETOOTH_SCO_HEADSET = 0x20, |
| 241 | DEVICE_OUT_BLUETOOTH_SCO_CARKIT = 0x40, |
| 242 | DEVICE_OUT_BLUETOOTH_A2DP = 0x80, |
| 243 | DEVICE_OUT_BLUETOOTH_A2DP_HEADPHONES = 0x100, |
| 244 | DEVICE_OUT_BLUETOOTH_A2DP_SPEAKER = 0x200, |
| 245 | DEVICE_OUT_AUX_DIGITAL = 0x400, |
| 246 | DEVICE_OUT_ANLG_DOCK_HEADSET = 0x800, |
| 247 | DEVICE_OUT_DGTL_DOCK_HEADSET = 0x1000, |
| 248 | DEVICE_OUT_DEFAULT = 0x8000, |
| 249 | DEVICE_OUT_ALL = |
| 250 | (DEVICE_OUT_EARPIECE | DEVICE_OUT_SPEAKER | DEVICE_OUT_WIRED_HEADSET | |
| 251 | DEVICE_OUT_WIRED_HEADPHONE | DEVICE_OUT_BLUETOOTH_SCO | |
| 252 | DEVICE_OUT_BLUETOOTH_SCO_HEADSET | DEVICE_OUT_BLUETOOTH_SCO_CARKIT | |
| 253 | DEVICE_OUT_BLUETOOTH_A2DP | DEVICE_OUT_BLUETOOTH_A2DP_HEADPHONES | |
| 254 | DEVICE_OUT_BLUETOOTH_A2DP_SPEAKER | DEVICE_OUT_AUX_DIGITAL | |
| 255 | DEVICE_OUT_ANLG_DOCK_HEADSET | DEVICE_OUT_DGTL_DOCK_HEADSET | DEVICE_OUT_DEFAULT), |
| 256 | DEVICE_OUT_ALL_A2DP = (DEVICE_OUT_BLUETOOTH_A2DP | DEVICE_OUT_BLUETOOTH_A2DP_HEADPHONES | |
| 257 | DEVICE_OUT_BLUETOOTH_A2DP_SPEAKER), |
| 258 | |
| 259 | // input devices |
| 260 | DEVICE_IN_COMMUNICATION = 0x10000, |
| 261 | DEVICE_IN_AMBIENT = 0x20000, |
| 262 | DEVICE_IN_BUILTIN_MIC = 0x40000, |
| 263 | DEVICE_IN_BLUETOOTH_SCO_HEADSET = 0x80000, |
| 264 | DEVICE_IN_WIRED_HEADSET = 0x100000, |
| 265 | DEVICE_IN_AUX_DIGITAL = 0x200000, |
| 266 | DEVICE_IN_VOICE_CALL = 0x400000, |
| 267 | DEVICE_IN_BACK_MIC = 0x800000, |
| 268 | DEVICE_IN_DEFAULT = 0x80000000, |
| 269 | |
| 270 | DEVICE_IN_ALL = |
| 271 | (DEVICE_IN_COMMUNICATION | DEVICE_IN_AMBIENT | DEVICE_IN_BUILTIN_MIC | |
| 272 | DEVICE_IN_BLUETOOTH_SCO_HEADSET | DEVICE_IN_WIRED_HEADSET | DEVICE_IN_AUX_DIGITAL | |
| 273 | DEVICE_IN_VOICE_CALL | DEVICE_IN_BACK_MIC | DEVICE_IN_DEFAULT) |
| 274 | }; |
| 275 | |
| 276 | // request to open a direct output with getOutput() (by opposition to sharing an output with |
| 277 | // other AudioTracks) |
| 278 | enum output_flags { OUTPUT_FLAG_INDIRECT = 0x0, OUTPUT_FLAG_DIRECT = 0x1 }; |
| 279 | |
| 280 | // device categories used for setForceUse() |
| 281 | enum forced_config { |
| 282 | FORCE_NONE, |
| 283 | FORCE_SPEAKER, |
| 284 | FORCE_HEADPHONES, |
| 285 | FORCE_BT_SCO, |
| 286 | FORCE_BT_A2DP, |
| 287 | FORCE_WIRED_ACCESSORY, |
| 288 | FORCE_BT_CAR_DOCK, |
| 289 | FORCE_BT_DESK_DOCK, |
| 290 | FORCE_ANALOG_DOCK, |
| 291 | FORCE_DIGITAL_DOCK, |
| 292 | FORCE_NO_BT_A2DP, |
| 293 | FORCE_SYSTEM_ENFORCED, |
| 294 | NUM_FORCE_CONFIG, |
| 295 | FORCE_DEFAULT = FORCE_NONE |
| 296 | }; |
| 297 | |
| 298 | // usages used for setForceUse() |
| 299 | enum force_use { |
| 300 | FOR_COMMUNICATION, |
| 301 | FOR_MEDIA, |
| 302 | FOR_RECORD, |
| 303 | FOR_DOCK, |
| 304 | FOR_SYSTEM, |
| 305 | NUM_FORCE_USE |
| 306 | }; |
| 307 | |
| 308 | // |
| 309 | // AudioPolicyService interface |
| 310 | // |
| 311 | |
| 312 | // device connection states used for setDeviceConnectionState() |
| 313 | enum device_connection_state { |
| 314 | DEVICE_STATE_UNAVAILABLE, |
| 315 | DEVICE_STATE_AVAILABLE, |
| 316 | NUM_DEVICE_STATES |
| 317 | }; |
| 318 | |
| 319 | #endif |
| 320 | |
| 321 | static uint32_t popCount(uint32_t u) { return popcount(u); } |
| 322 | |
| 323 | #if 1 |
| 324 | static bool isOutputDevice(audio_devices device) { |
| 325 | if ((popcount(device) == 1) && ((device & ~DEVICE_OUT_ALL) == 0)) |
| 326 | return true; |
| 327 | else |
| 328 | return false; |
| 329 | } |
| 330 | static bool isInputDevice(audio_devices device) { |
| 331 | if ((popcount(device) == 1) && ((device & ~DEVICE_IN_ALL) == 0)) |
| 332 | return true; |
| 333 | else |
| 334 | return false; |
| 335 | } |
| 336 | static bool isA2dpDevice(audio_devices device) { |
| 337 | return audio_is_a2dp_device((audio_devices_t)device); |
| 338 | } |
| 339 | static bool isBluetoothScoDevice(audio_devices device) { |
| 340 | return audio_is_bluetooth_sco_device((audio_devices_t)device); |
| 341 | } |
| 342 | static bool isValidFormat(uint32_t format) { |
| 343 | return audio_is_valid_format((audio_format_t)format); |
| 344 | } |
| 345 | static bool isLinearPCM(uint32_t format) { return audio_is_linear_pcm((audio_format_t)format); } |
| 346 | static bool isOutputChannel(audio_channel_mask_t channel) { |
| 347 | return audio_is_output_channel(channel); |
| 348 | } |
| 349 | static bool isInputChannel(audio_channel_mask_t channel) { |
| 350 | return audio_is_input_channel(channel); |
| 351 | } |
| 352 | |
| 353 | #endif |
| 354 | }; |
| 355 | |
| 356 | }; // namespace android_audio_legacy |
| 357 | |
| 358 | #endif // ANDROID_AUDIOSYSTEM_LEGACY_H_ |