1bf215546Sopenharmony_ci/************************************************************************** 2bf215546Sopenharmony_ci * 3bf215546Sopenharmony_ci * Copyright 2021 Advanced Micro Devices, Inc. 4bf215546Sopenharmony_ci * All Rights Reserved. 5bf215546Sopenharmony_ci * 6bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a 7bf215546Sopenharmony_ci * copy of this software and associated documentation files (the "Software"), 8bf215546Sopenharmony_ci * to deal in the Software without restriction, including without limitation 9bf215546Sopenharmony_ci * the rights to use, copy, modify, merge, publish, distribute, sublicense, 10bf215546Sopenharmony_ci * and/or sell copies of the Software, and to permit persons to whom the 11bf215546Sopenharmony_ci * Software is furnished to do so, subject to the following conditions: 12bf215546Sopenharmony_ci * 13bf215546Sopenharmony_ci * The above copyright notice and this permission notice shall be included 14bf215546Sopenharmony_ci * in all copies or substantial portions of the Software. 15bf215546Sopenharmony_ci * 16bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 17bf215546Sopenharmony_ci * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18bf215546Sopenharmony_ci * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 19bf215546Sopenharmony_ci * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20bf215546Sopenharmony_ci * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21bf215546Sopenharmony_ci * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 22bf215546Sopenharmony_ci * SOFTWARE. 23bf215546Sopenharmony_ci * 24bf215546Sopenharmony_ci **************************************************************************/ 25bf215546Sopenharmony_ci 26bf215546Sopenharmony_ci#include "nir_helpers.h" 27bf215546Sopenharmony_ci#include "nir_xfb_info.h" 28bf215546Sopenharmony_ci 29bf215546Sopenharmony_civoid 30bf215546Sopenharmony_cinir_gather_stream_output_info(nir_shader *nir, 31bf215546Sopenharmony_ci struct pipe_stream_output_info *so) 32bf215546Sopenharmony_ci{ 33bf215546Sopenharmony_ci int slot_to_register[NUM_TOTAL_VARYING_SLOTS]; 34bf215546Sopenharmony_ci nir_xfb_info *info = nir_gather_xfb_info_from_intrinsics(nir, slot_to_register); 35bf215546Sopenharmony_ci 36bf215546Sopenharmony_ci memset(so, 0, sizeof(*so)); 37bf215546Sopenharmony_ci 38bf215546Sopenharmony_ci if (!info) 39bf215546Sopenharmony_ci return; 40bf215546Sopenharmony_ci 41bf215546Sopenharmony_ci so->num_outputs = info->output_count; 42bf215546Sopenharmony_ci 43bf215546Sopenharmony_ci for (unsigned i = 0; i < info->output_count; i++) { 44bf215546Sopenharmony_ci so->output[i].start_component = info->outputs[i].component_offset; 45bf215546Sopenharmony_ci so->output[i].num_components = util_bitcount(info->outputs[i].component_mask); 46bf215546Sopenharmony_ci so->output[i].output_buffer = info->outputs[i].buffer; 47bf215546Sopenharmony_ci so->output[i].dst_offset = info->outputs[i].offset / 4; 48bf215546Sopenharmony_ci so->output[i].stream = info->buffer_to_stream[info->outputs[i].buffer]; 49bf215546Sopenharmony_ci so->output[i].register_index = slot_to_register[info->outputs[i].location]; 50bf215546Sopenharmony_ci } 51bf215546Sopenharmony_ci 52bf215546Sopenharmony_ci for (unsigned i = 0; i < MAX_XFB_BUFFERS; i++) 53bf215546Sopenharmony_ci so->stride[i] = info->buffers[i].stride; 54bf215546Sopenharmony_ci 55bf215546Sopenharmony_ci free(info); 56bf215546Sopenharmony_ci} 57