1bf215546Sopenharmony_ci/**************************************************************************
2bf215546Sopenharmony_ci *
3bf215546Sopenharmony_ci * Copyright 2007 VMware, 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
8bf215546Sopenharmony_ci * "Software"), to deal in the Software without restriction, including
9bf215546Sopenharmony_ci * without limitation the rights to use, copy, modify, merge, publish,
10bf215546Sopenharmony_ci * distribute, sub license, and/or sell copies of the Software, and to
11bf215546Sopenharmony_ci * permit persons to whom the Software is furnished to do so, subject to
12bf215546Sopenharmony_ci * the following conditions:
13bf215546Sopenharmony_ci *
14bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the
15bf215546Sopenharmony_ci * next paragraph) shall be included in all copies or substantial portions
16bf215546Sopenharmony_ci * of the Software.
17bf215546Sopenharmony_ci *
18bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19bf215546Sopenharmony_ci * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20bf215546Sopenharmony_ci * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21bf215546Sopenharmony_ci * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR
22bf215546Sopenharmony_ci * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23bf215546Sopenharmony_ci * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24bf215546Sopenharmony_ci * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25bf215546Sopenharmony_ci *
26bf215546Sopenharmony_ci **************************************************************************/
27bf215546Sopenharmony_ci
28bf215546Sopenharmony_ci/* Authors:  Keith Whitwell <keithw@vmware.com>
29bf215546Sopenharmony_ci */
30bf215546Sopenharmony_ci
31bf215546Sopenharmony_ci#ifndef SP_QUAD_H
32bf215546Sopenharmony_ci#define SP_QUAD_H
33bf215546Sopenharmony_ci
34bf215546Sopenharmony_ci#include "pipe/p_state.h"
35bf215546Sopenharmony_ci#include "tgsi/tgsi_exec.h"
36bf215546Sopenharmony_ci
37bf215546Sopenharmony_ci
38bf215546Sopenharmony_ci#define QUAD_PRIM_POINT 1
39bf215546Sopenharmony_ci#define QUAD_PRIM_LINE  2
40bf215546Sopenharmony_ci#define QUAD_PRIM_TRI   3
41bf215546Sopenharmony_ci
42bf215546Sopenharmony_ci
43bf215546Sopenharmony_ci/* The rasterizer generates 2x2 quads of fragment and feeds them to
44bf215546Sopenharmony_ci * the current fp_machine (see below).
45bf215546Sopenharmony_ci * Remember that Y=0=top with Y increasing down the window.
46bf215546Sopenharmony_ci */
47bf215546Sopenharmony_ci#define QUAD_TOP_LEFT     0
48bf215546Sopenharmony_ci#define QUAD_TOP_RIGHT    1
49bf215546Sopenharmony_ci#define QUAD_BOTTOM_LEFT  2
50bf215546Sopenharmony_ci#define QUAD_BOTTOM_RIGHT 3
51bf215546Sopenharmony_ci
52bf215546Sopenharmony_ci#define MASK_TOP_LEFT     (1 << QUAD_TOP_LEFT)
53bf215546Sopenharmony_ci#define MASK_TOP_RIGHT    (1 << QUAD_TOP_RIGHT)
54bf215546Sopenharmony_ci#define MASK_BOTTOM_LEFT  (1 << QUAD_BOTTOM_LEFT)
55bf215546Sopenharmony_ci#define MASK_BOTTOM_RIGHT (1 << QUAD_BOTTOM_RIGHT)
56bf215546Sopenharmony_ci#define MASK_ALL          0xf
57bf215546Sopenharmony_ci
58bf215546Sopenharmony_ci
59bf215546Sopenharmony_ci/**
60bf215546Sopenharmony_ci * Quad stage inputs (pos, coverage, front/back face, etc)
61bf215546Sopenharmony_ci */
62bf215546Sopenharmony_cistruct quad_header_input
63bf215546Sopenharmony_ci{
64bf215546Sopenharmony_ci   int x0, y0;                /**< quad window pos, always even */
65bf215546Sopenharmony_ci   unsigned layer;
66bf215546Sopenharmony_ci   unsigned viewport_index;
67bf215546Sopenharmony_ci   float coverage[TGSI_QUAD_SIZE]; /**< fragment coverage for antialiasing */
68bf215546Sopenharmony_ci   unsigned facing:1;         /**< Front (0) or back (1) facing? */
69bf215546Sopenharmony_ci   unsigned prim:2;           /**< QUAD_PRIM_POINT, LINE, TRI */
70bf215546Sopenharmony_ci};
71bf215546Sopenharmony_ci
72bf215546Sopenharmony_ci
73bf215546Sopenharmony_ci/**
74bf215546Sopenharmony_ci * Quad stage inputs/outputs.
75bf215546Sopenharmony_ci */
76bf215546Sopenharmony_cistruct quad_header_inout
77bf215546Sopenharmony_ci{
78bf215546Sopenharmony_ci   unsigned mask:4;
79bf215546Sopenharmony_ci};
80bf215546Sopenharmony_ci
81bf215546Sopenharmony_ci
82bf215546Sopenharmony_ci/**
83bf215546Sopenharmony_ci * Quad stage outputs (color & depth).
84bf215546Sopenharmony_ci */
85bf215546Sopenharmony_cistruct quad_header_output
86bf215546Sopenharmony_ci{
87bf215546Sopenharmony_ci   /** colors in SOA format (rrrr, gggg, bbbb, aaaa) */
88bf215546Sopenharmony_ci   float color[PIPE_MAX_COLOR_BUFS][TGSI_NUM_CHANNELS][TGSI_QUAD_SIZE];
89bf215546Sopenharmony_ci   float depth[TGSI_QUAD_SIZE];
90bf215546Sopenharmony_ci   uint8_t stencil[TGSI_QUAD_SIZE];
91bf215546Sopenharmony_ci};
92bf215546Sopenharmony_ci
93bf215546Sopenharmony_ci
94bf215546Sopenharmony_ci/**
95bf215546Sopenharmony_ci * Encodes everything we need to know about a 2x2 pixel block.  Uses
96bf215546Sopenharmony_ci * "Channel-Serial" or "SoA" layout.
97bf215546Sopenharmony_ci */
98bf215546Sopenharmony_cistruct quad_header {
99bf215546Sopenharmony_ci   struct quad_header_input input;
100bf215546Sopenharmony_ci   struct quad_header_inout inout;
101bf215546Sopenharmony_ci   struct quad_header_output output;
102bf215546Sopenharmony_ci
103bf215546Sopenharmony_ci   /* Redundant/duplicated:
104bf215546Sopenharmony_ci    */
105bf215546Sopenharmony_ci   const struct tgsi_interp_coef *posCoef;
106bf215546Sopenharmony_ci   const struct tgsi_interp_coef *coef;
107bf215546Sopenharmony_ci};
108bf215546Sopenharmony_ci
109bf215546Sopenharmony_ci#endif /* SP_QUAD_H */
110