
Certain attributes (position, psize, etc.) don't count as params; they are handled separately by the hw. However, the VS is required to export at least one param and r600_shader_from_tgsi() takes care of adding a dummy export if there is none. Make sure the VS param export count in the SPI properly accounts for this. Note: This is a candidate for the 7.11 branch. Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
54 lines
1.7 KiB
C
54 lines
1.7 KiB
C
/*
|
|
* Copyright 2010 Jerome Glisse <glisse@freedesktop.org>
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
* to deal in the Software without restriction, including without limitation
|
|
* on the rights to use, copy, modify, merge, publish, distribute, sub
|
|
* license, and/or sell copies of the Software, and to permit persons to whom
|
|
* the Software is furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice (including the next
|
|
* paragraph) shall be included in all copies or substantial portions of the
|
|
* Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
|
|
* THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,
|
|
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
|
* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
|
* USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
#ifndef R600_SHADER_H
|
|
#define R600_SHADER_H
|
|
|
|
#include "r600_asm.h"
|
|
|
|
struct r600_shader_io {
|
|
unsigned name;
|
|
unsigned gpr;
|
|
unsigned done;
|
|
int sid;
|
|
unsigned interpolate;
|
|
boolean centroid;
|
|
unsigned lds_pos; /* for evergreen */
|
|
};
|
|
|
|
struct r600_shader {
|
|
unsigned processor_type;
|
|
struct r600_bc bc;
|
|
unsigned ninput;
|
|
unsigned noutput;
|
|
unsigned npos;
|
|
unsigned nlds;
|
|
struct r600_shader_io input[32];
|
|
struct r600_shader_io output[32];
|
|
boolean uses_kill;
|
|
boolean fs_write_all;
|
|
boolean clamp_color;
|
|
unsigned nr_cbufs;
|
|
};
|
|
|
|
#endif
|