stk-code_catmod/lib/graphics_engine/include/ge_vulkan_driver.hpp

552 lines
25 KiB
C++
Raw Normal View History

2021-06-09 13:02:24 -04:00
#ifndef __VULKAN_DRIVER_INCLUDED__
#define __VULKAN_DRIVER_INCLUDED__
#include "IrrCompileConfig.h"
#ifdef _IRR_COMPILE_WITH_VULKAN_
#include "vulkan_wrapper.h"
2022-07-11 00:58:03 -04:00
#include "ge_vma.hpp"
2021-06-09 13:02:24 -04:00
#include "SDL_video.h"
#include "../source/Irrlicht/CNullDriver.h"
#include "SIrrCreationParameters.h"
#include "SColor.h"
2022-03-19 03:14:55 -04:00
#include <array>
2022-03-01 02:59:48 -05:00
#include <memory>
#include <mutex>
#include <set>
2021-06-09 13:02:24 -04:00
#include <string>
#include <vector>
using namespace irr;
using namespace video;
namespace GE
{
2022-09-14 04:19:38 -04:00
class GESPM;
2022-07-10 02:48:07 -04:00
class GEVulkanDepthTexture;
class GEVulkanDrawCall;
class GEVulkanDynamicSPMBuffer;
class GEVulkanFBOTexture;
class GEVulkanMeshCache;
2022-07-21 00:26:06 -04:00
class GEVulkanTextureDescriptor;
2022-01-23 03:43:33 -05:00
enum GEVulkanSampler : unsigned
{
2022-03-19 03:14:55 -04:00
GVS_MIN = 0,
GVS_NEAREST = GVS_MIN,
2022-08-21 02:09:56 -04:00
GVS_SKYBOX,
2022-07-22 22:58:37 -04:00
GVS_3D_MESH_MIPMAP_2,
GVS_3D_MESH_MIPMAP_4,
GVS_3D_MESH_MIPMAP_16,
2022-04-19 01:18:59 -04:00
GVS_2D_RENDER,
2022-03-19 03:14:55 -04:00
GVS_COUNT,
2022-01-23 03:43:33 -05:00
};
2021-06-09 13:02:24 -04:00
class GEVulkanDriver : public video::CNullDriver
{
public:
//! constructor
GEVulkanDriver(const SIrrlichtCreationParameters& params, io::IFileSystem* io, SDL_Window* window,
IrrlichtDevice* device);
2021-06-09 13:02:24 -04:00
//! destructor
virtual ~GEVulkanDriver();
//! applications must call this method before performing any rendering. returns false if failed.
virtual bool beginScene(bool backBuffer=true, bool zBuffer=true,
SColor color=SColor(255,0,0,0),
const SExposedVideoData& videoData=SExposedVideoData(),
2022-03-19 03:14:55 -04:00
core::rect<s32>* sourceRect=0);
2021-06-09 13:02:24 -04:00
//! applications must call this method after performing any rendering. returns false if failed.
2022-03-19 03:14:55 -04:00
virtual bool endScene();
2021-06-09 13:02:24 -04:00
//! queries the features of the driver, returns true if feature is available
virtual bool queryFeature(E_VIDEO_DRIVER_FEATURE feature) const { return true; }
//! sets transformation
virtual void setTransform(E_TRANSFORMATION_STATE state, const core::matrix4& mat) {}
//! sets a material
2022-03-19 03:14:55 -04:00
virtual void setMaterial(const SMaterial& material) { Material = material; }
2021-06-09 13:02:24 -04:00
//! sets a render target
virtual bool setRenderTarget(video::ITexture* texture,
bool clearBackBuffer=true, bool clearZBuffer=true,
SColor color=video::SColor(0,0,0,0));
2021-06-09 13:02:24 -04:00
//! Sets multiple render targets
virtual bool setRenderTarget(const core::array<video::IRenderTarget>& texture,
bool clearBackBuffer=true, bool clearZBuffer=true,
SColor color=video::SColor(0,0,0,0)) { return true; }
//! sets a viewport
virtual void setViewPort(const core::rect<s32>& area);
2021-06-09 13:02:24 -04:00
//! gets the area of the current viewport
virtual const core::rect<s32>& getViewPort() const { return m_viewport; }
2021-06-09 13:02:24 -04:00
//! updates hardware buffer if needed
virtual bool updateHardwareBuffer(SHWBufferLink *HWBuffer) { return false; }
//! Create hardware buffer from mesh
virtual SHWBufferLink *createHardwareBuffer(const scene::IMeshBuffer* mb) { return NULL; }
//! Delete hardware buffer (only some drivers can)
virtual void deleteHardwareBuffer(SHWBufferLink *HWBuffer) {}
//! Draw hardware buffer
virtual void drawHardwareBuffer(SHWBufferLink *HWBuffer) {}
//! Create occlusion query.
/** Use node for identification and mesh for occlusion test. */
virtual void addOcclusionQuery(scene::ISceneNode* node,
const scene::IMesh* mesh=0) {}
//! Remove occlusion query.
virtual void removeOcclusionQuery(scene::ISceneNode* node) {}
//! Run occlusion query. Draws mesh stored in query.
/** If the mesh shall not be rendered visible, use
overrideMaterial to disable the color and depth buffer. */
virtual void runOcclusionQuery(scene::ISceneNode* node, bool visible=false) {}
//! Update occlusion query. Retrieves results from GPU.
/** If the query shall not block, set the flag to false.
Update might not occur in this case, though */
virtual void updateOcclusionQuery(scene::ISceneNode* node, bool block=true) {}
//! Return query result.
/** Return value is the number of visible pixels/fragments.
The value is a safe approximation, i.e. can be larger then the
actual value of pixels. */
virtual u32 getOcclusionQueryResult(scene::ISceneNode* node) const { return 0; }
//! draws a vertex primitive list
virtual void drawVertexPrimitiveList(const void* vertices, u32 vertexCount,
const void* indexList, u32 primitiveCount,
E_VERTEX_TYPE vType, scene::E_PRIMITIVE_TYPE pType,
E_INDEX_TYPE iType) {}
//! draws a vertex primitive list in 2d
virtual void draw2DVertexPrimitiveList(const void* vertices, u32 vertexCount,
const void* indexList, u32 primitiveCount,
E_VERTEX_TYPE vType, scene::E_PRIMITIVE_TYPE pType,
2022-03-19 03:14:55 -04:00
E_INDEX_TYPE iType);
2021-06-09 13:02:24 -04:00
//! draws an 2d image, using a color (if color is other then Color(255,255,255,255)) and the alpha channel of the texture if wanted.
virtual void draw2DImage(const video::ITexture* texture, const core::position2d<s32>& destPos,
const core::rect<s32>& sourceRect, const core::rect<s32>* clipRect = 0,
2022-03-19 03:14:55 -04:00
SColor color=SColor(255,255,255,255), bool useAlphaChannelOfTexture=false);
2021-06-09 13:02:24 -04:00
//! Draws a part of the texture into the rectangle.
virtual void draw2DImage(const video::ITexture* texture, const core::rect<s32>& destRect,
const core::rect<s32>& sourceRect, const core::rect<s32>* clipRect = 0,
2022-03-19 03:14:55 -04:00
const video::SColor* const colors=0, bool useAlphaChannelOfTexture=false);
2021-06-09 13:02:24 -04:00
//! Draws a set of 2d images, using a color and the alpha channel of the texture.
virtual void draw2DImageBatch(const video::ITexture* texture,
const core::array<core::position2d<s32> >& positions,
const core::array<core::rect<s32> >& sourceRects,
const core::rect<s32>* clipRect=0,
SColor color=SColor(255,255,255,255),
2022-03-19 03:14:55 -04:00
bool useAlphaChannelOfTexture=false);
2021-06-09 13:02:24 -04:00
//!Draws an 2d rectangle with a gradient.
virtual void draw2DRectangle(const core::rect<s32>& pos,
SColor colorLeftUp, SColor colorRightUp, SColor colorLeftDown, SColor colorRightDown,
const core::rect<s32>* clip)
{
SColor color[4] = { colorLeftUp, colorLeftDown, colorRightDown, colorRightUp };
draw2DImage(m_white_texture, pos, core::recti(0, 0, 2, 2), clip, color, true);
}
2021-06-09 13:02:24 -04:00
//! Draws a 2d line.
virtual void draw2DLine(const core::position2d<s32>& start,
const core::position2d<s32>& end,
SColor color=SColor(255,255,255,255)) {}
//! Draws a pixel.
virtual void drawPixel(u32 x, u32 y, const SColor & color) {}
//! Draws a 3d line.
virtual void draw3DLine(const core::vector3df& start,
const core::vector3df& end, SColor color = SColor(255,255,255,255)) {}
//! \return Returns the name of the video driver. Example: In case of the DIRECT3D8
//! driver, it would return "Direct3D8.1".
virtual const wchar_t* getName() const { return L""; }
//! deletes all dynamic lights there are
virtual void deleteAllDynamicLights() {}
//! adds a dynamic light, returning an index to the light
//! \param light: the light data to use to create the light
//! \return An index to the light, or -1 if an error occurs
virtual s32 addDynamicLight(const SLight& light) { return -1; }
//! Turns a dynamic light on or off
//! \param lightIndex: the index returned by addDynamicLight
//! \param turnOn: true to turn the light on, false to turn it off
virtual void turnLightOn(s32 lightIndex, bool turnOn) {}
//! returns the maximal amount of dynamic lights the device can handle
virtual u32 getMaximalDynamicLightAmount() const { return (u32)-1; }
//! Sets the dynamic ambient light color. The default color is
//! (0,0,0,0) which means it is dark.
//! \param color: New color of the ambient light.
virtual void setAmbientLight(const SColorf& color) {}
//! Draws a shadow volume into the stencil buffer.
virtual void drawStencilShadowVolume(const core::array<core::vector3df>& triangles, bool zfail=true, u32 debugDataVisible=0) {}
//! Fills the stencil shadow with color.
virtual void drawStencilShadow(bool clearStencilBuffer=false,
video::SColor leftUpEdge = video::SColor(0,0,0,0),
video::SColor rightUpEdge = video::SColor(0,0,0,0),
video::SColor leftDownEdge = video::SColor(0,0,0,0),
video::SColor rightDownEdge = video::SColor(0,0,0,0)) {}
//! Returns the maximum amount of primitives (mostly vertices) which
//! the device is able to render with one drawIndexedTriangleList
//! call.
virtual u32 getMaximalPrimitiveCount() const { return (u32)-1; }
//! Enables or disables a texture creation flag.
virtual void setTextureCreationFlag(E_TEXTURE_CREATION_FLAG flag, bool enabled) {}
//! Sets the fog mode.
virtual void setFog(SColor color, E_FOG_TYPE fogType, f32 start,
f32 end, f32 density, bool pixelFog, bool rangeFog) {}
//! Only used by the internal engine. Used to notify the driver that
//! the window was resized.
2021-12-28 00:51:03 -05:00
virtual void OnResize(const core::dimension2d<u32>& size);
2021-06-09 13:02:24 -04:00
//! Returns type of video driver
virtual E_DRIVER_TYPE getDriverType() const { return video::EDT_VULKAN; }
//! Returns the transformation set by setTransform
virtual const core::matrix4& getTransform(E_TRANSFORMATION_STATE state) const
{
static core::matrix4 unused;
return unused;
}
//! Creates a render target texture.
virtual ITexture* addRenderTargetTexture(const core::dimension2d<u32>& size,
const io::path& name, const ECOLOR_FORMAT format = ECF_UNKNOWN, const bool useStencil = false);
2021-06-09 13:02:24 -04:00
//! Clears the ZBuffer.
virtual void clearZBuffer() {}
//! Returns an image created from the last rendered frame.
virtual IImage* createScreenShot(video::ECOLOR_FORMAT format=video::ECF_UNKNOWN, video::E_RENDER_TARGET target=video::ERT_FRAME_BUFFER) { return NULL; }
//! Set/unset a clipping plane.
virtual bool setClipPlane(u32 index, const core::plane3df& plane, bool enable=false) { return true; }
//! Enable/disable a clipping plane.
virtual void enableClipPlane(u32 index, bool enable) {}
//! Returns the graphics card vendor name.
virtual core::stringc getVendorInfo()
{
switch (m_properties.vendorID)
{
case 0x1002: return "AMD";
case 0x1010: return "ImgTec";
case 0x106B: return "Apple";
case 0x10DE: return "NVIDIA";
case 0x13B5: return "ARM";
case 0x14e4: return "Broadcom";
case 0x5143: return "Qualcomm";
case 0x8086: return "INTEL";
// llvmpipe
case 0x10005: return "Mesa";
default: return "Unknown";
}
}
//! Enable the 2d override material
virtual void enableMaterial2D(bool enable=true) {}
//! Check if the driver was recently reset.
virtual bool checkDriverReset() { return false; }
//! Get the current color format of the color buffer
/** \return Color format of the color buffer. */
virtual ECOLOR_FORMAT getColorFormat() const { return ECF_A8R8G8B8; }
//! Returns the maximum texture size supported.
virtual core::dimension2du getMaxTextureSize() const { return core::dimension2du(16384, 16384); }
2022-03-20 23:54:28 -04:00
virtual void enableScissorTest(const core::rect<s32>& r) { m_clip = r; }
core::rect<s32> getFullscreenClip() const
{
return core::rect<s32>(0, 0, ScreenSize.Width, ScreenSize.Height);
}
virtual void disableScissorTest() { m_clip = getFullscreenClip(); }
2022-03-19 03:14:55 -04:00
virtual const core::dimension2d<u32>& getCurrentRenderTargetSize() const { return ScreenSize; }
2022-01-23 03:43:33 -05:00
VkSampler getSampler(GEVulkanSampler s) const
{
2022-03-19 03:14:55 -04:00
if (s >= GVS_COUNT)
2022-01-23 03:43:33 -05:00
return VK_NULL_HANDLE;
2022-03-19 03:14:55 -04:00
return m_vk->samplers[s];
2022-03-01 02:59:48 -05:00
}
VkDevice getDevice() const { return m_vk->device; }
2022-03-18 04:24:33 -04:00
void destroyVulkan();
2022-07-12 03:46:33 -04:00
bool createBuffer(VkDeviceSize size, VkBufferUsageFlags usage,
VmaAllocationCreateInfo& alloc_create_info,
VkBuffer& buffer, VmaAllocation& buffer_allocation);
2022-03-01 00:22:20 -05:00
VkPhysicalDevice getPhysicalDevice() const { return m_physical_device; }
const VkPhysicalDeviceFeatures& getPhysicalDeviceFeatures() const
{ return m_features; }
2022-03-18 04:24:33 -04:00
const VkPhysicalDeviceProperties& getPhysicalDeviceProperties() const
{ return m_properties; }
2022-03-19 03:14:55 -04:00
VkExtent2D getSwapChainExtent() const { return m_swap_chain_extent; }
size_t getSwapChainImagesCount() const
{ return m_vk->swap_chain_images.size(); }
VkRenderPass getRenderPass() const { return m_vk->render_pass; }
void copyBuffer(VkBuffer src_buffer, VkBuffer dst_buffer, VkDeviceSize size);
VkCommandBuffer getCurrentCommandBuffer()
{ return m_vk->command_buffers[m_current_frame]; }
std::vector<VkImage>& getSwapChainImages()
{ return m_vk->swap_chain_images; }
std::vector<VkFramebuffer>& getSwapChainFramebuffers()
{ return m_vk->swap_chain_framebuffers; }
unsigned int getCurrentFrame() const { return m_current_frame; }
unsigned int getCurrentImageIndex() const { return m_image_index; }
constexpr static unsigned getMaxFrameInFlight() { return 2; }
video::SColor getClearColor() const { return m_clear_color; }
video::SColor getRTTClearColor() const { return m_rtt_clear_color; }
2022-03-20 23:54:28 -04:00
const core::rect<s32>& getCurrentClip() const { return m_clip; }
video::ITexture* getWhiteTexture() const { return m_white_texture; }
video::ITexture* getTransparentTexture() const
{ return m_transparent_texture; }
void getRotatedRect2D(VkRect2D* rect);
2022-08-27 00:49:17 -04:00
void getRotatedViewport(VkViewport* vp, bool handle_rtt);
const core::matrix4& getPreRotationMatrix()
{ return m_pre_rotation_matrix; }
virtual void pauseRendering();
virtual void unpauseRendering();
void updateSwapInterval(int value)
{
if (m_params.SwapInterval == value)
return;
m_params.SwapInterval = value;
destroySwapChainRelated(false/*handle_surface*/);
createSwapChainRelated(false/*handle_surface*/);
}
void updateRenderScale(float value);
uint32_t getGraphicsFamily() const { return m_graphics_family; }
unsigned getGraphicsQueueCount() const
{ return m_graphics_queue_count; }
std::unique_lock<std::mutex> getGraphicsQueue(VkQueue* queue) const;
void waitIdle(bool flush_command_loader = false);
void setDisableWaitIdle(bool val) { m_disable_wait_idle = val; }
IrrlichtDevice* getIrrlichtDevice() const { return m_irrlicht_device; }
2022-07-10 02:48:07 -04:00
GEVulkanDepthTexture* getDepthTexture() const { return m_depth_texture; }
VkFormat findSupportedFormat(const std::vector<VkFormat>& candidates,
VkImageTiling tiling,
VkFormatFeatureFlags features);
2022-07-11 00:58:03 -04:00
VmaAllocator getVmaAllocator() const { return m_vk->allocator; }
2022-07-19 03:56:08 -04:00
GEVulkanMeshCache* getVulkanMeshCache() const;
2022-07-21 00:26:06 -04:00
GEVulkanTextureDescriptor* getMeshTextureDescriptor() const
{ return m_mesh_texture_descriptor; }
GEVulkanFBOTexture* getRTTTexture() const { return m_rtt_texture; }
2022-08-27 00:49:17 -04:00
GEVulkanFBOTexture* getSeparateRTTTexture() const
{ return m_separate_rtt_texture; }
void handleDeletedTextures();
void addRTTPolyCount(unsigned count) { m_rtt_polycount += count; }
SDL_Window* getSDLWindow() const { return m_window; }
void clearDrawCallsCache();
void addDrawCallToCache(std::unique_ptr<GEVulkanDrawCall>& dc);
std::unique_ptr<GEVulkanDrawCall> getDrawCallFromCache();
2022-09-14 04:19:38 -04:00
GESPM* getBillboardQuad() const { return m_billboard_quad; }
int getCurrentBufferIdx() const { return m_current_buffer_idx; }
void addDynamicSPMBuffer(GEVulkanDynamicSPMBuffer* buffer)
{ m_dynamic_spm_buffers.insert(buffer); }
void removeDynamicSPMBuffer(GEVulkanDynamicSPMBuffer* buffer)
{ m_dynamic_spm_buffers.erase(buffer); }
2021-06-09 13:02:24 -04:00
private:
2021-12-28 00:51:03 -05:00
struct SwapChainSupportDetails
{
VkSurfaceCapabilitiesKHR capabilities;
std::vector<VkSurfaceFormatKHR> formats;
std::vector<VkPresentModeKHR> presentModes;
};
2021-06-09 13:02:24 -04:00
//! returns a device dependent texture from a software surface (IImage)
//! THIS METHOD HAS TO BE OVERRIDDEN BY DERIVED DRIVERS WITH OWN TEXTURES
virtual video::ITexture* createDeviceDependentTexture(IImage* surface, const io::path& name, void* mipmapData=0) { return NULL; }
//! Adds a new material renderer to the VideoDriver, based on a high level shading
//! language.
virtual s32 addHighLevelShaderMaterial(
const c8* vertexShaderProgram,
const c8* vertexShaderEntryPointName,
E_VERTEX_SHADER_TYPE vsCompileTarget,
const c8* pixelShaderProgram,
const c8* pixelShaderEntryPointName,
E_PIXEL_SHADER_TYPE psCompileTarget,
const c8* geometryShaderProgram,
const c8* geometryShaderEntryPointName = "main",
E_GEOMETRY_SHADER_TYPE gsCompileTarget = EGST_GS_4_0,
scene::E_PRIMITIVE_TYPE inType = scene::EPT_TRIANGLES,
scene::E_PRIMITIVE_TYPE outType = scene::EPT_TRIANGLE_STRIP,
u32 verticesOut = 0,
IShaderConstantSetCallBack* callback = 0,
E_MATERIAL_TYPE baseMaterial = video::EMT_SOLID,
s32 userData = 0,
E_GPU_SHADING_LANGUAGE shadingLang = EGSL_DEFAULT) { return 0; }
2021-12-28 00:51:03 -05:00
SIrrlichtCreationParameters m_params;
2022-03-19 03:14:55 -04:00
SMaterial Material;
2021-06-09 13:02:24 -04:00
// RAII to auto cleanup
struct VK
{
VkInstance instance;
2022-07-10 03:36:27 -04:00
VkDebugUtilsMessengerEXT debug;
2021-06-09 13:02:24 -04:00
VkSurfaceKHR surface;
VkDevice device;
2022-07-11 00:58:03 -04:00
VmaAllocator allocator;
2021-12-28 00:51:03 -05:00
VkSwapchainKHR swap_chain;
std::vector<VkImage> swap_chain_images;
std::vector<VkImageView> swap_chain_image_views;
std::vector<VkSemaphore> image_available_semaphores;
std::vector<VkSemaphore> render_finished_semaphores;
std::vector<VkFence> in_flight_fences;
std::vector<VkCommandPool> command_pools;
std::vector<VkCommandBuffer> command_buffers;
2022-03-19 03:14:55 -04:00
std::array<VkSampler, GVS_COUNT> samplers;
VkRenderPass render_pass;
std::vector<VkFramebuffer> swap_chain_framebuffers;
2021-06-09 13:02:24 -04:00
VK()
{
instance = VK_NULL_HANDLE;
2022-07-10 03:36:27 -04:00
debug = VK_NULL_HANDLE;
2021-06-09 13:02:24 -04:00
surface = VK_NULL_HANDLE;
device = VK_NULL_HANDLE;
2022-07-11 00:58:03 -04:00
allocator = VK_NULL_HANDLE;
2021-12-28 00:51:03 -05:00
swap_chain = VK_NULL_HANDLE;
2022-03-19 03:14:55 -04:00
samplers = {{}};
render_pass = VK_NULL_HANDLE;
2021-06-09 13:02:24 -04:00
}
~VK()
{
for (unsigned i = 0; i < command_buffers.size(); i++)
{
vkFreeCommandBuffers(device, command_pools[i], 1,
&command_buffers[i]);
vkDestroyCommandPool(device, command_pools[i], NULL);
}
2022-03-19 03:14:55 -04:00
for (VkFramebuffer& framebuffer : swap_chain_framebuffers)
vkDestroyFramebuffer(device, framebuffer, NULL);
if (render_pass != VK_NULL_HANDLE)
vkDestroyRenderPass(device, render_pass, NULL);
2022-07-23 03:10:45 -04:00
if (device != VK_NULL_HANDLE)
{
for (unsigned i = 0; i < GVS_COUNT; i++)
vkDestroySampler(device, samplers[i], NULL);
}
for (VkSemaphore& semaphore : image_available_semaphores)
vkDestroySemaphore(device, semaphore, NULL);
for (VkSemaphore& semaphore : render_finished_semaphores)
vkDestroySemaphore(device, semaphore, NULL);
for (VkFence& fence : in_flight_fences)
vkDestroyFence(device, fence, NULL);
2021-12-28 00:51:03 -05:00
for (VkImageView& image_view : swap_chain_image_views)
vkDestroyImageView(device, image_view, NULL);
if (swap_chain != VK_NULL_HANDLE)
vkDestroySwapchainKHR(device, swap_chain, NULL);
2022-07-11 00:58:03 -04:00
if (allocator != VK_NULL_HANDLE)
vmaDestroyAllocator(allocator);
2021-06-09 13:02:24 -04:00
if (device != VK_NULL_HANDLE)
vkDestroyDevice(device, NULL);
if (surface != VK_NULL_HANDLE)
vkDestroySurfaceKHR(instance, surface, NULL);
2022-07-10 03:36:27 -04:00
if (vkDestroyDebugUtilsMessengerEXT && debug != VK_NULL_HANDLE)
vkDestroyDebugUtilsMessengerEXT(instance, debug, NULL);
2021-06-09 13:02:24 -04:00
if (instance != VK_NULL_HANDLE)
vkDestroyInstance(instance, NULL);
}
};
2022-03-01 02:59:48 -05:00
std::unique_ptr<VK> m_vk;
2021-12-28 00:51:03 -05:00
VkFormat m_swap_chain_image_format;
VkExtent2D m_swap_chain_extent;
2021-06-09 13:02:24 -04:00
VkPhysicalDevice m_physical_device;
std::vector<const char*> m_device_extensions;
VkSurfaceCapabilitiesKHR m_surface_capabilities;
std::vector<VkSurfaceFormatKHR> m_surface_formats;
std::vector<VkPresentModeKHR> m_present_modes;
std::vector<VkQueue> m_graphics_queue;
2021-06-09 13:02:24 -04:00
VkQueue m_present_queue;
mutable std::vector<std::mutex*> m_graphics_queue_mutexes;
2021-06-09 13:02:24 -04:00
uint32_t m_graphics_family;
uint32_t m_present_family;
unsigned m_graphics_queue_count;
2021-06-09 13:02:24 -04:00
VkPhysicalDeviceProperties m_properties;
VkPhysicalDeviceFeatures m_features;
2022-03-19 03:14:55 -04:00
unsigned int m_current_frame;
uint32_t m_image_index;
video::SColor m_clear_color, m_rtt_clear_color;
2022-03-20 23:54:28 -04:00
core::rect<s32> m_clip;
core::rect<s32> m_viewport;
core::matrix4 m_pre_rotation_matrix;
2022-03-19 03:14:55 -04:00
video::ITexture* m_white_texture;
video::ITexture* m_transparent_texture;
SDL_Window* m_window;
bool m_disable_wait_idle;
IrrlichtDevice* m_irrlicht_device;
2022-07-10 02:48:07 -04:00
GEVulkanDepthTexture* m_depth_texture;
2022-07-21 00:26:06 -04:00
GEVulkanTextureDescriptor* m_mesh_texture_descriptor;
GEVulkanFBOTexture* m_rtt_texture;
2022-08-27 00:49:17 -04:00
GEVulkanFBOTexture* m_prev_rtt_texture;
GEVulkanFBOTexture* m_separate_rtt_texture;
u32 m_rtt_polycount;
std::vector<std::unique_ptr<GEVulkanDrawCall> > m_draw_calls_cache;
2022-09-14 04:19:38 -04:00
GESPM* m_billboard_quad;
int m_current_buffer_idx;
std::set<GEVulkanDynamicSPMBuffer*> m_dynamic_spm_buffers;
2021-06-09 13:02:24 -04:00
void createInstance(SDL_Window* window);
void findPhysicalDevice();
bool checkDeviceExtensions(VkPhysicalDevice device);
bool findQueueFamilies(VkPhysicalDevice device, uint32_t* graphics_family, unsigned* graphics_queue_count, uint32_t* present_family);
2021-06-09 13:02:24 -04:00
bool updateSurfaceInformation(VkPhysicalDevice device,
VkSurfaceCapabilitiesKHR* surface_capabilities,
std::vector<VkSurfaceFormatKHR>* surface_formats,
std::vector<VkPresentModeKHR>* present_modes);
void createDevice();
2021-12-28 00:51:03 -05:00
void createSwapChain();
void createSyncObjects();
void createCommandBuffers();
2022-01-23 03:43:33 -05:00
void createSamplers();
2022-03-19 03:14:55 -04:00
void createRenderPass();
void createFramebuffers();
void createUnicolorTextures();
void initPreRotationMatrix();
2021-06-09 13:02:24 -04:00
std::string getVulkanVersionString() const;
std::string getDriverVersionString() const;
void destroySwapChainRelated(bool handle_surface);
void createSwapChainRelated(bool handle_surface);
void buildCommandBuffers();
2022-09-14 04:19:38 -04:00
void createBillboardQuad();
2021-06-09 13:02:24 -04:00
};
}
#endif // _IRR_COMPILE_WITH_VULKAN_
#endif // __VULKAN_DRIVER_INCLUDED__