| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | // Copyright 2018 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "common/bit_field.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-10-26 23:07:36 -04:00
										 |  |  | #include "video_core/cdma_pusher.h"
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  | #include "video_core/framebuffer_config.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-15 22:05:17 -05:00
										 |  |  | namespace Core { | 
					
						
							| 
									
										
										
										
											2020-03-24 20:58:49 -06:00
										 |  |  | class System; | 
					
						
							|  |  |  | } // namespace Core
 | 
					
						
							| 
									
										
										
										
											2019-02-15 22:05:17 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  | namespace VideoCore { | 
					
						
							| 
									
										
										
										
											2019-01-07 23:32:02 -05:00
										 |  |  | class RendererBase; | 
					
						
							| 
									
										
										
										
											2020-07-10 13:36:38 +10:00
										 |  |  | class ShaderNotify; | 
					
						
							| 
									
										
										
										
											2019-01-07 23:32:02 -05:00
										 |  |  | } // namespace VideoCore
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | namespace Tegra { | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  | class DmaPusher; | 
					
						
							|  |  |  | struct CommandList; | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-24 00:45:24 -04:00
										 |  |  | enum class RenderTargetFormat : u32 { | 
					
						
							| 
									
										
										
										
											2018-03-25 17:57:53 -04:00
										 |  |  |     NONE = 0x0, | 
					
						
							| 
									
										
										
										
											2020-07-01 02:28:53 -03:00
										 |  |  |     R32B32G32A32_FLOAT = 0xC0, | 
					
						
							|  |  |  |     R32G32B32A32_SINT = 0xC1, | 
					
						
							|  |  |  |     R32G32B32A32_UINT = 0xC2, | 
					
						
							|  |  |  |     R16G16B16A16_UNORM = 0xC6, | 
					
						
							|  |  |  |     R16G16B16A16_SNORM = 0xC7, | 
					
						
							|  |  |  |     R16G16B16A16_SINT = 0xC8, | 
					
						
							|  |  |  |     R16G16B16A16_UINT = 0xC9, | 
					
						
							|  |  |  |     R16G16B16A16_FLOAT = 0xCA, | 
					
						
							|  |  |  |     R32G32_FLOAT = 0xCB, | 
					
						
							|  |  |  |     R32G32_SINT = 0xCC, | 
					
						
							|  |  |  |     R32G32_UINT = 0xCD, | 
					
						
							|  |  |  |     R16G16B16X16_FLOAT = 0xCE, | 
					
						
							|  |  |  |     B8G8R8A8_UNORM = 0xCF, | 
					
						
							|  |  |  |     B8G8R8A8_SRGB = 0xD0, | 
					
						
							|  |  |  |     A2B10G10R10_UNORM = 0xD1, | 
					
						
							|  |  |  |     A2B10G10R10_UINT = 0xD2, | 
					
						
							|  |  |  |     A8B8G8R8_UNORM = 0xD5, | 
					
						
							|  |  |  |     A8B8G8R8_SRGB = 0xD6, | 
					
						
							|  |  |  |     A8B8G8R8_SNORM = 0xD7, | 
					
						
							|  |  |  |     A8B8G8R8_SINT = 0xD8, | 
					
						
							|  |  |  |     A8B8G8R8_UINT = 0xD9, | 
					
						
							|  |  |  |     R16G16_UNORM = 0xDA, | 
					
						
							|  |  |  |     R16G16_SNORM = 0xDB, | 
					
						
							|  |  |  |     R16G16_SINT = 0xDC, | 
					
						
							|  |  |  |     R16G16_UINT = 0xDD, | 
					
						
							|  |  |  |     R16G16_FLOAT = 0xDE, | 
					
						
							|  |  |  |     B10G11R11_FLOAT = 0xE0, | 
					
						
							| 
									
										
										
										
											2020-02-25 17:19:34 -03:00
										 |  |  |     R32_SINT = 0xE3, | 
					
						
							| 
									
										
										
										
											2018-08-13 22:55:16 +10:00
										 |  |  |     R32_UINT = 0xE4, | 
					
						
							| 
									
										
										
										
											2018-08-01 15:31:42 +02:00
										 |  |  |     R32_FLOAT = 0xE5, | 
					
						
							| 
									
										
										
										
											2020-07-01 02:28:53 -03:00
										 |  |  |     R5G6B5_UNORM = 0xE8, | 
					
						
							|  |  |  |     A1R5G5B5_UNORM = 0xE9, | 
					
						
							|  |  |  |     R8G8_UNORM = 0xEA, | 
					
						
							|  |  |  |     R8G8_SNORM = 0xEB, | 
					
						
							|  |  |  |     R8G8_SINT = 0xEC, | 
					
						
							|  |  |  |     R8G8_UINT = 0xED, | 
					
						
							| 
									
										
										
										
											2018-08-11 20:01:50 +02:00
										 |  |  |     R16_UNORM = 0xEE, | 
					
						
							|  |  |  |     R16_SNORM = 0xEF, | 
					
						
							|  |  |  |     R16_SINT = 0xF0, | 
					
						
							|  |  |  |     R16_UINT = 0xF1, | 
					
						
							| 
									
										
										
										
											2018-07-25 23:19:15 -05:00
										 |  |  |     R16_FLOAT = 0xF2, | 
					
						
							| 
									
										
										
										
											2018-07-24 16:47:50 -05:00
										 |  |  |     R8_UNORM = 0xF3, | 
					
						
							| 
									
										
										
										
											2020-06-30 03:51:42 -03:00
										 |  |  |     R8_SNORM = 0xF4, | 
					
						
							| 
									
										
										
										
											2020-06-30 04:00:23 -03:00
										 |  |  |     R8_SINT = 0xF5, | 
					
						
							| 
									
										
										
										
											2018-08-12 03:44:42 +02:00
										 |  |  |     R8_UINT = 0xF6, | 
					
						
							| 
									
										
										
										
											2018-03-22 16:40:11 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 12:42:04 -05:00
										 |  |  | enum class DepthFormat : u32 { | 
					
						
							| 
									
										
										
										
											2020-07-01 02:28:53 -03:00
										 |  |  |     D32_FLOAT = 0xA, | 
					
						
							|  |  |  |     D16_UNORM = 0x13, | 
					
						
							|  |  |  |     S8_UINT_Z24_UNORM = 0x14, | 
					
						
							|  |  |  |     D24X8_UNORM = 0x15, | 
					
						
							|  |  |  |     D24S8_UNORM = 0x16, | 
					
						
							| 
									
										
										
										
											2021-11-17 15:04:38 -05:00
										 |  |  |     S8_UINT = 0x17, | 
					
						
							| 
									
										
										
										
											2020-07-01 02:28:53 -03:00
										 |  |  |     D24C8_UNORM = 0x18, | 
					
						
							|  |  |  |     D32_FLOAT_S8X24_UINT = 0x19, | 
					
						
							| 
									
										
										
										
											2018-07-02 12:42:04 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-18 15:15:05 -05:00
										 |  |  | namespace Engines { | 
					
						
							|  |  |  | class Maxwell3D; | 
					
						
							| 
									
										
										
										
											2019-01-22 20:49:31 -03:00
										 |  |  | class KeplerCompute; | 
					
						
							| 
									
										
										
										
											2018-03-18 15:15:05 -05:00
										 |  |  | } // namespace Engines
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | enum class EngineID { | 
					
						
							|  |  |  |     FERMI_TWOD_A = 0x902D, // 2D Engine
 | 
					
						
							|  |  |  |     MAXWELL_B = 0xB197,    // 3D Engine
 | 
					
						
							| 
									
										
										
										
											2019-01-22 20:49:31 -03:00
										 |  |  |     KEPLER_COMPUTE_B = 0xB1C0, | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  |     KEPLER_INLINE_TO_MEMORY_B = 0xA140, | 
					
						
							|  |  |  |     MAXWELL_DMA_COPY_A = 0xB0B5, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-03 23:54:16 -05:00
										 |  |  | class MemoryManager; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  | class GPU final { | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2018-11-23 23:20:56 -05:00
										 |  |  |     struct MethodCall { | 
					
						
							|  |  |  |         u32 method{}; | 
					
						
							|  |  |  |         u32 argument{}; | 
					
						
							|  |  |  |         u32 subchannel{}; | 
					
						
							|  |  |  |         u32 method_count{}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-04 14:39:12 -05:00
										 |  |  |         explicit MethodCall(u32 method_, u32 argument_, u32 subchannel_ = 0, u32 method_count_ = 0) | 
					
						
							|  |  |  |             : method(method_), argument(argument_), subchannel(subchannel_), | 
					
						
							|  |  |  |               method_count(method_count_) {} | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |         [[nodiscard]] bool IsLastCall() const { | 
					
						
							|  |  |  |             return method_count <= 1; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-11-23 23:20:56 -05:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     enum class FenceOperation : u32 { | 
					
						
							|  |  |  |         Acquire = 0, | 
					
						
							|  |  |  |         Increment = 1, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     union FenceAction { | 
					
						
							|  |  |  |         u32 raw; | 
					
						
							|  |  |  |         BitField<0, 1, FenceOperation> op; | 
					
						
							|  |  |  |         BitField<8, 24, u32> syncpoint_id; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     explicit GPU(Core::System& system, bool is_async, bool use_nvdec); | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     ~GPU(); | 
					
						
							| 
									
										
										
										
											2020-06-11 00:58:57 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Binds a renderer to the GPU.
 | 
					
						
							|  |  |  |     void BindRenderer(std::unique_ptr<VideoCore::RendererBase> renderer); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-23 23:20:56 -05:00
										 |  |  |     /// Calls a GPU method.
 | 
					
						
							|  |  |  |     void CallMethod(const MethodCall& method_call); | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-20 02:16:56 -04:00
										 |  |  |     /// Calls a GPU multivalue method.
 | 
					
						
							| 
									
										
										
										
											2020-04-20 13:42:14 -04:00
										 |  |  |     void CallMultiMethod(u32 method, u32 subchannel, const u32* base_start, u32 amount, | 
					
						
							|  |  |  |                          u32 methods_pending); | 
					
						
							| 
									
										
										
										
											2020-04-20 02:16:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-16 12:29:53 -04:00
										 |  |  |     /// Flush all current written commands into the host GPU for execution.
 | 
					
						
							| 
									
										
										
										
											2019-07-26 14:20:43 -04:00
										 |  |  |     void FlushCommands(); | 
					
						
							| 
									
										
										
										
											2020-04-16 12:29:53 -04:00
										 |  |  |     /// Synchronizes CPU writes with Host GPU memory.
 | 
					
						
							| 
									
										
										
										
											2020-02-16 09:51:37 -04:00
										 |  |  |     void SyncGuestHost(); | 
					
						
							| 
									
										
										
										
											2020-04-16 12:29:53 -04:00
										 |  |  |     /// Signal the ending of command list.
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void OnCommandListEnd(); | 
					
						
							| 
									
										
										
										
											2019-07-26 14:20:43 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-16 12:29:53 -04:00
										 |  |  |     /// Request a host GPU memory flush from the CPU.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] u64 RequestFlush(VAddr addr, std::size_t size); | 
					
						
							| 
									
										
										
										
											2020-02-20 11:55:32 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-16 12:29:53 -04:00
										 |  |  |     /// Obtains current flush request fence id.
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     [[nodiscard]] u64 CurrentFlushRequestFence() const; | 
					
						
							| 
									
										
										
										
											2020-02-20 11:55:32 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-16 12:29:53 -04:00
										 |  |  |     /// Tick pending requests within the GPU.
 | 
					
						
							| 
									
										
										
										
											2020-02-20 11:55:32 -04:00
										 |  |  |     void TickWork(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 10:57:56 -04:00
										 |  |  |     /// Returns a reference to the Maxwell3D GPU engine.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] Engines::Maxwell3D& Maxwell3D(); | 
					
						
							| 
									
										
										
										
											2018-08-28 10:57:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-20 18:31:36 -04:00
										 |  |  |     /// Returns a const reference to the Maxwell3D GPU engine.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] const Engines::Maxwell3D& Maxwell3D() const; | 
					
						
							| 
									
										
										
										
											2018-07-20 18:31:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-14 22:25:13 -03:00
										 |  |  |     /// Returns a reference to the KeplerCompute GPU engine.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] Engines::KeplerCompute& KeplerCompute(); | 
					
						
							| 
									
										
										
										
											2019-07-14 22:25:13 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Returns a reference to the KeplerCompute GPU engine.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] const Engines::KeplerCompute& KeplerCompute() const; | 
					
						
							| 
									
										
										
										
											2019-07-14 22:25:13 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 10:57:56 -04:00
										 |  |  |     /// Returns a reference to the GPU memory manager.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] Tegra::MemoryManager& MemoryManager(); | 
					
						
							| 
									
										
										
										
											2018-03-22 15:19:35 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 10:57:56 -04:00
										 |  |  |     /// Returns a const reference to the GPU memory manager.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] const Tegra::MemoryManager& MemoryManager() const; | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-23 23:20:56 -05:00
										 |  |  |     /// Returns a reference to the GPU DMA pusher.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] Tegra::DmaPusher& DmaPusher(); | 
					
						
							| 
									
										
										
										
											2018-11-23 23:20:56 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-26 23:07:36 -04:00
										 |  |  |     /// Returns a const reference to the GPU DMA pusher.
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] const Tegra::DmaPusher& DmaPusher() const; | 
					
						
							| 
									
										
										
										
											2020-10-26 23:07:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     /// Returns a reference to the underlying renderer.
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     [[nodiscard]] VideoCore::RendererBase& Renderer(); | 
					
						
							| 
									
										
										
										
											2020-03-24 20:58:49 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     /// Returns a const reference to the underlying renderer.
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     [[nodiscard]] const VideoCore::RendererBase& Renderer() const; | 
					
						
							| 
									
										
										
										
											2020-03-24 20:58:49 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     /// Returns a reference to the shader notifier.
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     [[nodiscard]] VideoCore::ShaderNotify& ShaderNotify(); | 
					
						
							| 
									
										
										
										
											2020-07-10 13:36:38 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     /// Returns a const reference to the shader notifier.
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     [[nodiscard]] const VideoCore::ShaderNotify& ShaderNotify() const; | 
					
						
							| 
									
										
										
										
											2020-07-10 13:36:38 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-25 19:43:23 -04:00
										 |  |  |     /// Allows the CPU/NvFlinger to wait on the GPU before presenting a frame.
 | 
					
						
							| 
									
										
										
										
											2022-01-03 20:28:54 -05:00
										 |  |  |     void WaitFence(u32 syncpoint_id, u32 value); | 
					
						
							| 
									
										
										
										
											2019-09-25 19:43:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-18 20:53:21 -04:00
										 |  |  |     void IncrementSyncPoint(u32 syncpoint_id); | 
					
						
							| 
									
										
										
										
											2019-06-07 12:56:30 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] u32 GetSyncpointValue(u32 syncpoint_id) const; | 
					
						
							| 
									
										
										
										
											2019-06-07 12:56:30 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-18 20:53:21 -04:00
										 |  |  |     void RegisterSyncptInterrupt(u32 syncpoint_id, u32 value); | 
					
						
							| 
									
										
										
										
											2019-06-07 21:13:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] bool CancelSyncptInterrupt(u32 syncpoint_id, u32 value); | 
					
						
							| 
									
										
										
										
											2019-06-07 12:56:30 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-17 07:14:44 -05:00
										 |  |  |     [[nodiscard]] u64 GetTicks() const; | 
					
						
							| 
									
										
										
										
											2020-02-10 10:32:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     [[nodiscard]] bool IsAsync() const; | 
					
						
							| 
									
										
										
										
											2019-06-10 08:19:27 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     [[nodiscard]] bool UseNvdec() const; | 
					
						
							| 
									
										
										
										
											2018-11-23 23:20:56 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-15 20:34:20 -04:00
										 |  |  |     void RendererFrameEndNotify(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-09 14:02:00 -04:00
										 |  |  |     /// Performs any additional setup necessary in order to begin GPU emulation.
 | 
					
						
							|  |  |  |     /// This can be used to launch any necessary threads and register any necessary
 | 
					
						
							|  |  |  |     /// core timing events.
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void Start(); | 
					
						
							| 
									
										
										
										
											2019-04-09 14:02:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-03 20:31:51 -05:00
										 |  |  |     /// Performs any additional necessary steps to shutdown GPU emulation.
 | 
					
						
							|  |  |  |     void NotifyShutdown(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 11:58:43 -04:00
										 |  |  |     /// Obtain the CPU Context
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void ObtainContext(); | 
					
						
							| 
									
										
										
										
											2020-04-03 11:58:43 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Release the CPU Context
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void ReleaseContext(); | 
					
						
							| 
									
										
										
										
											2020-04-03 11:58:43 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-21 15:18:09 -05:00
										 |  |  |     /// Push GPU command entries to be processed
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void PushGPUEntries(Tegra::CommandList&& entries); | 
					
						
							| 
									
										
										
										
											2019-01-21 15:18:09 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-26 23:07:36 -04:00
										 |  |  |     /// Push GPU command buffer entries to be processed
 | 
					
						
							| 
									
										
										
										
											2021-12-02 12:19:43 +08:00
										 |  |  |     void PushCommandBuffer(u32 id, Tegra::ChCommandHeaderList& entries); | 
					
						
							| 
									
										
										
										
											2020-10-26 23:07:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-24 19:22:09 -04:00
										 |  |  |     /// Frees the CDMAPusher instance to free up resources
 | 
					
						
							| 
									
										
										
										
											2021-12-02 12:19:43 +08:00
										 |  |  |     void ClearCdmaInstance(u32 id); | 
					
						
							| 
									
										
										
										
											2021-03-30 20:37:40 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-21 15:18:09 -05:00
										 |  |  |     /// Swap buffers (render frame)
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void SwapBuffers(const Tegra::FramebufferConfig* framebuffer); | 
					
						
							| 
									
										
										
										
											2019-01-29 18:49:18 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-23 22:17:55 -05:00
										 |  |  |     /// Notify rasterizer that any caches of the specified region should be flushed to Switch memory
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void FlushRegion(VAddr addr, u64 size); | 
					
						
							| 
									
										
										
										
											2019-01-23 22:17:55 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Notify rasterizer that any caches of the specified region should be invalidated
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void InvalidateRegion(VAddr addr, u64 size); | 
					
						
							| 
									
										
										
										
											2019-01-23 22:17:55 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Notify rasterizer that any caches of the specified region should be flushed and invalidated
 | 
					
						
							| 
									
										
										
										
											2020-12-11 22:26:14 -08:00
										 |  |  |     void FlushAndInvalidateRegion(VAddr addr, u64 size); | 
					
						
							| 
									
										
										
										
											2019-01-23 22:17:55 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-08 23:21:53 -05:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2021-10-01 00:57:02 -04:00
										 |  |  |     struct Impl; | 
					
						
							|  |  |  |     std::unique_ptr<Impl> impl; | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Tegra
 |