From 5f1eb7146d6ad4d7cfefff43d36f96b35388c55e Mon Sep 17 00:00:00 2001 From: xperia64 Date: Thu, 31 Dec 2020 00:21:03 +0000 Subject: [PATCH] Merge generic part of Android microphone changes (#5624) --- src/audio_core/cubeb_input.cpp | 9 ++++++++- src/audio_core/cubeb_input.h | 7 +++++++ src/core/frontend/mic.cpp | 26 ++++++++++++++++++++++++++ src/core/frontend/mic.h | 19 +++++++++++++++++++ src/core/hle/service/mic_u.cpp | 9 +-------- 5 files changed, 61 insertions(+), 9 deletions(-) diff --git a/src/audio_core/cubeb_input.cpp b/src/audio_core/cubeb_input.cpp index 04d89e5259..abb42ac402 100644 --- a/src/audio_core/cubeb_input.cpp +++ b/src/audio_core/cubeb_input.cpp @@ -86,7 +86,7 @@ void CubebInput::StartSampling(const Frontend::Mic::Parameters& params) { input_params.format = CUBEB_SAMPLE_S16LE; input_params.rate = params.sample_rate; - u32 latency_frames; + u32 latency_frames = 512; // Firefox default if (cubeb_get_min_latency(impl->ctx, &input_params, &latency_frames) != CUBEB_OK) { LOG_ERROR(Audio, "Could not get minimum latency"); } @@ -189,4 +189,11 @@ std::vector ListCubebInputDevices() { cubeb_destroy(ctx); return device_list; } + +CubebFactory::~CubebFactory() = default; + +std::unique_ptr CubebFactory::Create(std::string mic_device_name) { + return std::make_unique(std::move(mic_device_name)); +} + } // namespace AudioCore diff --git a/src/audio_core/cubeb_input.h b/src/audio_core/cubeb_input.h index 2e752da7ab..f81fb5ac26 100644 --- a/src/audio_core/cubeb_input.h +++ b/src/audio_core/cubeb_input.h @@ -31,4 +31,11 @@ private: std::vector ListCubebInputDevices(); +class CubebFactory final : public Frontend::Mic::RealMicFactory { +public: + ~CubebFactory() override; + + std::unique_ptr Create(std::string mic_device_name) override; +}; + } // namespace AudioCore diff --git a/src/core/frontend/mic.cpp b/src/core/frontend/mic.cpp index 543a237677..c9dbc9cc7e 100644 --- a/src/core/frontend/mic.cpp +++ b/src/core/frontend/mic.cpp @@ -5,6 +5,10 @@ #include #include "core/frontend/mic.h" +#ifdef HAVE_CUBEB +#include "audio_core/cubeb_input.h" +#endif + namespace Frontend::Mic { constexpr std::array NOISE_SAMPLE_8_BIT = {0xFC, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, @@ -57,4 +61,26 @@ Samples StaticMic::Read() { return (sample_size == 8) ? CACHE_8_BIT : CACHE_16_BIT; } +RealMicFactory::~RealMicFactory() = default; + +NullFactory::~NullFactory() = default; + +std::unique_ptr NullFactory::Create([[maybe_unused]] std::string mic_device_name) { + return std::make_unique(); +} + +#ifdef HAVE_CUBEB +static std::unique_ptr g_factory = std::make_unique(); +#else +static std::unique_ptr g_factory = std::make_unique(); +#endif + +void RegisterRealMicFactory(std::unique_ptr factory) { + g_factory = std::move(factory); +} + +std::unique_ptr CreateRealMic(std::string mic_device_name) { + return g_factory->Create(std::move(mic_device_name)); +} + } // namespace Frontend::Mic diff --git a/src/core/frontend/mic.h b/src/core/frontend/mic.h index 1504ad3ca6..28738df524 100644 --- a/src/core/frontend/mic.h +++ b/src/core/frontend/mic.h @@ -115,4 +115,23 @@ private: std::vector CACHE_16_BIT; }; +/// Factory for creating a real Mic input device; +class RealMicFactory { +public: + virtual ~RealMicFactory(); + + virtual std::unique_ptr Create(std::string mic_device_name) = 0; +}; + +class NullFactory final : public RealMicFactory { +public: + ~NullFactory() override; + + std::unique_ptr Create(std::string mic_device_name) override; +}; + +void RegisterRealMicFactory(std::unique_ptr factory); + +std::unique_ptr CreateRealMic(std::string mic_device_name); + } // namespace Frontend::Mic diff --git a/src/core/hle/service/mic_u.cpp b/src/core/hle/service/mic_u.cpp index de1bfc074b..39e375d398 100644 --- a/src/core/hle/service/mic_u.cpp +++ b/src/core/hle/service/mic_u.cpp @@ -3,9 +3,6 @@ // Refer to the license.txt file included. #include -#ifdef HAVE_CUBEB -#include "audio_core/cubeb_input.h" -#endif #include "common/archives.h" #include "common/logging/log.h" #include "core/core.h" @@ -359,11 +356,7 @@ struct MIC_U::Impl { new_mic = std::make_unique(); break; case Settings::MicInputType::Real: -#if HAVE_CUBEB - new_mic = std::make_unique(Settings::values.mic_input_device); -#else - new_mic = std::make_unique(); -#endif + new_mic = Frontend::Mic::CreateRealMic(Settings::values.mic_input_device); break; case Settings::MicInputType::Static: new_mic = std::make_unique();