• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2 **
3 ** Copyright 2007, The Android Open Source Project
4 **
5 ** Licensed under the Apache License, Version 2.0 (the "License");
6 ** you may not use this file except in compliance with the License.
7 ** You may obtain a copy of the License at
8 **
9 **     http://www.apache.org/licenses/LICENSE-2.0
10 **
11 ** Unless required by applicable law or agreed to in writing, software
12 ** distributed under the License is distributed on an "AS IS" BASIS,
13 ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ** See the License for the specific language governing permissions and
15 ** limitations under the License.
16 */
17 
18 #define LOG_TAG "AudioMixer"
19 //#define LOG_NDEBUG 0
20 
21 #include <sstream>
22 #include <stdint.h>
23 #include <string.h>
24 #include <stdlib.h>
25 #include <math.h>
26 #include <sys/types.h>
27 
28 #include <utils/Errors.h>
29 #include <utils/Log.h>
30 
31 #include <system/audio.h>
32 
33 #include <audio_utils/primitives.h>
34 #include <audio_utils/format.h>
35 #include <media/AudioMixer.h>
36 
37 #include "AudioMixerOps.h"
38 
39 // The FCC_2 macro refers to the Fixed Channel Count of 2 for the legacy integer mixer.
40 #ifndef FCC_2
41 #define FCC_2 2
42 #endif
43 
44 // Look for MONO_HACK for any Mono hack involving legacy mono channel to
45 // stereo channel conversion.
46 
47 /* VERY_VERY_VERBOSE_LOGGING will show exactly which process hook and track hook is
48  * being used. This is a considerable amount of log spam, so don't enable unless you
49  * are verifying the hook based code.
50  */
51 //#define VERY_VERY_VERBOSE_LOGGING
52 #ifdef VERY_VERY_VERBOSE_LOGGING
53 #define ALOGVV ALOGV
54 //define ALOGVV printf  // for test-mixer.cpp
55 #else
56 #define ALOGVV(a...) do { } while (0)
57 #endif
58 
59 // Set to default copy buffer size in frames for input processing.
60 static constexpr size_t kCopyBufferFrameCount = 256;
61 
62 namespace android {
63 
64 // ----------------------------------------------------------------------------
65 
isValidChannelMask(audio_channel_mask_t channelMask) const66 bool AudioMixer::isValidChannelMask(audio_channel_mask_t channelMask) const {
67     return audio_channel_mask_is_valid(channelMask); // the RemixBufferProvider is flexible.
68 }
69 
70 // Called when channel masks have changed for a track name
71 // TODO: Fix DownmixerBufferProvider not to (possibly) change mixer input format,
72 // which will simplify this logic.
setChannelMasks(int name,audio_channel_mask_t trackChannelMask,audio_channel_mask_t mixerChannelMask)73 bool AudioMixer::setChannelMasks(int name,
74         audio_channel_mask_t trackChannelMask, audio_channel_mask_t mixerChannelMask) {
75     LOG_ALWAYS_FATAL_IF(!exists(name), "invalid name: %d", name);
76     const std::shared_ptr<Track> &track = getTrack(name);
77 
78     if (trackChannelMask == (track->channelMask | track->mHapticChannelMask)
79             && mixerChannelMask == (track->mMixerChannelMask | track->mMixerHapticChannelMask)) {
80         return false;  // no need to change
81     }
82     const audio_channel_mask_t hapticChannelMask =
83             static_cast<audio_channel_mask_t>(trackChannelMask & AUDIO_CHANNEL_HAPTIC_ALL);
84     trackChannelMask = static_cast<audio_channel_mask_t>(
85             trackChannelMask & ~AUDIO_CHANNEL_HAPTIC_ALL);
86     const audio_channel_mask_t mixerHapticChannelMask = static_cast<audio_channel_mask_t>(
87             mixerChannelMask & AUDIO_CHANNEL_HAPTIC_ALL);
88     mixerChannelMask = static_cast<audio_channel_mask_t>(
89             mixerChannelMask & ~AUDIO_CHANNEL_HAPTIC_ALL);
90     // always recompute for both channel masks even if only one has changed.
91     const uint32_t trackChannelCount = audio_channel_count_from_out_mask(trackChannelMask);
92     const uint32_t mixerChannelCount = audio_channel_count_from_out_mask(mixerChannelMask);
93     const uint32_t hapticChannelCount = audio_channel_count_from_out_mask(hapticChannelMask);
94     const uint32_t mixerHapticChannelCount =
95             audio_channel_count_from_out_mask(mixerHapticChannelMask);
96 
97     ALOG_ASSERT((trackChannelCount <= MAX_NUM_CHANNELS_TO_DOWNMIX)
98             && trackChannelCount
99             && mixerChannelCount);
100     track->channelMask = trackChannelMask;
101     track->channelCount = trackChannelCount;
102     track->mMixerChannelMask = mixerChannelMask;
103     track->mMixerChannelCount = mixerChannelCount;
104     track->mHapticChannelMask = hapticChannelMask;
105     track->mHapticChannelCount = hapticChannelCount;
106     track->mMixerHapticChannelMask = mixerHapticChannelMask;
107     track->mMixerHapticChannelCount = mixerHapticChannelCount;
108 
109     if (track->mHapticChannelCount > 0) {
110         track->mAdjustInChannelCount = track->channelCount + track->mHapticChannelCount;
111         track->mAdjustOutChannelCount = track->channelCount;
112         track->mKeepContractedChannels = track->mHapticPlaybackEnabled;
113     } else {
114         track->mAdjustInChannelCount = 0;
115         track->mAdjustOutChannelCount = 0;
116         track->mKeepContractedChannels = false;
117     }
118 
119     track->mInputFrameSize = audio_bytes_per_frame(
120             track->channelCount + track->mHapticChannelCount, track->mFormat);
121 
122     // channel masks have changed, does this track need a downmixer?
123     // update to try using our desired format (if we aren't already using it)
124     const status_t status = track->prepareForDownmix();
125     ALOGE_IF(status != OK,
126             "prepareForDownmix error %d, track channel mask %#x, mixer channel mask %#x",
127             status, track->channelMask, track->mMixerChannelMask);
128 
129     // always do reformat since channel mask changed,
130     // do it after downmix since track format may change!
131     track->prepareForReformat();
132 
133     track->prepareForAdjustChannels(mFrameCount);
134 
135     // Resampler channels may have changed.
136     track->recreateResampler(mSampleRate);
137     return true;
138 }
139 
unprepareForDownmix()140 void AudioMixer::Track::unprepareForDownmix() {
141     ALOGV("AudioMixer::unprepareForDownmix(%p)", this);
142 
143     if (mPostDownmixReformatBufferProvider.get() != nullptr) {
144         // release any buffers held by the mPostDownmixReformatBufferProvider
145         // before deallocating the mDownmixerBufferProvider.
146         mPostDownmixReformatBufferProvider->reset();
147     }
148 
149     mDownmixRequiresFormat = AUDIO_FORMAT_INVALID;
150     if (mDownmixerBufferProvider.get() != nullptr) {
151         // this track had previously been configured with a downmixer, delete it
152         mDownmixerBufferProvider.reset(nullptr);
153         reconfigureBufferProviders();
154     } else {
155         ALOGV(" nothing to do, no downmixer to delete");
156     }
157 }
158 
prepareForDownmix()159 status_t AudioMixer::Track::prepareForDownmix()
160 {
161     ALOGV("AudioMixer::prepareForDownmix(%p) with mask 0x%x",
162             this, channelMask);
163 
164     // discard the previous downmixer if there was one
165     unprepareForDownmix();
166     // MONO_HACK Only remix (upmix or downmix) if the track and mixer/device channel masks
167     // are not the same and not handled internally, as mono for channel position masks is.
168     if (channelMask == mMixerChannelMask
169             || (channelMask == AUDIO_CHANNEL_OUT_MONO
170                     && isAudioChannelPositionMask(mMixerChannelMask))) {
171         return NO_ERROR;
172     }
173     // DownmixerBufferProvider is only used for position masks.
174     if (audio_channel_mask_get_representation(channelMask)
175                 == AUDIO_CHANNEL_REPRESENTATION_POSITION
176             && DownmixerBufferProvider::isMultichannelCapable()) {
177 
178         // Check if we have a float or int16 downmixer, in that order.
179         for (const audio_format_t format : { AUDIO_FORMAT_PCM_FLOAT, AUDIO_FORMAT_PCM_16_BIT }) {
180             mDownmixerBufferProvider.reset(new DownmixerBufferProvider(
181                     channelMask, mMixerChannelMask,
182                     format,
183                     sampleRate, sessionId, kCopyBufferFrameCount));
184             if (static_cast<DownmixerBufferProvider *>(mDownmixerBufferProvider.get())
185                     ->isValid()) {
186                 mDownmixRequiresFormat = format;
187                 reconfigureBufferProviders();
188                 return NO_ERROR;
189             }
190         }
191         // mDownmixerBufferProvider reset below.
192     }
193 
194     // See if we should use our built-in non-effect downmixer.
195     if (mMixerInFormat == AUDIO_FORMAT_PCM_FLOAT
196             && ChannelMixBufferProvider::isOutputChannelMaskSupported(mMixerChannelMask)
197             && audio_channel_mask_get_representation(channelMask)
198                     == AUDIO_CHANNEL_REPRESENTATION_POSITION) {
199         mDownmixerBufferProvider.reset(new ChannelMixBufferProvider(channelMask,
200                 mMixerChannelMask, mMixerInFormat, kCopyBufferFrameCount));
201         if (static_cast<ChannelMixBufferProvider *>(mDownmixerBufferProvider.get())
202                 ->isValid()) {
203             mDownmixRequiresFormat = mMixerInFormat;
204             reconfigureBufferProviders();
205             ALOGD("%s: Fallback using ChannelMix", __func__);
206             return NO_ERROR;
207         } else {
208             ALOGD("%s: ChannelMix not supported for channel mask %#x", __func__, channelMask);
209         }
210     }
211 
212     // Effect downmixer does not accept the channel conversion.  Let's use our remixer.
213     mDownmixerBufferProvider.reset(new RemixBufferProvider(channelMask,
214             mMixerChannelMask, mMixerInFormat, kCopyBufferFrameCount));
215     // Remix always finds a conversion whereas Downmixer effect above may fail.
216     reconfigureBufferProviders();
217     return NO_ERROR;
218 }
219 
unprepareForReformat()220 void AudioMixer::Track::unprepareForReformat() {
221     ALOGV("AudioMixer::unprepareForReformat(%p)", this);
222     bool requiresReconfigure = false;
223     if (mReformatBufferProvider.get() != nullptr) {
224         mReformatBufferProvider.reset(nullptr);
225         requiresReconfigure = true;
226     }
227     if (mPostDownmixReformatBufferProvider.get() != nullptr) {
228         mPostDownmixReformatBufferProvider.reset(nullptr);
229         requiresReconfigure = true;
230     }
231     if (requiresReconfigure) {
232         reconfigureBufferProviders();
233     }
234 }
235 
prepareForReformat()236 status_t AudioMixer::Track::prepareForReformat()
237 {
238     ALOGV("AudioMixer::prepareForReformat(%p) with format %#x", this, mFormat);
239     // discard previous reformatters
240     unprepareForReformat();
241     // only configure reformatters as needed
242     const audio_format_t targetFormat = mDownmixRequiresFormat != AUDIO_FORMAT_INVALID
243             ? mDownmixRequiresFormat : mMixerInFormat;
244     bool requiresReconfigure = false;
245     if (mFormat != targetFormat) {
246         mReformatBufferProvider.reset(new ReformatBufferProvider(
247                 audio_channel_count_from_out_mask(channelMask),
248                 mFormat,
249                 targetFormat,
250                 kCopyBufferFrameCount));
251         requiresReconfigure = true;
252     } else if (mFormat == AUDIO_FORMAT_PCM_FLOAT) {
253         // Input and output are floats, make sure application did not provide > 3db samples
254         // that would break volume application (b/68099072)
255         // TODO: add a trusted source flag to avoid the overhead
256         mReformatBufferProvider.reset(new ClampFloatBufferProvider(
257                 audio_channel_count_from_out_mask(channelMask),
258                 kCopyBufferFrameCount));
259         requiresReconfigure = true;
260     }
261     if (targetFormat != mMixerInFormat) {
262         mPostDownmixReformatBufferProvider.reset(new ReformatBufferProvider(
263                 audio_channel_count_from_out_mask(mMixerChannelMask),
264                 targetFormat,
265                 mMixerInFormat,
266                 kCopyBufferFrameCount));
267         requiresReconfigure = true;
268     }
269     if (requiresReconfigure) {
270         reconfigureBufferProviders();
271     }
272     return NO_ERROR;
273 }
274 
unprepareForAdjustChannels()275 void AudioMixer::Track::unprepareForAdjustChannels()
276 {
277     ALOGV("AUDIOMIXER::unprepareForAdjustChannels");
278     if (mAdjustChannelsBufferProvider.get() != nullptr) {
279         mAdjustChannelsBufferProvider.reset(nullptr);
280         reconfigureBufferProviders();
281     }
282 }
283 
prepareForAdjustChannels(size_t frames)284 status_t AudioMixer::Track::prepareForAdjustChannels(size_t frames)
285 {
286     ALOGV("AudioMixer::prepareForAdjustChannels(%p) with inChannelCount: %u, outChannelCount: %u",
287             this, mAdjustInChannelCount, mAdjustOutChannelCount);
288     unprepareForAdjustChannels();
289     if (mAdjustInChannelCount != mAdjustOutChannelCount) {
290         uint8_t* buffer = mKeepContractedChannels
291                 ? (uint8_t*)mainBuffer + frames * audio_bytes_per_frame(
292                         mMixerChannelCount, mMixerFormat)
293                 : nullptr;
294         mAdjustChannelsBufferProvider.reset(new AdjustChannelsBufferProvider(
295                 mFormat, mAdjustInChannelCount, mAdjustOutChannelCount, frames,
296                 mKeepContractedChannels ? mMixerFormat : AUDIO_FORMAT_INVALID,
297                 buffer, mMixerHapticChannelCount));
298         reconfigureBufferProviders();
299     }
300     return NO_ERROR;
301 }
302 
unprepareForTee()303 void AudioMixer::Track::unprepareForTee() {
304     ALOGV("AudioMixer::%s", __func__);
305     if (mTeeBufferProvider.get() != nullptr) {
306         mTeeBufferProvider.reset(nullptr);
307         reconfigureBufferProviders();
308     }
309 }
310 
prepareForTee()311 status_t AudioMixer::Track::prepareForTee() {
312     ALOGV("AudioMixer::%s(%p) teeBuffer=%p", __func__, this, teeBuffer);
313     unprepareForTee();
314     if (teeBuffer != nullptr) {
315         mTeeBufferProvider.reset(new TeeBufferProvider(
316                 mInputFrameSize, mInputFrameSize, kCopyBufferFrameCount,
317                 (uint8_t*)teeBuffer, mTeeBufferFrameCount));
318         reconfigureBufferProviders();
319     }
320     return NO_ERROR;
321 }
322 
clearContractedBuffer()323 void AudioMixer::Track::clearContractedBuffer()
324 {
325     if (mAdjustChannelsBufferProvider.get() != nullptr) {
326         static_cast<AdjustChannelsBufferProvider*>(
327                 mAdjustChannelsBufferProvider.get())->clearContractedFrames();
328     }
329 }
330 
clearTeeFrameCopied()331 void AudioMixer::Track::clearTeeFrameCopied() {
332     if (mTeeBufferProvider.get() != nullptr) {
333         static_cast<TeeBufferProvider*>(mTeeBufferProvider.get())->clearFramesCopied();
334     }
335 }
336 
reconfigureBufferProviders()337 void AudioMixer::Track::reconfigureBufferProviders()
338 {
339     // configure from upstream to downstream buffer providers.
340     bufferProvider = mInputBufferProvider;
341     if (mTeeBufferProvider != nullptr) {
342         mTeeBufferProvider->setBufferProvider(bufferProvider);
343         bufferProvider = mTeeBufferProvider.get();
344     }
345     if (mAdjustChannelsBufferProvider.get() != nullptr) {
346         mAdjustChannelsBufferProvider->setBufferProvider(bufferProvider);
347         bufferProvider = mAdjustChannelsBufferProvider.get();
348     }
349     if (mReformatBufferProvider.get() != nullptr) {
350         mReformatBufferProvider->setBufferProvider(bufferProvider);
351         bufferProvider = mReformatBufferProvider.get();
352     }
353     if (mDownmixerBufferProvider.get() != nullptr) {
354         mDownmixerBufferProvider->setBufferProvider(bufferProvider);
355         bufferProvider = mDownmixerBufferProvider.get();
356     }
357     if (mPostDownmixReformatBufferProvider.get() != nullptr) {
358         mPostDownmixReformatBufferProvider->setBufferProvider(bufferProvider);
359         bufferProvider = mPostDownmixReformatBufferProvider.get();
360     }
361     if (mTimestretchBufferProvider.get() != nullptr) {
362         mTimestretchBufferProvider->setBufferProvider(bufferProvider);
363         bufferProvider = mTimestretchBufferProvider.get();
364     }
365 }
366 
setParameter(int name,int target,int param,void * value)367 void AudioMixer::setParameter(int name, int target, int param, void *value)
368 {
369     LOG_ALWAYS_FATAL_IF(!exists(name), "invalid name: %d", name);
370     const std::shared_ptr<Track> &track = getTrack(name);
371 
372     int valueInt = static_cast<int>(reinterpret_cast<uintptr_t>(value));
373     int32_t *valueBuf = reinterpret_cast<int32_t*>(value);
374 
375     switch (target) {
376 
377     case TRACK:
378         switch (param) {
379         case CHANNEL_MASK: {
380             const audio_channel_mask_t trackChannelMask =
381                 static_cast<audio_channel_mask_t>(valueInt);
382             if (setChannelMasks(name, trackChannelMask,
383                     static_cast<audio_channel_mask_t>(
384                             track->mMixerChannelMask | track->mMixerHapticChannelMask))) {
385                 ALOGV("setParameter(TRACK, CHANNEL_MASK, %x)", trackChannelMask);
386                 invalidate();
387             }
388             } break;
389         case MAIN_BUFFER:
390             if (track->mainBuffer != valueBuf) {
391                 track->mainBuffer = valueBuf;
392                 ALOGV("setParameter(TRACK, MAIN_BUFFER, %p)", valueBuf);
393                 if (track->mKeepContractedChannels) {
394                     track->prepareForAdjustChannels(mFrameCount);
395                 }
396                 invalidate();
397             }
398             break;
399         case AUX_BUFFER:
400             AudioMixerBase::setParameter(name, target, param, value);
401             break;
402         case FORMAT: {
403             audio_format_t format = static_cast<audio_format_t>(valueInt);
404             if (track->mFormat != format) {
405                 ALOG_ASSERT(audio_is_linear_pcm(format), "Invalid format %#x", format);
406                 track->mFormat = format;
407                 ALOGV("setParameter(TRACK, FORMAT, %#x)", format);
408                 track->prepareForReformat();
409                 invalidate();
410             }
411             } break;
412         // FIXME do we want to support setting the downmix type from AudioFlinger?
413         //         for a specific track? or per mixer?
414         /* case DOWNMIX_TYPE:
415             break          */
416         case MIXER_FORMAT: {
417             audio_format_t format = static_cast<audio_format_t>(valueInt);
418             if (track->mMixerFormat != format) {
419                 track->mMixerFormat = format;
420                 ALOGV("setParameter(TRACK, MIXER_FORMAT, %#x)", format);
421                 if (track->mKeepContractedChannels) {
422                     track->prepareForAdjustChannels(mFrameCount);
423                 }
424             }
425             } break;
426         case MIXER_CHANNEL_MASK: {
427             const audio_channel_mask_t mixerChannelMask =
428                     static_cast<audio_channel_mask_t>(valueInt);
429             if (setChannelMasks(name, static_cast<audio_channel_mask_t>(
430                                     track->channelMask | track->mHapticChannelMask),
431                     mixerChannelMask)) {
432                 ALOGV("setParameter(TRACK, MIXER_CHANNEL_MASK, %#x)", mixerChannelMask);
433                 invalidate();
434             }
435             } break;
436         case HAPTIC_ENABLED: {
437             const bool hapticPlaybackEnabled = static_cast<bool>(valueInt);
438             if (track->mHapticPlaybackEnabled != hapticPlaybackEnabled) {
439                 track->mHapticPlaybackEnabled = hapticPlaybackEnabled;
440                 track->mKeepContractedChannels = hapticPlaybackEnabled;
441                 track->prepareForAdjustChannels(mFrameCount);
442             }
443             } break;
444         case HAPTIC_INTENSITY: {
445             const os::HapticScale hapticIntensity = static_cast<os::HapticScale>(valueInt);
446             if (track->mHapticIntensity != hapticIntensity) {
447                 track->mHapticIntensity = hapticIntensity;
448             }
449             } break;
450         case HAPTIC_MAX_AMPLITUDE: {
451             const float hapticMaxAmplitude = *reinterpret_cast<float*>(value);
452             if (track->mHapticMaxAmplitude != hapticMaxAmplitude) {
453                 track->mHapticMaxAmplitude = hapticMaxAmplitude;
454             }
455             } break;
456         case TEE_BUFFER:
457             if (track->teeBuffer != valueBuf) {
458                 track->teeBuffer = valueBuf;
459                 ALOGV("setParameter(TRACK, TEE_BUFFER, %p)", valueBuf);
460                 track->prepareForTee();
461             }
462             break;
463         case TEE_BUFFER_FRAME_COUNT:
464             if (track->mTeeBufferFrameCount != valueInt) {
465                 track->mTeeBufferFrameCount = valueInt;
466                 ALOGV("setParameter(TRACK, TEE_BUFFER_FRAME_COUNT, %i)", valueInt);
467                 track->prepareForTee();
468             }
469             break;
470         default:
471             LOG_ALWAYS_FATAL("setParameter track: bad param %d", param);
472         }
473         break;
474 
475     case RESAMPLE:
476     case RAMP_VOLUME:
477     case VOLUME:
478         AudioMixerBase::setParameter(name, target, param, value);
479         break;
480     case TIMESTRETCH:
481         switch (param) {
482         case PLAYBACK_RATE: {
483             const AudioPlaybackRate *playbackRate =
484                     reinterpret_cast<AudioPlaybackRate*>(value);
485             ALOGW_IF(!isAudioPlaybackRateValid(*playbackRate),
486                     "bad parameters speed %f, pitch %f",
487                     playbackRate->mSpeed, playbackRate->mPitch);
488             if (track->setPlaybackRate(*playbackRate)) {
489                 ALOGV("setParameter(TIMESTRETCH, PLAYBACK_RATE, STRETCH_MODE, FALLBACK_MODE "
490                         "%f %f %d %d",
491                         playbackRate->mSpeed,
492                         playbackRate->mPitch,
493                         playbackRate->mStretchMode,
494                         playbackRate->mFallbackMode);
495                 // invalidate();  (should not require reconfigure)
496             }
497         } break;
498         default:
499             LOG_ALWAYS_FATAL("setParameter timestretch: bad param %d", param);
500         }
501         break;
502 
503     default:
504         LOG_ALWAYS_FATAL("setParameter: bad target %d", target);
505     }
506 }
507 
setPlaybackRate(const AudioPlaybackRate & playbackRate)508 bool AudioMixer::Track::setPlaybackRate(const AudioPlaybackRate &playbackRate)
509 {
510     if ((mTimestretchBufferProvider.get() == nullptr &&
511             fabs(playbackRate.mSpeed - mPlaybackRate.mSpeed) < AUDIO_TIMESTRETCH_SPEED_MIN_DELTA &&
512             fabs(playbackRate.mPitch - mPlaybackRate.mPitch) < AUDIO_TIMESTRETCH_PITCH_MIN_DELTA) ||
513             isAudioPlaybackRateEqual(playbackRate, mPlaybackRate)) {
514         return false;
515     }
516     mPlaybackRate = playbackRate;
517     if (mTimestretchBufferProvider.get() == nullptr) {
518         // TODO: Remove MONO_HACK. Resampler sees #channels after the downmixer
519         // but if none exists, it is the channel count (1 for mono).
520         const int timestretchChannelCount = getOutputChannelCount();
521         mTimestretchBufferProvider.reset(new TimestretchBufferProvider(timestretchChannelCount,
522                 mMixerInFormat, sampleRate, playbackRate));
523         reconfigureBufferProviders();
524     } else {
525         static_cast<TimestretchBufferProvider*>(mTimestretchBufferProvider.get())
526                 ->setPlaybackRate(playbackRate);
527     }
528     return true;
529 }
530 
setBufferProvider(int name,AudioBufferProvider * bufferProvider)531 void AudioMixer::setBufferProvider(int name, AudioBufferProvider* bufferProvider)
532 {
533     LOG_ALWAYS_FATAL_IF(!exists(name), "invalid name: %d", name);
534     const std::shared_ptr<Track> &track = getTrack(name);
535 
536     if (track->mInputBufferProvider == bufferProvider) {
537         return; // don't reset any buffer providers if identical.
538     }
539     // reset order from downstream to upstream buffer providers.
540     if (track->mTimestretchBufferProvider.get() != nullptr) {
541         track->mTimestretchBufferProvider->reset();
542     } else if (track->mPostDownmixReformatBufferProvider.get() != nullptr) {
543         track->mPostDownmixReformatBufferProvider->reset();
544     } else if (track->mDownmixerBufferProvider != nullptr) {
545         track->mDownmixerBufferProvider->reset();
546     } else if (track->mReformatBufferProvider.get() != nullptr) {
547         track->mReformatBufferProvider->reset();
548     } else if (track->mAdjustChannelsBufferProvider.get() != nullptr) {
549         track->mAdjustChannelsBufferProvider->reset();
550     } else if (track->mTeeBufferProvider.get() != nullptr) {
551         track->mTeeBufferProvider->reset();
552     }
553 
554     track->mInputBufferProvider = bufferProvider;
555     track->reconfigureBufferProviders();
556 }
557 
558 /*static*/ pthread_once_t AudioMixer::sOnceControl = PTHREAD_ONCE_INIT;
559 
sInitRoutine()560 /*static*/ void AudioMixer::sInitRoutine()
561 {
562     DownmixerBufferProvider::init(); // for the downmixer
563 }
564 
preCreateTrack()565 std::shared_ptr<AudioMixerBase::TrackBase> AudioMixer::preCreateTrack()
566 {
567     return std::make_shared<Track>();
568 }
569 
postCreateTrack(TrackBase * track)570 status_t AudioMixer::postCreateTrack(TrackBase *track)
571 {
572     Track* t = static_cast<Track*>(track);
573 
574     audio_channel_mask_t channelMask = t->channelMask;
575     t->mHapticChannelMask = static_cast<audio_channel_mask_t>(
576             channelMask & AUDIO_CHANNEL_HAPTIC_ALL);
577     t->mHapticChannelCount = audio_channel_count_from_out_mask(t->mHapticChannelMask);
578     channelMask = static_cast<audio_channel_mask_t>(channelMask & ~AUDIO_CHANNEL_HAPTIC_ALL);
579     t->channelCount = audio_channel_count_from_out_mask(channelMask);
580     ALOGV_IF(audio_channel_mask_get_bits(channelMask) != AUDIO_CHANNEL_OUT_STEREO,
581             "Non-stereo channel mask: %d\n", channelMask);
582     t->channelMask = channelMask;
583     t->mInputBufferProvider = NULL;
584     t->mDownmixRequiresFormat = AUDIO_FORMAT_INVALID; // no format required
585     t->mPlaybackRate = AUDIO_PLAYBACK_RATE_DEFAULT;
586     // haptic
587     t->mHapticPlaybackEnabled = false;
588     t->mHapticIntensity = os::HapticScale::NONE;
589     t->mHapticMaxAmplitude = NAN;
590     t->mMixerHapticChannelMask = AUDIO_CHANNEL_NONE;
591     t->mMixerHapticChannelCount = 0;
592     t->mAdjustInChannelCount = t->channelCount + t->mHapticChannelCount;
593     t->mAdjustOutChannelCount = t->channelCount;
594     t->mKeepContractedChannels = false;
595     t->mInputFrameSize = audio_bytes_per_frame(
596             t->channelCount + t->mHapticChannelCount, t->mFormat);
597     // Check the downmixing (or upmixing) requirements.
598     status_t status = t->prepareForDownmix();
599     if (status != OK) {
600         ALOGE("AudioMixer::getTrackName invalid channelMask (%#x)", channelMask);
601         return BAD_VALUE;
602     }
603     // prepareForDownmix() may change mDownmixRequiresFormat
604     ALOGVV("mMixerFormat:%#x  mMixerInFormat:%#x\n", t->mMixerFormat, t->mMixerInFormat);
605     t->prepareForReformat();
606     t->prepareForAdjustChannels(mFrameCount);
607     return OK;
608 }
609 
preProcess()610 void AudioMixer::preProcess()
611 {
612     for (const auto &pair : mTracks) {
613         // Clear contracted buffer before processing if contracted channels are saved
614         const std::shared_ptr<TrackBase> &tb = pair.second;
615         Track *t = static_cast<Track*>(tb.get());
616         if (t->mKeepContractedChannels) {
617             t->clearContractedBuffer();
618         }
619         t->clearTeeFrameCopied();
620     }
621 }
622 
postProcess()623 void AudioMixer::postProcess()
624 {
625     // Process haptic data.
626     // Need to keep consistent with VibrationEffect.scale(int, float, int)
627     for (const auto &pair : mGroups) {
628         // process by group of tracks with same output main buffer.
629         const auto &group = pair.second;
630         for (const int name : group) {
631             const std::shared_ptr<Track> &t = getTrack(name);
632             if (t->mHapticPlaybackEnabled) {
633                 size_t sampleCount = mFrameCount * t->mMixerHapticChannelCount;
634                 uint8_t* buffer = (uint8_t*)pair.first + mFrameCount * audio_bytes_per_frame(
635                         t->mMixerChannelCount, t->mMixerFormat);
636                 switch (t->mMixerFormat) {
637                 // Mixer format should be AUDIO_FORMAT_PCM_FLOAT.
638                 case AUDIO_FORMAT_PCM_FLOAT: {
639                     os::scaleHapticData((float*) buffer, sampleCount, t->mHapticIntensity,
640                                         t->mHapticMaxAmplitude);
641                 } break;
642                 default:
643                     LOG_ALWAYS_FATAL("bad mMixerFormat: %#x", t->mMixerFormat);
644                     break;
645                 }
646                 break;
647             }
648             if (t->teeBuffer != nullptr && t->volumeRL == 0) {
649                 // Need to mute tee
650                 memset(t->teeBuffer, 0, t->mTeeBufferFrameCount * t->mInputFrameSize);
651             }
652         }
653     }
654 }
655 
656 // ----------------------------------------------------------------------------
657 } // namespace android
658