| /* |
| * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #include "webrtc/modules/audio_device/audio_device_impl.h" |
| #include "webrtc/common_audio/signal_processing/include/signal_processing_library.h" |
| #include "webrtc/modules/audio_device/audio_device_config.h" |
| #include "webrtc/modules/audio_device/audio_device_generic.h" |
| #include "webrtc/rtc_base/checks.h" |
| #include "webrtc/rtc_base/logging.h" |
| #include "webrtc/rtc_base/refcount.h" |
| #include "webrtc/rtc_base/timeutils.h" |
| #include "webrtc/system_wrappers/include/metrics.h" |
| |
| #include <assert.h> |
| #include <string.h> |
| |
| #if defined(_WIN32) |
| #if defined(WEBRTC_WINDOWS_CORE_AUDIO_BUILD) |
| #include "audio_device_core_win.h" |
| #endif |
| #elif defined(WEBRTC_ANDROID) |
| #include <stdlib.h> |
| #include "webrtc/modules/audio_device/android/audio_device_template.h" |
| #include "webrtc/modules/audio_device/android/audio_manager.h" |
| #include "webrtc/modules/audio_device/android/audio_record_jni.h" |
| #include "webrtc/modules/audio_device/android/audio_track_jni.h" |
| #include "webrtc/modules/audio_device/android/opensles_player.h" |
| #include "webrtc/modules/audio_device/android/opensles_recorder.h" |
| #elif defined(WEBRTC_LINUX) |
| #if defined(LINUX_ALSA) |
| #include "audio_device_alsa_linux.h" |
| #endif |
| #if defined(LINUX_PULSE) |
| #include "audio_device_pulse_linux.h" |
| #endif |
| #elif defined(WEBRTC_IOS) |
| #include "audio_device_ios.h" |
| #elif defined(WEBRTC_MAC) |
| #include "audio_device_mac.h" |
| #endif |
| |
| #if defined(WEBRTC_DUMMY_FILE_DEVICES) |
| #include "webrtc/modules/audio_device/dummy/file_audio_device_factory.h" |
| #endif |
| |
| #include "webrtc/modules/audio_device/dummy/audio_device_dummy.h" |
| #include "webrtc/modules/audio_device/dummy/file_audio_device.h" |
| |
| #define CHECK_INITIALIZED() \ |
| { \ |
| if (!_initialized) { \ |
| return -1; \ |
| }; \ |
| } |
| |
| #define CHECK_INITIALIZED_BOOL() \ |
| { \ |
| if (!_initialized) { \ |
| return false; \ |
| }; \ |
| } |
| |
| namespace webrtc { |
| |
| // ============================================================================ |
| // Static methods |
| // ============================================================================ |
| |
| // ---------------------------------------------------------------------------- |
| // AudioDeviceModule::Create() |
| // ---------------------------------------------------------------------------- |
| |
| rtc::scoped_refptr<AudioDeviceModule> AudioDeviceModule::Create( |
| const int32_t id, |
| const AudioLayer audio_layer) { |
| LOG(INFO) << __FUNCTION__; |
| // Create the generic ref counted (platform independent) implementation. |
| rtc::scoped_refptr<AudioDeviceModuleImpl> audioDevice( |
| new rtc::RefCountedObject<AudioDeviceModuleImpl>(id, audio_layer)); |
| |
| // Ensure that the current platform is supported. |
| if (audioDevice->CheckPlatform() == -1) { |
| return nullptr; |
| } |
| |
| // Create the platform-dependent implementation. |
| if (audioDevice->CreatePlatformSpecificObjects() == -1) { |
| return nullptr; |
| } |
| |
| // Ensure that the generic audio buffer can communicate with the |
| // platform-specific parts. |
| if (audioDevice->AttachAudioBuffer() == -1) { |
| return nullptr; |
| } |
| |
| WebRtcSpl_Init(); |
| |
| return audioDevice; |
| } |
| |
| // ============================================================================ |
| // Construction & Destruction |
| // ============================================================================ |
| |
| // ---------------------------------------------------------------------------- |
| // AudioDeviceModuleImpl - ctor |
| // ---------------------------------------------------------------------------- |
| |
| AudioDeviceModuleImpl::AudioDeviceModuleImpl(const int32_t id, |
| const AudioLayer audioLayer) |
| : _ptrCbAudioDeviceObserver(NULL), |
| _ptrAudioDevice(NULL), |
| _id(id), |
| _platformAudioLayer(audioLayer), |
| _lastProcessTime(rtc::TimeMillis()), |
| _platformType(kPlatformNotSupported), |
| _initialized(false), |
| _lastError(kAdmErrNone) { |
| LOG(INFO) << __FUNCTION__; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // CheckPlatform |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::CheckPlatform() { |
| LOG(INFO) << __FUNCTION__; |
| |
| // Ensure that the current platform is supported |
| // |
| PlatformType platform(kPlatformNotSupported); |
| |
| #if defined(_WIN32) |
| platform = kPlatformWin32; |
| LOG(INFO) << "current platform is Win32"; |
| #elif defined(WEBRTC_ANDROID) |
| platform = kPlatformAndroid; |
| LOG(INFO) << "current platform is Android"; |
| #elif defined(WEBRTC_LINUX) |
| platform = kPlatformLinux; |
| LOG(INFO) << "current platform is Linux"; |
| #elif defined(WEBRTC_IOS) |
| platform = kPlatformIOS; |
| LOG(INFO) << "current platform is IOS"; |
| #elif defined(WEBRTC_MAC) |
| platform = kPlatformMac; |
| LOG(INFO) << "current platform is Mac"; |
| #endif |
| |
| if (platform == kPlatformNotSupported) { |
| LOG(LERROR) << "current platform is not supported => this module will self " |
| "destruct!"; |
| return -1; |
| } |
| |
| // Store valid output results |
| // |
| _platformType = platform; |
| |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // CreatePlatformSpecificObjects |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::CreatePlatformSpecificObjects() { |
| LOG(INFO) << __FUNCTION__; |
| |
| AudioDeviceGeneric* ptrAudioDevice(NULL); |
| |
| #if defined(WEBRTC_DUMMY_AUDIO_BUILD) |
| ptrAudioDevice = new AudioDeviceDummy(Id()); |
| LOG(INFO) << "Dummy Audio APIs will be utilized"; |
| #elif defined(WEBRTC_DUMMY_FILE_DEVICES) |
| ptrAudioDevice = FileAudioDeviceFactory::CreateFileAudioDevice(Id()); |
| if (ptrAudioDevice) { |
| LOG(INFO) << "Will use file-playing dummy device."; |
| } else { |
| // Create a dummy device instead. |
| ptrAudioDevice = new AudioDeviceDummy(Id()); |
| LOG(INFO) << "Dummy Audio APIs will be utilized"; |
| } |
| #else |
| AudioLayer audioLayer(PlatformAudioLayer()); |
| |
| // Create the *Windows* implementation of the Audio Device |
| // |
| #if defined(WEBRTC_WINDOWS_CORE_AUDIO_BUILD) |
| if ((audioLayer == kWindowsCoreAudio) || |
| (audioLayer == kPlatformDefaultAudio)) { |
| LOG(INFO) << "attempting to use the Windows Core Audio APIs..."; |
| |
| if (AudioDeviceWindowsCore::CoreAudioIsSupported()) { |
| // create *Windows Core Audio* implementation |
| ptrAudioDevice = new AudioDeviceWindowsCore(Id()); |
| LOG(INFO) << "Windows Core Audio APIs will be utilized"; |
| } |
| } |
| #endif // defined(WEBRTC_WINDOWS_CORE_AUDIO_BUILD) |
| |
| #if defined(WEBRTC_ANDROID) |
| // Create an Android audio manager. |
| _audioManagerAndroid.reset(new AudioManager()); |
| // Select best possible combination of audio layers. |
| if (audioLayer == kPlatformDefaultAudio) { |
| if (_audioManagerAndroid->IsLowLatencyPlayoutSupported() && |
| _audioManagerAndroid->IsLowLatencyRecordSupported()) { |
| // Use OpenSL ES for both playout and recording. |
| audioLayer = kAndroidOpenSLESAudio; |
| } else if (_audioManagerAndroid->IsLowLatencyPlayoutSupported() && |
| !_audioManagerAndroid->IsLowLatencyRecordSupported()) { |
| // Use OpenSL ES for output on devices that only supports the |
| // low-latency output audio path. |
| audioLayer = kAndroidJavaInputAndOpenSLESOutputAudio; |
| } else { |
| // Use Java-based audio in both directions when low-latency output is |
| // not supported. |
| audioLayer = kAndroidJavaAudio; |
| } |
| } |
| AudioManager* audio_manager = _audioManagerAndroid.get(); |
| if (audioLayer == kAndroidJavaAudio) { |
| // Java audio for both input and output audio. |
| ptrAudioDevice = new AudioDeviceTemplate<AudioRecordJni, AudioTrackJni>( |
| audioLayer, audio_manager); |
| } else if (audioLayer == kAndroidOpenSLESAudio) { |
| // OpenSL ES based audio for both input and output audio. |
| ptrAudioDevice = new AudioDeviceTemplate<OpenSLESRecorder, OpenSLESPlayer>( |
| audioLayer, audio_manager); |
| } else if (audioLayer == kAndroidJavaInputAndOpenSLESOutputAudio) { |
| // Java audio for input and OpenSL ES for output audio (i.e. mixed APIs). |
| // This combination provides low-latency output audio and at the same |
| // time support for HW AEC using the AudioRecord Java API. |
| ptrAudioDevice = new AudioDeviceTemplate<AudioRecordJni, OpenSLESPlayer>( |
| audioLayer, audio_manager); |
| } else { |
| // Invalid audio layer. |
| ptrAudioDevice = nullptr; |
| } |
| // END #if defined(WEBRTC_ANDROID) |
| |
| // Create the *Linux* implementation of the Audio Device |
| // |
| #elif defined(WEBRTC_LINUX) |
| if ((audioLayer == kLinuxPulseAudio) || |
| (audioLayer == kPlatformDefaultAudio)) { |
| #if defined(LINUX_PULSE) |
| LOG(INFO) << "attempting to use the Linux PulseAudio APIs..."; |
| |
| // create *Linux PulseAudio* implementation |
| AudioDeviceLinuxPulse* pulseDevice = new AudioDeviceLinuxPulse(Id()); |
| if (pulseDevice->Init() == AudioDeviceGeneric::InitStatus::OK) { |
| ptrAudioDevice = pulseDevice; |
| LOG(INFO) << "Linux PulseAudio APIs will be utilized"; |
| } else { |
| delete pulseDevice; |
| #endif |
| #if defined(LINUX_ALSA) |
| // create *Linux ALSA Audio* implementation |
| ptrAudioDevice = new AudioDeviceLinuxALSA(Id()); |
| if (ptrAudioDevice != NULL) { |
| // Pulse Audio was not supported => revert to ALSA instead |
| _platformAudioLayer = |
| kLinuxAlsaAudio; // modify the state set at construction |
| LOG(WARNING) << "Linux PulseAudio is *not* supported => ALSA APIs will " |
| "be utilized instead"; |
| } |
| #endif |
| #if defined(LINUX_PULSE) |
| } |
| #endif |
| } else if (audioLayer == kLinuxAlsaAudio) { |
| #if defined(LINUX_ALSA) |
| // create *Linux ALSA Audio* implementation |
| ptrAudioDevice = new AudioDeviceLinuxALSA(Id()); |
| LOG(INFO) << "Linux ALSA APIs will be utilized"; |
| #endif |
| } |
| #endif // #if defined(WEBRTC_LINUX) |
| |
| // Create the *iPhone* implementation of the Audio Device |
| // |
| #if defined(WEBRTC_IOS) |
| if (audioLayer == kPlatformDefaultAudio) { |
| // Create iOS Audio Device implementation. |
| ptrAudioDevice = new AudioDeviceIOS(); |
| LOG(INFO) << "iPhone Audio APIs will be utilized"; |
| } |
| // END #if defined(WEBRTC_IOS) |
| |
| // Create the *Mac* implementation of the Audio Device |
| // |
| #elif defined(WEBRTC_MAC) |
| if (audioLayer == kPlatformDefaultAudio) { |
| // Create *Mac Audio* implementation |
| ptrAudioDevice = new AudioDeviceMac(Id()); |
| LOG(INFO) << "Mac OS X Audio APIs will be utilized"; |
| } |
| #endif // WEBRTC_MAC |
| |
| // Create the *Dummy* implementation of the Audio Device |
| // Available for all platforms |
| // |
| if (audioLayer == kDummyAudio) { |
| // Create *Dummy Audio* implementation |
| assert(!ptrAudioDevice); |
| ptrAudioDevice = new AudioDeviceDummy(Id()); |
| LOG(INFO) << "Dummy Audio APIs will be utilized"; |
| } |
| #endif // if defined(WEBRTC_DUMMY_AUDIO_BUILD) |
| |
| if (ptrAudioDevice == NULL) { |
| LOG(LERROR) |
| << "unable to create the platform specific audio device implementation"; |
| return -1; |
| } |
| |
| // Store valid output pointers |
| // |
| _ptrAudioDevice = ptrAudioDevice; |
| |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // AttachAudioBuffer |
| // |
| // Install "bridge" between the platform implemetation and the generic |
| // implementation. The "child" shall set the native sampling rate and the |
| // number of channels in this function call. |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::AttachAudioBuffer() { |
| LOG(INFO) << __FUNCTION__; |
| |
| _audioDeviceBuffer.SetId(_id); |
| _ptrAudioDevice->AttachAudioBuffer(&_audioDeviceBuffer); |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // ~AudioDeviceModuleImpl - dtor |
| // ---------------------------------------------------------------------------- |
| |
| AudioDeviceModuleImpl::~AudioDeviceModuleImpl() { |
| LOG(INFO) << __FUNCTION__; |
| if (_ptrAudioDevice) { |
| delete _ptrAudioDevice; |
| _ptrAudioDevice = NULL; |
| } |
| } |
| |
| // ============================================================================ |
| // Module |
| // ============================================================================ |
| |
| // ---------------------------------------------------------------------------- |
| // Module::TimeUntilNextProcess |
| // |
| // Returns the number of milliseconds until the module want a worker thread |
| // to call Process(). |
| // ---------------------------------------------------------------------------- |
| |
| int64_t AudioDeviceModuleImpl::TimeUntilNextProcess() { |
| int64_t now = rtc::TimeMillis(); |
| int64_t deltaProcess = kAdmMaxIdleTimeProcess - (now - _lastProcessTime); |
| return deltaProcess; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // Module::Process |
| // |
| // Check for posted error and warning reports. Generate callbacks if |
| // new reports exists. |
| // ---------------------------------------------------------------------------- |
| |
| void AudioDeviceModuleImpl::Process() { |
| _lastProcessTime = rtc::TimeMillis(); |
| |
| // kPlayoutWarning |
| if (_ptrAudioDevice->PlayoutWarning()) { |
| rtc::CritScope lock(&_critSectEventCb); |
| if (_ptrCbAudioDeviceObserver) { |
| LOG(WARNING) << "=> OnWarningIsReported(kPlayoutWarning)"; |
| _ptrCbAudioDeviceObserver->OnWarningIsReported( |
| AudioDeviceObserver::kPlayoutWarning); |
| } |
| _ptrAudioDevice->ClearPlayoutWarning(); |
| } |
| |
| // kPlayoutError |
| if (_ptrAudioDevice->PlayoutError()) { |
| rtc::CritScope lock(&_critSectEventCb); |
| if (_ptrCbAudioDeviceObserver) { |
| LOG(LERROR) << "=> OnErrorIsReported(kPlayoutError)"; |
| _ptrCbAudioDeviceObserver->OnErrorIsReported( |
| AudioDeviceObserver::kPlayoutError); |
| } |
| _ptrAudioDevice->ClearPlayoutError(); |
| } |
| |
| // kRecordingWarning |
| if (_ptrAudioDevice->RecordingWarning()) { |
| rtc::CritScope lock(&_critSectEventCb); |
| if (_ptrCbAudioDeviceObserver) { |
| LOG(WARNING) << "=> OnWarningIsReported(kRecordingWarning)"; |
| _ptrCbAudioDeviceObserver->OnWarningIsReported( |
| AudioDeviceObserver::kRecordingWarning); |
| } |
| _ptrAudioDevice->ClearRecordingWarning(); |
| } |
| |
| // kRecordingError |
| if (_ptrAudioDevice->RecordingError()) { |
| rtc::CritScope lock(&_critSectEventCb); |
| if (_ptrCbAudioDeviceObserver) { |
| LOG(LERROR) << "=> OnErrorIsReported(kRecordingError)"; |
| _ptrCbAudioDeviceObserver->OnErrorIsReported( |
| AudioDeviceObserver::kRecordingError); |
| } |
| _ptrAudioDevice->ClearRecordingError(); |
| } |
| } |
| |
| // ============================================================================ |
| // Public API |
| // ============================================================================ |
| |
| // ---------------------------------------------------------------------------- |
| // ActiveAudioLayer |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::ActiveAudioLayer(AudioLayer* audioLayer) const { |
| LOG(INFO) << __FUNCTION__; |
| AudioLayer activeAudio; |
| if (_ptrAudioDevice->ActiveAudioLayer(activeAudio) == -1) { |
| return -1; |
| } |
| *audioLayer = activeAudio; |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // LastError |
| // ---------------------------------------------------------------------------- |
| |
| AudioDeviceModule::ErrorCode AudioDeviceModuleImpl::LastError() const { |
| LOG(INFO) << __FUNCTION__; |
| return _lastError; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // Init |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::Init() { |
| LOG(INFO) << __FUNCTION__; |
| if (_initialized) |
| return 0; |
| RTC_CHECK(_ptrAudioDevice); |
| |
| AudioDeviceGeneric::InitStatus status = _ptrAudioDevice->Init(); |
| RTC_HISTOGRAM_ENUMERATION( |
| "WebRTC.Audio.InitializationResult", static_cast<int>(status), |
| static_cast<int>(AudioDeviceGeneric::InitStatus::NUM_STATUSES)); |
| if (status != AudioDeviceGeneric::InitStatus::OK) { |
| LOG(LS_ERROR) << "Audio device initialization failed."; |
| return -1; |
| } |
| |
| _initialized = true; |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // Terminate |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::Terminate() { |
| LOG(INFO) << __FUNCTION__; |
| if (!_initialized) |
| return 0; |
| |
| if (_ptrAudioDevice->Terminate() == -1) { |
| return -1; |
| } |
| |
| _initialized = false; |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // Initialized |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::Initialized() const { |
| LOG(INFO) << __FUNCTION__ << ": " << _initialized; |
| return (_initialized); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // InitSpeaker |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::InitSpeaker() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->InitSpeaker()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // InitMicrophone |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::InitMicrophone() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->InitMicrophone()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SpeakerVolumeIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SpeakerVolumeIsAvailable(bool* available) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->SpeakerVolumeIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetSpeakerVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetSpeakerVolume(uint32_t volume) { |
| LOG(INFO) << __FUNCTION__ << "(" << volume << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetSpeakerVolume(volume)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SpeakerVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SpeakerVolume(uint32_t* volume) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint32_t level(0); |
| |
| if (_ptrAudioDevice->SpeakerVolume(level) == -1) { |
| return -1; |
| } |
| |
| *volume = level; |
| LOG(INFO) << "output: " << *volume; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetWaveOutVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetWaveOutVolume(uint16_t volumeLeft, |
| uint16_t volumeRight) { |
| LOG(INFO) << __FUNCTION__ << "(" << volumeLeft << ", " << volumeRight << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetWaveOutVolume(volumeLeft, volumeRight)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // WaveOutVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::WaveOutVolume(uint16_t* volumeLeft, |
| uint16_t* volumeRight) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint16_t volLeft(0); |
| uint16_t volRight(0); |
| |
| if (_ptrAudioDevice->WaveOutVolume(volLeft, volRight) == -1) { |
| return -1; |
| } |
| |
| *volumeLeft = volLeft; |
| *volumeRight = volRight; |
| LOG(INFO) << "output: " << *volumeLeft << ", " << *volumeRight; |
| |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SpeakerIsInitialized |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::SpeakerIsInitialized() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| |
| bool isInitialized = _ptrAudioDevice->SpeakerIsInitialized(); |
| LOG(INFO) << "output: " << isInitialized; |
| return (isInitialized); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneIsInitialized |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::MicrophoneIsInitialized() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| |
| bool isInitialized = _ptrAudioDevice->MicrophoneIsInitialized(); |
| LOG(INFO) << "output: " << isInitialized; |
| return (isInitialized); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MaxSpeakerVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MaxSpeakerVolume(uint32_t* maxVolume) const { |
| CHECK_INITIALIZED(); |
| |
| uint32_t maxVol(0); |
| |
| if (_ptrAudioDevice->MaxSpeakerVolume(maxVol) == -1) { |
| return -1; |
| } |
| |
| *maxVolume = maxVol; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MinSpeakerVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MinSpeakerVolume(uint32_t* minVolume) const { |
| CHECK_INITIALIZED(); |
| |
| uint32_t minVol(0); |
| |
| if (_ptrAudioDevice->MinSpeakerVolume(minVol) == -1) { |
| return -1; |
| } |
| |
| *minVolume = minVol; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SpeakerVolumeStepSize |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SpeakerVolumeStepSize(uint16_t* stepSize) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint16_t delta(0); |
| |
| if (_ptrAudioDevice->SpeakerVolumeStepSize(delta) == -1) { |
| LOG(LERROR) << "failed to retrieve the speaker-volume step size"; |
| return -1; |
| } |
| |
| *stepSize = delta; |
| LOG(INFO) << "output: " << *stepSize; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SpeakerMuteIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SpeakerMuteIsAvailable(bool* available) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->SpeakerMuteIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetSpeakerMute |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetSpeakerMute(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetSpeakerMute(enable)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SpeakerMute |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SpeakerMute(bool* enabled) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool muted(false); |
| |
| if (_ptrAudioDevice->SpeakerMute(muted) == -1) { |
| return -1; |
| } |
| |
| *enabled = muted; |
| LOG(INFO) << "output: " << muted; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneMuteIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MicrophoneMuteIsAvailable(bool* available) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->MicrophoneMuteIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetMicrophoneMute |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetMicrophoneMute(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetMicrophoneMute(enable)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneMute |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MicrophoneMute(bool* enabled) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool muted(false); |
| |
| if (_ptrAudioDevice->MicrophoneMute(muted) == -1) { |
| return -1; |
| } |
| |
| *enabled = muted; |
| LOG(INFO) << "output: " << muted; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneBoostIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MicrophoneBoostIsAvailable(bool* available) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->MicrophoneBoostIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetMicrophoneBoost |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetMicrophoneBoost(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetMicrophoneBoost(enable)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneBoost |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MicrophoneBoost(bool* enabled) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool onOff(false); |
| |
| if (_ptrAudioDevice->MicrophoneBoost(onOff) == -1) { |
| return -1; |
| } |
| |
| *enabled = onOff; |
| LOG(INFO) << "output: " << onOff; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneVolumeIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MicrophoneVolumeIsAvailable(bool* available) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->MicrophoneVolumeIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetMicrophoneVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetMicrophoneVolume(uint32_t volume) { |
| LOG(INFO) << __FUNCTION__ << "(" << volume << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetMicrophoneVolume(volume)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MicrophoneVolume(uint32_t* volume) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint32_t level(0); |
| |
| if (_ptrAudioDevice->MicrophoneVolume(level) == -1) { |
| return -1; |
| } |
| |
| *volume = level; |
| LOG(INFO) << "output: " << *volume; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StereoRecordingIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StereoRecordingIsAvailable( |
| bool* available) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->StereoRecordingIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetStereoRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetStereoRecording(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| |
| if (_ptrAudioDevice->RecordingIsInitialized()) { |
| LOG(WARNING) << "recording in stereo is not supported"; |
| return -1; |
| } |
| |
| if (_ptrAudioDevice->SetStereoRecording(enable) == -1) { |
| LOG(WARNING) << "failed to change stereo recording"; |
| return -1; |
| } |
| |
| int8_t nChannels(1); |
| if (enable) { |
| nChannels = 2; |
| } |
| _audioDeviceBuffer.SetRecordingChannels(nChannels); |
| |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StereoRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StereoRecording(bool* enabled) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool stereo(false); |
| |
| if (_ptrAudioDevice->StereoRecording(stereo) == -1) { |
| return -1; |
| } |
| |
| *enabled = stereo; |
| LOG(INFO) << "output: " << stereo; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetRecordingChannel |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetRecordingChannel(const ChannelType channel) { |
| if (channel == kChannelBoth) { |
| LOG(INFO) << __FUNCTION__ << "(both)"; |
| } else if (channel == kChannelLeft) { |
| LOG(INFO) << __FUNCTION__ << "(left)"; |
| } else { |
| LOG(INFO) << __FUNCTION__ << "(right)"; |
| } |
| CHECK_INITIALIZED(); |
| |
| bool stereo(false); |
| |
| if (_ptrAudioDevice->StereoRecording(stereo) == -1) { |
| LOG(WARNING) << "recording in stereo is not supported"; |
| return -1; |
| } |
| |
| return (_audioDeviceBuffer.SetRecordingChannel(channel)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RecordingChannel |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::RecordingChannel(ChannelType* channel) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| ChannelType chType; |
| |
| if (_audioDeviceBuffer.RecordingChannel(chType) == -1) { |
| return -1; |
| } |
| |
| *channel = chType; |
| if (*channel == kChannelBoth) { |
| LOG(INFO) << "output: both"; |
| } else if (*channel == kChannelLeft) { |
| LOG(INFO) << "output: left"; |
| } else { |
| LOG(INFO) << "output: right"; |
| } |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StereoPlayoutIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StereoPlayoutIsAvailable(bool* available) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->StereoPlayoutIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetStereoPlayout |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetStereoPlayout(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| |
| if (_ptrAudioDevice->PlayoutIsInitialized()) { |
| LOG(LERROR) |
| << "unable to set stereo mode while playing side is initialized"; |
| return -1; |
| } |
| |
| if (_ptrAudioDevice->SetStereoPlayout(enable)) { |
| LOG(WARNING) << "stereo playout is not supported"; |
| return -1; |
| } |
| |
| int8_t nChannels(1); |
| if (enable) { |
| nChannels = 2; |
| } |
| _audioDeviceBuffer.SetPlayoutChannels(nChannels); |
| |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StereoPlayout |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StereoPlayout(bool* enabled) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool stereo(false); |
| |
| if (_ptrAudioDevice->StereoPlayout(stereo) == -1) { |
| return -1; |
| } |
| |
| *enabled = stereo; |
| LOG(INFO) << "output: " << stereo; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetAGC |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetAGC(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetAGC(enable)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // AGC |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::AGC() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| return (_ptrAudioDevice->AGC()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlayoutIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::PlayoutIsAvailable(bool* available) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->PlayoutIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RecordingIsAvailable |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::RecordingIsAvailable(bool* available) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| bool isAvailable(0); |
| |
| if (_ptrAudioDevice->RecordingIsAvailable(isAvailable) == -1) { |
| return -1; |
| } |
| |
| *available = isAvailable; |
| LOG(INFO) << "output: " << isAvailable; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MaxMicrophoneVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MaxMicrophoneVolume(uint32_t* maxVolume) const { |
| CHECK_INITIALIZED(); |
| |
| uint32_t maxVol(0); |
| |
| if (_ptrAudioDevice->MaxMicrophoneVolume(maxVol) == -1) { |
| return -1; |
| } |
| |
| *maxVolume = maxVol; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MinMicrophoneVolume |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MinMicrophoneVolume(uint32_t* minVolume) const { |
| CHECK_INITIALIZED(); |
| |
| uint32_t minVol(0); |
| |
| if (_ptrAudioDevice->MinMicrophoneVolume(minVol) == -1) { |
| return -1; |
| } |
| |
| *minVolume = minVol; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // MicrophoneVolumeStepSize |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::MicrophoneVolumeStepSize( |
| uint16_t* stepSize) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint16_t delta(0); |
| |
| if (_ptrAudioDevice->MicrophoneVolumeStepSize(delta) == -1) { |
| return -1; |
| } |
| |
| *stepSize = delta; |
| LOG(INFO) << "output: " << *stepSize; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlayoutDevices |
| // ---------------------------------------------------------------------------- |
| |
| int16_t AudioDeviceModuleImpl::PlayoutDevices() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint16_t nPlayoutDevices = _ptrAudioDevice->PlayoutDevices(); |
| LOG(INFO) << "output: " << nPlayoutDevices; |
| return ((int16_t)(nPlayoutDevices)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetPlayoutDevice I (II) |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetPlayoutDevice(uint16_t index) { |
| LOG(INFO) << __FUNCTION__ << "(" << index << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetPlayoutDevice(index)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetPlayoutDevice II (II) |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetPlayoutDevice(WindowsDeviceType device) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| return (_ptrAudioDevice->SetPlayoutDevice(device)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlayoutDeviceName |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::PlayoutDeviceName( |
| uint16_t index, |
| char name[kAdmMaxDeviceNameSize], |
| char guid[kAdmMaxGuidSize]) { |
| LOG(INFO) << __FUNCTION__ << "(" << index << ", ...)"; |
| CHECK_INITIALIZED(); |
| |
| if (name == NULL) { |
| _lastError = kAdmErrArgument; |
| return -1; |
| } |
| |
| if (_ptrAudioDevice->PlayoutDeviceName(index, name, guid) == -1) { |
| return -1; |
| } |
| |
| if (name != NULL) { |
| LOG(INFO) << "output: name = " << name; |
| } |
| if (guid != NULL) { |
| LOG(INFO) << "output: guid = " << guid; |
| } |
| |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RecordingDeviceName |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::RecordingDeviceName( |
| uint16_t index, |
| char name[kAdmMaxDeviceNameSize], |
| char guid[kAdmMaxGuidSize]) { |
| LOG(INFO) << __FUNCTION__ << "(" << index << ", ...)"; |
| CHECK_INITIALIZED(); |
| |
| if (name == NULL) { |
| _lastError = kAdmErrArgument; |
| return -1; |
| } |
| |
| if (_ptrAudioDevice->RecordingDeviceName(index, name, guid) == -1) { |
| return -1; |
| } |
| |
| if (name != NULL) { |
| LOG(INFO) << "output: name = " << name; |
| } |
| if (guid != NULL) { |
| LOG(INFO) << "output: guid = " << guid; |
| } |
| |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RecordingDevices |
| // ---------------------------------------------------------------------------- |
| |
| int16_t AudioDeviceModuleImpl::RecordingDevices() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint16_t nRecordingDevices = _ptrAudioDevice->RecordingDevices(); |
| |
| LOG(INFO) << "output: " << nRecordingDevices; |
| return ((int16_t)nRecordingDevices); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetRecordingDevice I (II) |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetRecordingDevice(uint16_t index) { |
| LOG(INFO) << __FUNCTION__ << "(" << index << ")"; |
| CHECK_INITIALIZED(); |
| return (_ptrAudioDevice->SetRecordingDevice(index)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetRecordingDevice II (II) |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetRecordingDevice(WindowsDeviceType device) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| return (_ptrAudioDevice->SetRecordingDevice(device)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // InitPlayout |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::InitPlayout() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| if (PlayoutIsInitialized()) { |
| return 0; |
| } |
| int32_t result = _ptrAudioDevice->InitPlayout(); |
| LOG(INFO) << "output: " << result; |
| RTC_HISTOGRAM_BOOLEAN("WebRTC.Audio.InitPlayoutSuccess", |
| static_cast<int>(result == 0)); |
| return result; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // InitRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::InitRecording() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| if (RecordingIsInitialized()) { |
| return 0; |
| } |
| int32_t result = _ptrAudioDevice->InitRecording(); |
| LOG(INFO) << "output: " << result; |
| RTC_HISTOGRAM_BOOLEAN("WebRTC.Audio.InitRecordingSuccess", |
| static_cast<int>(result == 0)); |
| return result; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlayoutIsInitialized |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::PlayoutIsInitialized() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| return (_ptrAudioDevice->PlayoutIsInitialized()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RecordingIsInitialized |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::RecordingIsInitialized() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| return (_ptrAudioDevice->RecordingIsInitialized()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StartPlayout |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StartPlayout() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| if (Playing()) { |
| return 0; |
| } |
| _audioDeviceBuffer.StartPlayout(); |
| int32_t result = _ptrAudioDevice->StartPlayout(); |
| LOG(INFO) << "output: " << result; |
| RTC_HISTOGRAM_BOOLEAN("WebRTC.Audio.StartPlayoutSuccess", |
| static_cast<int>(result == 0)); |
| return result; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StopPlayout |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StopPlayout() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| int32_t result = _ptrAudioDevice->StopPlayout(); |
| _audioDeviceBuffer.StopPlayout(); |
| LOG(INFO) << "output: " << result; |
| RTC_HISTOGRAM_BOOLEAN("WebRTC.Audio.StopPlayoutSuccess", |
| static_cast<int>(result == 0)); |
| return result; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // Playing |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::Playing() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| return (_ptrAudioDevice->Playing()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StartRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StartRecording() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| if (Recording()) { |
| return 0; |
| } |
| _audioDeviceBuffer.StartRecording(); |
| int32_t result = _ptrAudioDevice->StartRecording(); |
| LOG(INFO) << "output: " << result; |
| RTC_HISTOGRAM_BOOLEAN("WebRTC.Audio.StartRecordingSuccess", |
| static_cast<int>(result == 0)); |
| return result; |
| } |
| // ---------------------------------------------------------------------------- |
| // StopRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StopRecording() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| int32_t result = _ptrAudioDevice->StopRecording(); |
| _audioDeviceBuffer.StopRecording(); |
| LOG(INFO) << "output: " << result; |
| RTC_HISTOGRAM_BOOLEAN("WebRTC.Audio.StopRecordingSuccess", |
| static_cast<int>(result == 0)); |
| return result; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // Recording |
| // ---------------------------------------------------------------------------- |
| |
| bool AudioDeviceModuleImpl::Recording() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| return (_ptrAudioDevice->Recording()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RegisterEventObserver |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::RegisterEventObserver( |
| AudioDeviceObserver* eventCallback) { |
| LOG(INFO) << __FUNCTION__; |
| rtc::CritScope lock(&_critSectEventCb); |
| _ptrCbAudioDeviceObserver = eventCallback; |
| |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RegisterAudioCallback |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::RegisterAudioCallback( |
| AudioTransport* audioCallback) { |
| LOG(INFO) << __FUNCTION__; |
| rtc::CritScope lock(&_critSectAudioCb); |
| return _audioDeviceBuffer.RegisterAudioCallback(audioCallback); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StartRawInputFileRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StartRawInputFileRecording( |
| const char pcmFileNameUTF8[kAdmMaxFileNameSize]) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| if (NULL == pcmFileNameUTF8) { |
| return -1; |
| } |
| |
| return (_audioDeviceBuffer.StartInputFileRecording(pcmFileNameUTF8)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StopRawInputFileRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StopRawInputFileRecording() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| return (_audioDeviceBuffer.StopInputFileRecording()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StartRawOutputFileRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StartRawOutputFileRecording( |
| const char pcmFileNameUTF8[kAdmMaxFileNameSize]) { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| if (NULL == pcmFileNameUTF8) { |
| return -1; |
| } |
| |
| return (_audioDeviceBuffer.StartOutputFileRecording(pcmFileNameUTF8)); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // StopRawOutputFileRecording |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::StopRawOutputFileRecording() { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| return (_audioDeviceBuffer.StopOutputFileRecording()); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetPlayoutBuffer |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetPlayoutBuffer(const BufferType type, |
| uint16_t sizeMS) { |
| if (type == kFixedBufferSize) { |
| LOG(INFO) << __FUNCTION__ << "(fixed buffer, " << sizeMS << "ms)"; |
| } else if (type == kAdaptiveBufferSize) { |
| LOG(INFO) << __FUNCTION__ << "(adaptive buffer, " << sizeMS << "ms)"; |
| } else { |
| LOG(INFO) << __FUNCTION__ << "(?, " << sizeMS << "ms)"; |
| } |
| CHECK_INITIALIZED(); |
| |
| if (_ptrAudioDevice->PlayoutIsInitialized()) { |
| LOG(LERROR) << "unable to modify the playout buffer while playing side is " |
| "initialized"; |
| return -1; |
| } |
| |
| int32_t ret(0); |
| |
| if (kFixedBufferSize == type) { |
| if (sizeMS < kAdmMinPlayoutBufferSizeMs || |
| sizeMS > kAdmMaxPlayoutBufferSizeMs) { |
| LOG(LERROR) << "size parameter is out of range"; |
| return -1; |
| } |
| } |
| |
| if ((ret = _ptrAudioDevice->SetPlayoutBuffer(type, sizeMS)) == -1) { |
| LOG(LERROR) << "failed to set the playout buffer (error: " << LastError() |
| << ")"; |
| } |
| |
| return ret; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlayoutBuffer |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::PlayoutBuffer(BufferType* type, |
| uint16_t* sizeMS) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| BufferType bufType; |
| uint16_t size(0); |
| |
| if (_ptrAudioDevice->PlayoutBuffer(bufType, size) == -1) { |
| LOG(LERROR) << "failed to retrieve the buffer type and size"; |
| return -1; |
| } |
| |
| *type = bufType; |
| *sizeMS = size; |
| |
| LOG(INFO) << "output: type = " << *type << ", sizeMS = " << *sizeMS; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlayoutDelay |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::PlayoutDelay(uint16_t* delayMS) const { |
| CHECK_INITIALIZED(); |
| |
| uint16_t delay(0); |
| |
| if (_ptrAudioDevice->PlayoutDelay(delay) == -1) { |
| LOG(LERROR) << "failed to retrieve the playout delay"; |
| return -1; |
| } |
| |
| *delayMS = delay; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RecordingDelay |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::RecordingDelay(uint16_t* delayMS) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint16_t delay(0); |
| |
| if (_ptrAudioDevice->RecordingDelay(delay) == -1) { |
| LOG(LERROR) << "failed to retrieve the recording delay"; |
| return -1; |
| } |
| |
| *delayMS = delay; |
| LOG(INFO) << "output: " << *delayMS; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // CPULoad |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::CPULoad(uint16_t* load) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| uint16_t cpuLoad(0); |
| |
| if (_ptrAudioDevice->CPULoad(cpuLoad) == -1) { |
| LOG(LERROR) << "failed to retrieve the CPU load"; |
| return -1; |
| } |
| |
| *load = cpuLoad; |
| LOG(INFO) << "output: " << *load; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetRecordingSampleRate |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetRecordingSampleRate( |
| const uint32_t samplesPerSec) { |
| LOG(INFO) << __FUNCTION__ << "(" << samplesPerSec << ")"; |
| CHECK_INITIALIZED(); |
| |
| if (_ptrAudioDevice->SetRecordingSampleRate(samplesPerSec) != 0) { |
| return -1; |
| } |
| |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // RecordingSampleRate |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::RecordingSampleRate( |
| uint32_t* samplesPerSec) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| int32_t sampleRate = _audioDeviceBuffer.RecordingSampleRate(); |
| |
| if (sampleRate == -1) { |
| LOG(LERROR) << "failed to retrieve the sample rate"; |
| return -1; |
| } |
| |
| *samplesPerSec = sampleRate; |
| LOG(INFO) << "output: " << *samplesPerSec; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetPlayoutSampleRate |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetPlayoutSampleRate( |
| const uint32_t samplesPerSec) { |
| LOG(INFO) << __FUNCTION__ << "(" << samplesPerSec << ")"; |
| CHECK_INITIALIZED(); |
| |
| if (_ptrAudioDevice->SetPlayoutSampleRate(samplesPerSec) != 0) { |
| return -1; |
| } |
| |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlayoutSampleRate |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::PlayoutSampleRate( |
| uint32_t* samplesPerSec) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| |
| int32_t sampleRate = _audioDeviceBuffer.PlayoutSampleRate(); |
| |
| if (sampleRate == -1) { |
| LOG(LERROR) << "failed to retrieve the sample rate"; |
| return -1; |
| } |
| |
| *samplesPerSec = sampleRate; |
| LOG(INFO) << "output: " << *samplesPerSec; |
| return (0); |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // ResetAudioDevice |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::ResetAudioDevice() { |
| LOG(INFO) << __FUNCTION__; |
| FATAL() << "Should never be called"; |
| return -1; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // SetLoudspeakerStatus |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::SetLoudspeakerStatus(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| |
| if (_ptrAudioDevice->SetLoudspeakerStatus(enable) != 0) { |
| return -1; |
| } |
| |
| return 0; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // GetLoudspeakerStatus |
| // ---------------------------------------------------------------------------- |
| |
| int32_t AudioDeviceModuleImpl::GetLoudspeakerStatus(bool* enabled) const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED(); |
| int32_t ok = 0; |
| if (_ptrAudioDevice->GetLoudspeakerStatus(*enabled) != 0) { |
| ok = -1; |
| } |
| LOG(INFO) << "output: " << ok; |
| return ok; |
| } |
| |
| bool AudioDeviceModuleImpl::BuiltInAECIsAvailable() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| bool isAvailable = _ptrAudioDevice->BuiltInAECIsAvailable(); |
| LOG(INFO) << "output: " << isAvailable; |
| return isAvailable; |
| } |
| |
| int32_t AudioDeviceModuleImpl::EnableBuiltInAEC(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| int32_t ok = _ptrAudioDevice->EnableBuiltInAEC(enable); |
| LOG(INFO) << "output: " << ok; |
| return ok; |
| } |
| |
| bool AudioDeviceModuleImpl::BuiltInAGCIsAvailable() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| bool isAvailable = _ptrAudioDevice->BuiltInAGCIsAvailable(); |
| LOG(INFO) << "output: " << isAvailable; |
| return isAvailable; |
| } |
| |
| int32_t AudioDeviceModuleImpl::EnableBuiltInAGC(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| int32_t ok = _ptrAudioDevice->EnableBuiltInAGC(enable); |
| LOG(INFO) << "output: " << ok; |
| return ok; |
| } |
| |
| bool AudioDeviceModuleImpl::BuiltInNSIsAvailable() const { |
| LOG(INFO) << __FUNCTION__; |
| CHECK_INITIALIZED_BOOL(); |
| bool isAvailable = _ptrAudioDevice->BuiltInNSIsAvailable(); |
| LOG(INFO) << "output: " << isAvailable; |
| return isAvailable; |
| } |
| |
| int32_t AudioDeviceModuleImpl::EnableBuiltInNS(bool enable) { |
| LOG(INFO) << __FUNCTION__ << "(" << enable << ")"; |
| CHECK_INITIALIZED(); |
| int32_t ok = _ptrAudioDevice->EnableBuiltInNS(enable); |
| LOG(INFO) << "output: " << ok; |
| return ok; |
| } |
| |
| #if defined(WEBRTC_IOS) |
| int AudioDeviceModuleImpl::GetPlayoutAudioParameters( |
| AudioParameters* params) const { |
| LOG(INFO) << __FUNCTION__; |
| int r = _ptrAudioDevice->GetPlayoutAudioParameters(params); |
| LOG(INFO) << "output: " << r; |
| return r; |
| } |
| |
| int AudioDeviceModuleImpl::GetRecordAudioParameters( |
| AudioParameters* params) const { |
| LOG(INFO) << __FUNCTION__; |
| int r = _ptrAudioDevice->GetRecordAudioParameters(params); |
| LOG(INFO) << "output: " << r; |
| return r; |
| } |
| #endif // WEBRTC_IOS |
| |
| // ============================================================================ |
| // Private Methods |
| // ============================================================================ |
| |
| // ---------------------------------------------------------------------------- |
| // Platform |
| // ---------------------------------------------------------------------------- |
| |
| AudioDeviceModuleImpl::PlatformType AudioDeviceModuleImpl::Platform() const { |
| LOG(INFO) << __FUNCTION__; |
| return _platformType; |
| } |
| |
| // ---------------------------------------------------------------------------- |
| // PlatformAudioLayer |
| // ---------------------------------------------------------------------------- |
| |
| AudioDeviceModule::AudioLayer AudioDeviceModuleImpl::PlatformAudioLayer() |
| const { |
| LOG(INFO) << __FUNCTION__; |
| return _platformAudioLayer; |
| } |
| |
| } // namespace webrtc |