Android audio history | |
=== | |
A list of important audio features, bugs, fixes and workarounds for various Android versions. [(List of all Android Versions)](https://developer.android.com/guide/topics/manifest/uses-sdk-element#ApiLevels) | |
### 11.0 R - API 30 | |
- Bug in **AAudio** on RQ1A (Oboe works around this issue from version 1.5 onwards). A stream is normally disconnected when a **headset is plugged in** or because of other device changes. An `AAUDIO_ERROR_DISCONNECTED` error code should be passed to the error callback. But a bug in Shared MMAP streams causes `AAUDIO_ERROR_TIMEOUT` to be returned. So if your error callback is checking for `AAUDIO_ERROR_DISCONNECTED` then it may not respond properly. We recommend **always stopping and closing the stream** regardless of the error code. Oboe does this. So if you are using Oboe callbacks you are OK. This issue was not in the original R release. It was introduced in RQ1A, which is being delivered by OTA starting in November 2020. It will be fixed in a future update. Follow it on [this public Android issue](https://issuetracker.google.com/173928197). | |
- Fixed. A race condition in AudioFlinger could cause an assert in releaseBuffer() when a headset was plugged in or out. More details [here](notes/rlsbuffer.md) | |
### 10.0 Q - API 29 | |
- Fixed: Setting capacity of Legacy input streams < 4096 can prevent use of FAST path. https://github.com/google/oboe/issues/183. Also fixed in AAudio with ag/7116429 | |
- Add InputPreset:VoicePerformance for low latency recording. | |
- Regression bug: [AAudio] Headphone disconnect event not fired for MMAP streams. See P item below. Still in first Q release but fixed in some Q updates. | |
### 9.0 Pie - API 28 (August 6, 2018) | |
- AAudio adds support for setUsage(), setSessionId(), setContentType(), setInputPreset() for builders. | |
- Regression bug: [AAudio] Headphone disconnect event not fired for MMAP streams. Issue [#252](https://github.com/google/oboe/issues/252) Also see tech note [Disconnected Streams](notes/disconnect.md). | |
- AAudio input streams with LOW_LATENCY will open a FAST path using INT16 and convert the data to FLOAT if needed. See: https://github.com/google/oboe/issues/276 | |
### 8.1 Oreo MR1 - API 27 | |
- Oboe uses AAudio by default. | |
- AAudio MMAP data path enabled on Pixel devices. PerformanceMode::Exclusive supported. | |
- Fixed: [AAudio] RefBase issue | |
- Fixed: Requesting a stereo recording stream can result in sub-optimal latency. | |
### 8.0 Oreo - API 26 (August 21, 2017) | |
- [AAudio API introduced](https://developer.android.com/ndk/guides/audio/aaudio/aaudio) | |
- Bug: RefBase issue causes crash after stream closed. This why AAudio is not recommended for 8.0. Oboe will use OpenSL ES for 8.0 and earlier. | |
https://github.com/google/oboe/issues/40 | |
- Bug: Requesting a stereo recording stream can result in sub-optimal latency. [Details](https://issuetracker.google.com/issues/68666622) | |
### 7.1 Nougat MR1 - API 25 | |
- OpenSL adds supports for setting and querying of PerformanceMode. | |
### 7.0 Nougat - API 24 (August 22, 2016) | |
- OpenSL method `acquireJavaProxy` added, which allows the Java AudioTrack object associated with playback to be obtained (which allows underrun count). | |
### 6.0 Marshmallow - API 23 (October 5, 2015) | |
- Floating point recording supported. But it does not allow a FAST "low latency" path. | |
- [MIDI API introduced](https://developer.android.com/reference/android/media/midi/package-summary) | |
- Sound output is broken on the API 23 emulator | |
### 5.0 Lollipop - API 21 (November 12, 2014) | |
- Floating point playback supported. | |