6d0551196d
Like with CPU emulation, we generally don't want to fire off the threads immediately after the relevant classes are initialized, we want to do this after all necessary data is done loading first. This splits the thread creation into its own interface member function to allow controlling when these threads in particular get created.
42 lines
1.1 KiB
C++
42 lines
1.1 KiB
C++
// Copyright 2019 yuzu Emulator Project
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#include "video_core/gpu_asynch.h"
|
|
#include "video_core/gpu_thread.h"
|
|
#include "video_core/renderer_base.h"
|
|
|
|
namespace VideoCommon {
|
|
|
|
GPUAsynch::GPUAsynch(Core::System& system, VideoCore::RendererBase& renderer)
|
|
: GPU(system, renderer), gpu_thread{system} {}
|
|
|
|
GPUAsynch::~GPUAsynch() = default;
|
|
|
|
void GPUAsynch::Start() {
|
|
gpu_thread.StartThread(renderer, *dma_pusher);
|
|
}
|
|
|
|
void GPUAsynch::PushGPUEntries(Tegra::CommandList&& entries) {
|
|
gpu_thread.SubmitList(std::move(entries));
|
|
}
|
|
|
|
void GPUAsynch::SwapBuffers(
|
|
std::optional<std::reference_wrapper<const Tegra::FramebufferConfig>> framebuffer) {
|
|
gpu_thread.SwapBuffers(std::move(framebuffer));
|
|
}
|
|
|
|
void GPUAsynch::FlushRegion(CacheAddr addr, u64 size) {
|
|
gpu_thread.FlushRegion(addr, size);
|
|
}
|
|
|
|
void GPUAsynch::InvalidateRegion(CacheAddr addr, u64 size) {
|
|
gpu_thread.InvalidateRegion(addr, size);
|
|
}
|
|
|
|
void GPUAsynch::FlushAndInvalidateRegion(CacheAddr addr, u64 size) {
|
|
gpu_thread.FlushAndInvalidateRegion(addr, size);
|
|
}
|
|
|
|
} // namespace VideoCommon
|