summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64/dev/creatorreg.h
blob: c9a3ceb9c87fc52a1ded769d76c11277e9ee4ec8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
/*	$OpenBSD: creatorreg.h,v 1.6 2003/03/27 18:17:58 jason Exp $	*/

/*
 * Copyright (c) 2002 Jason L. Wright (jason@thought.net)
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. All advertising materials mentioning features or use of this software
 *    must display the following acknowledgement:
 *	This product includes software developed by Jason L. Wright
 * 4. The name of the author may not be used to endorse or promote products
 *    derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

/* Number of register sets */
#define	FFB_NREGS		24

/* Register set numbers */
#define	FFB_REG_PROM		0
#define	FFB_REG_DAC		1
#define	FFB_REG_FBC		2
#define	FFB_REG_DFB8R		3
#define	FFB_REG_DFB8G		4
#define	FFB_REG_DFB8B		5
#define	FFB_REG_DFB8X		6
#define	FFB_REG_DFB24		7
#define	FFB_REG_DFB32		8
#define	FFB_REG_SFB8R		9
#define	FFB_REG_SFB8G		10
#define	FFB_REG_SFB8B		11
#define	FFB_REG_SFB8X		12
#define	FFB_REG_SFB32		13
#define	FFB_REG_SFB64		14
#define	FFB_REG_DFB422A		15

/* Virtual offsets */
#define	FFB_VOFF_SFB8R		0x00000000UL
#define	FFB_VOFF_SFB8G		0x00400000UL
#define	FFB_VOFF_SFB8B		0x00800000UL
#define	FFB_VOFF_SFB8X		0x00c00000UL
#define	FFB_VOFF_SFB32		0x01000000UL
#define	FFB_VOFF_SFB64		0x02000000UL
#define	FFB_VOFF_FBC_REGS	0x04000000UL
#define	FFB_VOFF_BM_FBC_REGS	0x04002000UL
#define	FFB_VOFF_DFB8R		0x04004000UL
#define	FFB_VOFF_DFB8G		0x04404000UL
#define	FFB_VOFF_DFB8B		0x04804000UL
#define	FFB_VOFF_DFB8X		0x04c04000UL
#define	FFB_VOFF_DFB24		0x05004000UL
#define	FFB_VOFF_DFB32		0x06004000UL
#define	FFB_VOFF_DFB422A	0x07004000UL	/* DFB 422 mode write to A */
#define	FFB_VOFF_DFB422AD	0x07804000UL	/* DFB 422 mode with line doubling */
#define	FFB_VOFF_DFB24B		0x08004000UL	/* DFB 24bit mode write to B */
#define	FFB_VOFF_DFB422B	0x09004000UL	/* DFB 422 mode write to B */
#define	FFB_VOFF_DFB422BD	0x09804000UL	/* DFB 422 mode with line doubling */
#define	FFB_VOFF_SFB16Z		0x0a004000UL	/* 16bit mode Z planes */
#define	FFB_VOFF_SFB8Z		0x0a404000UL	/* 8bit mode Z planes */
#define	FFB_VOFF_SFB422		0x0ac04000UL	/* SFB 422 mode write to A/B */
#define	FFB_VOFF_SFB422D	0x0b404000UL	/* SFB 422 mode with line doubling */
#define	FFB_VOFF_FBC_KREGS	0x0bc04000UL
#define	FFB_VOFF_DAC		0x0bc06000UL
#define	FFB_VOFF_PROM		0x0bc08000UL
#define	FFB_VOFF_EXP		0x0bc18000UL

/* Virtual lengths */
#define	FFB_VLEN_SFB8R		0x0400000
#define	FFB_VLEN_SFB8G		0x0400000
#define	FFB_VLEN_SFB8B		0x0400000
#define	FFB_VLEN_SFB8X		0x0400000
#define	FFB_VLEN_SFB32		0x1000000
#define	FFB_VLEN_SFB64		0x2000000
#define	FFB_VLEN_FBC_REGS	0x0002000
#define	FFB_VLEN_BM_FBC_REGS	0x0002000
#define	FFB_VLEN_DFB8R		0x0400000
#define	FFB_VLEN_DFB8G		0x0400000
#define	FFB_VLEN_DFB8B		0x0400000
#define	FFB_VLEN_DFB8X		0x0400000
#define	FFB_VLEN_DFB24		0x1000000
#define	FFB_VLEN_DFB32		0x1000000
#define	FFB_VLEN_DFB422A	0x0800000
#define	FFB_VLEN_DFB422AD	0x0800000
#define	FFB_VLEN_DFB24B		0x1000000
#define	FFB_VLEN_DFB422B	0x0800000
#define	FFB_VLEN_DFB422BD	0x0800000
#define	FFB_VLEN_SFB16Z		0x0800000
#define	FFB_VLEN_SFB8Z		0x0800000
#define	FFB_VLEN_SFB422		0x0800000
#define	FFB_VLEN_SFB422D	0x0800000
#define	FFB_VLEN_FBC_KREGS	0x0002000
#define	FFB_VLEN_DAC		0x0002000
#define	FFB_VLEN_PROM		0x0010000
#define	FFB_VLEN_EXP		0x0002000

/* Physical offsets */
#define	FFB_POFF_SFB8R		0x04000000UL
#define	FFB_POFF_SFB8G		0x04400000UL
#define	FFB_POFF_SFB8B		0x04800000UL
#define	FFB_POFF_SFB8X		0x04c00000UL
#define	FFB_POFF_SFB32		0x05000000UL
#define	FFB_POFF_SFB64		0x06000000UL
#define	FFB_POFF_FBC_REGS	0x00600000UL
#define	FFB_POFF_BM_FBC_REGS	0x00600000UL
#define	FFB_POFF_DFB8R		0x01000000UL
#define	FFB_POFF_DFB8G		0x01400000UL
#define	FFB_POFF_DFB8B		0x01800000UL
#define	FFB_POFF_DFB8X		0x01c00000UL
#define	FFB_POFF_DFB24		0x02000000UL
#define	FFB_POFF_DFB32		0x03000000UL
#define	FFB_POFF_FBC_KREGS	0x00610000UL
#define	FFB_POFF_DAC		0x00400000UL
#define	FFB_POFF_PROM		0x00000000UL
#define	FFB_POFF_EXP		0x00200000UL
#define	FFB_POFF_DFB422A	0x09000000UL
#define	FFB_POFF_DFB422AD	0x09800000UL
#define	FFB_POFF_DFB24B		0x0a000000UL
#define	FFB_POFF_DFB422B	0x0b000000UL
#define	FFB_POFF_DFB422BD	0x0b800000UL
#define	FFB_POFF_SFB16Z		0x0c800000UL
#define	FFB_POFF_SFB8Z		0x0c000000UL
#define	FFB_POFF_SFB422		0x0d000000UL
#define	FFB_POFF_SFB422D	0x0d800000UL

#define	FFB_FBC_ALPHA		0x00c
#define	FFB_FBC_RED		0x010
#define	FFB_FBC_GREEN		0x014
#define	FFB_FBC_BLUE		0x018
#define	FFB_FBC_DEPTH		0x01c
#define	FFB_FBC_Y		0x020
#define	FFB_FBC_X		0x024
#define	FFB_FBC_RYF		0x030
#define	FFB_FBC_RXF		0x034
#define	FFB_FBC_DMYF		0x040
#define	FFB_FBC_DMXF		0x044
#define	FFB_FBC_EBYI		0x050
#define	FFB_FBC_EBXI		0x054
#define	FFB_FBC_BY		0x060
#define	FFB_FBC_BX		0x064
#define	FFB_FBC_DY		0x068
#define	FFB_FBC_DX		0x06c
#define	FFB_FBC_BH		0x070
#define	FFB_FBC_BW		0x074
#define	FFB_FBC_SUVTX		0x100
#define	FFB_FBC_PPC		0x200	/* pixel processor control */
#define	FFB_FBC_WID		0x204
#define	FFB_FBC_FG		0x208
#define	FFB_FBC_BG		0x20c
#define	FFB_FBC_CONSTY		0x210
#define	FFB_FBC_CONSTZ		0x214
#define	FFB_FBC_XCLIP		0x218
#define	FFB_FBC_DCSS		0x21c
#define	FFB_FBC_VCLIPMIN	0x220
#define	FFB_FBC_VCLIPMAX	0x224
#define	FFB_FBC_VCLIPZMIN	0x228
#define	FFB_FBC_VCLIPZMAX	0x22c
#define	FFB_FBC_DCSF		0x230
#define	FFB_FBC_DCSB		0x234
#define	FFB_FBC_DCZF		0x238
#define	FFB_FBC_DCZB		0x23c
#define	FFB_FBC_BLENDC		0x244
#define	FFB_FBC_BLENDC1		0x248
#define	FFB_FBC_BLENDC2		0x24c
#define	FFB_FBC_FBRAMITC	0x250
#define	FFB_FBC_FBC		0x254	/* Frame Buffer Control	*/
#define	FFB_FBC_ROP		0x258	/* Raster OPeration */
#define	FFB_FBC_CMP		0x25c	/* Frame Buffer Compare */
#define	FFB_FBC_MATCHAB		0x260	/* Buffer AB Match Mask	*/
#define	FFB_FBC_MATCHC		0x264
#define	FFB_FBC_MAGNAB		0x268	/* Buffer AB Magnitude Mask */
#define	FFB_FBC_MAGNC		0x26c
#define	FFB_FBC_FBCFG0		0x270
#define	FFB_FBC_FBCFG1		0x274
#define	FFB_FBC_FBCFG2		0x278
#define	FFB_FBC_FBCFG3		0x27c
#define	FFB_FBC_PPCFG		0x280
#define	FFB_FBC_PICK		0x284
#define	FFB_FBC_FILLMODE	0x288
#define	FFB_FBC_FBRAMWAC	0x28c
#define	FFB_FBC_PMASK		0x290	/* RGB Plane Mask */
#define	FFB_FBC_XPMASK		0x294	/* X PlaneMask */
#define	FFB_FBC_YPMASK		0x298
#define	FFB_FBC_ZPMASK		0x29c
#define	FFB_FBC_CLIP0MIN	0x2a0
#define	FFB_FBC_CLIP0MAX	0x2a4
#define	FFB_FBC_CLIP1MIN	0x2a8
#define	FFB_FBC_CLIP1MAX	0x2ac
#define	FFB_FBC_CLIP2MIN	0x2b0
#define	FFB_FBC_CLIP2MAX	0x2b4
#define	FFB_FBC_CLIP3MIN	0x2b8
#define	FFB_FBC_CLIP3MAX	0x2bc
#define	FFB_FBC_RAWBLEND2	0x2c0
#define	FFB_FBC_RAWPREBLEND	0x2c4
#define	FFB_FBC_RAWSTENCIL	0x2c8
#define	FFB_FBC_RAWSTENCILCTL	0x2cc
#define	FFB_FBC_THREEDRAM1	0x2d0
#define	FFB_FBC_THREEDRAM2	0x2d4
#define	FFB_FBC_PASSIN		0x2d8
#define	FFB_FBC_RAWCLRDEPTH	0x2dc
#define	FFB_FBC_RAWPMASK	0x2e0
#define	FFB_FBC_RAWCSRC		0x2e4
#define	FFB_FBC_RAWMATCH	0x2e8
#define	FFB_FBC_RAWMAGN		0x2ec
#define	FFB_FBC_RAWROPBLEND	0x2f0
#define	FFB_FBC_RAWCMP		0x2f4
#define	FFB_FBC_RAWWAC		0x2f8
#define	FFB_FBC_FBRAMID		0x2fc
#define	FFB_FBC_DRAWOP		0x300	/* Draw OPeration */
#define	FFB_FBC_FONTLPAT	0x30c
#define	FFB_FBC_FONTXY		0x314
#define	FFB_FBC_FONTW		0x318	/* Font Width */
#define	FFB_FBC_FONTINC		0x31c	/* Font Increment */
#define	FFB_FBC_FONT		0x320
#define	FFB_FBC_BLEND2		0x330
#define	FFB_FBC_PREBLEND	0x334
#define	FFB_FBC_STENCIL		0x338
#define	FFB_FBC_STENCILCTL	0x33c
#define	FFB_FBC_DCSS1		0x350
#define	FFB_FBC_DCSS2		0x354
#define	FFB_FBC_DCSS3		0x358
#define	FFB_FBC_WIDPMASK	0x35c
#define	FFB_FBC_DCS2		0x360
#define	FFB_FBC_DCS3		0x364
#define	FFB_FBC_DCS4		0x368
#define	FFB_FBC_DCD2		0x370
#define	FFB_FBC_DCD3		0x374
#define	FFB_FBC_DCD4		0x378
#define	FFB_FBC_PATTERN		0x380
#define	FFB_FBC_DEVID		0x800
#define	FFB_FBC_UCSR		0x900	/* User Control & Status */
#define	FFB_FBC_MER		0x980

#define	FFB_FBC_WB_A		0x20000000
#define	FFB_FBC_WM_COMBINED	0x00080000
#define	FFB_FBC_RB_A		0x00004000
#define	FFB_FBC_SB_BOTH		0x00003000
#define	FFB_FBC_ZE_OFF		0x00000400
#define	FFB_FBC_YE_OFF		0x00000100
#define	FFB_FBC_XE_ON		0x00000080
#define	FFB_FBC_XE_OFF		0x00000040
#define	FFB_FBC_RGBE_ON		0x0000002a
#define	FFB_FBC_RGBE_MASK	0x0000003f

#define	FBC_PPC_FW_DIS		0x00800000	/* force wid disable */
#define	FBC_PPC_FW_ENA		0x00c00000	/* force wid enable */
#define	FBC_PPC_ACE_DIS		0x00040000	/* aux clip disable */
#define	FBC_PPC_ACE_AUXSUB	0x00080000	/* aux clip add */
#define	FBC_PPC_ACE_AUXADD	0x000c0000	/* aux clip subtract */
#define	FBC_PPC_DCE_DIS		0x00020000	/* depth cue disable */
#define	FBC_PPC_DCE_ENA		0x00020000	/* depth cue enable */
#define	FBC_PPC_ABE_DIS		0x00008000	/* alpha blend disable */
#define	FBC_PPC_ABE_ENA		0x0000c000	/* alpha blend enable */
#define	FBC_PPC_VCE_DIS		0x00001000	/* view clip disable */
#define	FBC_PPC_VCE_2D		0x00002000	/* view clip 2d */
#define	FBC_PPC_VCE_3D		0x00003000	/* view clip 3d */
#define	FBC_PPC_APE_DIS		0x00000800	/* area pattern disable */
#define	FBC_PPC_APE_ENA		0x00000c00	/* area pattern enable */
#define	FBC_PPC_TBE_OPAQUE	0x00000200	/* opaque background */
#define	FBC_PPC_TBE_TRANSPAR	0x00000300	/* transparent background */
#define	FBC_PPC_ZS_VAR		0x00000080	/* z source ??? */
#define	FBC_PPC_ZS_CONST	0x000000c0	/* z source ??? */
#define	FBC_PPC_YS_VAR		0x00000020	/* y source ??? */
#define	FBC_PPC_YS_CONST	0x00000030	/* y source ??? */
#define	FBC_PPC_XS_WID		0x00000004	/* x source ??? */
#define	FBC_PPC_XS_VAR		0x00000008	/* x source ??? */
#define	FBC_PPC_XS_CONST	0x0000000c	/* x source ??? */
#define	FBC_PPC_CS_VAR		0x00000002	/* color source ??? */
#define	FBC_PPC_CS_CONST	0x00000003	/* color source ??? */

#define	FBC_ROP_NEW		0x83
#define	FBC_ROP_OLD		0x85

#define	FBC_UCSR_FIFO_MASK	0x00000fff
#define	FBC_UCSR_FB_BUSY	0x01000000
#define	FBC_UCSR_RP_BUSY	0x02000000
#define	FBC_UCSR_READ_ERR	0x40000000
#define	FBC_UCSR_FIFO_OVFL	0x80000000

#define	FBC_DRAWOP_DOT		0x00
#define	FBC_DRAWOP_AADOT	0x01
#define	FBC_DRAWOP_BRLINECAP	0x02
#define	FBC_DRAWOP_BRLINEOPEN	0x03
#define	FBC_DRAWOP_DDLINE	0x04
#define	FBC_DRAWOP_AALINE	0x05
#define	FBC_DRAWOP_TRIANGLE	0x06
#define	FBC_DRAWOP_POLYGON	0x07
#define	FBC_DRAWOP_RECTANGLE	0x08
#define	FBC_DRAWOP_FASTFILL	0x09
#define	FBC_DRAWOP_BCOPY	0x0a	/* block copy: not implemented */
#define	FBC_DRAWOP_VSCROLL	0x0b	/* vertical scroll */

#define	FFB_DAC_TYPE		0x00
#define	FFB_DAC_VALUE		0x04
#define	FFB_DAC_TYPE2		0x08
#define	FFB_DAC_VALUE2		0x0c

#define	DAC_TYPE_CMAP		0x2000	/* load cmap */
#define	DAC_TYPE_BLANK		0x6000	/* blank/unblank */
#define	DAC_TYPE_GETREV		0x8000	/* get dac revision */

#define	DAC_TYPE2_CURSENAB	0x100	/* cursor enable */
#define	DAC_TYPE2_CURSCMAP	0x102	/* set cursor colormap */
#define	DAC_TYPE2_CURSPOS	0x104	/* set cursor position */