1b8e80941Smrg/* 2b8e80941Smrg * Copyright © 2013 Intel Corporation 3b8e80941Smrg * 4b8e80941Smrg * Permission is hereby granted, free of charge, to any person obtaining a 5b8e80941Smrg * copy of this software and associated documentation files (the "Software"), 6b8e80941Smrg * to deal in the Software without restriction, including without limitation 7b8e80941Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8b8e80941Smrg * and/or sell copies of the Software, and to permit persons to whom the 9b8e80941Smrg * Software is furnished to do so, subject to the following conditions: 10b8e80941Smrg * 11b8e80941Smrg * The above copyright notice and this permission notice (including the next 12b8e80941Smrg * paragraph) shall be included in all copies or substantial portions of the 13b8e80941Smrg * Software. 14b8e80941Smrg * 15b8e80941Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16b8e80941Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17b8e80941Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18b8e80941Smrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19b8e80941Smrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20b8e80941Smrg * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 21b8e80941Smrg * IN THE SOFTWARE. 22b8e80941Smrg */ 23b8e80941Smrg 24b8e80941Smrg#include "brw_compiler.h" 25b8e80941Smrg#include "compiler/nir/nir.h" 26b8e80941Smrg 27b8e80941Smrgstatic char const *get_qual_name(int mode) 28b8e80941Smrg{ 29b8e80941Smrg switch (mode) { 30b8e80941Smrg case INTERP_MODE_NONE: return "none"; 31b8e80941Smrg case INTERP_MODE_FLAT: return "flat"; 32b8e80941Smrg case INTERP_MODE_SMOOTH: return "smooth"; 33b8e80941Smrg case INTERP_MODE_NOPERSPECTIVE: return "nopersp"; 34b8e80941Smrg default: return "???"; 35b8e80941Smrg } 36b8e80941Smrg} 37b8e80941Smrg 38b8e80941Smrgstatic void 39b8e80941Smrggen4_frag_prog_set_interp_modes(struct brw_wm_prog_data *prog_data, 40b8e80941Smrg struct brw_vue_map *vue_map, 41b8e80941Smrg unsigned location, unsigned slot_count, 42b8e80941Smrg enum glsl_interp_mode interp) 43b8e80941Smrg{ 44b8e80941Smrg for (unsigned k = 0; k < slot_count; k++) { 45b8e80941Smrg unsigned slot = vue_map->varying_to_slot[location + k]; 46b8e80941Smrg if (slot != -1 && prog_data->interp_mode[slot] == INTERP_MODE_NONE) { 47b8e80941Smrg prog_data->interp_mode[slot] = interp; 48b8e80941Smrg 49b8e80941Smrg if (prog_data->interp_mode[slot] == INTERP_MODE_FLAT) { 50b8e80941Smrg prog_data->contains_flat_varying = true; 51b8e80941Smrg } else if (prog_data->interp_mode[slot] == INTERP_MODE_NOPERSPECTIVE) { 52b8e80941Smrg prog_data->contains_noperspective_varying = true; 53b8e80941Smrg } 54b8e80941Smrg } 55b8e80941Smrg } 56b8e80941Smrg} 57b8e80941Smrg 58b8e80941Smrg/* Set up interpolation modes for every element in the VUE */ 59b8e80941Smrgvoid 60b8e80941Smrgbrw_setup_vue_interpolation(struct brw_vue_map *vue_map, nir_shader *nir, 61b8e80941Smrg struct brw_wm_prog_data *prog_data) 62b8e80941Smrg{ 63b8e80941Smrg /* Initialise interp_mode. INTERP_MODE_NONE == 0 */ 64b8e80941Smrg memset(prog_data->interp_mode, 0, sizeof(prog_data->interp_mode)); 65b8e80941Smrg 66b8e80941Smrg if (!vue_map) 67b8e80941Smrg return; 68b8e80941Smrg 69b8e80941Smrg /* HPOS always wants noperspective. setting it up here allows 70b8e80941Smrg * us to not need special handling in the SF program. 71b8e80941Smrg */ 72b8e80941Smrg unsigned pos_slot = vue_map->varying_to_slot[VARYING_SLOT_POS]; 73b8e80941Smrg if (pos_slot != -1) {; 74b8e80941Smrg prog_data->interp_mode[pos_slot] = INTERP_MODE_NOPERSPECTIVE; 75b8e80941Smrg prog_data->contains_noperspective_varying = true; 76b8e80941Smrg } 77b8e80941Smrg 78b8e80941Smrg foreach_list_typed(nir_variable, var, node, &nir->inputs) { 79b8e80941Smrg unsigned location = var->data.location; 80b8e80941Smrg unsigned slot_count = glsl_count_attribute_slots(var->type, false); 81b8e80941Smrg 82b8e80941Smrg gen4_frag_prog_set_interp_modes(prog_data, vue_map, location, slot_count, 83b8e80941Smrg var->data.interpolation); 84b8e80941Smrg 85b8e80941Smrg if (location == VARYING_SLOT_COL0 || location == VARYING_SLOT_COL1) { 86b8e80941Smrg location = location + VARYING_SLOT_BFC0 - VARYING_SLOT_COL0; 87b8e80941Smrg gen4_frag_prog_set_interp_modes(prog_data, vue_map, location, 88b8e80941Smrg slot_count, var->data.interpolation); 89b8e80941Smrg } 90b8e80941Smrg } 91b8e80941Smrg 92b8e80941Smrg bool debug = false; 93b8e80941Smrg if (debug) { 94b8e80941Smrg fprintf(stderr, "VUE map:\n"); 95b8e80941Smrg for (int i = 0; i < vue_map->num_slots; i++) { 96b8e80941Smrg int varying = vue_map->slot_to_varying[i]; 97b8e80941Smrg if (varying == -1) { 98b8e80941Smrg fprintf(stderr, "%d: --\n", i); 99b8e80941Smrg continue; 100b8e80941Smrg } 101b8e80941Smrg 102b8e80941Smrg fprintf(stderr, "%d: %d %s ofs %d\n", 103b8e80941Smrg i, varying, 104b8e80941Smrg get_qual_name(prog_data->interp_mode[i]), 105b8e80941Smrg brw_vue_slot_to_offset(i)); 106b8e80941Smrg } 107b8e80941Smrg } 108b8e80941Smrg} 109