mirror of
				https://git.eden-emu.dev/eden-emu/eden.git
				synced 2025-10-25 00:17:48 +00:00 
			
		
		
		
	service/nvflinger: Move display specifics over to vi_display
With the display and layer structures relocated to the vi service, we can begin giving these a proper interface before beginning to properly support the display types. This converts the display struct into a class and provides it with the necessary functions to preserve behavior within the NVFlinger class.
This commit is contained in:
		
							parent
							
								
									aa49308c7e
								
							
						
					
					
						commit
						00b5069249
					
				
					 4 changed files with 141 additions and 35 deletions
				
			
		|  | @ -2,8 +2,12 @@ | |||
| // Licensed under GPLv2 or any later version
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include <algorithm> | ||||
| #include <utility> | ||||
| 
 | ||||
| #include <fmt/format.h> | ||||
| 
 | ||||
| #include "common/assert.h" | ||||
| #include "core/core.h" | ||||
| #include "core/hle/kernel/readable_event.h" | ||||
| #include "core/hle/service/vi/display/vi_display.h" | ||||
|  | @ -19,4 +23,49 @@ Display::Display(u64 id, std::string name) : id{id}, name{std::move(name)} { | |||
| 
 | ||||
| Display::~Display() = default; | ||||
| 
 | ||||
| Layer& Display::GetLayer(std::size_t index) { | ||||
|     return layers.at(index); | ||||
| } | ||||
| 
 | ||||
| const Layer& Display::GetLayer(std::size_t index) const { | ||||
|     return layers.at(index); | ||||
| } | ||||
| 
 | ||||
| Kernel::SharedPtr<Kernel::ReadableEvent> Display::GetVSyncEvent() const { | ||||
|     return vsync_event.readable; | ||||
| } | ||||
| 
 | ||||
| void Display::SignalVSyncEvent() { | ||||
|     vsync_event.writable->Signal(); | ||||
| } | ||||
| 
 | ||||
| void Display::CreateLayer(u64 id, std::shared_ptr<NVFlinger::BufferQueue> buffer_queue) { | ||||
|     // TODO(Subv): Support more than 1 layer.
 | ||||
|     ASSERT_MSG(layers.empty(), "Only one layer is supported per display at the moment"); | ||||
| 
 | ||||
|     layers.emplace_back(id, std::move(buffer_queue)); | ||||
| } | ||||
| 
 | ||||
| Layer* Display::FindLayer(u64 id) { | ||||
|     const auto itr = std::find_if(layers.begin(), layers.end(), | ||||
|                                   [id](const VI::Layer& layer) { return layer.id == id; }); | ||||
| 
 | ||||
|     if (itr == layers.end()) { | ||||
|         return nullptr; | ||||
|     } | ||||
| 
 | ||||
|     return &*itr; | ||||
| } | ||||
| 
 | ||||
| const Layer* Display::FindLayer(u64 id) const { | ||||
|     const auto itr = std::find_if(layers.begin(), layers.end(), | ||||
|                                   [id](const VI::Layer& layer) { return layer.id == id; }); | ||||
| 
 | ||||
|     if (itr == layers.end()) { | ||||
|         return nullptr; | ||||
|     } | ||||
| 
 | ||||
|     return &*itr; | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::VI
 | ||||
|  |  | |||
|  | @ -10,14 +10,84 @@ | |||
| #include "common/common_types.h" | ||||
| #include "core/hle/kernel/writable_event.h" | ||||
| 
 | ||||
| namespace Service::NVFlinger { | ||||
| class BufferQueue; | ||||
| } | ||||
| 
 | ||||
| namespace Service::VI { | ||||
| 
 | ||||
| struct Layer; | ||||
| 
 | ||||
| struct Display { | ||||
| /// Represents a single display type
 | ||||
| class Display { | ||||
| public: | ||||
|     /// Constructs a display with a given unique ID and name.
 | ||||
|     ///
 | ||||
|     /// @param id   The unique ID for this display.
 | ||||
|     /// @param name The name for this display.
 | ||||
|     ///
 | ||||
|     Display(u64 id, std::string name); | ||||
|     ~Display(); | ||||
| 
 | ||||
|     Display(const Display&) = delete; | ||||
|     Display& operator=(const Display&) = delete; | ||||
| 
 | ||||
|     Display(Display&&) = default; | ||||
|     Display& operator=(Display&&) = default; | ||||
| 
 | ||||
|     /// Gets the unique ID assigned to this display.
 | ||||
|     u64 GetID() const { | ||||
|         return id; | ||||
|     } | ||||
| 
 | ||||
|     /// Gets the name of this display
 | ||||
|     const std::string& GetName() const { | ||||
|         return name; | ||||
|     } | ||||
| 
 | ||||
|     /// Whether or not this display has any layers added to it.
 | ||||
|     bool HasLayers() const { | ||||
|         return !layers.empty(); | ||||
|     } | ||||
| 
 | ||||
|     /// Gets a layer for this display based off an index.
 | ||||
|     Layer& GetLayer(std::size_t index); | ||||
| 
 | ||||
|     /// Gets a layer for this display based off an index.
 | ||||
|     const Layer& GetLayer(std::size_t index) const; | ||||
| 
 | ||||
|     /// Gets the readable vsync event.
 | ||||
|     Kernel::SharedPtr<Kernel::ReadableEvent> GetVSyncEvent() const; | ||||
| 
 | ||||
|     /// Signals the internal vsync event.
 | ||||
|     void SignalVSyncEvent(); | ||||
| 
 | ||||
|     /// Creates and adds a layer to this display with the given ID.
 | ||||
|     ///
 | ||||
|     /// @param id           The ID to assign to the created layer.
 | ||||
|     /// @param buffer_queue The buffer queue for the layer instance to use.
 | ||||
|     ///
 | ||||
|     void CreateLayer(u64 id, std::shared_ptr<NVFlinger::BufferQueue> buffer_queue); | ||||
| 
 | ||||
|     /// Attempts to find a layer with the given ID.
 | ||||
|     ///
 | ||||
|     /// @param id The layer ID.
 | ||||
|     ///
 | ||||
|     /// @returns If found, the Layer instance with the given ID.
 | ||||
|     ///          If not found, then nullptr is returned.
 | ||||
|     ///
 | ||||
|     Layer* FindLayer(u64 id); | ||||
| 
 | ||||
|     /// Attempts to find a layer with the given ID.
 | ||||
|     ///
 | ||||
|     /// @param id The layer ID.
 | ||||
|     ///
 | ||||
|     /// @returns If found, the Layer instance with the given ID.
 | ||||
|     ///          If not found, then nullptr is returned.
 | ||||
|     ///
 | ||||
|     const Layer* FindLayer(u64 id) const; | ||||
| 
 | ||||
| private: | ||||
|     u64 id; | ||||
|     std::string name; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash