mirror of
https://github.com/yuzu-emu/yuzu-android
synced 2024-12-28 08:51:21 -08:00
aae8c180cb
Instead of waiting immediately for executed commands, defer the query until the guest CPU reads it. This way we get closer to what the guest program is doing. To archive this we have to build a dependency queue, because host APIs (like OpenGL and Vulkan) use ranged queries instead of counters like NVN. Waiting for queries implicitly uses fences and this requires a command being queued, otherwise the driver will lock waiting until a timeout. To fix this when there are no commands queued, we explicitly call glFlush.
108 lines
3.6 KiB
C++
108 lines
3.6 KiB
C++
// Copyright 2018 yuzu Emulator Project
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#pragma once
|
|
|
|
#include <atomic>
|
|
#include <functional>
|
|
#include "common/common_types.h"
|
|
#include "video_core/engines/fermi_2d.h"
|
|
#include "video_core/gpu.h"
|
|
#include "video_core/guest_driver.h"
|
|
|
|
namespace Tegra {
|
|
class MemoryManager;
|
|
}
|
|
|
|
namespace VideoCore {
|
|
|
|
enum class QueryType {
|
|
SamplesPassed,
|
|
};
|
|
constexpr std::size_t NumQueryTypes = 1;
|
|
|
|
enum class LoadCallbackStage {
|
|
Prepare,
|
|
Decompile,
|
|
Build,
|
|
Complete,
|
|
};
|
|
using DiskResourceLoadCallback = std::function<void(LoadCallbackStage, std::size_t, std::size_t)>;
|
|
|
|
class RasterizerInterface {
|
|
public:
|
|
virtual ~RasterizerInterface() {}
|
|
|
|
/// Draw the current batch of vertex arrays
|
|
virtual bool DrawBatch(bool is_indexed) = 0;
|
|
|
|
/// Draw the current batch of multiple instances of vertex arrays
|
|
virtual bool DrawMultiBatch(bool is_indexed) = 0;
|
|
|
|
/// Clear the current framebuffer
|
|
virtual void Clear() = 0;
|
|
|
|
/// Dispatches a compute shader invocation
|
|
virtual void DispatchCompute(GPUVAddr code_addr) = 0;
|
|
|
|
/// Resets the counter of a query
|
|
virtual void ResetCounter(QueryType type) = 0;
|
|
|
|
/// Records a GPU query and caches it
|
|
virtual void Query(GPUVAddr gpu_addr, QueryType type) = 0;
|
|
|
|
/// Notify rasterizer that all caches should be flushed to Switch memory
|
|
virtual void FlushAll() = 0;
|
|
|
|
/// Notify rasterizer that any caches of the specified region should be flushed to Switch memory
|
|
virtual void FlushRegion(CacheAddr addr, u64 size) = 0;
|
|
|
|
/// Notify rasterizer that any caches of the specified region should be invalidated
|
|
virtual void InvalidateRegion(CacheAddr addr, u64 size) = 0;
|
|
|
|
/// Notify rasterizer that any caches of the specified region should be flushed to Switch memory
|
|
/// and invalidated
|
|
virtual void FlushAndInvalidateRegion(CacheAddr addr, u64 size) = 0;
|
|
|
|
/// Notify the rasterizer to send all written commands to the host GPU.
|
|
virtual void FlushCommands() = 0;
|
|
|
|
/// Notify rasterizer that a frame is about to finish
|
|
virtual void TickFrame() = 0;
|
|
|
|
/// Attempt to use a faster method to perform a surface copy
|
|
virtual bool AccelerateSurfaceCopy(const Tegra::Engines::Fermi2D::Regs::Surface& src,
|
|
const Tegra::Engines::Fermi2D::Regs::Surface& dst,
|
|
const Tegra::Engines::Fermi2D::Config& copy_config) {
|
|
return false;
|
|
}
|
|
|
|
/// Attempt to use a faster method to display the framebuffer to screen
|
|
virtual bool AccelerateDisplay(const Tegra::FramebufferConfig& config, VAddr framebuffer_addr,
|
|
u32 pixel_stride) {
|
|
return false;
|
|
}
|
|
|
|
/// Increase/decrease the number of object in pages touching the specified region
|
|
virtual void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) {}
|
|
|
|
/// Initialize disk cached resources for the game being emulated
|
|
virtual void LoadDiskResources(const std::atomic_bool& stop_loading = false,
|
|
const DiskResourceLoadCallback& callback = {}) {}
|
|
|
|
/// Grant access to the Guest Driver Profile for recording/obtaining info on the guest driver.
|
|
GuestDriverProfile& AccessGuestDriverProfile() {
|
|
return guest_driver_profile;
|
|
}
|
|
|
|
/// Grant access to the Guest Driver Profile for recording/obtaining info on the guest driver.
|
|
const GuestDriverProfile& AccessGuestDriverProfile() const {
|
|
return guest_driver_profile;
|
|
}
|
|
|
|
private:
|
|
GuestDriverProfile guest_driver_profile{};
|
|
};
|
|
} // namespace VideoCore
|