forked from eden-emu/eden
		
	general: Replace NonCopyable struct with equivalents
This commit is contained in:
		
							parent
							
								
									76d83ffbec
								
							
						
					
					
						commit
						f785f73e92
					
				
					 12 changed files with 219 additions and 129 deletions
				
			
		|  | @ -8,6 +8,7 @@ | ||||||
| #include <map> | #include <map> | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <string> | #include <string> | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| 
 | 
 | ||||||
| namespace Common::Telemetry { | namespace Common::Telemetry { | ||||||
|  | @ -28,7 +29,7 @@ struct VisitorInterface; | ||||||
| /**
 | /**
 | ||||||
|  * Interface class for telemetry data fields. |  * Interface class for telemetry data fields. | ||||||
|  */ |  */ | ||||||
| class FieldInterface : NonCopyable { | class FieldInterface { | ||||||
| public: | public: | ||||||
|     virtual ~FieldInterface() = default; |     virtual ~FieldInterface() = default; | ||||||
| 
 | 
 | ||||||
|  | @ -52,14 +53,15 @@ public: | ||||||
| template <typename T> | template <typename T> | ||||||
| class Field : public FieldInterface { | class Field : public FieldInterface { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(Field); | ||||||
|  | 
 | ||||||
|     Field(FieldType type_, std::string name_, T value_) |     Field(FieldType type_, std::string name_, T value_) | ||||||
|         : name(std::move(name_)), type(type_), value(std::move(value_)) {} |         : name(std::move(name_)), type(type_), value(std::move(value_)) {} | ||||||
| 
 | 
 | ||||||
|     Field(const Field&) = default; |     ~Field() override = default; | ||||||
|     Field& operator=(const Field&) = default; |  | ||||||
| 
 | 
 | ||||||
|     Field(Field&&) = default; |     Field(Field&&) noexcept = default; | ||||||
|     Field& operator=(Field&& other) = default; |     Field& operator=(Field&& other) noexcept = default; | ||||||
| 
 | 
 | ||||||
|     void Accept(VisitorInterface& visitor) const override; |     void Accept(VisitorInterface& visitor) const override; | ||||||
| 
 | 
 | ||||||
|  | @ -98,9 +100,15 @@ private: | ||||||
| /**
 | /**
 | ||||||
|  * Collection of data fields that have been logged. |  * Collection of data fields that have been logged. | ||||||
|  */ |  */ | ||||||
| class FieldCollection final : NonCopyable { | class FieldCollection final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(FieldCollection); | ||||||
|  | 
 | ||||||
|     FieldCollection() = default; |     FieldCollection() = default; | ||||||
|  |     ~FieldCollection() = default; | ||||||
|  | 
 | ||||||
|  |     FieldCollection(FieldCollection&&) noexcept = default; | ||||||
|  |     FieldCollection& operator=(FieldCollection&&) noexcept = default; | ||||||
| 
 | 
 | ||||||
|     /**
 |     /**
 | ||||||
|      * Accept method for the visitor pattern, visits each field in the collection. |      * Accept method for the visitor pattern, visits each field in the collection. | ||||||
|  | @ -133,7 +141,7 @@ private: | ||||||
|  * Telemetry fields visitor interface class. A backend to log to a web service should implement |  * Telemetry fields visitor interface class. A backend to log to a web service should implement | ||||||
|  * this interface. |  * this interface. | ||||||
|  */ |  */ | ||||||
| struct VisitorInterface : NonCopyable { | struct VisitorInterface { | ||||||
|     virtual ~VisitorInterface() = default; |     virtual ~VisitorInterface() = default; | ||||||
| 
 | 
 | ||||||
|     virtual void Visit(const Field<bool>& field) = 0; |     virtual void Visit(const Field<bool>& field) = 0; | ||||||
|  | @ -160,8 +168,8 @@ struct VisitorInterface : NonCopyable { | ||||||
|  * Empty implementation of VisitorInterface that drops all fields. Used when a functional |  * Empty implementation of VisitorInterface that drops all fields. Used when a functional | ||||||
|  * backend implementation is not available. |  * backend implementation is not available. | ||||||
|  */ |  */ | ||||||
| struct NullVisitor : public VisitorInterface { | struct NullVisitor final : public VisitorInterface { | ||||||
|     ~NullVisitor() = default; |     YUZU_NON_COPYABLE(NullVisitor); | ||||||
| 
 | 
 | ||||||
|     void Visit(const Field<bool>& /*field*/) override {} |     void Visit(const Field<bool>& /*field*/) override {} | ||||||
|     void Visit(const Field<double>& /*field*/) override {} |     void Visit(const Field<double>& /*field*/) override {} | ||||||
|  |  | ||||||
|  | @ -6,6 +6,7 @@ | ||||||
| 
 | 
 | ||||||
| #include <array> | #include <array> | ||||||
| #include <vector> | #include <vector> | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/hardware_properties.h" | #include "core/hardware_properties.h" | ||||||
| 
 | 
 | ||||||
|  | @ -24,8 +25,11 @@ class CPUInterruptHandler; | ||||||
| using CPUInterrupts = std::array<CPUInterruptHandler, Core::Hardware::NUM_CPU_CORES>; | using CPUInterrupts = std::array<CPUInterruptHandler, Core::Hardware::NUM_CPU_CORES>; | ||||||
| 
 | 
 | ||||||
| /// Generic ARMv8 CPU interface
 | /// Generic ARMv8 CPU interface
 | ||||||
| class ARM_Interface : NonCopyable { | class ARM_Interface { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(ARM_Interface); | ||||||
|  |     YUZU_NON_MOVEABLE(ARM_Interface); | ||||||
|  | 
 | ||||||
|     explicit ARM_Interface(System& system_, CPUInterrupts& interrupt_handlers_, |     explicit ARM_Interface(System& system_, CPUInterrupts& interrupt_handlers_, | ||||||
|                            bool uses_wall_clock_) |                            bool uses_wall_clock_) | ||||||
|         : system{system_}, interrupt_handlers{interrupt_handlers_}, uses_wall_clock{ |         : system{system_}, interrupt_handlers{interrupt_handlers_}, uses_wall_clock{ | ||||||
|  |  | ||||||
|  | @ -12,6 +12,7 @@ | ||||||
| #include <type_traits> | #include <type_traits> | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/file_sys/vfs_types.h" | #include "core/file_sys/vfs_types.h" | ||||||
| 
 | 
 | ||||||
|  | @ -29,8 +30,11 @@ enum class VfsEntryType { | ||||||
| // A class representing an abstract filesystem. A default implementation given the root VirtualDir
 | // A class representing an abstract filesystem. A default implementation given the root VirtualDir
 | ||||||
| // is provided for convenience, but if the Vfs implementation has any additional state or
 | // is provided for convenience, but if the Vfs implementation has any additional state or
 | ||||||
| // functionality, they will need to override.
 | // functionality, they will need to override.
 | ||||||
| class VfsFilesystem : NonCopyable { | class VfsFilesystem { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(VfsFilesystem); | ||||||
|  |     YUZU_NON_MOVEABLE(VfsFilesystem); | ||||||
|  | 
 | ||||||
|     explicit VfsFilesystem(VirtualDir root); |     explicit VfsFilesystem(VirtualDir root); | ||||||
|     virtual ~VfsFilesystem(); |     virtual ~VfsFilesystem(); | ||||||
| 
 | 
 | ||||||
|  | @ -77,8 +81,12 @@ protected: | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // A class representing a file in an abstract filesystem.
 | // A class representing a file in an abstract filesystem.
 | ||||||
| class VfsFile : NonCopyable { | class VfsFile { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(VfsFile); | ||||||
|  |     YUZU_NON_MOVEABLE(VfsFile); | ||||||
|  | 
 | ||||||
|  |     VfsFile() = default; | ||||||
|     virtual ~VfsFile(); |     virtual ~VfsFile(); | ||||||
| 
 | 
 | ||||||
|     // Retrieves the file name.
 |     // Retrieves the file name.
 | ||||||
|  | @ -176,8 +184,12 @@ public: | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // A class representing a directory in an abstract filesystem.
 | // A class representing a directory in an abstract filesystem.
 | ||||||
| class VfsDirectory : NonCopyable { | class VfsDirectory { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(VfsDirectory); | ||||||
|  |     YUZU_NON_MOVEABLE(VfsDirectory); | ||||||
|  | 
 | ||||||
|  |     VfsDirectory() = default; | ||||||
|     virtual ~VfsDirectory(); |     virtual ~VfsDirectory(); | ||||||
| 
 | 
 | ||||||
|     // Retrives the file located at path as if the current directory was root. Returns nullptr if
 |     // Retrives the file located at path as if the current directory was root. Returns nullptr if
 | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ | ||||||
| #include <mutex> | #include <mutex> | ||||||
| #include <tuple> | #include <tuple> | ||||||
| 
 | 
 | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/hle/kernel/k_page_heap.h" | #include "core/hle/kernel/k_page_heap.h" | ||||||
| #include "core/hle/result.h" | #include "core/hle/result.h" | ||||||
|  | @ -20,8 +21,11 @@ namespace Kernel { | ||||||
| 
 | 
 | ||||||
| class KPageLinkedList; | class KPageLinkedList; | ||||||
| 
 | 
 | ||||||
| class KMemoryManager final : NonCopyable { | class KMemoryManager final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KMemoryManager); | ||||||
|  |     YUZU_NON_MOVEABLE(KMemoryManager); | ||||||
|  | 
 | ||||||
|     enum class Pool : u32 { |     enum class Pool : u32 { | ||||||
|         Application = 0, |         Application = 0, | ||||||
|         Applet = 1, |         Applet = 1, | ||||||
|  | @ -88,26 +92,13 @@ public: | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     class Impl final : NonCopyable { |     class Impl final { | ||||||
|     private: |  | ||||||
|         using RefCount = u16; |  | ||||||
| 
 |  | ||||||
|     private: |  | ||||||
|         KPageHeap heap; |  | ||||||
|         Pool pool{}; |  | ||||||
| 
 |  | ||||||
|     public: |     public: | ||||||
|         static std::size_t CalculateManagementOverheadSize(std::size_t region_size); |         YUZU_NON_COPYABLE(Impl); | ||||||
|  |         YUZU_NON_MOVEABLE(Impl); | ||||||
| 
 | 
 | ||||||
|         static constexpr std::size_t CalculateOptimizedProcessOverheadSize( |  | ||||||
|             std::size_t region_size) { |  | ||||||
|             return (Common::AlignUp((region_size / PageSize), Common::BitSize<u64>()) / |  | ||||||
|                     Common::BitSize<u64>()) * |  | ||||||
|                    sizeof(u64); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|     public: |  | ||||||
|         Impl() = default; |         Impl() = default; | ||||||
|  |         ~Impl() = default; | ||||||
| 
 | 
 | ||||||
|         std::size_t Initialize(Pool new_pool, u64 start_address, u64 end_address); |         std::size_t Initialize(Pool new_pool, u64 start_address, u64 end_address); | ||||||
| 
 | 
 | ||||||
|  | @ -130,6 +121,21 @@ private: | ||||||
|         constexpr VAddr GetEndAddress() const { |         constexpr VAddr GetEndAddress() const { | ||||||
|             return heap.GetEndAddress(); |             return heap.GetEndAddress(); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         static std::size_t CalculateManagementOverheadSize(std::size_t region_size); | ||||||
|  | 
 | ||||||
|  |         static constexpr std::size_t CalculateOptimizedProcessOverheadSize( | ||||||
|  |             std::size_t region_size) { | ||||||
|  |             return (Common::AlignUp((region_size / PageSize), Common::BitSize<u64>()) / | ||||||
|  |                     Common::BitSize<u64>()) * | ||||||
|  |                    sizeof(u64); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     private: | ||||||
|  |         using RefCount = u16; | ||||||
|  | 
 | ||||||
|  |         KPageHeap heap; | ||||||
|  |         Pool pool{}; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  |  | ||||||
|  | @ -5,6 +5,7 @@ | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include "common/assert.h" | #include "common/assert.h" | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "common/intrusive_red_black_tree.h" | #include "common/intrusive_red_black_tree.h" | ||||||
| #include "core/hle/kernel/k_memory_region_type.h" | #include "core/hle/kernel/k_memory_region_type.h" | ||||||
|  | @ -13,11 +14,13 @@ namespace Kernel { | ||||||
| 
 | 
 | ||||||
| class KMemoryRegionAllocator; | class KMemoryRegionAllocator; | ||||||
| 
 | 
 | ||||||
| class KMemoryRegion final : public Common::IntrusiveRedBlackTreeBaseNode<KMemoryRegion>, | class KMemoryRegion final : public Common::IntrusiveRedBlackTreeBaseNode<KMemoryRegion> { | ||||||
|                             NonCopyable { |  | ||||||
|     friend class KMemoryRegionTree; |     friend class KMemoryRegionTree; | ||||||
| 
 | 
 | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KMemoryRegion); | ||||||
|  |     YUZU_NON_MOVEABLE(KMemoryRegion); | ||||||
|  | 
 | ||||||
|     constexpr KMemoryRegion() = default; |     constexpr KMemoryRegion() = default; | ||||||
|     constexpr KMemoryRegion(u64 address_, u64 last_address_) |     constexpr KMemoryRegion(u64 address_, u64 last_address_) | ||||||
|         : address{address_}, last_address{last_address_} {} |         : address{address_}, last_address{last_address_} {} | ||||||
|  | @ -29,6 +32,8 @@ public: | ||||||
|         : KMemoryRegion(address_, last_address_, std::numeric_limits<u64>::max(), attributes_, |         : KMemoryRegion(address_, last_address_, std::numeric_limits<u64>::max(), attributes_, | ||||||
|                         type_id_) {} |                         type_id_) {} | ||||||
| 
 | 
 | ||||||
|  |     ~KMemoryRegion() = default; | ||||||
|  | 
 | ||||||
|     static constexpr int Compare(const KMemoryRegion& lhs, const KMemoryRegion& rhs) { |     static constexpr int Compare(const KMemoryRegion& lhs, const KMemoryRegion& rhs) { | ||||||
|         if (lhs.GetAddress() < rhs.GetAddress()) { |         if (lhs.GetAddress() < rhs.GetAddress()) { | ||||||
|             return -1; |             return -1; | ||||||
|  | @ -39,16 +44,6 @@ public: | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: |  | ||||||
|     constexpr void Reset(u64 a, u64 la, u64 p, u32 r, u32 t) { |  | ||||||
|         address = a; |  | ||||||
|         pair_address = p; |  | ||||||
|         last_address = la; |  | ||||||
|         attributes = r; |  | ||||||
|         type_id = t; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| public: |  | ||||||
|     constexpr u64 GetAddress() const { |     constexpr u64 GetAddress() const { | ||||||
|         return address; |         return address; | ||||||
|     } |     } | ||||||
|  | @ -108,6 +103,14 @@ public: | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  |     constexpr void Reset(u64 a, u64 la, u64 p, u32 r, u32 t) { | ||||||
|  |         address = a; | ||||||
|  |         pair_address = p; | ||||||
|  |         last_address = la; | ||||||
|  |         attributes = r; | ||||||
|  |         type_id = t; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     u64 address{}; |     u64 address{}; | ||||||
|     u64 last_address{}; |     u64 last_address{}; | ||||||
|     u64 pair_address{}; |     u64 pair_address{}; | ||||||
|  | @ -115,8 +118,25 @@ private: | ||||||
|     u32 type_id{}; |     u32 type_id{}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class KMemoryRegionTree final : NonCopyable { | class KMemoryRegionTree final { | ||||||
|  | private: | ||||||
|  |     using TreeType = | ||||||
|  |         Common::IntrusiveRedBlackTreeBaseTraits<KMemoryRegion>::TreeType<KMemoryRegion>; | ||||||
|  | 
 | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KMemoryRegionTree); | ||||||
|  |     YUZU_NON_MOVEABLE(KMemoryRegionTree); | ||||||
|  | 
 | ||||||
|  |     using value_type = TreeType::value_type; | ||||||
|  |     using size_type = TreeType::size_type; | ||||||
|  |     using difference_type = TreeType::difference_type; | ||||||
|  |     using pointer = TreeType::pointer; | ||||||
|  |     using const_pointer = TreeType::const_pointer; | ||||||
|  |     using reference = TreeType::reference; | ||||||
|  |     using const_reference = TreeType::const_reference; | ||||||
|  |     using iterator = TreeType::iterator; | ||||||
|  |     using const_iterator = TreeType::const_iterator; | ||||||
|  | 
 | ||||||
|     struct DerivedRegionExtents { |     struct DerivedRegionExtents { | ||||||
|         const KMemoryRegion* first_region{}; |         const KMemoryRegion* first_region{}; | ||||||
|         const KMemoryRegion* last_region{}; |         const KMemoryRegion* last_region{}; | ||||||
|  | @ -140,29 +160,9 @@ public: | ||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| private: |  | ||||||
|     using TreeType = |  | ||||||
|         Common::IntrusiveRedBlackTreeBaseTraits<KMemoryRegion>::TreeType<KMemoryRegion>; |  | ||||||
| 
 |  | ||||||
| public: |  | ||||||
|     using value_type = TreeType::value_type; |  | ||||||
|     using size_type = TreeType::size_type; |  | ||||||
|     using difference_type = TreeType::difference_type; |  | ||||||
|     using pointer = TreeType::pointer; |  | ||||||
|     using const_pointer = TreeType::const_pointer; |  | ||||||
|     using reference = TreeType::reference; |  | ||||||
|     using const_reference = TreeType::const_reference; |  | ||||||
|     using iterator = TreeType::iterator; |  | ||||||
|     using const_iterator = TreeType::const_iterator; |  | ||||||
| 
 |  | ||||||
| private: |  | ||||||
|     TreeType m_tree{}; |  | ||||||
|     KMemoryRegionAllocator& memory_region_allocator; |  | ||||||
| 
 |  | ||||||
| public: |  | ||||||
|     explicit KMemoryRegionTree(KMemoryRegionAllocator& memory_region_allocator_); |     explicit KMemoryRegionTree(KMemoryRegionAllocator& memory_region_allocator_); | ||||||
|  |     ~KMemoryRegionTree() = default; | ||||||
| 
 | 
 | ||||||
| public: |  | ||||||
|     KMemoryRegion* FindModifiable(u64 address) { |     KMemoryRegion* FindModifiable(u64 address) { | ||||||
|         if (auto it = this->find(KMemoryRegion(address, address, 0, 0)); it != this->end()) { |         if (auto it = this->find(KMemoryRegion(address, address, 0, 0)); it != this->end()) { | ||||||
|             return std::addressof(*it); |             return std::addressof(*it); | ||||||
|  | @ -241,7 +241,6 @@ public: | ||||||
|         return GetDerivedRegionExtents(static_cast<KMemoryRegionType>(type_id)); |         return GetDerivedRegionExtents(static_cast<KMemoryRegionType>(type_id)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| public: |  | ||||||
|     void InsertDirectly(u64 address, u64 last_address, u32 attr = 0, u32 type_id = 0); |     void InsertDirectly(u64 address, u64 last_address, u32 attr = 0, u32 type_id = 0); | ||||||
|     bool Insert(u64 address, size_t size, u32 type_id, u32 new_attr = 0, u32 old_attr = 0); |     bool Insert(u64 address, size_t size, u32 type_id, u32 new_attr = 0, u32 old_attr = 0); | ||||||
| 
 | 
 | ||||||
|  | @ -252,7 +251,6 @@ public: | ||||||
|         return this->GetRandomAlignedRegion(size + 2 * guard_size, alignment, type_id) + guard_size; |         return this->GetRandomAlignedRegion(size + 2 * guard_size, alignment, type_id) + guard_size; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| public: |  | ||||||
|     // Iterator accessors.
 |     // Iterator accessors.
 | ||||||
|     iterator begin() { |     iterator begin() { | ||||||
|         return m_tree.begin(); |         return m_tree.begin(); | ||||||
|  | @ -322,13 +320,21 @@ public: | ||||||
|     iterator nfind(const_reference ref) const { |     iterator nfind(const_reference ref) const { | ||||||
|         return m_tree.nfind(ref); |         return m_tree.nfind(ref); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  | private: | ||||||
|  |     TreeType m_tree{}; | ||||||
|  |     KMemoryRegionAllocator& memory_region_allocator; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class KMemoryRegionAllocator final : NonCopyable { | class KMemoryRegionAllocator final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KMemoryRegionAllocator); | ||||||
|  |     YUZU_NON_MOVEABLE(KMemoryRegionAllocator); | ||||||
|  | 
 | ||||||
|     static constexpr size_t MaxMemoryRegions = 200; |     static constexpr size_t MaxMemoryRegions = 200; | ||||||
| 
 | 
 | ||||||
|     constexpr KMemoryRegionAllocator() = default; |     constexpr KMemoryRegionAllocator() = default; | ||||||
|  |     constexpr ~KMemoryRegionAllocator() = default; | ||||||
| 
 | 
 | ||||||
|     template <typename... Args> |     template <typename... Args> | ||||||
|     KMemoryRegion* Allocate(Args&&... args) { |     KMemoryRegion* Allocate(Args&&... args) { | ||||||
|  |  | ||||||
|  | @ -8,14 +8,44 @@ | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
| #include "common/alignment.h" | #include "common/alignment.h" | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/hle/kernel/k_page_bitmap.h" | #include "core/hle/kernel/k_page_bitmap.h" | ||||||
| #include "core/hle/kernel/memory_types.h" | #include "core/hle/kernel/memory_types.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
| 
 | 
 | ||||||
| class KPageHeap final : NonCopyable { | class KPageHeap final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KPageHeap); | ||||||
|  |     YUZU_NON_MOVEABLE(KPageHeap); | ||||||
|  | 
 | ||||||
|  |     KPageHeap() = default; | ||||||
|  |     ~KPageHeap() = default; | ||||||
|  | 
 | ||||||
|  |     constexpr VAddr GetAddress() const { | ||||||
|  |         return heap_address; | ||||||
|  |     } | ||||||
|  |     constexpr std::size_t GetSize() const { | ||||||
|  |         return heap_size; | ||||||
|  |     } | ||||||
|  |     constexpr VAddr GetEndAddress() const { | ||||||
|  |         return GetAddress() + GetSize(); | ||||||
|  |     } | ||||||
|  |     constexpr std::size_t GetPageOffset(VAddr block) const { | ||||||
|  |         return (block - GetAddress()) / PageSize; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     void Initialize(VAddr heap_address, std::size_t heap_size, std::size_t metadata_size); | ||||||
|  |     VAddr AllocateBlock(s32 index, bool random); | ||||||
|  |     void Free(VAddr addr, std::size_t num_pages); | ||||||
|  | 
 | ||||||
|  |     void UpdateUsedSize() { | ||||||
|  |         used_size = heap_size - (GetNumFreePages() * PageSize); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     static std::size_t CalculateManagementOverheadSize(std::size_t region_size); | ||||||
|  | 
 | ||||||
|     static constexpr s32 GetAlignedBlockIndex(std::size_t num_pages, std::size_t align_pages) { |     static constexpr s32 GetAlignedBlockIndex(std::size_t num_pages, std::size_t align_pages) { | ||||||
|         const auto target_pages{std::max(num_pages, align_pages)}; |         const auto target_pages{std::max(num_pages, align_pages)}; | ||||||
|         for (std::size_t i = 0; i < NumMemoryBlockPageShifts; i++) { |         for (std::size_t i = 0; i < NumMemoryBlockPageShifts; i++) { | ||||||
|  | @ -45,21 +75,13 @@ public: | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     static constexpr std::size_t NumMemoryBlockPageShifts{7}; |     class Block final { | ||||||
|     static constexpr std::array<std::size_t, NumMemoryBlockPageShifts> MemoryBlockPageShifts{ |  | ||||||
|         0xC, 0x10, 0x15, 0x16, 0x19, 0x1D, 0x1E, |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     class Block final : NonCopyable { |  | ||||||
|     private: |  | ||||||
|         KPageBitmap bitmap; |  | ||||||
|         VAddr heap_address{}; |  | ||||||
|         uintptr_t end_offset{}; |  | ||||||
|         std::size_t block_shift{}; |  | ||||||
|         std::size_t next_block_shift{}; |  | ||||||
| 
 |  | ||||||
|     public: |     public: | ||||||
|  |         YUZU_NON_COPYABLE(Block); | ||||||
|  |         YUZU_NON_MOVEABLE(Block); | ||||||
|  | 
 | ||||||
|         Block() = default; |         Block() = default; | ||||||
|  |         ~Block() = default; | ||||||
| 
 | 
 | ||||||
|         constexpr std::size_t GetShift() const { |         constexpr std::size_t GetShift() const { | ||||||
|             return block_shift; |             return block_shift; | ||||||
|  | @ -129,7 +151,6 @@ private: | ||||||
|             return heap_address + (offset << GetShift()); |             return heap_address + (offset << GetShift()); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|     public: |  | ||||||
|         static constexpr std::size_t CalculateManagementOverheadSize(std::size_t region_size, |         static constexpr std::size_t CalculateManagementOverheadSize(std::size_t region_size, | ||||||
|                                                                      std::size_t cur_block_shift, |                                                                      std::size_t cur_block_shift, | ||||||
|                                                                      std::size_t next_block_shift) { |                                                                      std::size_t next_block_shift) { | ||||||
|  | @ -139,35 +160,15 @@ private: | ||||||
|             return KPageBitmap::CalculateManagementOverheadSize( |             return KPageBitmap::CalculateManagementOverheadSize( | ||||||
|                 (align * 2 + Common::AlignUp(region_size, align)) / cur_block_size); |                 (align * 2 + Common::AlignUp(region_size, align)) / cur_block_size); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |     private: | ||||||
|  |         KPageBitmap bitmap; | ||||||
|  |         VAddr heap_address{}; | ||||||
|  |         uintptr_t end_offset{}; | ||||||
|  |         std::size_t block_shift{}; | ||||||
|  |         std::size_t next_block_shift{}; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| public: |  | ||||||
|     KPageHeap() = default; |  | ||||||
| 
 |  | ||||||
|     constexpr VAddr GetAddress() const { |  | ||||||
|         return heap_address; |  | ||||||
|     } |  | ||||||
|     constexpr std::size_t GetSize() const { |  | ||||||
|         return heap_size; |  | ||||||
|     } |  | ||||||
|     constexpr VAddr GetEndAddress() const { |  | ||||||
|         return GetAddress() + GetSize(); |  | ||||||
|     } |  | ||||||
|     constexpr std::size_t GetPageOffset(VAddr block) const { |  | ||||||
|         return (block - GetAddress()) / PageSize; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     void Initialize(VAddr heap_address, std::size_t heap_size, std::size_t metadata_size); |  | ||||||
|     VAddr AllocateBlock(s32 index, bool random); |  | ||||||
|     void Free(VAddr addr, std::size_t num_pages); |  | ||||||
| 
 |  | ||||||
|     void UpdateUsedSize() { |  | ||||||
|         used_size = heap_size - (GetNumFreePages() * PageSize); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     static std::size_t CalculateManagementOverheadSize(std::size_t region_size); |  | ||||||
| 
 |  | ||||||
| private: |  | ||||||
|     constexpr std::size_t GetNumFreePages() const { |     constexpr std::size_t GetNumFreePages() const { | ||||||
|         std::size_t num_free{}; |         std::size_t num_free{}; | ||||||
| 
 | 
 | ||||||
|  | @ -180,6 +181,11 @@ private: | ||||||
| 
 | 
 | ||||||
|     void FreeBlock(VAddr block, s32 index); |     void FreeBlock(VAddr block, s32 index); | ||||||
| 
 | 
 | ||||||
|  |     static constexpr std::size_t NumMemoryBlockPageShifts{7}; | ||||||
|  |     static constexpr std::array<std::size_t, NumMemoryBlockPageShifts> MemoryBlockPageShifts{ | ||||||
|  |         0xC, 0x10, 0x15, 0x16, 0x19, 0x1D, 0x1E, | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|     VAddr heap_address{}; |     VAddr heap_address{}; | ||||||
|     std::size_t heap_size{}; |     std::size_t heap_size{}; | ||||||
|     std::size_t used_size{}; |     std::size_t used_size{}; | ||||||
|  |  | ||||||
|  | @ -63,6 +63,8 @@ constexpr std::size_t GetSizeInRange(const KMemoryInfo& info, VAddr start, VAddr | ||||||
| 
 | 
 | ||||||
| KPageTable::KPageTable(Core::System& system_) : system{system_} {} | KPageTable::KPageTable(Core::System& system_) : system{system_} {} | ||||||
| 
 | 
 | ||||||
|  | KPageTable::~KPageTable() = default; | ||||||
|  | 
 | ||||||
| ResultCode KPageTable::InitializeForProcess(FileSys::ProgramAddressSpaceType as_type, | ResultCode KPageTable::InitializeForProcess(FileSys::ProgramAddressSpaceType as_type, | ||||||
|                                             bool enable_aslr, VAddr code_addr, |                                             bool enable_aslr, VAddr code_addr, | ||||||
|                                             std::size_t code_size, KMemoryManager::Pool pool) { |                                             std::size_t code_size, KMemoryManager::Pool pool) { | ||||||
|  |  | ||||||
|  | @ -7,6 +7,7 @@ | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <mutex> | #include <mutex> | ||||||
| 
 | 
 | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "common/page_table.h" | #include "common/page_table.h" | ||||||
| #include "core/file_sys/program_metadata.h" | #include "core/file_sys/program_metadata.h" | ||||||
|  | @ -22,9 +23,13 @@ namespace Kernel { | ||||||
| 
 | 
 | ||||||
| class KMemoryBlockManager; | class KMemoryBlockManager; | ||||||
| 
 | 
 | ||||||
| class KPageTable final : NonCopyable { | class KPageTable final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KPageTable); | ||||||
|  |     YUZU_NON_MOVEABLE(KPageTable); | ||||||
|  | 
 | ||||||
|     explicit KPageTable(Core::System& system_); |     explicit KPageTable(Core::System& system_); | ||||||
|  |     ~KPageTable(); | ||||||
| 
 | 
 | ||||||
|     ResultCode InitializeForProcess(FileSys::ProgramAddressSpaceType as_type, bool enable_aslr, |     ResultCode InitializeForProcess(FileSys::ProgramAddressSpaceType as_type, bool enable_aslr, | ||||||
|                                     VAddr code_addr, std::size_t code_size, |                                     VAddr code_addr, std::size_t code_size, | ||||||
|  |  | ||||||
|  | @ -7,6 +7,7 @@ | ||||||
| #include <atomic> | #include <atomic> | ||||||
| 
 | 
 | ||||||
| #include "common/assert.h" | #include "common/assert.h" | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| 
 | 
 | ||||||
| namespace Kernel { | namespace Kernel { | ||||||
|  | @ -15,13 +16,17 @@ class KernelCore; | ||||||
| 
 | 
 | ||||||
| namespace impl { | namespace impl { | ||||||
| 
 | 
 | ||||||
| class KSlabHeapImpl final : NonCopyable { | class KSlabHeapImpl final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KSlabHeapImpl); | ||||||
|  |     YUZU_NON_MOVEABLE(KSlabHeapImpl); | ||||||
|  | 
 | ||||||
|     struct Node { |     struct Node { | ||||||
|         Node* next{}; |         Node* next{}; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     constexpr KSlabHeapImpl() = default; |     constexpr KSlabHeapImpl() = default; | ||||||
|  |     constexpr ~KSlabHeapImpl() = default; | ||||||
| 
 | 
 | ||||||
|     void Initialize(std::size_t size) { |     void Initialize(std::size_t size) { | ||||||
|         ASSERT(head == nullptr); |         ASSERT(head == nullptr); | ||||||
|  | @ -64,9 +69,13 @@ private: | ||||||
| 
 | 
 | ||||||
| } // namespace impl
 | } // namespace impl
 | ||||||
| 
 | 
 | ||||||
| class KSlabHeapBase : NonCopyable { | class KSlabHeapBase { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(KSlabHeapBase); | ||||||
|  |     YUZU_NON_MOVEABLE(KSlabHeapBase); | ||||||
|  | 
 | ||||||
|     constexpr KSlabHeapBase() = default; |     constexpr KSlabHeapBase() = default; | ||||||
|  |     constexpr ~KSlabHeapBase() = default; | ||||||
| 
 | 
 | ||||||
|     constexpr bool Contains(uintptr_t addr) const { |     constexpr bool Contains(uintptr_t addr) const { | ||||||
|         return start <= addr && addr < end; |         return start <= addr && addr < end; | ||||||
|  |  | ||||||
|  | @ -11,6 +11,7 @@ | ||||||
| #include <utility> | #include <utility> | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/file_sys/control_metadata.h" | #include "core/file_sys/control_metadata.h" | ||||||
| #include "core/file_sys/vfs.h" | #include "core/file_sys/vfs.h" | ||||||
|  | @ -139,8 +140,11 @@ std::string GetResultStatusString(ResultStatus status); | ||||||
| std::ostream& operator<<(std::ostream& os, ResultStatus status); | std::ostream& operator<<(std::ostream& os, ResultStatus status); | ||||||
| 
 | 
 | ||||||
| /// Interface for loading an application
 | /// Interface for loading an application
 | ||||||
| class AppLoader : NonCopyable { | class AppLoader { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(AppLoader); | ||||||
|  |     YUZU_NON_MOVEABLE(AppLoader); | ||||||
|  | 
 | ||||||
|     struct LoadParameters { |     struct LoadParameters { | ||||||
|         s32 main_thread_priority; |         s32 main_thread_priority; | ||||||
|         u64 main_thread_stack_size; |         u64 main_thread_stack_size; | ||||||
|  |  | ||||||
|  | @ -5,9 +5,10 @@ | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include <atomic> | #include <atomic> | ||||||
|  | #include <functional> | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <optional> |  | ||||||
| 
 | 
 | ||||||
|  | #include "common/common_funcs.h" | ||||||
| #include "common/common_types.h" | #include "common/common_types.h" | ||||||
| #include "core/frontend/emu_window.h" | #include "core/frontend/emu_window.h" | ||||||
| #include "video_core/gpu.h" | #include "video_core/gpu.h" | ||||||
|  | @ -28,8 +29,11 @@ struct RendererSettings { | ||||||
|     Layout::FramebufferLayout screenshot_framebuffer_layout; |     Layout::FramebufferLayout screenshot_framebuffer_layout; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class RendererBase : NonCopyable { | class RendererBase { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(RendererBase); | ||||||
|  |     YUZU_NON_MOVEABLE(RendererBase); | ||||||
|  | 
 | ||||||
|     explicit RendererBase(Core::Frontend::EmuWindow& window, |     explicit RendererBase(Core::Frontend::EmuWindow& window, | ||||||
|                           std::unique_ptr<Core::Frontend::GraphicsContext> context); |                           std::unique_ptr<Core::Frontend::GraphicsContext> context); | ||||||
|     virtual ~RendererBase(); |     virtual ~RendererBase(); | ||||||
|  |  | ||||||
|  | @ -7,12 +7,14 @@ | ||||||
| #include <string_view> | #include <string_view> | ||||||
| #include <utility> | #include <utility> | ||||||
| #include <glad/glad.h> | #include <glad/glad.h> | ||||||
| #include "common/common_types.h" | #include "common/common_funcs.h" | ||||||
| 
 | 
 | ||||||
| namespace OpenGL { | namespace OpenGL { | ||||||
| 
 | 
 | ||||||
| class OGLRenderbuffer : private NonCopyable { | class OGLRenderbuffer final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLRenderbuffer); | ||||||
|  | 
 | ||||||
|     OGLRenderbuffer() = default; |     OGLRenderbuffer() = default; | ||||||
| 
 | 
 | ||||||
|     OGLRenderbuffer(OGLRenderbuffer&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLRenderbuffer(OGLRenderbuffer&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -36,8 +38,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLTexture : private NonCopyable { | class OGLTexture final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLTexture); | ||||||
|  | 
 | ||||||
|     OGLTexture() = default; |     OGLTexture() = default; | ||||||
| 
 | 
 | ||||||
|     OGLTexture(OGLTexture&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLTexture(OGLTexture&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -61,8 +65,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLTextureView : private NonCopyable { | class OGLTextureView final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLTextureView); | ||||||
|  | 
 | ||||||
|     OGLTextureView() = default; |     OGLTextureView() = default; | ||||||
| 
 | 
 | ||||||
|     OGLTextureView(OGLTextureView&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLTextureView(OGLTextureView&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -86,8 +92,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLSampler : private NonCopyable { | class OGLSampler final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLSampler); | ||||||
|  | 
 | ||||||
|     OGLSampler() = default; |     OGLSampler() = default; | ||||||
| 
 | 
 | ||||||
|     OGLSampler(OGLSampler&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLSampler(OGLSampler&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -111,8 +119,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLShader : private NonCopyable { | class OGLShader final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLShader); | ||||||
|  | 
 | ||||||
|     OGLShader() = default; |     OGLShader() = default; | ||||||
| 
 | 
 | ||||||
|     OGLShader(OGLShader&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLShader(OGLShader&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -132,8 +142,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLProgram : private NonCopyable { | class OGLProgram final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLProgram); | ||||||
|  | 
 | ||||||
|     OGLProgram() = default; |     OGLProgram() = default; | ||||||
| 
 | 
 | ||||||
|     OGLProgram(OGLProgram&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLProgram(OGLProgram&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -154,8 +166,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLAssemblyProgram : private NonCopyable { | class OGLAssemblyProgram final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLAssemblyProgram); | ||||||
|  | 
 | ||||||
|     OGLAssemblyProgram() = default; |     OGLAssemblyProgram() = default; | ||||||
| 
 | 
 | ||||||
|     OGLAssemblyProgram(OGLAssemblyProgram&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLAssemblyProgram(OGLAssemblyProgram&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -176,8 +190,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLPipeline : private NonCopyable { | class OGLPipeline final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLPipeline); | ||||||
|  | 
 | ||||||
|     OGLPipeline() = default; |     OGLPipeline() = default; | ||||||
|     OGLPipeline(OGLPipeline&& o) noexcept : handle{std::exchange<GLuint>(o.handle, 0)} {} |     OGLPipeline(OGLPipeline&& o) noexcept : handle{std::exchange<GLuint>(o.handle, 0)} {} | ||||||
| 
 | 
 | ||||||
|  | @ -198,8 +214,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLBuffer : private NonCopyable { | class OGLBuffer final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLBuffer); | ||||||
|  | 
 | ||||||
|     OGLBuffer() = default; |     OGLBuffer() = default; | ||||||
| 
 | 
 | ||||||
|     OGLBuffer(OGLBuffer&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLBuffer(OGLBuffer&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -223,8 +241,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLSync : private NonCopyable { | class OGLSync final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLSync); | ||||||
|  | 
 | ||||||
|     OGLSync() = default; |     OGLSync() = default; | ||||||
| 
 | 
 | ||||||
|     OGLSync(OGLSync&& o) noexcept : handle(std::exchange(o.handle, nullptr)) {} |     OGLSync(OGLSync&& o) noexcept : handle(std::exchange(o.handle, nullptr)) {} | ||||||
|  | @ -247,8 +267,10 @@ public: | ||||||
|     GLsync handle = 0; |     GLsync handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLFramebuffer : private NonCopyable { | class OGLFramebuffer final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLFramebuffer); | ||||||
|  | 
 | ||||||
|     OGLFramebuffer() = default; |     OGLFramebuffer() = default; | ||||||
| 
 | 
 | ||||||
|     OGLFramebuffer(OGLFramebuffer&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLFramebuffer(OGLFramebuffer&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  | @ -272,8 +294,10 @@ public: | ||||||
|     GLuint handle = 0; |     GLuint handle = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class OGLQuery : private NonCopyable { | class OGLQuery final { | ||||||
| public: | public: | ||||||
|  |     YUZU_NON_COPYABLE(OGLQuery); | ||||||
|  | 
 | ||||||
|     OGLQuery() = default; |     OGLQuery() = default; | ||||||
| 
 | 
 | ||||||
|     OGLQuery(OGLQuery&& o) noexcept : handle(std::exchange(o.handle, 0)) {} |     OGLQuery(OGLQuery&& o) noexcept : handle(std::exchange(o.handle, 0)) {} | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash