2015-05-24 06:32:32 +02:00
|
|
|
// Copyright 2015 Dolphin Emulator Project
|
2021-07-05 03:22:19 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2015-05-24 06:32:32 +02:00
|
|
|
|
2021-12-09 18:22:16 -08:00
|
|
|
#include "VideoCommon/AsyncRequests.h"
|
|
|
|
|
2016-01-17 16:54:31 -05:00
|
|
|
#include <mutex>
|
|
|
|
|
2022-12-09 20:01:25 +01:00
|
|
|
#include "Core/System.h"
|
2023-01-30 03:40:15 +13:00
|
|
|
|
2015-03-05 17:12:24 +01:00
|
|
|
#include "VideoCommon/Fifo.h"
|
2018-03-26 21:33:16 +02:00
|
|
|
#include "VideoCommon/VertexManagerBase.h"
|
2016-01-17 16:54:31 -05:00
|
|
|
#include "VideoCommon/VideoBackendBase.h"
|
2023-01-30 23:59:54 +13:00
|
|
|
#include "VideoCommon/VideoEvents.h"
|
2015-01-31 11:38:23 +01:00
|
|
|
|
|
|
|
AsyncRequests AsyncRequests::s_singleton;
|
|
|
|
|
2018-04-01 19:01:55 -04:00
|
|
|
AsyncRequests::AsyncRequests() = default;
|
2015-01-31 11:38:23 +01:00
|
|
|
|
|
|
|
void AsyncRequests::PullEventsInternal()
|
|
|
|
{
|
2018-03-26 21:33:16 +02:00
|
|
|
// This is only called if the queue isn't empty.
|
|
|
|
// So just flush the pipeline to get accurate results.
|
|
|
|
g_vertex_manager->Flush();
|
|
|
|
|
2015-01-31 11:38:23 +01:00
|
|
|
std::unique_lock<std::mutex> lock(m_mutex);
|
2016-08-05 16:04:39 +02:00
|
|
|
m_empty.Set();
|
2016-06-24 10:43:46 +02:00
|
|
|
|
2015-01-31 11:38:23 +01:00
|
|
|
while (!m_queue.empty())
|
|
|
|
{
|
2025-03-06 21:14:38 -06:00
|
|
|
Event e = std::move(m_queue.front());
|
2015-01-31 11:38:23 +01:00
|
|
|
lock.unlock();
|
2025-03-06 21:14:38 -06:00
|
|
|
std::invoke(e);
|
2015-01-31 11:38:23 +01:00
|
|
|
lock.lock();
|
2016-06-24 10:43:46 +02:00
|
|
|
|
2015-01-31 11:38:23 +01:00
|
|
|
m_queue.pop();
|
|
|
|
}
|
2016-06-24 10:43:46 +02:00
|
|
|
|
2025-03-06 21:14:38 -06:00
|
|
|
m_cond.notify_one();
|
2015-01-31 11:38:23 +01:00
|
|
|
}
|
|
|
|
|
2025-03-06 21:14:38 -06:00
|
|
|
void AsyncRequests::QueueEvent(Event&& event)
|
2015-01-31 11:38:23 +01:00
|
|
|
{
|
2016-08-05 16:04:39 +02:00
|
|
|
m_empty.Clear();
|
2015-01-31 11:38:23 +01:00
|
|
|
|
|
|
|
if (!m_enable)
|
|
|
|
return;
|
|
|
|
|
2025-03-06 21:14:38 -06:00
|
|
|
m_queue.push(std::move(event));
|
2015-01-31 11:38:23 +01:00
|
|
|
|
2022-12-09 20:01:25 +01:00
|
|
|
auto& system = Core::System::GetInstance();
|
2023-12-18 21:31:32 -05:00
|
|
|
system.GetFifo().RunGpu();
|
2015-01-31 11:38:23 +01:00
|
|
|
}
|
|
|
|
|
2020-04-07 19:37:32 +02:00
|
|
|
void AsyncRequests::WaitForEmptyQueue()
|
|
|
|
{
|
|
|
|
std::unique_lock<std::mutex> lock(m_mutex);
|
|
|
|
m_cond.wait(lock, [this] { return m_queue.empty(); });
|
|
|
|
}
|
|
|
|
|
2015-01-31 11:38:23 +01:00
|
|
|
void AsyncRequests::SetEnable(bool enable)
|
|
|
|
{
|
|
|
|
std::unique_lock<std::mutex> lock(m_mutex);
|
|
|
|
m_enable = enable;
|
2016-06-24 10:43:46 +02:00
|
|
|
|
2015-01-31 11:38:23 +01:00
|
|
|
if (!enable)
|
|
|
|
{
|
|
|
|
// flush the queue on disabling
|
|
|
|
while (!m_queue.empty())
|
|
|
|
m_queue.pop();
|
2025-03-06 21:14:38 -06:00
|
|
|
m_cond.notify_one();
|
2015-01-31 11:38:23 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-31 12:01:01 +01:00
|
|
|
void AsyncRequests::SetPassthrough(bool enable)
|
|
|
|
{
|
|
|
|
std::unique_lock<std::mutex> lock(m_mutex);
|
|
|
|
m_passthrough = enable;
|
|
|
|
}
|