1a8c21a54SThe etnaviv authors #ifndef STATE_XML
2a8c21a54SThe etnaviv authors #define STATE_XML
3a8c21a54SThe etnaviv authors 
4a8c21a54SThe etnaviv authors /* Autogenerated file, DO NOT EDIT manually!
5a8c21a54SThe etnaviv authors 
6a8c21a54SThe etnaviv authors This file was generated by the rules-ng-ng headergen tool in this git repository:
7a8c21a54SThe etnaviv authors http://0x04.net/cgit/index.cgi/rules-ng-ng
8a8c21a54SThe etnaviv authors git clone git://0x04.net/rules-ng-ng
9a8c21a54SThe etnaviv authors 
10a8c21a54SThe etnaviv authors The rules-ng-ng source files this header was generated from are:
11a8c21a54SThe etnaviv authors - state.xml    (  18882 bytes, from 2015-03-25 11:42:32)
12a8c21a54SThe etnaviv authors - common.xml   (  18437 bytes, from 2015-03-25 11:27:41)
13a8c21a54SThe etnaviv authors - state_hi.xml (  23420 bytes, from 2015-03-25 11:47:21)
14a8c21a54SThe etnaviv authors - state_2d.xml (  51549 bytes, from 2015-03-25 11:25:06)
15a8c21a54SThe etnaviv authors - state_3d.xml (  54600 bytes, from 2015-03-25 11:25:19)
16a8c21a54SThe etnaviv authors - state_vg.xml (   5973 bytes, from 2015-03-25 11:26:01)
17a8c21a54SThe etnaviv authors 
18a8c21a54SThe etnaviv authors Copyright (C) 2015
19a8c21a54SThe etnaviv authors */
20a8c21a54SThe etnaviv authors 
21a8c21a54SThe etnaviv authors 
22a8c21a54SThe etnaviv authors #define VARYING_COMPONENT_USE_UNUSED				0x00000000
23a8c21a54SThe etnaviv authors #define VARYING_COMPONENT_USE_USED				0x00000001
24a8c21a54SThe etnaviv authors #define VARYING_COMPONENT_USE_POINTCOORD_X			0x00000002
25a8c21a54SThe etnaviv authors #define VARYING_COMPONENT_USE_POINTCOORD_Y			0x00000003
26a8c21a54SThe etnaviv authors #define FE_VERTEX_STREAM_CONTROL_VERTEX_STRIDE__MASK		0x000000ff
27a8c21a54SThe etnaviv authors #define FE_VERTEX_STREAM_CONTROL_VERTEX_STRIDE__SHIFT		0
28a8c21a54SThe etnaviv authors #define FE_VERTEX_STREAM_CONTROL_VERTEX_STRIDE(x)		(((x) << FE_VERTEX_STREAM_CONTROL_VERTEX_STRIDE__SHIFT) & FE_VERTEX_STREAM_CONTROL_VERTEX_STRIDE__MASK)
29a8c21a54SThe etnaviv authors #define VIVS_FE							0x00000000
30a8c21a54SThe etnaviv authors 
31a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG(i0)		       (0x00000600 + 0x4*(i0))
32a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG__ESIZE			0x00000004
33a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG__LEN			0x00000010
34a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE__MASK		0x0000000f
35a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE__SHIFT		0
36a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_BYTE			0x00000000
37a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_UNSIGNED_BYTE	0x00000001
38a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_SHORT		0x00000002
39a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_UNSIGNED_SHORT	0x00000003
40a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_INT			0x00000004
41a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_UNSIGNED_INT		0x00000005
42a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_FLOAT		0x00000008
43a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_HALF_FLOAT		0x00000009
44a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_FIXED		0x0000000b
45a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_INT_10_10_10_2	0x0000000c
46a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_TYPE_UNSIGNED_INT_10_10_10_2	0x0000000d
47a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_ENDIAN__MASK		0x00000030
48a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_ENDIAN__SHIFT		4
49a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_ENDIAN(x)			(((x) << VIVS_FE_VERTEX_ELEMENT_CONFIG_ENDIAN__SHIFT) & VIVS_FE_VERTEX_ELEMENT_CONFIG_ENDIAN__MASK)
50a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NONCONSECUTIVE		0x00000080
51a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_STREAM__MASK		0x00000700
52a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_STREAM__SHIFT		8
53a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_STREAM(x)			(((x) << VIVS_FE_VERTEX_ELEMENT_CONFIG_STREAM__SHIFT) & VIVS_FE_VERTEX_ELEMENT_CONFIG_STREAM__MASK)
54a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NUM__MASK			0x00003000
55a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NUM__SHIFT		12
56a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NUM(x)			(((x) << VIVS_FE_VERTEX_ELEMENT_CONFIG_NUM__SHIFT) & VIVS_FE_VERTEX_ELEMENT_CONFIG_NUM__MASK)
57a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NORMALIZE__MASK		0x0000c000
58a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NORMALIZE__SHIFT		14
59a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NORMALIZE_OFF		0x00000000
60a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_NORMALIZE_ON		0x00008000
61a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_START__MASK		0x00ff0000
62a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_START__SHIFT		16
63a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_START(x)			(((x) << VIVS_FE_VERTEX_ELEMENT_CONFIG_START__SHIFT) & VIVS_FE_VERTEX_ELEMENT_CONFIG_START__MASK)
64a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_END__MASK			0xff000000
65a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_END__SHIFT		24
66a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_ELEMENT_CONFIG_END(x)			(((x) << VIVS_FE_VERTEX_ELEMENT_CONFIG_END__SHIFT) & VIVS_FE_VERTEX_ELEMENT_CONFIG_END__MASK)
67a8c21a54SThe etnaviv authors 
68a8c21a54SThe etnaviv authors #define VIVS_FE_CMD_STREAM_BASE_ADDR				0x00000640
69a8c21a54SThe etnaviv authors 
70a8c21a54SThe etnaviv authors #define VIVS_FE_INDEX_STREAM_BASE_ADDR				0x00000644
71a8c21a54SThe etnaviv authors 
72a8c21a54SThe etnaviv authors #define VIVS_FE_INDEX_STREAM_CONTROL				0x00000648
73a8c21a54SThe etnaviv authors #define VIVS_FE_INDEX_STREAM_CONTROL_TYPE__MASK			0x00000003
74a8c21a54SThe etnaviv authors #define VIVS_FE_INDEX_STREAM_CONTROL_TYPE__SHIFT		0
75a8c21a54SThe etnaviv authors #define VIVS_FE_INDEX_STREAM_CONTROL_TYPE_UNSIGNED_CHAR		0x00000000
76a8c21a54SThe etnaviv authors #define VIVS_FE_INDEX_STREAM_CONTROL_TYPE_UNSIGNED_SHORT	0x00000001
77a8c21a54SThe etnaviv authors #define VIVS_FE_INDEX_STREAM_CONTROL_TYPE_UNSIGNED_INT		0x00000002
78a8c21a54SThe etnaviv authors 
79a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_STREAM_BASE_ADDR				0x0000064c
80a8c21a54SThe etnaviv authors 
81a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_STREAM_CONTROL				0x00000650
82a8c21a54SThe etnaviv authors 
83a8c21a54SThe etnaviv authors #define VIVS_FE_COMMAND_ADDRESS					0x00000654
84a8c21a54SThe etnaviv authors 
85a8c21a54SThe etnaviv authors #define VIVS_FE_COMMAND_CONTROL					0x00000658
86a8c21a54SThe etnaviv authors #define VIVS_FE_COMMAND_CONTROL_PREFETCH__MASK			0x0000ffff
87a8c21a54SThe etnaviv authors #define VIVS_FE_COMMAND_CONTROL_PREFETCH__SHIFT			0
88a8c21a54SThe etnaviv authors #define VIVS_FE_COMMAND_CONTROL_PREFETCH(x)			(((x) << VIVS_FE_COMMAND_CONTROL_PREFETCH__SHIFT) & VIVS_FE_COMMAND_CONTROL_PREFETCH__MASK)
89a8c21a54SThe etnaviv authors #define VIVS_FE_COMMAND_CONTROL_ENABLE				0x00010000
90a8c21a54SThe etnaviv authors 
91a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_STATUS					0x0000065c
92a8c21a54SThe etnaviv authors 
93a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE					0x00000660
94a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE__MASK			0x0000001f
95a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE__SHIFT		0
96a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_IDLE			0x00000000
97a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_DEC			0x00000001
98a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_ADR0			0x00000002
99a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_LOAD0			0x00000003
100a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_ADR1			0x00000004
101a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_LOAD1			0x00000005
102a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_3DADR			0x00000006
103a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_3DCMD			0x00000007
104a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_3DCNTL		0x00000008
105a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_3DIDXCNTL		0x00000009
106a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_INITREQDMA		0x0000000a
107a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_DRAWIDX		0x0000000b
108a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_DRAW			0x0000000c
109a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_2DRECT0		0x0000000d
110a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_2DRECT1		0x0000000e
111a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_2DDATA0		0x0000000f
112a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_2DDATA1		0x00000010
113a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_WAITFIFO		0x00000011
114a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_WAIT			0x00000012
115a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_LINK			0x00000013
116a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_END			0x00000014
117a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_STATE_STALL			0x00000015
118a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_DMA_STATE__MASK		0x00000300
119a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_DMA_STATE__SHIFT		8
120a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_DMA_STATE_IDLE		0x00000000
121a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_DMA_STATE_START		0x00000100
122a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_DMA_STATE_REQ		0x00000200
123a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_DMA_STATE_END		0x00000300
124a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_FETCH_STATE__MASK		0x00000c00
125a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_FETCH_STATE__SHIFT		10
126a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_FETCH_STATE_IDLE		0x00000000
127a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_FETCH_STATE_RAMVALID	0x00000400
128a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CMD_FETCH_STATE_VALID		0x00000800
129a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_REQ_DMA_STATE__MASK		0x00003000
130a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_REQ_DMA_STATE__SHIFT		12
131a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_REQ_DMA_STATE_IDLE		0x00000000
132a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_REQ_DMA_STATE_WAITIDX		0x00001000
133a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_REQ_DMA_STATE_CAL		0x00002000
134a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CAL_STATE__MASK			0x0000c000
135a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CAL_STATE__SHIFT		14
136a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CAL_STATE_IDLE			0x00000000
137a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CAL_STATE_LDADR			0x00004000
138a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_CAL_STATE_IDXCALC		0x00008000
139a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_VE_REQ_STATE__MASK		0x00030000
140a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_VE_REQ_STATE__SHIFT		16
141a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_VE_REQ_STATE_IDLE		0x00000000
142a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_VE_REQ_STATE_CKCACHE		0x00010000
143a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_DEBUG_STATE_VE_REQ_STATE_MISS		0x00020000
144a8c21a54SThe etnaviv authors 
145a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_ADDRESS					0x00000664
146a8c21a54SThe etnaviv authors 
147a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_LOW						0x00000668
148a8c21a54SThe etnaviv authors 
149a8c21a54SThe etnaviv authors #define VIVS_FE_DMA_HIGH					0x0000066c
150a8c21a54SThe etnaviv authors 
151a8c21a54SThe etnaviv authors #define VIVS_FE_AUTO_FLUSH					0x00000670
152a8c21a54SThe etnaviv authors 
153a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00678					0x00000678
154a8c21a54SThe etnaviv authors 
155a8c21a54SThe etnaviv authors #define VIVS_FE_UNK0067C					0x0000067c
156a8c21a54SThe etnaviv authors 
157a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_STREAMS(i0)			       (0x00000000 + 0x4*(i0))
158a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_STREAMS__ESIZE				0x00000004
159a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_STREAMS__LEN				0x00000008
160a8c21a54SThe etnaviv authors 
161a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_STREAMS_BASE_ADDR(i0)		       (0x00000680 + 0x4*(i0))
162a8c21a54SThe etnaviv authors 
163a8c21a54SThe etnaviv authors #define VIVS_FE_VERTEX_STREAMS_CONTROL(i0)		       (0x000006a0 + 0x4*(i0))
164a8c21a54SThe etnaviv authors 
165a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00700(i0)				       (0x00000700 + 0x4*(i0))
166a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00700__ESIZE					0x00000004
167a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00700__LEN					0x00000010
168a8c21a54SThe etnaviv authors 
169a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00740(i0)				       (0x00000740 + 0x4*(i0))
170a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00740__ESIZE					0x00000004
171a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00740__LEN					0x00000010
172a8c21a54SThe etnaviv authors 
173a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00780(i0)				       (0x00000780 + 0x4*(i0))
174a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00780__ESIZE					0x00000004
175a8c21a54SThe etnaviv authors #define VIVS_FE_UNK00780__LEN					0x00000010
176a8c21a54SThe etnaviv authors 
177a8c21a54SThe etnaviv authors #define VIVS_GL							0x00000000
178a8c21a54SThe etnaviv authors 
179a8c21a54SThe etnaviv authors #define VIVS_GL_PIPE_SELECT					0x00003800
180a8c21a54SThe etnaviv authors #define VIVS_GL_PIPE_SELECT_PIPE__MASK				0x00000001
181a8c21a54SThe etnaviv authors #define VIVS_GL_PIPE_SELECT_PIPE__SHIFT				0
182a8c21a54SThe etnaviv authors #define VIVS_GL_PIPE_SELECT_PIPE(x)				(((x) << VIVS_GL_PIPE_SELECT_PIPE__SHIFT) & VIVS_GL_PIPE_SELECT_PIPE__MASK)
183a8c21a54SThe etnaviv authors 
184a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT						0x00003804
185a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_EVENT_ID__MASK				0x0000001f
186a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_EVENT_ID__SHIFT				0
187a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_EVENT_ID(x)				(((x) << VIVS_GL_EVENT_EVENT_ID__SHIFT) & VIVS_GL_EVENT_EVENT_ID__MASK)
188a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_FROM_FE					0x00000020
189a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_FROM_PE					0x00000040
190a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_SOURCE__MASK				0x00001f00
191a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_SOURCE__SHIFT				8
192a8c21a54SThe etnaviv authors #define VIVS_GL_EVENT_SOURCE(x)					(((x) << VIVS_GL_EVENT_SOURCE__SHIFT) & VIVS_GL_EVENT_SOURCE__MASK)
193a8c21a54SThe etnaviv authors 
194a8c21a54SThe etnaviv authors #define VIVS_GL_SEMAPHORE_TOKEN					0x00003808
195a8c21a54SThe etnaviv authors #define VIVS_GL_SEMAPHORE_TOKEN_FROM__MASK			0x0000001f
196a8c21a54SThe etnaviv authors #define VIVS_GL_SEMAPHORE_TOKEN_FROM__SHIFT			0
197a8c21a54SThe etnaviv authors #define VIVS_GL_SEMAPHORE_TOKEN_FROM(x)				(((x) << VIVS_GL_SEMAPHORE_TOKEN_FROM__SHIFT) & VIVS_GL_SEMAPHORE_TOKEN_FROM__MASK)
198a8c21a54SThe etnaviv authors #define VIVS_GL_SEMAPHORE_TOKEN_TO__MASK			0x00001f00
199a8c21a54SThe etnaviv authors #define VIVS_GL_SEMAPHORE_TOKEN_TO__SHIFT			8
200a8c21a54SThe etnaviv authors #define VIVS_GL_SEMAPHORE_TOKEN_TO(x)				(((x) << VIVS_GL_SEMAPHORE_TOKEN_TO__SHIFT) & VIVS_GL_SEMAPHORE_TOKEN_TO__MASK)
201a8c21a54SThe etnaviv authors 
202a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE					0x0000380c
203a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE_DEPTH				0x00000001
204a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE_COLOR				0x00000002
205a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE_TEXTURE				0x00000004
206a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE_PE2D				0x00000008
207a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE_TEXTUREVS				0x00000010
208a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE_SHADER_L1				0x00000020
209a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_CACHE_SHADER_L2				0x00000040
210a8c21a54SThe etnaviv authors 
211a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_MMU					0x00003810
212a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_MMU_FLUSH_FEMMU				0x00000001
213a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_MMU_FLUSH_UNK1				0x00000002
214a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_MMU_FLUSH_UNK2				0x00000004
215a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_MMU_FLUSH_PEMMU				0x00000008
216a8c21a54SThe etnaviv authors #define VIVS_GL_FLUSH_MMU_FLUSH_UNK4				0x00000010
217a8c21a54SThe etnaviv authors 
218a8c21a54SThe etnaviv authors #define VIVS_GL_VERTEX_ELEMENT_CONFIG				0x00003814
219a8c21a54SThe etnaviv authors 
220a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG				0x00003818
221a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_SAMPLES__MASK		0x00000003
222a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_SAMPLES__SHIFT		0
223a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_SAMPLES_NONE		0x00000000
224a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_SAMPLES_2X		0x00000001
225a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_SAMPLES_4X		0x00000002
226a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_SAMPLES_MASK		0x00000008
227a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_ENABLES__MASK		0x000000f0
228a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_ENABLES__SHIFT		4
229a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_ENABLES(x)		(((x) << VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_ENABLES__SHIFT) & VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_ENABLES__MASK)
230a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_MSAA_ENABLES_MASK		0x00000100
231a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK12__MASK			0x00007000
232a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK12__SHIFT		12
233a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK12(x)			(((x) << VIVS_GL_MULTI_SAMPLE_CONFIG_UNK12__SHIFT) & VIVS_GL_MULTI_SAMPLE_CONFIG_UNK12__MASK)
234a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK12_MASK			0x00008000
235a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK16__MASK			0x00030000
236a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK16__SHIFT		16
237a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK16(x)			(((x) << VIVS_GL_MULTI_SAMPLE_CONFIG_UNK16__SHIFT) & VIVS_GL_MULTI_SAMPLE_CONFIG_UNK16__MASK)
238a8c21a54SThe etnaviv authors #define VIVS_GL_MULTI_SAMPLE_CONFIG_UNK16_MASK			0x00080000
239a8c21a54SThe etnaviv authors 
240a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_TOTAL_COMPONENTS			0x0000381c
241a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_TOTAL_COMPONENTS_NUM__MASK		0x000000ff
242a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_TOTAL_COMPONENTS_NUM__SHIFT		0
243a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_TOTAL_COMPONENTS_NUM(x)			(((x) << VIVS_GL_VARYING_TOTAL_COMPONENTS_NUM__SHIFT) & VIVS_GL_VARYING_TOTAL_COMPONENTS_NUM__MASK)
244a8c21a54SThe etnaviv authors 
245a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS				0x00003820
246a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR0__MASK		0x00000007
247a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR0__SHIFT		0
248a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR0(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR0__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR0__MASK)
249a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR1__MASK		0x00000070
250a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR1__SHIFT		4
251a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR1(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR1__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR1__MASK)
252a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR2__MASK		0x00000700
253a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR2__SHIFT		8
254a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR2(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR2__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR2__MASK)
255a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR3__MASK		0x00007000
256a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR3__SHIFT		12
257a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR3(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR3__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR3__MASK)
258a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR4__MASK		0x00070000
259a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR4__SHIFT		16
260a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR4(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR4__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR4__MASK)
261a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR5__MASK		0x00700000
262a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR5__SHIFT		20
263a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR5(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR5__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR5__MASK)
264a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR6__MASK		0x07000000
265a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR6__SHIFT		24
266a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR6(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR6__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR6__MASK)
267a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR7__MASK		0x70000000
268a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR7__SHIFT		28
269a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_NUM_COMPONENTS_VAR7(x)			(((x) << VIVS_GL_VARYING_NUM_COMPONENTS_VAR7__SHIFT) & VIVS_GL_VARYING_NUM_COMPONENTS_VAR7__MASK)
270a8c21a54SThe etnaviv authors 
271a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE(i0)		       (0x00003828 + 0x4*(i0))
272a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE__ESIZE			0x00000004
273a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE__LEN			0x00000002
274a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP0__MASK		0x00000003
275a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP0__SHIFT		0
276a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP0(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP0__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP0__MASK)
277a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP1__MASK		0x0000000c
278a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP1__SHIFT		2
279a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP1(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP1__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP1__MASK)
280a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP2__MASK		0x00000030
281a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP2__SHIFT		4
282a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP2(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP2__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP2__MASK)
283a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP3__MASK		0x000000c0
284a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP3__SHIFT		6
285a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP3(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP3__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP3__MASK)
286a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP4__MASK		0x00000300
287a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP4__SHIFT		8
288a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP4(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP4__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP4__MASK)
289a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP5__MASK		0x00000c00
290a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP5__SHIFT		10
291a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP5(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP5__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP5__MASK)
292a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP6__MASK		0x00003000
293a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP6__SHIFT		12
294a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP6(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP6__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP6__MASK)
295a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP7__MASK		0x0000c000
296a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP7__SHIFT		14
297a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP7(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP7__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP7__MASK)
298a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP8__MASK		0x00030000
299a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP8__SHIFT		16
300a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP8(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP8__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP8__MASK)
301a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP9__MASK		0x000c0000
302a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP9__SHIFT		18
303a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP9(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP9__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP9__MASK)
304a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP10__MASK		0x00300000
305a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP10__SHIFT		20
306a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP10(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP10__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP10__MASK)
307a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP11__MASK		0x00c00000
308a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP11__SHIFT		22
309a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP11(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP11__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP11__MASK)
310a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP12__MASK		0x03000000
311a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP12__SHIFT		24
312a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP12(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP12__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP12__MASK)
313a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP13__MASK		0x0c000000
314a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP13__SHIFT		26
315a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP13(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP13__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP13__MASK)
316a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP14__MASK		0x30000000
317a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP14__SHIFT		28
318a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP14(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP14__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP14__MASK)
319a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP15__MASK		0xc0000000
320a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP15__SHIFT		30
321a8c21a54SThe etnaviv authors #define VIVS_GL_VARYING_COMPONENT_USE_COMP15(x)			(((x) << VIVS_GL_VARYING_COMPONENT_USE_COMP15__SHIFT) & VIVS_GL_VARYING_COMPONENT_USE_COMP15__MASK)
322a8c21a54SThe etnaviv authors 
323a8c21a54SThe etnaviv authors #define VIVS_GL_UNK03834					0x00003834
324a8c21a54SThe etnaviv authors 
325a8c21a54SThe etnaviv authors #define VIVS_GL_UNK03838					0x00003838
326a8c21a54SThe etnaviv authors 
327a8c21a54SThe etnaviv authors #define VIVS_GL_API_MODE					0x0000384c
328a8c21a54SThe etnaviv authors #define VIVS_GL_API_MODE_OPENGL					0x00000000
329a8c21a54SThe etnaviv authors #define VIVS_GL_API_MODE_OPENVG					0x00000001
330a8c21a54SThe etnaviv authors #define VIVS_GL_API_MODE_OPENCL					0x00000002
331a8c21a54SThe etnaviv authors 
332a8c21a54SThe etnaviv authors #define VIVS_GL_CONTEXT_POINTER					0x00003850
333a8c21a54SThe etnaviv authors 
334a8c21a54SThe etnaviv authors #define VIVS_GL_UNK03A00					0x00003a00
335a8c21a54SThe etnaviv authors 
336a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN					0x00003c00
337a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_FROM__MASK				0x0000001f
338a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_FROM__SHIFT				0
339a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_FROM(x)				(((x) << VIVS_GL_STALL_TOKEN_FROM__SHIFT) & VIVS_GL_STALL_TOKEN_FROM__MASK)
340a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_TO__MASK				0x00001f00
341a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_TO__SHIFT				8
342a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_TO(x)				(((x) << VIVS_GL_STALL_TOKEN_TO__SHIFT) & VIVS_GL_STALL_TOKEN_TO__MASK)
343a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_FLIP0				0x40000000
344a8c21a54SThe etnaviv authors #define VIVS_GL_STALL_TOKEN_FLIP1				0x80000000
345a8c21a54SThe etnaviv authors 
346a8c21a54SThe etnaviv authors #define VIVS_DUMMY						0x00000000
347a8c21a54SThe etnaviv authors 
348a8c21a54SThe etnaviv authors #define VIVS_DUMMY_DUMMY					0x0003fffc
349a8c21a54SThe etnaviv authors 
350a8c21a54SThe etnaviv authors 
351a8c21a54SThe etnaviv authors #endif /* STATE_XML */
352