blob: 9048775460f72c836bbcf382bf5feaf291a8490d [file] [log] [blame]
aleloi77ad3942016-07-04 06:33:02 -07001/*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
aleloi5d167d62016-08-24 02:20:54 -070011#ifndef WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_
12#define WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_
aleloi77ad3942016-07-04 06:33:02 -070013
aleloi77ad3942016-07-04 06:33:02 -070014#include <memory>
aleloidf9e4d92016-08-08 10:26:09 -070015#include <vector>
aleloi77ad3942016-07-04 06:33:02 -070016
aleloidc7669a2016-10-04 04:06:20 -070017#include "webrtc/base/thread_annotations.h"
aleloi8b2233f2016-07-28 06:24:14 -070018#include "webrtc/base/thread_checker.h"
aleloi5d167d62016-08-24 02:20:54 -070019#include "webrtc/modules/audio_mixer/audio_mixer.h"
aleloidc7669a2016-10-04 04:06:20 -070020#include "webrtc/modules/audio_processing/include/audio_processing.h"
aleloi77ad3942016-07-04 06:33:02 -070021#include "webrtc/modules/include/module_common_types.h"
aleloidc7669a2016-10-04 04:06:20 -070022#include "webrtc/system_wrappers/include/critical_section_wrapper.h"
aleloi616df1e2016-08-24 01:17:12 -070023#include "webrtc/voice_engine/level_indicator.h"
mflodman7056be92016-10-07 07:07:28 +020024#include "webrtc/voice_engine_configurations.h"
aleloi77ad3942016-07-04 06:33:02 -070025
26namespace webrtc {
aleloi77ad3942016-07-04 06:33:02 -070027
aleloi652ac892016-09-07 07:42:14 -070028typedef std::vector<AudioFrame*> AudioFrameList;
aleloi77ad3942016-07-04 06:33:02 -070029
aleloi5d167d62016-08-24 02:20:54 -070030class AudioMixerImpl : public AudioMixer {
aleloi77ad3942016-07-04 06:33:02 -070031 public:
aleloi4b8bfb82016-10-12 02:14:59 -070032 struct SourceStatus {
33 SourceStatus(Source* audio_source, bool is_mixed, float gain)
34 : audio_source(audio_source), is_mixed(is_mixed), gain(gain) {}
35 Source* audio_source = nullptr;
36 bool is_mixed = false;
37 float gain = 0.0f;
38 };
39
40 typedef std::vector<SourceStatus> SourceStatusList;
41
aleloi77ad3942016-07-04 06:33:02 -070042 // AudioProcessing only accepts 10 ms frames.
aleloi5d167d62016-08-24 02:20:54 -070043 static const int kFrameDurationInMs = 10;
aleloie97974d2016-10-12 03:06:09 -070044 static const int kDefaultFrequency = 48000;
aleloi77ad3942016-07-04 06:33:02 -070045
aleloie97974d2016-10-12 03:06:09 -070046 static std::unique_ptr<AudioMixerImpl> Create();
aleloi77ad3942016-07-04 06:33:02 -070047
aleloi5d167d62016-08-24 02:20:54 -070048 ~AudioMixerImpl() override;
aleloi70f866c2016-08-16 02:15:49 -070049
aleloi5d167d62016-08-24 02:20:54 -070050 // AudioMixer functions
aleloie8914152016-10-11 06:18:31 -070051 int32_t SetMixabilityStatus(Source* audio_source, bool mixable) override;
aleloi44968092016-08-08 10:18:58 -070052 void Mix(int sample_rate,
53 size_t number_of_channels,
54 AudioFrame* audio_frame_for_mixing) override;
aleloi77ad3942016-07-04 06:33:02 -070055
aleloi36542512016-10-07 05:28:32 -070056 // Returns true if the source was mixed last round. Returns
57 // false and logs an error if the source was never added to the
58 // mixer.
aleloie97974d2016-10-12 03:06:09 -070059 bool GetAudioSourceMixabilityStatusForTest(Source* audio_source) const;
aleloi36542512016-10-07 05:28:32 -070060
aleloi77ad3942016-07-04 06:33:02 -070061 private:
aleloie97974d2016-10-12 03:06:09 -070062 explicit AudioMixerImpl(std::unique_ptr<AudioProcessing> limiter);
aleloi311525e2016-09-07 06:13:12 -070063
aleloi77ad3942016-07-04 06:33:02 -070064 // Set/get mix frequency
aleloie97974d2016-10-12 03:06:09 -070065 void SetOutputFrequency(int frequency);
66 int OutputFrequency() const;
aleloi77ad3942016-07-04 06:33:02 -070067
aleloi652ac892016-09-07 07:42:14 -070068 // Compute what audio sources to mix from audio_source_list_. Ramp
69 // in and out. Update mixed status. Mixes up to
70 // kMaximumAmountOfMixedAudioSources audio sources.
aleloi36542512016-10-07 05:28:32 -070071 AudioFrameList GetNonAnonymousAudio() EXCLUSIVE_LOCKS_REQUIRED(crit_);
aleloi77ad3942016-07-04 06:33:02 -070072
aleloi77ad3942016-07-04 06:33:02 -070073
74 // Add/remove the MixerAudioSource to the specified
75 // MixerAudioSource list.
aleloie8914152016-10-11 06:18:31 -070076 bool AddAudioSourceToList(Source* audio_source,
aleloi4b8bfb82016-10-12 02:14:59 -070077 SourceStatusList* audio_source_list) const;
aleloie8914152016-10-11 06:18:31 -070078 bool RemoveAudioSourceFromList(Source* remove_audio_source,
aleloi4b8bfb82016-10-12 02:14:59 -070079 SourceStatusList* audio_source_list) const;
aleloi77ad3942016-07-04 06:33:02 -070080
aleloia4c21062016-09-08 01:25:46 -070081 bool LimitMixedAudio(AudioFrame* mixed_audio) const;
aleloi77ad3942016-07-04 06:33:02 -070082
aleloi616df1e2016-08-24 01:17:12 -070083
aleloi311525e2016-09-07 06:13:12 -070084 rtc::CriticalSection crit_;
aleloi77ad3942016-07-04 06:33:02 -070085
aleloi77ad3942016-07-04 06:33:02 -070086 // The current sample frequency and sample size when mixing.
aleloie97974d2016-10-12 03:06:09 -070087 int output_frequency_ ACCESS_ON(&thread_checker_);
aleloi311525e2016-09-07 06:13:12 -070088 size_t sample_size_ ACCESS_ON(&thread_checker_);
aleloi77ad3942016-07-04 06:33:02 -070089
aleloi09f45102016-07-28 03:52:15 -070090 // List of all audio sources. Note all lists are disjunct
aleloi4b8bfb82016-10-12 02:14:59 -070091 SourceStatusList audio_source_list_ GUARDED_BY(crit_); // May be mixed.
aleloia0db81f2016-07-28 06:36:22 -070092
aleloi311525e2016-09-07 06:13:12 -070093 size_t num_mixed_audio_sources_ GUARDED_BY(crit_);
aleloi77ad3942016-07-04 06:33:02 -070094 // Determines if we will use a limiter for clipping protection during
95 // mixing.
aleloi311525e2016-09-07 06:13:12 -070096 bool use_limiter_ ACCESS_ON(&thread_checker_);
aleloi77ad3942016-07-04 06:33:02 -070097
aleloi311525e2016-09-07 06:13:12 -070098 uint32_t time_stamp_ ACCESS_ON(&thread_checker_);
aleloi77ad3942016-07-04 06:33:02 -070099
aleloi8b2233f2016-07-28 06:24:14 -0700100 // Ensures that Mix is called from the same thread.
101 rtc::ThreadChecker thread_checker_;
aleloi77ad3942016-07-04 06:33:02 -0700102
103 // Used for inhibiting saturation in mixing.
aleloi311525e2016-09-07 06:13:12 -0700104 std::unique_ptr<AudioProcessing> limiter_ ACCESS_ON(&thread_checker_);
aleloi616df1e2016-08-24 01:17:12 -0700105
aleloia4c21062016-09-08 01:25:46 -0700106 RTC_DISALLOW_COPY_AND_ASSIGN(AudioMixerImpl);
aleloi77ad3942016-07-04 06:33:02 -0700107};
108} // namespace webrtc
109
aleloi5d167d62016-08-24 02:20:54 -0700110#endif // WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_