pineapple/src/video_core/rasterizer_interface.h

177 lines
6.4 KiB
C
Raw Normal View History

2022-11-05 13:58:44 +01:00
// SPDX-FileCopyrightText: Copyright 2018 yuzu Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later
#pragma once
#include <functional>
#include <optional>
#include <span>
2023-01-06 04:23:54 +01:00
#include <utility>
2022-11-05 13:58:44 +01:00
#include "common/common_types.h"
2022-11-22 21:10:41 +01:00
#include "common/polyfill_thread.h"
2022-12-25 07:12:57 +01:00
#include "video_core/cache_types.h"
2022-11-05 13:58:44 +01:00
#include "video_core/engines/fermi_2d.h"
#include "video_core/gpu.h"
2023-08-24 18:22:48 +02:00
#include "video_core/query_cache/types.h"
2023-05-04 16:44:44 +02:00
#include "video_core/rasterizer_download_area.h"
2022-11-05 13:58:44 +01:00
namespace Tegra {
class MemoryManager;
namespace Engines {
class AccelerateDMAInterface;
}
namespace Control {
struct ChannelState;
}
} // namespace Tegra
namespace VideoCore {
enum class LoadCallbackStage {
Prepare,
Build,
Complete,
};
using DiskResourceLoadCallback = std::function<void(LoadCallbackStage, std::size_t, std::size_t)>;
class RasterizerInterface {
public:
virtual ~RasterizerInterface() = default;
/// Dispatches a draw invocation
virtual void Draw(bool is_indexed, u32 instance_count) = 0;
2022-12-25 07:12:57 +01:00
/// Dispatches an indirect draw invocation
virtual void DrawIndirect() {}
2023-01-06 23:12:33 +01:00
/// Dispatches an draw texture invocation
virtual void DrawTexture() = 0;
2022-11-05 13:58:44 +01:00
/// Clear the current framebuffer
2022-11-17 18:04:39 +01:00
virtual void Clear(u32 layer_count) = 0;
2022-11-05 13:58:44 +01:00
/// Dispatches a compute shader invocation
virtual void DispatchCompute() = 0;
/// Resets the counter of a query
2023-08-24 18:22:48 +02:00
virtual void ResetCounter(VideoCommon::QueryType type) = 0;
2022-11-05 13:58:44 +01:00
/// Records a GPU query and caches it
2023-08-24 18:22:48 +02:00
virtual void Query(GPUVAddr gpu_addr, VideoCommon::QueryType type,
VideoCommon::QueryPropertiesFlags flags, u32 payload, u32 subreport) = 0;
2022-11-05 13:58:44 +01:00
/// Signal an uniform buffer binding
virtual void BindGraphicsUniformBuffer(size_t stage, u32 index, GPUVAddr gpu_addr,
u32 size) = 0;
/// Signal disabling of a uniform buffer
virtual void DisableGraphicsUniformBuffer(size_t stage, u32 index) = 0;
/// Signal a GPU based semaphore as a fence
virtual void SignalFence(std::function<void()>&& func) = 0;
/// Send an operation to be done after a certain amount of flushes.
virtual void SyncOperation(std::function<void()>&& func) = 0;
/// Signal a GPU based syncpoint as a fence
virtual void SignalSyncPoint(u32 value) = 0;
/// Signal a GPU based reference as point
virtual void SignalReference() = 0;
/// Release all pending fences.
2023-08-24 18:22:48 +02:00
virtual void ReleaseFences(bool force = true) = 0;
2022-11-05 13:58:44 +01:00
/// 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
2024-01-07 10:47:31 +01:00
virtual void FlushRegion(DAddr addr, u64 size,
2022-12-25 07:12:57 +01:00
VideoCommon::CacheType which = VideoCommon::CacheType::All) = 0;
2022-11-05 13:58:44 +01:00
/// Check if the the specified memory area requires flushing to CPU Memory.
2024-01-07 10:47:31 +01:00
virtual bool MustFlushRegion(DAddr addr, u64 size,
2022-12-25 07:12:57 +01:00
VideoCommon::CacheType which = VideoCommon::CacheType::All) = 0;
2022-11-05 13:58:44 +01:00
2024-01-07 10:47:31 +01:00
virtual RasterizerDownloadArea GetFlushArea(DAddr addr, u64 size) = 0;
2023-05-04 16:44:44 +02:00
2022-11-05 13:58:44 +01:00
/// Notify rasterizer that any caches of the specified region should be invalidated
2024-01-07 10:47:31 +01:00
virtual void InvalidateRegion(DAddr addr, u64 size,
2022-12-25 07:12:57 +01:00
VideoCommon::CacheType which = VideoCommon::CacheType::All) = 0;
2022-11-05 13:58:44 +01:00
2024-01-07 10:47:31 +01:00
virtual void InnerInvalidation(std::span<const std::pair<DAddr, std::size_t>> sequences) {
2023-01-06 04:23:54 +01:00
for (const auto& [cpu_addr, size] : sequences) {
InvalidateRegion(cpu_addr, size);
}
}
2022-11-05 13:58:44 +01:00
/// Notify rasterizer that any caches of the specified region are desync with guest
2024-01-07 10:47:31 +01:00
virtual void OnCacheInvalidation(PAddr addr, u64 size) = 0;
2023-06-29 17:22:15 +02:00
2024-01-07 10:47:31 +01:00
virtual bool OnCPUWrite(PAddr addr, u64 size) = 0;
2022-11-05 13:58:44 +01:00
/// Sync memory between guest and host.
virtual void InvalidateGPUCache() = 0;
/// Unmap memory range
2024-01-07 10:47:31 +01:00
virtual void UnmapMemory(DAddr addr, u64 size) = 0;
2022-11-05 13:58:44 +01:00
/// Remap GPU memory range. This means underneath backing memory changed
virtual void ModifyGPUMemory(size_t as_id, GPUVAddr addr, u64 size) = 0;
/// Notify rasterizer that any caches of the specified region should be flushed to Switch memory
/// and invalidated
2022-12-25 07:12:57 +01:00
virtual void FlushAndInvalidateRegion(
2024-01-07 10:47:31 +01:00
DAddr addr, u64 size, VideoCommon::CacheType which = VideoCommon::CacheType::All) = 0;
2022-11-05 13:58:44 +01:00
/// Notify the host renderer to wait for previous primitive and compute operations.
virtual void WaitForIdle() = 0;
/// Notify the host renderer to wait for reads and writes to render targets and flush caches.
virtual void FragmentBarrier() = 0;
/// Notify the host renderer to make available previous render target writes.
virtual void TiledCacheBarrier() = 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;
2022-12-25 07:12:57 +01:00
virtual bool AccelerateConditionalRendering() {
return false;
}
2022-11-05 13:58:44 +01:00
/// Attempt to use a faster method to perform a surface copy
[[nodiscard]] virtual bool AccelerateSurfaceCopy(
const Tegra::Engines::Fermi2D::Surface& src, const Tegra::Engines::Fermi2D::Surface& dst,
const Tegra::Engines::Fermi2D::Config& copy_config) {
return false;
}
[[nodiscard]] virtual Tegra::Engines::AccelerateDMAInterface& AccessAccelerateDMA() = 0;
virtual void AccelerateInlineToMemory(GPUVAddr address, size_t copy_size,
std::span<const u8> memory) = 0;
/// Initialize disk cached resources for the game being emulated
virtual void LoadDiskResources(u64 title_id, std::stop_token stop_loading,
const DiskResourceLoadCallback& callback) {}
virtual void InitializeChannel(Tegra::Control::ChannelState& channel) {}
virtual void BindChannel(Tegra::Control::ChannelState& channel) {}
virtual void ReleaseChannel(s32 channel_id) {}
2023-12-22 19:51:46 +01:00
/// Register the address as a Transform Feedback Object
virtual void RegisterTransformFeedback(GPUVAddr tfb_object_addr) {}
/// Returns true when the rasterizer has Draw Transform Feedback capabilities
virtual bool HasDrawTransformFeedback() {
return false;
}
2022-11-05 13:58:44 +01:00
};
} // namespace VideoCore