SpiecsEngine
 
Loading...
Searching...
No Matches
VulkanDevice.h
Go to the documentation of this file.
1/**
2* @file VulkanDevice.h.
3* @brief The VulkanDevice Class Definitions.
4* @author Spices.
5*/
6
7#pragma once
8#include "Core/Core.h"
9#include "VulkanUtils.h"
10
11#include <optional>
12
13namespace Spices {
14
15 /**
16 * @brief This struct contains all queues's identify we need.
17 */
19 {
20 /**
21 * @brief The graphic queue's in used identify.
22 */
24
25 /**
26 * @brief The present queue's in used identify.
27 */
29
30 /**
31 * @brief The transfer queue's in used identify.
32 */
34
35 /**
36 * @brief The compute queue's in used identify.
37 */
39
40 /**
41 * @brief Whether all queues that we need is valid.
42 */
43 bool isComplete() const
44 {
45 return
46
47 /**
48 * @brief Whether graphicqueue is supported by device.
49 */
50 graphicqueuefamily.has_value() &&
51
52 /**
53 * @brief Whether presentqueue is supported by device.
54 */
55 presentqueuefamily.has_value() &&
56
57 /**
58 * @brief Whether transferqueu is supported by device.
59 */
60 transferqueuefamily.has_value() &&
61
62 /**
63 * @brief Whether computequeue is supported by device.
64 */
65 computequeuefamily.has_value() ;
66 }
67 };
68
69 /**
70 * @brief SwapChain Utils.
71 * Queried from device.
72 */
74 {
75 /**
76 * @brief VkSurfaceCapabilitiesKHR.
77 */
79
80 /**
81 * @brief All supported VkSurfaceFormatKHR.
82 */
84
85 /**
86 * @brief All supported VkPresentModeKHR.
87 */
89
90 /**
91 * @brief The selected VkSurfaceFormatKHR.
92 */
94
95 /**
96 * @brief The selected VkPresentModeKHR.
97 */
99
100 /**
101 * @brief The VkSurface Size.
102 */
104
105 /**
106 * @brief The ViewPort Size.
107 * Init value. Reset by resize event.
108 */
109 VkExtent2D viewPortSize = { 1280, 960 };
110 };
111
112 /**
113 * @brief VulkanInstance Class.
114 * This class defines the VulkanDevice behave.
115 * This class is just a wrapper of vkdevice.
116 */
118 {
119 public:
120
121 /**
122 * @brief Constructor Function.
123 * Create vkDevice.
124 * @param[in] vulkanState The global VulkanState.
125 */
126 VulkanDevice(VulkanState& vulkanState);
127
128 /**
129 * @brief Destructor Function.
130 */
131 virtual ~VulkanDevice() override;
132
133 /**
134 * @brief Get SwapChain Utils.
135 * @return Returns SwapChain Utils.
136 */
137 inline const SwapChainSupportDetails& GetSwapChainSupport() { return m_SwapChainSupportDetails; }
138
139 /**
140 * @brief Requery device's SwapChainSupportDetails.
141 * Mainly VkExtent2D.
142 */
144
145 /**
146 * @brief Get QueueHelper variable.
147 * @return Returns QueueHelper variable.
148 */
149 inline const QueueHelper& GetQueueHelper() const { return m_QueueHelper; }
150
151 /**
152 * @brief Get device's max usable sample count.
153 * @return Returns device's max usable sample count.
154 */
156
157 /**
158 * @brief Get RayTracingPipelineProperties.
159 * @return Returns RayTracingPipelineProperties.
160 */
161 inline static VkPhysicalDeviceRayTracingPipelinePropertiesKHR& GetRTPipelineProperties() { return m_RayTracingProperties; }
162
163 /**
164 * @brief Get DeviceGeneratedCommandsPropertiesNV.
165 * @return Returns DeviceGeneratedCommandsPropertiesNV.
166 */
168
169 /**
170 * @brief Get VkPhysicalDeviceFeatures.
171 * @return Returns VkPhysicalDeviceFeatures.
172 */
173 inline static VkPhysicalDeviceFeatures& GetDeviceFeatures() { return m_DeviceFeatures; }
174
175 /**
176 * @brief Get VkPhysicalDeviceProperties.
177 * @return Returns VkPhysicalDeviceProperties.
178 */
179 inline static VkPhysicalDeviceProperties& GetDeviceProperties() { return m_DeviceProperties; }
180
181 private:
182
183 /**
184 * @brief select a suitable physical device.
185 * @param[in] instance VkInstance.
186 * @param[in] surface VkSurfaceKHR.
187 * @param[in] window The row pointer of GLFW window.
188 * @return Returns true if select one successfully.
189 * @todo multiple physical device support.
190 */
192 const VkInstance& instance ,
193 const VkSurfaceKHR& surface ,
194 GLFWwindow* window
195 );
196
197 /**
198 * @brief Check all Property we need meet.
199 * @param[in] device VkPhysicalDevice.
200 * @return Returns true if all Property we need meet.
201 */
202 bool IsPropertyMeetDemand(const VkPhysicalDevice& device);
203
204 /**
205 * @brief Check all Feature we need meet.
206 * @param[in] device VkPhysicalDevice.
207 * @return Returns true if all Feature we need meet.
208 */
209 bool IsFeatureMeetDemand(const VkPhysicalDevice& device);
210
211 /**
212 * @brief Get all physical device extension requirements our engine needed.
213 * Source 1 : user Setting.
214 * @todo Configurable
215 */
217
218 /**
219 * @brief Check all Extension we need meet;
220 * @param[in] device VkPhysicalDevice.
221 * @return Returns true if all Extension we need meet.
222 */
223 bool IsExtensionMeetDemand(const VkPhysicalDevice& device);
224
225 /**
226 * @brief Check all Queue we need meet;
227 * @param[in] device VkPhysicalDevice.
228 * @param[in] surface VkSurfaceKHR.
229 * @return Returns true if all Extension we need meet.
230 */
231 bool IsQueueMeetDemand(const VkPhysicalDevice& device, const VkSurfaceKHR& surface);
232
233 /**
234 * @brief Query physical device's SwapChainSupport.
235 * @param[in] device VkPhysicalDevice.
236 * @param[in] surface VkSurfaceKHR.
237 * @param[in] window The row pointer of GLFW window.
238 * @return Returns SwapChainSupportDetails.
239 */
241 const VkPhysicalDevice& device ,
242 const VkSurfaceKHR& surface ,
243 GLFWwindow* window
244 );
245
246 private:
247
248 /**
249 * @brief Device Extension Properties.
250 */
252
253 /**
254 * @brief Selected Physical Device Properties.
255 */
257
258 /**
259 * @brief Selected Physical Device Features.
260 */
262
263 /**
264 * @brief Device RayTracing Properties.
265 */
267
268 /**
269 * @brief Device DGC Properties.
270 */
272
273 /**
274 * @brief QueueHelper.
275 */
277
278 /**
279 * @brief SwapChainSupportDetails.
280 */
282 };
283}
#define EVENT_CLASS_TYPE(type)
Defines Event type.
Definition Event.h:74
#define EVENT_CLASS_CATEGORY(category)
Defines Event category.
Definition Event.h:82
#define SPICES_PROFILE_ZONEN(...)
#define SPICES_PROFILE_ZONE
#define SPICES_PROFILE_FRAME
virtual ~Application()
Destructor Function.
Application()
Constructor Function.
static void Run()
Run Our World.
Application Class. Our Engine Start here.
Definition Application.h:20
This Class is the basic Event Class. Inherit from it and create specific event class.
Definition Event.h:96
uint32_t m_PickMaterial
Identify of selected material.
Definition FrameInfo.h:89
FrameInfo(const FrameInfo &)=delete
Copy Constructor Function.
uint32_t m_FrameIndex
FrameIndex, varying during 0 - (MaxFrameInFlight - 1). Used almost anywhere.
Definition FrameInfo.h:69
FrameInfo & operator=(const FrameInfo &)=delete
Copy Assignment Operation.
virtual ~FrameInfo()=default
Destructor Function.
static FrameInfo & Get()
Get FrameInfo.
Definition FrameInfo.cpp:14
std::shared_ptr< World > m_World
The shared pointer of specific world.
Definition FrameInfo.h:94
scl::linked_unordered_map< int, std::string > m_PickEntityID
Definition FrameInfo.h:82
RendererType m_RendererType
The renderer type of current world.
Definition FrameInfo.h:99
FrameInfo()=default
Constructor Function.
uint32_t m_ImageIndex
ImageIndex, varying during 0 - (MaxFrameInFlight - 1). Used in swapchain index and framebuffer index.
Definition FrameInfo.h:75
FrameInfo Class. This class defines the FrameInfo data.
Definition FrameInfo.h:32
static void Init()
Init Log.
Definition Log.cpp:24
static void ShutDown()
Shutdown Log.
Definition Log.cpp:82
virtual std::string ToString() const override
Serialize this Event Class to string.
Definition WorldEvent.h:60
MeshAddedWorldEvent()=default
Constructor Function.
virtual ~MeshAddedWorldEvent() override=default
Destructor Function.
This Class is inherited from Event Class.
Definition WorldEvent.h:43
NativeScriptSystem Class. This class defines the specific behaves of NativeScriptSystem.
ResourceSystem Class. This class defines the specific behaves of RenderSystem.
RendererResourcePool Class. This class is a pool of all framebuffer's attachment.
ResourceSystem Class. Handles resource load/unload event.
This Class is inherited from Event Class. Called by Viewport Resize.
Definition SlateEvent.h:18
SlateSystem Class. This class defines the specific behaves of SlateSystem.
Definition SlateSystem.h:21
SystemManager()
Constructor Function.
static SystemManager & Get()
Get Static SystemManager.
SystemManager & PopSystem(const std::string &systemName)
Push a system to this manager.
SystemManager Class. This class defines the behave of SystemManager.
void Flush()
Refresh time in each engine loop.
Definition TimeStep.cpp:26
const uint64_t & fs() const
Get frames count.
Definition TimeStep.h:63
This Class handles our engine time step during frames. Global Unique.
Definition TimeStep.h:22
VulkanDescriptorPool Class. This class is the wrapper of VkDescriptorPool.
VkSampleCountFlagBits GetMaxUsableSampleCount() const
Get device's max usable sample count.
bool IsQueueMeetDemand(const VkPhysicalDevice &device, const VkSurfaceKHR &surface)
Check all Queue we need meet;.
static SwapChainSupportDetails QuerySwapChainSupport(const VkPhysicalDevice &device, const VkSurfaceKHR &surface, GLFWwindow *window)
Query physical device's SwapChainSupport.
const SwapChainSupportDetails & GetSwapChainSupport()
Get SwapChain Utils.
static VkPhysicalDeviceDeviceGeneratedCommandsPropertiesNV & GetDGCProperties()
Get DeviceGeneratedCommandsPropertiesNV.
QueueHelper m_QueueHelper
QueueHelper.
static VkPhysicalDeviceFeatures m_DeviceFeatures
Selected Physical Device Features.
static VkPhysicalDeviceProperties & GetDeviceProperties()
Get VkPhysicalDeviceProperties.
virtual ~VulkanDevice() override
Destructor Function.
static VkPhysicalDeviceRayTracingPipelinePropertiesKHR m_RayTracingProperties
Device RayTracing Properties.
static VkPhysicalDeviceFeatures & GetDeviceFeatures()
Get VkPhysicalDeviceFeatures.
bool IsPropertyMeetDemand(const VkPhysicalDevice &device)
Check all Property we need meet.
static VkPhysicalDeviceRayTracingPipelinePropertiesKHR & GetRTPipelineProperties()
Get RayTracingPipelineProperties.
bool IsFeatureMeetDemand(const VkPhysicalDevice &device)
Check all Feature we need meet.
void GetExtensionRequirements()
Get all physical device extension requirements our engine needed. Source 1 : user Setting.
static VkPhysicalDeviceProperties m_DeviceProperties
Selected Physical Device Properties.
static VkPhysicalDeviceDeviceGeneratedCommandsPropertiesNV m_DGCProperties
Device DGC Properties.
VulkanDevice(VulkanState &vulkanState)
Constructor Function. Create vkDevice.
bool SelectPhysicalDevice(const VkInstance &instance, const VkSurfaceKHR &surface, GLFWwindow *window)
select a suitable physical device.
SwapChainSupportDetails m_SwapChainSupportDetails
SwapChainSupportDetails.
bool IsExtensionMeetDemand(const VkPhysicalDevice &device)
Check all Extension we need meet;.
std::vector< const char * > m_ExtensionProperties
Device Extension Properties.
void RequerySwapChainSupport()
Requery device's SwapChainSupportDetails. Mainly VkExtent2D.
const QueueHelper & GetQueueHelper() const
Get QueueHelper variable.
VulkanInstance Class. This class defines the VulkanDevice behave. This class is just a wrapper of vkd...
void SetVulkanDebugCallbackFuncPointer()
Set Vulkan's debug message callback function pointer. Working with DEBUG mode.
virtual ~VulkanInstance() override
Destructor Function.
VkDebugUtilsMessengerCreateInfoEXT m_DebugMessengerCreateInfo
Debug Utils Messages used to execute message callback function. Also debug vkInstance create.
void CreateVulkanSurface() const
Create a Surface Object.
std::vector< const char * > m_LayerProperties
Instance Layer Properties.
VulkanInstance(VulkanState &vulkanState, const std::string &name, const std::string &engineName)
Constructor Function. Create vkInstance and vkSurface.
std::vector< const char * > m_ExtensionProperties
Instance Extension Properties.
bool CheckExtensionRequirementsSatisfied()
Iter all our extensions, check whether all satisfied or not.
VkDebugUtilsMessengerEXT m_DebugMessenger
Parameter for Create/Destroy DebugUtilsMessengerEXT.
void FillDebugMessengerCreateInfo()
Set m_DebugMessengerCreateInfo variable.
void GetExtensionRequirements()
Get all instance extension requirements our engine needed. Source 1 : glfw requirements....
bool ChecklayerRequirementsSatisfied()
Iter all our layers, check whether all satisfied or not.
void GetLayerRequirements()
Get all instance layer requirements our engine needed. Source 1 : user Setting.
VulkanInstance Class. This class defines the VulkanInstance behaves. This class is just a wrapper of ...
VulkanObject Class. This class defines the basic behaves of VulkanObject. When we create an new Vulka...
void EndFrame(FrameInfo &frameInfo)
End record the frame with vulkan render backend.
void RecreateSwapChain()
Called OnSlateResize.
std::shared_ptr< VulkanMemoryAllocator > m_VmaAllocator
VulkanMemoryAllocator.
std::unique_ptr< VulkanSwapChain > m_VulkanSwapChain
VulkanSwapChain.
virtual ~VulkanRenderBackend()
Destructor Function.
std::unique_ptr< VulkanCommandPool > m_VulkanCommandPool
VulkanCommandPool.
VulkanRenderBackend()
Constructor Function.
static std::shared_ptr< VulkanDescriptorPool > GetDescriptorPool()
Get DescriptorPool in use.
static VulkanState m_VulkanState
The VulkanState in use.
std::unique_ptr< VulkanCommandBuffer > m_VulkanCommandBuffer
VulkanCommandBuffer.
bool isWindowClosed()
Determine whether window is closed.
static std::shared_ptr< VulkanDescriptorPool > m_VulkanDescriptorPool
The VulkanDescriptorPool in use.
static std::shared_ptr< RendererResourcePool > m_RendererResourcePool
The RendererResourcePool in use.
static VulkanState & GetState()
Get VulkanState in use.
std::unique_ptr< VulkanWindows > m_VulkanWindows
VulkanWindows.
bool OnMeshAddedWorldEvent(WorldEvent &event)
This function is called on world mark query tick.
void RenderFrame(TimeStep &ts, FrameInfo &frameInfo)
Draw World.
void OnEvent(Event &event)
This function is called on global event function is called.
static std::shared_ptr< RendererResourcePool > GetRendererResourcePool()
Get RendererResourcePool in use.
void BeginFrame(FrameInfo &frameInfo)
Start record a new frame with vulkan render backend.
VulkanRenderBackend & operator=(const VulkanRenderBackend &)=delete
Copy Assignment Operation.
bool OnWindowResizeOver(WindowResizeOverEvent &event)
This function is called on window is resized over.
std::shared_ptr< VulkanDevice > m_VulkanDevice
VulkanDevice.
std::unique_ptr< VulkanInstance > m_VulkanInstance
VulkanInstance.
bool OnSlateResize(SlateResizeEvent &event)
This function is called on viewport is resized.
VulkanRenderBackend(const VulkanRenderBackend &)=delete
Copy Constructor Function.
This class defines the render backend behaves of Vulkan.
VulkanWindows(VulkanState &vulkanState, const WindowInfo &initInfo)
Constructor Function. Create Windows.
bool m_WindowsResized
True if viewPort is resized.
virtual ~VulkanWindows() override
Destructor Function.
void SetInternalCallBack() const
Set all needed GLFW events call back.
void SetResized(bool isResized)
Set m_WindowsResized variable.
WindowInfo m_WindowInfo
Window's info. not viewport's info.
bool IsResized() const
Get m_WindowsResized variable.
VulkanWindows Class. This class defines the windows behaves.
virtual ~WorldEvent() override=default
Destructor Function.
WorldEvent()=default
Constructor Function.
This Class is inherited from Event Class. Inherit from it and create specific KeyEvent class....
Definition WorldEvent.h:20
World Class. This class defines the basic behaves of World. When we create an new world,...
Definition World.h:41
The container combines hashmap and list together. Used in the case that we want iter a hashmap in ord...
@ EventCategoryWorld
Definition Event.h:68
@ MeshAdded
World Event.
RendererType
Definition FrameInfo.h:22
std::optional< uint32_t > graphicqueuefamily
The graphic queue's in used identify.
std::optional< uint32_t > presentqueuefamily
The present queue's in used identify.
std::optional< uint32_t > transferqueuefamily
The transfer queue's in used identify.
std::optional< uint32_t > computequeuefamily
The compute queue's in used identify.
bool isComplete() const
Whether all queues that we need is valid.
This struct contains all queues's identify we need.
VkExtent2D surfaceSize
The VkSurface Size.
std::vector< VkSurfaceFormatKHR > formats
All supported VkSurfaceFormatKHR.
VkSurfaceFormatKHR format
The selected VkSurfaceFormatKHR.
VkSurfaceCapabilitiesKHR capabilities
VkSurfaceCapabilitiesKHR.
VkPresentModeKHR presentMode
The selected VkPresentModeKHR.
VkExtent2D viewPortSize
The ViewPort Size. Init value. Reset by resize event.
std::vector< VkPresentModeKHR > presentModes
All supported VkPresentModeKHR.
SwapChain Utils. Queried from device.
This struct contains all Vulkan object in used global.
Definition VulkanUtils.h:74
GLFWimage image
GLFWimage.
WindowIcon(const std::string &iconPath)
Constructor Function. Load the icon file immediately.
virtual ~WindowIcon()
Destructor Function.
This struct helps load the icon of window.
std::shared_ptr< WindowIcon > icon
Window's icon.
std::string name
Window's name.
int width
Window's width.
int height
Window's height.
This struct defines the basic information of window.