Merge pull request #9603 from Bonta0/audio-init
AudioCommon: Split Initialization
This commit is contained in:
commit
fa04e5a7d3
|
@ -15,7 +15,6 @@
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
#include "Common/Logging/Log.h"
|
#include "Common/Logging/Log.h"
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/HW/AudioInterface.h"
|
|
||||||
|
|
||||||
// This shouldn't be a global, at least not here.
|
// This shouldn't be a global, at least not here.
|
||||||
std::unique_ptr<SoundStream> g_sound_stream;
|
std::unique_ptr<SoundStream> g_sound_stream;
|
||||||
|
@ -66,13 +65,11 @@ void InitSoundStream()
|
||||||
g_sound_stream = std::make_unique<NullSound>();
|
g_sound_stream = std::make_unique<NullSound>();
|
||||||
g_sound_stream->Init();
|
g_sound_stream->Init();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Ideally these two calls would be done in AudioInterface::Init so that we don't
|
void PostInitSoundStream()
|
||||||
// need to have a dependency on AudioInterface here, but this has to be done
|
{
|
||||||
// after creating g_sound_stream (above) and before starting audio dumping (below)
|
// This needs to be called after AudioInterface::Init where input sample rates are set
|
||||||
g_sound_stream->GetMixer()->SetDMAInputSampleRate(AudioInterface::GetAIDSampleRate());
|
|
||||||
g_sound_stream->GetMixer()->SetStreamInputSampleRate(AudioInterface::GetAISSampleRate());
|
|
||||||
|
|
||||||
UpdateSoundStream();
|
UpdateSoundStream();
|
||||||
SetSoundStreamRunning(true);
|
SetSoundStreamRunning(true);
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ extern std::unique_ptr<SoundStream> g_sound_stream;
|
||||||
namespace AudioCommon
|
namespace AudioCommon
|
||||||
{
|
{
|
||||||
void InitSoundStream();
|
void InitSoundStream();
|
||||||
|
void PostInitSoundStream();
|
||||||
void ShutdownSoundStream();
|
void ShutdownSoundStream();
|
||||||
std::string GetDefaultSoundBackend();
|
std::string GetDefaultSoundBackend();
|
||||||
std::vector<std::string> GetSoundBackends();
|
std::vector<std::string> GetSoundBackends();
|
||||||
|
|
|
@ -516,6 +516,9 @@ static void EmuThread(std::unique_ptr<BootParameters> boot, WindowSystemInfo wsi
|
||||||
Movie::Init(*boot);
|
Movie::Init(*boot);
|
||||||
Common::ScopeGuard movie_guard{&Movie::Shutdown};
|
Common::ScopeGuard movie_guard{&Movie::Shutdown};
|
||||||
|
|
||||||
|
AudioCommon::InitSoundStream();
|
||||||
|
Common::ScopeGuard audio_guard{&AudioCommon::ShutdownSoundStream};
|
||||||
|
|
||||||
HW::Init();
|
HW::Init();
|
||||||
|
|
||||||
Common::ScopeGuard hw_guard{[] {
|
Common::ScopeGuard hw_guard{[] {
|
||||||
|
@ -566,8 +569,7 @@ static void EmuThread(std::unique_ptr<BootParameters> boot, WindowSystemInfo wsi
|
||||||
// it's now ok to initialize any custom textures
|
// it's now ok to initialize any custom textures
|
||||||
HiresTexture::Update();
|
HiresTexture::Update();
|
||||||
|
|
||||||
AudioCommon::InitSoundStream();
|
AudioCommon::PostInitSoundStream();
|
||||||
Common::ScopeGuard audio_guard{&AudioCommon::ShutdownSoundStream};
|
|
||||||
|
|
||||||
// The hardware is initialized.
|
// The hardware is initialized.
|
||||||
s_hardware_initialized = true;
|
s_hardware_initialized = true;
|
||||||
|
|
|
@ -153,6 +153,9 @@ void Init()
|
||||||
s_aid_sample_rate = Get32KHzSampleRate();
|
s_aid_sample_rate = Get32KHzSampleRate();
|
||||||
|
|
||||||
event_type_ai = CoreTiming::RegisterEvent("AICallback", Update);
|
event_type_ai = CoreTiming::RegisterEvent("AICallback", Update);
|
||||||
|
|
||||||
|
g_sound_stream->GetMixer()->SetDMAInputSampleRate(GetAIDSampleRate());
|
||||||
|
g_sound_stream->GetMixer()->SetStreamInputSampleRate(GetAISSampleRate());
|
||||||
}
|
}
|
||||||
|
|
||||||
void Shutdown()
|
void Shutdown()
|
||||||
|
|
Loading…
Reference in New Issue