Path: blob/21.2-virgl/src/gallium/drivers/zink/zink_render_pass.h
4570 views
/*1* Copyright 2018 Collabora Ltd.2*3* Permission is hereby granted, free of charge, to any person obtaining a4* copy of this software and associated documentation files (the "Software"),5* to deal in the Software without restriction, including without limitation6* on the rights to use, copy, modify, merge, publish, distribute, sub7* license, and/or sell copies of the Software, and to permit persons to whom8* the Software is furnished to do so, subject to the following conditions:9*10* The above copyright notice and this permission notice (including the next11* paragraph) shall be included in all copies or substantial portions of the12* Software.13*14* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR15* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,16* FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL17* THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,18* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR19* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE20* USE OR OTHER DEALINGS IN THE SOFTWARE.21*/2223#ifndef ZINK_RENDERPASS_H24#define ZINK_RENDERPASS_H2526#include <vulkan/vulkan.h>2728#include "pipe/p_state.h"29#include "util/u_inlines.h"3031struct zink_screen;3233struct zink_rt_attrib {34VkFormat format;35VkSampleCountFlagBits samples;36bool clear_color;37bool clear_stencil;38union {39bool swapchain;40bool needs_write;41};42};4344struct zink_render_pass_state {45uint8_t num_cbufs : 4; /* PIPE_MAX_COLOR_BUFS = 8 */46uint8_t have_zsbuf : 1;47bool swapchain_init;48struct zink_rt_attrib rts[PIPE_MAX_COLOR_BUFS + 1];49unsigned num_rts;50uint32_t clears; //for extra verification and update flagging51};5253struct zink_render_pass {54VkRenderPass render_pass;55struct zink_render_pass_state state;56};5758struct zink_render_pass *59zink_create_render_pass(struct zink_screen *screen,60struct zink_render_pass_state *state);6162void63zink_destroy_render_pass(struct zink_screen *screen,64struct zink_render_pass *rp);6566VkImageLayout67zink_render_pass_attachment_get_barrier_info(const struct zink_render_pass *rp, unsigned idx, VkPipelineStageFlags *pipeline, VkAccessFlags *access);68#endif697071