ULRE/inc/hgl/graph/VK.h

248 lines
5.1 KiB
C
Raw Normal View History

#ifndef HGL_GRAPH_VULKAN_INCLUDE
#define HGL_GRAPH_VULKAN_INCLUDE
#include<hgl/math/Math.h>
#include<hgl/type/List.h>
2020-11-05 14:02:35 +08:00
#include<hgl/type/String.h>
#include<hgl/type/Map.h>
#include<iostream>
#include<hgl/graph/VKNamespace.h>
#include<hgl/graph/VKFormat.h>
2022-06-24 17:51:05 +08:00
#include<hgl/graph/VKPrimitiveType.h>
#include<hgl/graph/VKStruct.h>
#include<hgl/graph/VKRenderbufferInfo.h>
VK_NAMESPACE_BEGIN
2021-09-13 20:39:25 +08:00
#ifndef VK_DESCRIPTOR_TYPE_BEGIN_RANGE
constexpr size_t VK_DESCRIPTOR_TYPE_BEGIN_RANGE=VK_DESCRIPTOR_TYPE_SAMPLER;
#endif//VK_DESCRIPTOR_TYPE_BEGIN_RANGE
#ifndef VK_DESCRIPTOR_TYPE_END_RANGE
constexpr size_t VK_DESCRIPTOR_TYPE_END_RANGE=VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT;
#endif//VK_DESCRIPTOR_TYPE_END_RANGE
#ifndef VK_DESCRIPTOR_TYPE_RANGE_SIZE
constexpr size_t VK_DESCRIPTOR_TYPE_RANGE_SIZE=VK_DESCRIPTOR_TYPE_END_RANGE-VK_DESCRIPTOR_TYPE_BEGIN_RANGE+1;
#endif//VK_DESCRIPTOR_TYPE_RANGE_SIZE
2019-11-13 20:50:34 +08:00
using CharPointerList=hgl::List<const char *>;
using BindingMapping=Map<uint32_t,int>;
2019-11-13 20:50:34 +08:00
2020-10-21 12:39:22 +08:00
class VulkanInstance;
class GPUPhysicalDevice;
class GPUDevice;
struct GPUDeviceAttribute;
class DeviceQueue;
class ImageView;
class Framebuffer;
struct Swapchain;
class RenderTarget;
class SwapchainRenderTarget;
class Texture;
2019-05-18 15:41:49 +08:00
class Texture1D;
class Texture1DArray;
class Texture2D;
class Texture2DArray;
class Texture3D;
class TextureCube;
class TextureCubeArray;
2019-05-18 15:41:49 +08:00
2019-05-18 16:10:42 +08:00
class Sampler;
class DeviceMemory;
class DeviceBuffer;
struct DeviceBufferData;
class VertexAttribBuffer;
2021-11-29 15:58:48 +08:00
using VBO=VertexAttribBuffer;
class IndexBuffer;
2020-10-21 12:39:22 +08:00
class GPUCmdBuffer;
class RenderCmdBuffer;
class TextureCmdBuffer;
2021-09-22 15:32:20 +08:00
class RenderPass;
class DeviceRenderPassManage;
2022-10-14 19:27:29 +08:00
class Fence;
class Semaphore;
2021-09-14 20:31:15 +08:00
struct PipelineLayoutData;
class DescriptorSet;
2020-07-20 17:31:33 +08:00
struct ShaderStage;
class ShaderResource;
class ShaderModule;
class VertexShaderModule;
2021-06-16 20:29:25 +08:00
class ShaderModuleMap;
2021-09-13 20:39:25 +08:00
class MaterialDescriptorSets;
2021-06-16 20:29:25 +08:00
class Material;
class MaterialParameters;
2021-06-16 20:29:25 +08:00
class MaterialInstance;
struct PipelineData;
enum class InlinePipeline;
class Pipeline;
2021-11-29 17:04:55 +08:00
struct VAConfig
{
2023-02-21 18:36:42 +08:00
VkFormat format;
bool instance;
public:
2023-02-21 18:36:42 +08:00
VAConfig()
{
format=PF_UNDEFINED;
instance=false;
}
VAConfig(const VkFormat fmt,bool inst=false)
{
format=fmt;
instance=inst;
}
CompOperatorMemcmp(const VAConfig &);
};
2023-02-21 18:36:42 +08:00
class VILConfig:public Map<AnsiString,VAConfig>
{
public:
using Map<AnsiString,VAConfig>::Map;
bool Add(const AnsiString &name,const VkFormat fmt,const bool inst=false)
{
return Map<AnsiString,VAConfig>::Add(name,VAConfig(fmt,inst));
}
};
class VertexInputLayout;
using VIL=VertexInputLayout;
2022-06-24 17:51:05 +08:00
class Primitive;
class Renderable;
2020-10-21 12:39:22 +08:00
class RenderResource;
2020-09-02 18:27:19 +08:00
enum class SharingMode
{
Exclusive = 0,
Concurrent
};//
2020-10-23 21:21:09 +08:00
enum class Filter
{
Nearest=0,
Linear,
};//
2020-09-02 18:36:24 +08:00
enum ImageTiling
{
Optimal=0,
Linear
};//
inline const uint32_t GetMipLevel(const VkExtent2D &ext)
{
return hgl::GetMipLevel(ext.width,ext.height);
}
inline const uint32_t GetMipLevel(const VkExtent3D &ext)
{
return hgl::GetMipLevel(ext.width,ext.height,ext.depth);
}
2021-09-28 20:26:36 +08:00
/**
* ,VkIndexType
*/
enum IndexType
{
U16=0,
U32
};
/**
* max-lengths:
*
256 bytes: nvidia,arm
128 bytes: amd,intel,powervr,adreno
*/
struct PushConstant
{
Matrix4f local_to_world;
Matrix4f normal;
};
2020-06-09 19:40:08 +08:00
constexpr uint32_t MAX_PUSH_CONSTANT_BYTES=sizeof(PushConstant);
2020-06-24 19:13:29 +08:00
inline void copy(VkExtent3D &e3d,const VkExtent2D &e2d,const uint32 depth=1)
{
e3d.width =e2d.width;
e3d.height =e2d.height;
2020-06-24 19:13:29 +08:00
e3d.depth =depth;
}
2020-10-28 17:28:07 +08:00
inline void debug_out_vk_version(const uint32_t version)
{
std::cout<<VK_VERSION_MAJOR(version)<<"."
<<VK_VERSION_MINOR(version)<<"."
<<VK_VERSION_PATCH(version);
}
2020-11-05 14:02:35 +08:00
template<typename T>
inline hgl::String<T> VkUUID2String(const uint8_t *pipelineCacheUUID)
{
T *hstr=new T[VK_UUID_SIZE*2+1];
DataToLowerHexStr(hstr,pipelineCacheUUID,VK_UUID_SIZE);
return hgl::String<T>::newOf(hstr,VK_UUID_SIZE*2);
}
2020-10-28 17:28:07 +08:00
inline void debug_out(const char *front,const hgl::List<VkLayerProperties> &layer_properties)
{
const int property_count=layer_properties.GetCount();
if(property_count<=0)return;
const VkLayerProperties *lp=layer_properties.GetData();
for(int i=0;i<property_count;i++)
{
2020-10-28 17:28:07 +08:00
std::cout<<front<<" Layer Propertyes ["<<i<<"] : "<<lp->layerName<<" [spec: ";
debug_out_vk_version(lp->specVersion);
std::cout<<", impl: ";
debug_out_vk_version(lp->implementationVersion);
std::cout<<"] desc: "<<lp->description<<std::endl;
++lp;
}
}
2020-10-28 17:28:07 +08:00
inline void debug_out(const char *front,const hgl::List<VkExtensionProperties> &extension_properties)
{
const int extension_count=extension_properties.GetCount();
if(extension_count<=0)return;
VkExtensionProperties *ep=extension_properties.GetData();
for(int i=0;i<extension_count;i++)
{
2020-10-28 17:28:07 +08:00
std::cout<<front<<" Extension Propertyes ["<<i<<"] : "<<ep->extensionName<<" ver: ";
debug_out_vk_version(ep->specVersion);
std::cout<<std::endl;
++ep;
}
}
VK_NAMESPACE_END
#endif//HGL_GRAPH_VULKAN_INCLUDE