2021-01-11 01:24:15 +09:00
|
|
|
#ifndef __QF_Vulkan_barrier_h
|
|
|
|
#define __QF_Vulkan_barrier_h
|
|
|
|
|
|
|
|
typedef struct {
|
2021-04-24 12:42:29 +09:00
|
|
|
VkPipelineStageFlags srcStages;
|
|
|
|
VkPipelineStageFlags dstStages;
|
|
|
|
VkImageMemoryBarrier barrier;
|
|
|
|
} qfv_imagebarrier_t;
|
2021-01-11 01:24:15 +09:00
|
|
|
|
2021-04-24 15:47:31 +09:00
|
|
|
typedef struct {
|
|
|
|
VkPipelineStageFlags srcStages;
|
|
|
|
VkPipelineStageFlags dstStages;
|
|
|
|
VkBufferMemoryBarrier barrier;
|
|
|
|
} qfv_bufferbarrier_t;
|
|
|
|
|
2021-12-16 22:53:19 +09:00
|
|
|
// image layout transitions
|
2021-01-11 01:24:15 +09:00
|
|
|
enum {
|
|
|
|
qfv_LT_Undefined_to_TransferDst,
|
2021-04-24 12:42:29 +09:00
|
|
|
qfv_LT_TransferDst_to_TransferSrc,
|
2021-01-11 01:24:15 +09:00
|
|
|
qfv_LT_TransferDst_to_ShaderReadOnly,
|
2021-04-24 12:42:29 +09:00
|
|
|
qfv_LT_TransferSrc_to_ShaderReadOnly,
|
2021-01-21 17:13:17 +09:00
|
|
|
qfv_LT_ShaderReadOnly_to_TransferDst,
|
2021-01-11 01:24:15 +09:00
|
|
|
qfv_LT_Undefined_to_DepthStencil,
|
|
|
|
qfv_LT_Undefined_to_Color,
|
|
|
|
};
|
|
|
|
|
2021-12-16 22:53:19 +09:00
|
|
|
// buffer barriers
|
2021-04-24 15:47:31 +09:00
|
|
|
enum {
|
|
|
|
qfv_BB_Unknown_to_TransferWrite,
|
|
|
|
qfv_BB_TransferWrite_to_VertexAttrRead,
|
|
|
|
qfv_BB_TransferWrite_to_IndexRead,
|
|
|
|
qfv_BB_TransferWrite_to_UniformRead,
|
2021-12-16 23:02:16 +09:00
|
|
|
qfv_BB_ShaderRW_to_ShaderRO,
|
|
|
|
qfv_BB_ShaderRW_to_ShaderRO_VA,
|
|
|
|
qfv_BB_ShaderRO_to_ShaderWrite,
|
|
|
|
qfv_BB_ShaderRO_VA_to_ShaderWrite,
|
|
|
|
qfv_BB_ShaderWrite_to_ShaderRO,
|
|
|
|
qfv_BB_ShaderWrite_to_ShaderRW,
|
2021-04-24 15:47:31 +09:00
|
|
|
};
|
|
|
|
|
2021-04-24 12:42:29 +09:00
|
|
|
extern const qfv_imagebarrier_t imageBarriers[];
|
2021-04-24 15:47:31 +09:00
|
|
|
extern const qfv_bufferbarrier_t bufferBarriers[];
|
2021-01-11 01:24:15 +09:00
|
|
|
|
|
|
|
#endif//__QF_Vulkan_barrier_h
|