1848b8605Smrg/************************************************************************** 2848b8605Smrg * 3848b8605Smrg * Copyright 2008 VMware, Inc. 4848b8605Smrg * All Rights Reserved. 5848b8605Smrg * 6848b8605Smrg * Permission is hereby granted, free of charge, to any person obtaining a 7848b8605Smrg * copy of this software and associated documentation files (the 8848b8605Smrg * "Software"), to deal in the Software without restriction, including 9848b8605Smrg * without limitation the rights to use, copy, modify, merge, publish, 10848b8605Smrg * distribute, sub license, and/or sell copies of the Software, and to 11848b8605Smrg * permit persons to whom the Software is furnished to do so, subject to 12848b8605Smrg * the following conditions: 13848b8605Smrg * 14848b8605Smrg * The above copyright notice and this permission notice (including the 15848b8605Smrg * next paragraph) shall be included in all copies or substantial portions 16848b8605Smrg * of the Software. 17848b8605Smrg * 18848b8605Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 19848b8605Smrg * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20848b8605Smrg * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. 21848b8605Smrg * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR 22848b8605Smrg * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 23848b8605Smrg * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 24848b8605Smrg * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 25848b8605Smrg * 26848b8605Smrg **************************************************************************/ 27848b8605Smrg 28848b8605Smrg#ifndef TGSI_SCAN_H 29848b8605Smrg#define TGSI_SCAN_H 30848b8605Smrg 31848b8605Smrg 32848b8605Smrg#include "pipe/p_compiler.h" 33848b8605Smrg#include "pipe/p_state.h" 34848b8605Smrg#include "pipe/p_shader_tokens.h" 35848b8605Smrg 36b8e80941Smrg#ifdef __cplusplus 37b8e80941Smrgextern "C" { 38b8e80941Smrg#endif 39b8e80941Smrg 40848b8605Smrg/** 41848b8605Smrg * Shader summary info 42848b8605Smrg */ 43848b8605Smrgstruct tgsi_shader_info 44848b8605Smrg{ 45848b8605Smrg uint num_tokens; 46848b8605Smrg 47848b8605Smrg ubyte num_inputs; 48848b8605Smrg ubyte num_outputs; 49848b8605Smrg ubyte input_semantic_name[PIPE_MAX_SHADER_INPUTS]; /**< TGSI_SEMANTIC_x */ 50848b8605Smrg ubyte input_semantic_index[PIPE_MAX_SHADER_INPUTS]; 51848b8605Smrg ubyte input_interpolate[PIPE_MAX_SHADER_INPUTS]; 52848b8605Smrg ubyte input_interpolate_loc[PIPE_MAX_SHADER_INPUTS]; 53848b8605Smrg ubyte input_usage_mask[PIPE_MAX_SHADER_INPUTS]; 54848b8605Smrg ubyte input_cylindrical_wrap[PIPE_MAX_SHADER_INPUTS]; 55848b8605Smrg ubyte output_semantic_name[PIPE_MAX_SHADER_OUTPUTS]; /**< TGSI_SEMANTIC_x */ 56848b8605Smrg ubyte output_semantic_index[PIPE_MAX_SHADER_OUTPUTS]; 57b8e80941Smrg ubyte output_usagemask[PIPE_MAX_SHADER_OUTPUTS]; 58b8e80941Smrg ubyte output_streams[PIPE_MAX_SHADER_OUTPUTS]; 59848b8605Smrg 60848b8605Smrg ubyte num_system_values; 61848b8605Smrg ubyte system_value_semantic_name[PIPE_MAX_SHADER_INPUTS]; 62848b8605Smrg 63848b8605Smrg ubyte processor; 64848b8605Smrg 65848b8605Smrg uint file_mask[TGSI_FILE_COUNT]; /**< bitmask of declared registers */ 66848b8605Smrg uint file_count[TGSI_FILE_COUNT]; /**< number of declared registers */ 67848b8605Smrg int file_max[TGSI_FILE_COUNT]; /**< highest index of declared registers */ 68848b8605Smrg int const_file_max[PIPE_MAX_CONSTANT_BUFFERS]; 69b8e80941Smrg unsigned const_buffers_declared; /**< bitmask of declared const buffers */ 70b8e80941Smrg unsigned samplers_declared; /**< bitmask of declared samplers */ 71b8e80941Smrg ubyte sampler_targets[PIPE_MAX_SHADER_SAMPLER_VIEWS]; /**< TGSI_TEXTURE_x values */ 72b8e80941Smrg ubyte sampler_type[PIPE_MAX_SHADER_SAMPLER_VIEWS]; /**< TGSI_RETURN_TYPE_x */ 73b8e80941Smrg ubyte num_stream_output_components[4]; 74b8e80941Smrg 75b8e80941Smrg ubyte input_array_first[PIPE_MAX_SHADER_INPUTS]; 76b8e80941Smrg ubyte input_array_last[PIPE_MAX_SHADER_INPUTS]; 77b8e80941Smrg ubyte output_array_first[PIPE_MAX_SHADER_OUTPUTS]; 78b8e80941Smrg ubyte output_array_last[PIPE_MAX_SHADER_OUTPUTS]; 79b8e80941Smrg unsigned array_max[TGSI_FILE_COUNT]; /**< highest index array per register file */ 80848b8605Smrg 81848b8605Smrg uint immediate_count; /**< number of immediates declared */ 82848b8605Smrg uint num_instructions; 83b8e80941Smrg uint num_memory_instructions; /**< sampler, buffer, and image instructions */ 84848b8605Smrg 85848b8605Smrg uint opcode_count[TGSI_OPCODE_LAST]; /**< opcode histogram */ 86848b8605Smrg 87b8e80941Smrg /** 88b8e80941Smrg * If a tessellation control shader reads outputs, this describes which ones. 89b8e80941Smrg */ 90b8e80941Smrg boolean reads_pervertex_outputs; 91b8e80941Smrg boolean reads_perpatch_outputs; 92b8e80941Smrg boolean reads_tessfactor_outputs; 93b8e80941Smrg 94b8e80941Smrg ubyte colors_read; /**< which color components are read by the FS */ 95b8e80941Smrg ubyte colors_written; 96848b8605Smrg boolean reads_position; /**< does fragment shader read position? */ 97848b8605Smrg boolean reads_z; /**< does fragment shader read depth? */ 98b8e80941Smrg boolean reads_samplemask; /**< does fragment shader read sample mask? */ 99b8e80941Smrg boolean reads_tess_factors; /**< If TES reads TESSINNER or TESSOUTER */ 100848b8605Smrg boolean writes_z; /**< does fragment shader write Z value? */ 101848b8605Smrg boolean writes_stencil; /**< does fragment shader write stencil value? */ 102b8e80941Smrg boolean writes_samplemask; /**< does fragment shader write sample mask? */ 103848b8605Smrg boolean writes_edgeflag; /**< vertex shader outputs edgeflag */ 104848b8605Smrg boolean uses_kill; /**< KILL or KILL_IF instruction used? */ 105b8e80941Smrg boolean uses_persp_center; 106b8e80941Smrg boolean uses_persp_centroid; 107b8e80941Smrg boolean uses_persp_sample; 108b8e80941Smrg boolean uses_linear_center; 109b8e80941Smrg boolean uses_linear_centroid; 110b8e80941Smrg boolean uses_linear_sample; 111b8e80941Smrg boolean uses_persp_opcode_interp_centroid; 112b8e80941Smrg boolean uses_persp_opcode_interp_offset; 113b8e80941Smrg boolean uses_persp_opcode_interp_sample; 114b8e80941Smrg boolean uses_linear_opcode_interp_centroid; 115b8e80941Smrg boolean uses_linear_opcode_interp_offset; 116b8e80941Smrg boolean uses_linear_opcode_interp_sample; 117848b8605Smrg boolean uses_instanceid; 118848b8605Smrg boolean uses_vertexid; 119b8e80941Smrg boolean uses_vertexid_nobase; 120b8e80941Smrg boolean uses_basevertex; 121b8e80941Smrg boolean uses_drawid; 122848b8605Smrg boolean uses_primid; 123848b8605Smrg boolean uses_frontface; 124b8e80941Smrg boolean uses_invocationid; 125b8e80941Smrg boolean uses_thread_id[3]; 126b8e80941Smrg boolean uses_block_id[3]; 127b8e80941Smrg boolean uses_block_size; 128b8e80941Smrg boolean uses_grid_size; 129b8e80941Smrg boolean writes_position; 130b8e80941Smrg boolean writes_psize; 131b8e80941Smrg boolean writes_clipvertex; 132b8e80941Smrg boolean writes_primid; 133848b8605Smrg boolean writes_viewport_index; 134848b8605Smrg boolean writes_layer; 135b8e80941Smrg boolean writes_memory; /**< contains stores or atomics to buffers or images */ 136b8e80941Smrg boolean uses_doubles; /**< uses any of the double instructions */ 137b8e80941Smrg boolean uses_derivatives; 138b8e80941Smrg boolean uses_bindless_samplers; 139b8e80941Smrg boolean uses_bindless_images; 140b8e80941Smrg unsigned clipdist_writemask; 141b8e80941Smrg unsigned culldist_writemask; 142848b8605Smrg unsigned num_written_culldistance; 143848b8605Smrg unsigned num_written_clipdistance; 144b8e80941Smrg 145b8e80941Smrg unsigned images_declared; /**< bitmask of declared images */ 146b8e80941Smrg /** 147b8e80941Smrg * Bitmask indicating which declared image is a buffer. 148b8e80941Smrg */ 149b8e80941Smrg unsigned images_buffers; 150b8e80941Smrg unsigned images_load; /**< bitmask of images using loads */ 151b8e80941Smrg unsigned images_store; /**< bitmask of images using stores */ 152b8e80941Smrg unsigned images_atomic; /**< bitmask of images using atomics */ 153b8e80941Smrg unsigned shader_buffers_declared; /**< bitmask of declared shader buffers */ 154b8e80941Smrg unsigned shader_buffers_load; /**< bitmask of shader buffers using loads */ 155b8e80941Smrg unsigned shader_buffers_store; /**< bitmask of shader buffers using stores */ 156b8e80941Smrg unsigned shader_buffers_atomic; /**< bitmask of shader buffers using atomics */ 157b8e80941Smrg bool uses_bindless_buffer_load; 158b8e80941Smrg bool uses_bindless_buffer_store; 159b8e80941Smrg bool uses_bindless_buffer_atomic; 160b8e80941Smrg bool uses_bindless_image_load; 161b8e80941Smrg bool uses_bindless_image_store; 162b8e80941Smrg bool uses_bindless_image_atomic; 163b8e80941Smrg 164848b8605Smrg /** 165848b8605Smrg * Bitmask indicating which register files are accessed with 166848b8605Smrg * indirect addressing. The bits are (1 << TGSI_FILE_x), etc. 167848b8605Smrg */ 168848b8605Smrg unsigned indirect_files; 169b8e80941Smrg /** 170b8e80941Smrg * Bitmask indicating which register files are read / written with 171b8e80941Smrg * indirect addressing. The bits are (1 << TGSI_FILE_x). 172b8e80941Smrg */ 173b8e80941Smrg unsigned indirect_files_read; 174b8e80941Smrg unsigned indirect_files_written; 175b8e80941Smrg unsigned dim_indirect_files; /**< shader resource indexing */ 176b8e80941Smrg unsigned const_buffers_indirect; /**< const buffers using indirect addressing */ 177b8e80941Smrg 178b8e80941Smrg unsigned properties[TGSI_PROPERTY_COUNT]; /* index with TGSI_PROPERTY_ */ 179848b8605Smrg 180b8e80941Smrg /** 181b8e80941Smrg * Max nesting limit of loops/if's 182b8e80941Smrg */ 183b8e80941Smrg unsigned max_depth; 184b8e80941Smrg}; 185b8e80941Smrg 186b8e80941Smrgstruct tgsi_array_info 187b8e80941Smrg{ 188b8e80941Smrg /** Whether an array with this ID was declared. */ 189b8e80941Smrg bool declared; 190b8e80941Smrg 191b8e80941Smrg /** The OR of all writemasks used to write to this array. */ 192b8e80941Smrg ubyte writemask; 193b8e80941Smrg 194b8e80941Smrg /** The range with which the array was declared. */ 195b8e80941Smrg struct tgsi_declaration_range range; 196b8e80941Smrg}; 197b8e80941Smrg 198b8e80941Smrgstruct tgsi_tessctrl_info 199b8e80941Smrg{ 200b8e80941Smrg /** Whether all codepaths write tess factors in all invocations. */ 201b8e80941Smrg bool tessfactors_are_def_in_all_invocs; 202848b8605Smrg}; 203848b8605Smrg 204848b8605Smrgextern void 205848b8605Smrgtgsi_scan_shader(const struct tgsi_token *tokens, 206848b8605Smrg struct tgsi_shader_info *info); 207848b8605Smrg 208b8e80941Smrgvoid 209b8e80941Smrgtgsi_scan_arrays(const struct tgsi_token *tokens, 210b8e80941Smrg unsigned file, 211b8e80941Smrg unsigned max_array_id, 212b8e80941Smrg struct tgsi_array_info *arrays); 213848b8605Smrg 214b8e80941Smrgvoid 215b8e80941Smrgtgsi_scan_tess_ctrl(const struct tgsi_token *tokens, 216b8e80941Smrg const struct tgsi_shader_info *info, 217b8e80941Smrg struct tgsi_tessctrl_info *out); 218848b8605Smrg 219b8e80941Smrgstatic inline bool 220b8e80941Smrgtgsi_is_bindless_image_file(unsigned file) 221b8e80941Smrg{ 222b8e80941Smrg return file != TGSI_FILE_IMAGE && 223b8e80941Smrg file != TGSI_FILE_MEMORY && 224b8e80941Smrg file != TGSI_FILE_BUFFER && 225b8e80941Smrg file != TGSI_FILE_CONSTBUF && 226b8e80941Smrg file != TGSI_FILE_HW_ATOMIC; 227b8e80941Smrg} 228b8e80941Smrg 229b8e80941Smrg#ifdef __cplusplus 230b8e80941Smrg} // extern "C" 231b8e80941Smrg#endif 232848b8605Smrg 233848b8605Smrg#endif /* TGSI_SCAN_H */ 234