// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project // SPDX-License-Identifier: GPL-3.0-or-later // SPDX-FileCopyrightText: Copyright 2020 yuzu Emulator Project // SPDX-License-Identifier: GPL-2.0-or-later #pragma once #include #include #include #include "common/common_types.h" namespace Core { class System; } namespace Tegra::Engines { enum class EngineTypes : u32 { Nv01Timer, KeplerCompute, Maxwell3D, Fermi2D, MaxwellDMA, KeplerMemory, }; class EngineInterface { public: virtual ~EngineInterface() = default; /// Write the value to the register identified by method. virtual void CallMethod(Core::System& system, u32 method, u32 method_argument, bool is_last_call) = 0; /// Write multiple values to the register identified by method. virtual void CallMultiMethod(Core::System& system, u32 method, const u32* base_start, u32 amount, u32 methods_pending) = 0; void ConsumeSink(Core::System& system) { if (!method_sink.empty()) { ConsumeSinkImpl(system); } } std::bitset<(std::numeric_limits::max)()> execution_mask{}; std::vector> method_sink{}; GPUVAddr current_dma_segment; bool current_dirty{}; protected: virtual void ConsumeSinkImpl(Core::System& system) { for (auto [method, value] : method_sink) { CallMethod(system, method, value, true); } method_sink.clear(); } }; } // namespace Tegra::Engines