WebRTC repo contains a very useful audio processing module, which contains very useful tools such as Acoustic Echo Canceller, Sampler rate converter, Automatic Gain Control, Channel downmixer etc., If you want to use just the audio processing module of WebRTC without the other bloat, then the challenges are as follows.
- There is no simple way to build audio processing library and all its dependencies in a single binary.
- WebRTC officially supports only clang toolchain. Integrating a clang binary with a Windows or MacOS app using MSVC or XCode toolchain is not straight forward. If you try to build WebRTC for MSVC or XCode toolchain then you will run into a lot of build errors.
- WebRTC build system is based on Ninja/GN which is very difficult to debug build errors for users not familiar with it.
This repo tries to solve the above problem by using a simple CMake based system that builds only those source files required for audio processing module library. Since this is based cmake you are free to use your own toolchain.
The below points mention the steps for building the WebRTC release version M124, the latest stable release while writing this document. The list of WebRTC releases and its branch name is published here by the chromium team.
- Install the WebRTC developer pre-requisite softwares and tools as suggested here. The Windows section of the above page, redirects you to the chromium build steps. In the chromium build steps page, make sure to stop after installing the prerequisites. You need not follow the steps mentioned for downloading and building the chromium source(Obviously duh!).
- Fetch the latest webrtc src by running the following commands from the root folder of this repository. This fetch step might take anywhere between few minutes to few hours depending on your internet connection speed. So be patient. If you try believe the fetch step has hung, then just stop it and re-run the command to restart the download.
fetch --nohooks webrtc
gclient sync
- Checkout the branch corresponding to WebRTC release that we want to build. For example to checkout code corresponding to release M124, we need to checkout the branch
branch-heads/6367
cd src
git checkout branch-heads/6367
- Generate the WebRTC GN build files. This will autogenerate some protobuf source files that are required for building the library.
gn gen out/Default
- If you using Windows on x64, then apply the below changes manually.
C:\work\webrtc-audioprocessing\src>git diff
diff --git a/modules/audio_processing/aec3/matched_filter.cc b/modules/audio_processing/aec3/matched_filter.cc
index edaa2a4d14..f46387cfed 100644
--- a/modules/audio_processing/aec3/matched_filter.cc
+++ b/modules/audio_processing/aec3/matched_filter.cc
@@ -769,6 +769,7 @@ void MatchedFilter::Update(const DownsampledRenderBuffer& render_buffer,
filters_[n], &filters_updated, &error_sum, compute_pre_echo,
instantaneous_accumulated_error_, scratch_memory_);
break;
+#if defined(WEBRTC_ENABLE_AVX2)
case Aec3Optimization::kAvx2:
aec3::MatchedFilterCore_AVX2(
x_start_index, x2_sum_threshold, smoothing, render_buffer.buffer, y,
@@ -776,6 +777,7 @@ void MatchedFilter::Update(const DownsampledRenderBuffer& render_buffer,
instantaneous_accumulated_error_, scratch_memory_);
break;
#endif
+#endif
#if defined(WEBRTC_HAS_NEON)
case Aec3Optimization::kNeon:
aec3::MatchedFilterCore_NEON(
diff --git a/rtc_base/checks.h b/rtc_base/checks.h
index 99fee97d0a..1e243e8ad4 100644
--- a/rtc_base/checks.h
+++ b/rtc_base/checks.h
@@ -475,7 +475,7 @@ RTC_NORETURN RTC_EXPORT void UnreachableCodeReached();
// remainder is zero.
template <typename T>
inline T CheckedDivExact(T a, T b) {
- RTC_CHECK_EQ(a % b, 0) << a << " is not evenly divisible by " << b;
+ RTC_CHECK_EQ(a % b, 0);
return a / b;
}
- If you using Windows on arm64, then apply the below changes manually.
C:\karthick\webrtc-audioprocessing\src>git diff
diff --git a/system_wrappers/source/denormal_disabler.cc b/system_wrappers/source/denormal_disabler.cc
index bb9c05643c..b9634444e3 100644
--- a/system_wrappers/source/denormal_disabler.cc
+++ b/system_wrappers/source/denormal_disabler.cc
@@ -21,7 +21,7 @@ namespace {
#if defined(WEBRTC_DENORMAL_DISABLER_X86_SUPPORTED) || \
defined(WEBRTC_ARCH_ARM_FAMILY)
-#define WEBRTC_DENORMAL_DISABLER_SUPPORTED
+// #define WEBRTC_DENORMAL_DISABLER_SUPPORTED
#endif
constexpr int kUnspecifiedStatusWord = -1;
C:\karthick\webrtc-audioprocessing\src\third_party\zlib>git diff
diff --git a/zlib/cpu_features.c b/zlib/cpu_features.c
index 34ae7b913af..bcc258642e1 100644
--- a/zlib/cpu_features.c
+++ b/zlib/cpu_features.c
@@ -62,7 +62,7 @@ int ZLIB_INTERNAL riscv_cpu_enable_vclmul = 0;
#error cpu_features.c CPU feature detection in not defined for your platform
#endif
-#if !defined(CPU_NO_SIMD) && !defined(ARMV8_OS_MACOS)
+#if !defined(CPU_NO_SIMD) && !defined(ARMV8_OS_MACOS) && !defined(ARMV8_OS_WINDOWS)
static void _cpu_check_features(void);
#endif
- Now let's build the audio processing library, using cmake from the root folder of this repo
cd ..
mkdir build
mkdir install
cd build
cmake -DCMAKE_INSTALL_PREFIX=../install ..
cmake --build . --config Release --target install
- The
install
folder will contain the audio processing library(inlib
subfolder) and the header files needed to use them(insrc
subfolder)