AAudioService: integrated with audioserver
Call the MmapStreamInterface from AudioFlinger instead of the FakeHAL.
Fix sending timestamps from the thread.
Add shared mode in service.
Bug: 35260844
Test: CTS test_aaudio.cpp
Change-Id: I44c7e4ecae4ce205611b6b73a72e0ae8a5b243e5
Signed-off-by: Phil Burk <philburk@google.com>
diff --git a/services/audioflinger/AudioFlinger.cpp b/services/audioflinger/AudioFlinger.cpp
index 4b2e643..959baf7 100644
--- a/services/audioflinger/AudioFlinger.cpp
+++ b/services/audioflinger/AudioFlinger.cpp
@@ -2133,7 +2133,7 @@
return BAD_VALUE;
}
mMmapThreads.removeItem(output);
- ALOGV("closing mmapThread %p", mmapThread.get());
+ ALOGD("closing mmapThread %p", mmapThread.get());
}
const sp<AudioIoDescriptor> ioDesc = new AudioIoDescriptor();
ioDesc->mIoHandle = output;
@@ -2148,7 +2148,7 @@
closeOutputFinish(playbackThread);
}
} else if (mmapThread != 0) {
- ALOGV("mmapThread exit()");
+ ALOGD("mmapThread exit()");
mmapThread->exit();
AudioStreamOut *out = mmapThread->clearOutput();
ALOG_ASSERT(out != NULL, "out shouldn't be NULL");
diff --git a/services/audioflinger/Threads.cpp b/services/audioflinger/Threads.cpp
index 6a75bb0..e8cde88 100644
--- a/services/audioflinger/Threads.cpp
+++ b/services/audioflinger/Threads.cpp
@@ -7592,7 +7592,11 @@
if (mActiveTracks.size() == 0) {
// for the first track, reuse portId and session allocated when the stream was opened
- mHalStream->start();
+ ret = mHalStream->start();
+ if (ret != NO_ERROR) {
+ ALOGE("%s: error mHalStream->start() = %d for first track", __FUNCTION__, ret);
+ return ret;
+ }
portId = mPortId;
sessionId = mSessionId;
mStandby = false;
@@ -7647,6 +7651,7 @@
// abort if start is rejected by audio policy manager
if (ret != NO_ERROR) {
+ ALOGE("%s: error start rejected by AudioPolicyManager = %d", __FUNCTION__, ret);
if (mActiveTracks.size() != 0) {
if (isOutput()) {
AudioSystem::releaseOutput(mId, streamType(), sessionId);
@@ -7942,15 +7947,17 @@
if (isOutput() && mPrevOutDevice != mOutDevice) {
mPrevOutDevice = type;
sendIoConfigEvent_l(AUDIO_OUTPUT_CONFIG_CHANGED);
- if (mCallback != 0) {
- mCallback->onRoutingChanged(deviceId);
+ sp<MmapStreamCallback> callback = mCallback.promote();
+ if (callback != 0) {
+ callback->onRoutingChanged(deviceId);
}
}
if (!isOutput() && mPrevInDevice != mInDevice) {
mPrevInDevice = type;
sendIoConfigEvent_l(AUDIO_INPUT_CONFIG_CHANGED);
- if (mCallback != 0) {
- mCallback->onRoutingChanged(deviceId);
+ sp<MmapStreamCallback> callback = mCallback.promote();
+ if (callback != 0) {
+ callback->onRoutingChanged(deviceId);
}
}
return status;
@@ -8065,8 +8072,9 @@
void AudioFlinger::MmapThread::threadLoop_exit()
{
- if (mCallback != 0) {
- mCallback->onTearDown();
+ sp<MmapStreamCallback> callback = mCallback.promote();
+ if (callback != 0) {
+ callback->onTearDown();
}
}
@@ -8114,8 +8122,9 @@
{
for (const sp<MmapTrack> &track : mActiveTracks) {
if (track->isInvalid()) {
- if (mCallback != 0) {
- mCallback->onTearDown();
+ sp<MmapStreamCallback> callback = mCallback.promote();
+ if (callback != 0) {
+ callback->onTearDown();
}
break;
}
@@ -8290,7 +8299,8 @@
mOutput->stream->setVolume(volume, volume);
- if (mCallback != 0) {
+ sp<MmapStreamCallback> callback = mCallback.promote();
+ if (callback != 0) {
int channelCount;
if (isOutput()) {
channelCount = audio_channel_count_from_out_mask(mChannelMask);
@@ -8301,7 +8311,7 @@
for (int i = 0; i < channelCount; i++) {
values.add(volume);
}
- mCallback->onVolumeChanged(mChannelMask, values);
+ callback->onVolumeChanged(mChannelMask, values);
}
}
}
diff --git a/services/audioflinger/Threads.h b/services/audioflinger/Threads.h
index cc66cad..7469710 100644
--- a/services/audioflinger/Threads.h
+++ b/services/audioflinger/Threads.h
@@ -1528,7 +1528,7 @@
audio_session_t mSessionId;
audio_port_handle_t mPortId;
- sp<MmapStreamCallback> mCallback;
+ wp<MmapStreamCallback> mCallback;
sp<StreamHalInterface> mHalStream;
sp<DeviceHalInterface> mHalDevice;
AudioHwDevice* const mAudioHwDev;