2018-03-19 20:00:59 -07:00
|
|
|
// Copyright 2018 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2019-01-21 11:38:23 -08:00
|
|
|
#include <atomic>
|
2019-01-19 20:03:26 -08:00
|
|
|
#include <functional>
|
2019-11-27 21:15:34 -08:00
|
|
|
#include <optional>
|
2018-03-19 20:00:59 -07:00
|
|
|
#include "common/common_types.h"
|
2018-10-05 20:39:03 -07:00
|
|
|
#include "video_core/engines/fermi_2d.h"
|
2018-03-22 18:04:30 -07:00
|
|
|
#include "video_core/gpu.h"
|
2020-01-03 12:16:29 -08:00
|
|
|
#include "video_core/guest_driver.h"
|
2018-03-19 20:00:59 -07:00
|
|
|
|
2019-05-07 07:55:18 -07:00
|
|
|
namespace Tegra {
|
|
|
|
class MemoryManager;
|
|
|
|
}
|
|
|
|
|
2018-03-19 20:00:59 -07:00
|
|
|
namespace VideoCore {
|
|
|
|
|
2019-07-27 15:40:10 -07:00
|
|
|
enum class QueryType {
|
|
|
|
SamplesPassed,
|
|
|
|
};
|
2019-11-26 13:52:15 -08:00
|
|
|
constexpr std::size_t NumQueryTypes = 1;
|
2019-07-27 15:40:10 -07:00
|
|
|
|
2019-01-19 20:03:26 -08:00
|
|
|
enum class LoadCallbackStage {
|
|
|
|
Prepare,
|
2019-01-20 17:40:25 -08:00
|
|
|
Build,
|
2019-01-19 20:03:26 -08:00
|
|
|
Complete,
|
|
|
|
};
|
|
|
|
using DiskResourceLoadCallback = std::function<void(LoadCallbackStage, std::size_t, std::size_t)>;
|
|
|
|
|
2018-03-19 20:00:59 -07:00
|
|
|
class RasterizerInterface {
|
|
|
|
public:
|
2020-11-17 04:17:43 -08:00
|
|
|
virtual ~RasterizerInterface() = default;
|
2018-03-19 20:00:59 -07:00
|
|
|
|
2020-02-14 13:09:37 -08:00
|
|
|
/// Dispatches a draw invocation
|
|
|
|
virtual void Draw(bool is_indexed, bool is_instanced) = 0;
|
2019-09-15 08:48:54 -07:00
|
|
|
|
2018-06-06 21:54:25 -07:00
|
|
|
/// Clear the current framebuffer
|
|
|
|
virtual void Clear() = 0;
|
|
|
|
|
2019-07-14 18:25:13 -07:00
|
|
|
/// Dispatches a compute shader invocation
|
|
|
|
virtual void DispatchCompute(GPUVAddr code_addr) = 0;
|
|
|
|
|
2019-07-27 15:40:10 -07:00
|
|
|
/// Resets the counter of a query
|
|
|
|
virtual void ResetCounter(QueryType type) = 0;
|
|
|
|
|
2019-11-26 13:52:15 -08:00
|
|
|
/// Records a GPU query and caches it
|
2019-11-27 21:15:34 -08:00
|
|
|
virtual void Query(GPUVAddr gpu_addr, QueryType type, std::optional<u64> timestamp) = 0;
|
2019-07-27 15:40:10 -07:00
|
|
|
|
2020-02-19 09:40:37 -08:00
|
|
|
/// Signal a GPU based semaphore as a fence
|
|
|
|
virtual void SignalSemaphore(GPUVAddr addr, u32 value) = 0;
|
|
|
|
|
|
|
|
/// Signal a GPU based syncpoint as a fence
|
|
|
|
virtual void SignalSyncPoint(u32 value) = 0;
|
2020-02-17 14:10:23 -08:00
|
|
|
|
2020-02-18 09:24:38 -08:00
|
|
|
/// Release all pending fences.
|
|
|
|
virtual void ReleaseFences() = 0;
|
2020-02-17 14:10:23 -08:00
|
|
|
|
2018-04-04 14:07:58 -07:00
|
|
|
/// Notify rasterizer that all caches should be flushed to Switch memory
|
2018-03-19 20:00:59 -07:00
|
|
|
virtual void FlushAll() = 0;
|
|
|
|
|
2018-04-04 14:07:58 -07:00
|
|
|
/// Notify rasterizer that any caches of the specified region should be flushed to Switch memory
|
2020-04-05 09:58:23 -07:00
|
|
|
virtual void FlushRegion(VAddr addr, u64 size) = 0;
|
2018-03-19 20:00:59 -07:00
|
|
|
|
2020-04-16 09:29:53 -07:00
|
|
|
/// Check if the the specified memory area requires flushing to CPU Memory.
|
2020-02-17 18:29:04 -08:00
|
|
|
virtual bool MustFlushRegion(VAddr addr, u64 size) = 0;
|
|
|
|
|
2018-03-19 20:00:59 -07:00
|
|
|
/// Notify rasterizer that any caches of the specified region should be invalidated
|
2020-04-05 09:58:23 -07:00
|
|
|
virtual void InvalidateRegion(VAddr addr, u64 size) = 0;
|
2018-03-19 20:00:59 -07:00
|
|
|
|
2020-02-16 05:51:37 -08:00
|
|
|
/// Notify rasterizer that any caches of the specified region are desync with guest
|
|
|
|
virtual void OnCPUWrite(VAddr addr, u64 size) = 0;
|
|
|
|
|
|
|
|
/// Sync memory between guest and host.
|
|
|
|
virtual void SyncGuestHost() = 0;
|
|
|
|
|
2020-12-29 21:25:23 -08:00
|
|
|
/// Unmap memory range
|
|
|
|
virtual void UnmapMemory(VAddr addr, u64 size) = 0;
|
|
|
|
|
2018-04-04 14:07:58 -07:00
|
|
|
/// Notify rasterizer that any caches of the specified region should be flushed to Switch memory
|
2018-03-19 20:00:59 -07:00
|
|
|
/// and invalidated
|
2020-04-05 09:58:23 -07:00
|
|
|
virtual void FlushAndInvalidateRegion(VAddr addr, u64 size) = 0;
|
2018-03-19 20:00:59 -07:00
|
|
|
|
2020-04-27 22:14:11 -07:00
|
|
|
/// Notify the host renderer to wait for previous primitive and compute operations.
|
|
|
|
virtual void WaitForIdle() = 0;
|
|
|
|
|
2020-12-29 21:25:23 -08:00
|
|
|
/// 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;
|
|
|
|
|
2019-08-30 11:08:00 -07:00
|
|
|
/// Notify the rasterizer to send all written commands to the host GPU.
|
2019-07-26 11:20:43 -07:00
|
|
|
virtual void FlushCommands() = 0;
|
|
|
|
|
2019-06-19 23:22:25 -07:00
|
|
|
/// Notify rasterizer that a frame is about to finish
|
|
|
|
virtual void TickFrame() = 0;
|
|
|
|
|
2018-10-05 20:39:03 -07:00
|
|
|
/// Attempt to use a faster method to perform a surface copy
|
2020-11-17 04:17:43 -08:00
|
|
|
[[nodiscard]] virtual bool AccelerateSurfaceCopy(
|
2020-12-29 21:25:23 -08:00
|
|
|
const Tegra::Engines::Fermi2D::Surface& src, const Tegra::Engines::Fermi2D::Surface& dst,
|
2020-11-17 04:17:43 -08:00
|
|
|
const Tegra::Engines::Fermi2D::Config& copy_config) {
|
2018-03-19 20:00:59 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Attempt to use a faster method to display the framebuffer to screen
|
2020-11-17 04:17:43 -08:00
|
|
|
[[nodiscard]] virtual bool AccelerateDisplay(const Tegra::FramebufferConfig& config,
|
|
|
|
VAddr framebuffer_addr, u32 pixel_stride) {
|
2018-03-19 20:00:59 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-08-28 15:43:08 -07:00
|
|
|
/// Increase/decrease the number of object in pages touching the specified region
|
2019-02-18 17:58:32 -08:00
|
|
|
virtual void UpdatePagesCachedCount(VAddr addr, u64 size, int delta) {}
|
2019-01-13 17:05:53 -08:00
|
|
|
|
|
|
|
/// Initialize disk cached resources for the game being emulated
|
2020-06-11 17:24:45 -07:00
|
|
|
virtual void LoadDiskResources(u64 title_id, const std::atomic_bool& stop_loading,
|
|
|
|
const DiskResourceLoadCallback& callback) {}
|
2019-12-26 17:14:10 -08:00
|
|
|
|
2020-01-08 07:46:36 -08:00
|
|
|
/// Grant access to the Guest Driver Profile for recording/obtaining info on the guest driver.
|
2020-11-17 04:17:43 -08:00
|
|
|
[[nodiscard]] GuestDriverProfile& AccessGuestDriverProfile() {
|
2020-01-03 12:16:29 -08:00
|
|
|
return guest_driver_profile;
|
|
|
|
}
|
|
|
|
|
2020-01-08 07:46:36 -08:00
|
|
|
/// Grant access to the Guest Driver Profile for recording/obtaining info on the guest driver.
|
2020-11-17 04:17:43 -08:00
|
|
|
[[nodiscard]] const GuestDriverProfile& AccessGuestDriverProfile() const {
|
2020-01-08 06:28:29 -08:00
|
|
|
return guest_driver_profile;
|
|
|
|
}
|
|
|
|
|
2020-01-03 12:16:29 -08:00
|
|
|
private:
|
|
|
|
GuestDriverProfile guest_driver_profile{};
|
2018-03-19 20:00:59 -07:00
|
|
|
};
|
|
|
|
} // namespace VideoCore
|