atmel_lcdfb: AT91/AT32 LCD Controller framebuffer driver
[linux-2.6.git] / include / video / pm3fb.h
1 /*
2  *  linux/drivers/video/pm3fb.h -- 3DLabs Permedia3 frame buffer device
3  *  
4  *  Copyright (C) 2001 Romain Dolbeau <dolbeau@irisa.fr>
5  *  Copyright (C) 2001 Sven Luther, <luther@dpt-info.u-strasbg.fr>
6  *
7  *  This file is subject to the terms and conditions of the GNU General Public
8  *  License. See the file COPYING in the main directory of this archive for
9  *  more details.
10  */
11
12 #ifndef PM3FB_H
13 #define PM3FB_H
14
15 /**********************************************
16 *  GLINT Permedia3 Control Status registers   *
17 ***********************************************/
18 /* Control Status Registers */
19 #define PM3ResetStatus                                          0x0000
20 #define PM3IntEnable                                            0x0008
21 #define PM3IntFlags                                             0x0010
22 #define PM3InFIFOSpace                                          0x0018
23 #define PM3OutFIFOWords                                         0x0020
24 #define PM3DMAAddress                                           0x0028
25 #define PM3DMACount                                             0x0030
26 #define PM3ErrorFlags                                           0x0038
27 #define PM3VClkCtl                                              0x0040
28 #define PM3TestRegister                                         0x0048
29 #define PM3Aperture0                                            0x0050
30 #define PM3Aperture1                                            0x0058
31 #define PM3DMAControl                                           0x0060
32 #define PM3FIFODis                                              0x0068
33 #define PM3ChipConfig                                           0x0070
34 #define PM3AGPControl                                           0x0078
35
36 #define PM3GPOutDMAAddress                                      0x0080
37 #define PM3PCIFeedbackCount                                     0x0088
38 #define PM3PCIAbortStatus                                       0x0090
39 #define PM3PCIAbortAddress                                      0x0098
40
41 #define PM3PCIPLLStatus                                         0x00f0
42
43 #define PM3HostTextureAddress                                   0x0100
44 #define PM3TextureDownloadControl                               0x0108
45 #define PM3TextureOperation                                     0x0110
46 #define PM3LogicalTexturePage                                   0x0118
47 #define PM3TexDMAAddress                                        0x0120
48 #define PM3TexFIFOSpace                                         0x0128
49
50 /**********************************************
51 *  GLINT Permedia3 Region 0 Bypass Controls   *
52 ***********************************************/
53 #define PM3ByAperture1Mode                                      0x0300
54         #define PM3ByApertureMode_BYTESWAP_ABCD                 (0<<0)
55         #define PM3ByApertureMode_BYTESWAP_BADC                 (1<<0)
56         #define PM3ByApertureMode_BYTESWAP_CDAB                 (2<<0)
57         #define PM3ByApertureMode_BYTESWAP_DCBA                 (3<<0)
58         #define PM3ByApertureMode_PATCH_DISABLE                 (0<<2)
59         #define PM3ByApertureMode_PATCH_ENABLE                  (1<<2)
60         #define PM3ByApertureMode_FORMAT_RAW                    (0<<3)
61         #define PM3ByApertureMode_FORMAT_YUYV                   (1<<3)
62         #define PM3ByApertureMode_FORMAT_UYVY                   (2<<3)
63         #define PM3ByApertureMode_PIXELSIZE_8BIT                (0<<5)
64         #define PM3ByApertureMode_PIXELSIZE_16BIT               (1<<5)
65         #define PM3ByApertureMode_PIXELSIZE_32BIT               (2<<5)
66                 #define PM3ByApertureMode_PIXELSIZE_MASK        (3<<5)
67         #define PM3ByApertureMode_EFFECTIVE_STRIDE_1024         (0<<7)
68         #define PM3ByApertureMode_EFFECTIVE_STRIDE_2048         (1<<7)
69         #define PM3ByApertureMode_EFFECTIVE_STRIDE_4096         (2<<7)
70         #define PM3ByApertureMode_EFFECTIVE_STRIDE_8192         (3<<7)
71         #define PM3ByApertureMode_PATCH_OFFSET_X(off)   (((off)&7f)<<9)
72         #define PM3ByApertureMode_PATCH_OFFSET_Y(off)   (((off)&7f)<<16)
73         #define PM3ByApertureMode_FRAMEBUFFER                   (0<<21)
74         #define PM3ByApertureMode_LOCALBUFFER                   (1<<21)
75         #define PM3ByApertureMode_DOUBLE_WRITE_OFF              (0<<22)
76         #define PM3ByApertureMode_DOUBLE_WRITE_1MB              (1<<22)
77         #define PM3ByApertureMode_DOUBLE_WRITE_2MB              (2<<22)
78         #define PM3ByApertureMode_DOUBLE_WRITE_4MB              (3<<22)
79         #define PM3ByApertureMode_DOUBLE_WRITE_8MB              (4<<22)
80         #define PM3ByApertureMode_DOUBLE_WRITE_16MB             (5<<22)
81         #define PM3ByApertureMode_DOUBLE_WRITE_32MB             (6<<22)
82
83 #define PM3ByAperture2Mode                                      0x0328
84         
85 /**********************************************
86 *  GLINT Permedia3 Memory Control (0x1000)    *
87 ***********************************************/
88 #define PM3MemCounter                                           0x1000
89 #define PM3MemBypassWriteMask                                   0x1008
90 #define PM3MemScratch                                           0x1010
91 #define PM3LocalMemCaps                                         0x1018
92         #define PM3LocalMemCaps_NoWriteMask                     (1 << 28)
93 #define PM3LocalMemTimings                                      0x1020
94 #define PM3LocalMemControl                                      0x1028
95 #define PM3LocalMemRefresh                                      0x1030
96 #define PM3LocalMemPowerDown                                    0x1038
97 #define PM3RemoteMemControl                                     0x1100
98
99 /**********************************************
100 *  GLINT Permedia3 Video Control (0x3000)     *
101 ***********************************************/
102
103 #define PM3ScreenBase                                           0x3000
104 #define PM3ScreenStride                                         0x3008
105 #define PM3HTotal                                               0x3010
106 #define PM3HgEnd                                                0x3018
107 #define PM3HbEnd                                                0x3020
108 #define PM3HsStart                                              0x3028
109 #define PM3HsEnd                                                0x3030
110 #define PM3VTotal                                               0x3038
111 #define PM3VbEnd                                                0x3040
112 #define PM3VsStart                                              0x3048
113 #define PM3VsEnd                                                0x3050
114 #define PM3VideoControl                                         0x3058
115         #define PM3VideoControl_DISABLE                         (0<<0)
116         #define PM3VideoControl_ENABLE                          (1<<0)
117         #define PM3VideoControl_BLANK_ACTIVE_HIGH               (0<<1)
118         #define PM3VideoControl_BLANK_ACTIVE_LOW                (1<<1)
119         #define PM3VideoControl_LINE_DOUBLE_OFF                 (0<<2)
120         #define PM3VideoControl_LINE_DOUBLE_ON                  (1<<2)
121         #define PM3VideoControl_HSYNC_FORCE_HIGH                (0<<3)
122         #define PM3VideoControl_HSYNC_ACTIVE_HIGH               (1<<3)
123         #define PM3VideoControl_HSYNC_FORCE_LOW                 (2<<3)
124         #define PM3VideoControl_HSYNC_ACTIVE_LOW                (3<<3)
125         #define PM3VideoControl_HSYNC_MASK          (3<<3)
126         #define PM3VideoControl_VSYNC_FORCE_HIGH                (0<<5)
127         #define PM3VideoControl_VSYNC_ACTIVE_HIGH               (1<<5)
128         #define PM3VideoControl_VSYNC_FORCE_LOW                 (2<<5)
129         #define PM3VideoControl_VSYNC_ACTIVE_LOW                (3<<5)
130         #define PM3VideoControl_VSYNC_MASK          (3<<5)
131         #define PM3VideoControl_BYTE_DOUBLE_OFF                 (0<<7)
132         #define PM3VideoControl_BYTE_DOUBLE_ON                  (1<<7)
133         #define PM3VideoControl_BUFFER_SWAP_SYNCON_FRAMEBLANK   (0<<9)
134         #define PM3VideoControl_BUFFER_SWAP_FREE_RUNNING        (1<<9)
135         #define PM3VideoControl_BUFFER_SWAP_LIMITETO_FRAMERATE  (2<<9)
136         #define PM3VideoControl_STEREO_DISABLE                  (0<<11)
137         #define PM3VideoControl_STEREO_ENABLE                   (1<<11)
138         #define PM3VideoControl_RIGHT_EYE_ACTIVE_HIGH           (0<<12)
139         #define PM3VideoControl_RIGHT_EYE_ACTIVE_LOW            (1<<12)
140         #define PM3VideoControl_VIDEO_EXT_LOW                   (0<<14)
141         #define PM3VideoControl_VIDEO_EXT_HIGH                  (1<<14)
142         #define PM3VideoControl_SYNC_MODE_INDEPENDENT           (0<<16)
143         #define PM3VideoControl_SYNC_MODE_SYNCTO_VSA            (1<<16)
144         #define PM3VideoControl_SYNC_MODE_SYNCTO_VSB            (2<<16)
145         #define PM3VideoControl_PATCH_DISABLE                   (0<<18)
146         #define PM3VideoControl_PATCH_ENABLE                    (1<<18)
147         #define PM3VideoControl_PIXELSIZE_8BIT                  (0<<19)
148         #define PM3VideoControl_PIXELSIZE_16BIT                 (1<<19)
149         #define PM3VideoControl_PIXELSIZE_32BIT                 (2<<19)
150         #define PM3VideoControl_DISPLAY_DISABLE                 (0<<21)
151         #define PM3VideoControl_DISPLAY_ENABLE                  (1<<21)
152         #define PM3VideoControl_PATCH_OFFSET_X(off)     (((off)&0x3f)<<22)
153         #define PM3VideoControl_PATCH_OFFSET_Y(off)     (((off)&0x3f)<<28)
154 #define PM3InterruptLine                                        0x3060
155 #define PM3DisplayData                                          0x3068
156 #define PM3VerticalLineCount                                    0x3070
157 #define PM3FifoControl                                          0x3078
158 #define PM3ScreenBaseRight                                      0x3080
159 #define PM3MiscControl                                          0x3088
160
161 #define PM3VideoOverlayUpdate                                   0x3100
162         #define PM3VideoOverlayUpdate_DISABLE                   (0<<0)
163         #define PM3VideoOverlayUpdate_ENABLE                    (1<<0)
164 #define PM3VideoOverlayMode                                     0x3108
165         #define PM3VideoOverlayMode_DISABLE                     (0<<0)
166         #define PM3VideoOverlayMode_ENABLE                      (1<<0)
167         #define PM3VideoOverlayMode_BUFFERSYNC_MANUAL           (0<<1)
168         #define PM3VideoOverlayMode_BUFFERSYNC_VIDEOSTREAMA     (1<<1)
169         #define PM3VideoOverlayMode_BUFFERSYNC_VIDEOSTREAMB     (2<<1)
170         #define PM3VideoOverlayMode_FIELDPOLARITY_NORMAL        (0<<4)
171         #define PM3VideoOverlayMode_FIELDPOLARITY_INVERT        (1<<4)
172         #define PM3VideoOverlayMode_PIXELSIZE_8BIT              (0<<5)
173         #define PM3VideoOverlayMode_PIXELSIZE_16BIT             (1<<5)
174         #define PM3VideoOverlayMode_PIXELSIZE_32BIT             (2<<5)
175         #define PM3VideoOverlayMode_COLORFORMAT_RGB8888 ((0<<7)|(1<<12)|(2<<5))
176         #define PM3VideoOverlayMode_COLORFORMAT_RGB4444 ((1<<7)|(1<<12)|(1<<5))
177         #define PM3VideoOverlayMode_COLORFORMAT_RGB5551 ((2<<7)|(1<<12)|(1<<5))
178         #define PM3VideoOverlayMode_COLORFORMAT_RGB565  ((3<<7)|(1<<12)|(1<<5))
179         #define PM3VideoOverlayMode_COLORFORMAT_RGB332  ((4<<7)|(1<<12)|(0<<5))
180         #define PM3VideoOverlayMode_COLORFORMAT_BGR8888 ((0<<7)|(2<<5))
181         #define PM3VideoOverlayMode_COLORFORMAT_BGR4444 ((1<<7)|(1<<5))
182         #define PM3VideoOverlayMode_COLORFORMAT_BGR5551 ((2<<7)|(1<<5))
183         #define PM3VideoOverlayMode_COLORFORMAT_BGR565  ((3<<7)|(1<<5))
184         #define PM3VideoOverlayMode_COLORFORMAT_BGR332  ((4<<7)|(0<<5))
185         #define PM3VideoOverlayMode_COLORFORMAT_CI8     ((5<<7)|(1<<12)|(0<<5))
186         #define PM3VideoOverlayMode_COLORFORMAT_VUY444  ((2<<10)|(1<<12)|(2<<5))
187         #define PM3VideoOverlayMode_COLORFORMAT_YUV444  ((2<<10)|(2<<5))
188         #define PM3VideoOverlayMode_COLORFORMAT_VUY422  ((1<<10)|(1<<12)|(1<<5))
189         #define PM3VideoOverlayMode_COLORFORMAT_YUV422  ((1<<10)|(1<<5))
190         #define PM3VideoOverlayMode_COLORORDER_BGR              (0<<12)
191         #define PM3VideoOverlayMode_COLORORDER_RGB              (1<<12)
192         #define PM3VideoOverlayMode_LINEARCOLOREXT_OFF          (0<<13)
193         #define PM3VideoOverlayMode_LINEARCOLOREXT_ON           (1<<13)
194         #define PM3VideoOverlayMode_FILTER_MASK                 (3<<14)
195         #define PM3VideoOverlayMode_FILTER_OFF                  (0<<14)
196         #define PM3VideoOverlayMode_FILTER_FULL                 (1<<14)
197         #define PM3VideoOverlayMode_FILTER_PARTIAL              (2<<14)
198         #define PM3VideoOverlayMode_DEINTERLACE_OFF             (0<<16)
199         #define PM3VideoOverlayMode_DEINTERLACE_BOB             (1<<16)
200         #define PM3VideoOverlayMode_PATCHMODE_OFF               (0<<18)
201         #define PM3VideoOverlayMode_PATCHMODE_ON                (1<<18)
202         #define PM3VideoOverlayMode_FLIP_VIDEO                  (0<<20)
203         #define PM3VideoOverlayMode_FLIP_VIDEOSTREAMA           (1<<20)
204         #define PM3VideoOverlayMode_FLIP_VIDEOSTREAMB           (2<<20)
205         #define PM3VideoOverlayMode_MIRROR_MASK                 (3<<23)
206         #define PM3VideoOverlayMode_MIRRORX_OFF                 (0<<23)
207         #define PM3VideoOverlayMode_MIRRORX_ON                  (1<<23)
208         #define PM3VideoOverlayMode_MIRRORY_OFF                 (0<<24)
209         #define PM3VideoOverlayMode_MIRRORY_ON                  (1<<24)
210 #define PM3VideoOverlayFifoControl                              0x3110
211 #define PM3VideoOverlayIndex                                    0x3118
212 #define PM3VideoOverlayBase0                                    0x3120
213 #define PM3VideoOverlayBase1                                    0x3128
214 #define PM3VideoOverlayBase2                                    0x3130
215 #define PM3VideoOverlayStride                                   0x3138
216         #define PM3VideoOverlayStride_STRIDE(s)         (((s)&0xfff)<<0)
217 #define PM3VideoOverlayWidth                                    0x3140
218         #define PM3VideoOverlayWidth_WIDTH(w)           (((w)&0xfff)<<0)
219 #define PM3VideoOverlayHeight                                   0x3148
220         #define PM3VideoOverlayHeight_HEIGHT(h)         (((h)&0xfff)<<0)
221 #define PM3VideoOverlayOrigin                                   0x3150
222         #define PM3VideoOverlayOrigin_XORIGIN(x)        (((x)&0xfff)<<0)
223         #define PM3VideoOverlayOrigin_YORIGIN(y)        (((y)&0xfff)<<16)
224 #define PM3VideoOverlayShrinkXDelta                             0x3158
225         #define PM3VideoOverlayShrinkXDelta_NONE                (1<<16)
226         #define PM3VideoOverlayShrinkXDelta_DELTA(s,d)          \
227                 ((((s)<<16)/(d))&0x0ffffff0)
228 #define PM3VideoOverlayZoomXDelta                               0x3160
229         #define PM3VideoOverlayZoomXDelta_NONE                  (1<<16)
230         #define PM3VideoOverlayZoomXDelta_DELTA(s,d)            \
231                 ((((s)<<16)/(d))&0x0001fff0)
232 #define PM3VideoOverlayYDelta                                   0x3168
233         #define PM3VideoOverlayYDelta_NONE                      (1<<16)
234         #define PM3VideoOverlayYDelta_DELTA(s,d)                        \
235                 ((((s)<<16)/(d))&0x0ffffff0)
236 #define PM3VideoOverlayFieldOffset                              0x3170
237 #define PM3VideoOverlayStatus                                   0x3178
238
239 /**********************************************
240 *  GLINT Permedia3 RAMDAC Registers (0x4000)  *
241 ***********************************************/
242 /* Direct Registers */
243 #define PM3RD_PaletteWriteAddress                               0x4000
244 #define PM3RD_PaletteData                                       0x4008
245 #define PM3RD_PixelMask                                         0x4010
246 #define PM3RD_PaletteReadAddress                                0x4018
247
248 #define PM3RD_IndexLow                                          0x4020
249 #define PM3RD_IndexHigh                                         0x4028
250 #define PM3RD_IndexedData                                       0x4030
251 #define PM3RD_IndexControl                                      0x4038
252         #define PM3RD_IndexControl_AUTOINCREMENT_ENABLE         (1<<0)
253         #define PM3RD_IndexControl_AUTOINCREMENT_DISABLE        (0<<0)
254
255 /* Indirect Registers */
256 #define PM3RD_MiscControl                                       0x000
257         #define PM3RD_MiscControl_HIGHCOLOR_RES_DISABLE         (0<<0)
258         #define PM3RD_MiscControl_HIGHCOLOR_RES_ENABLE          (1<<0)
259         #define PM3RD_MiscControl_PIXELDOUBLE_DISABLE           (0<<1)
260         #define PM3RD_MiscControl_PIXELDOUBLE_ENABLE            (1<<1)
261         #define PM3RD_MiscControl_LASTREAD_ADDR_DISABLE         (0<<2)
262         #define PM3RD_MiscControl_LASTREAD_ADDR_ENABLE          (1<<2)
263         #define PM3RD_MiscControl_DIRECTCOLOR_DISABLE           (0<<3)
264         #define PM3RD_MiscControl_DIRECTCOLOR_ENABLE            (1<<3)
265         #define PM3RD_MiscControl_OVERLAY_DISABLE               (0<<4)
266         #define PM3RD_MiscControl_OVERLAY_ENABLE                (1<<4)
267         #define PM3RD_MiscControl_PIXELDOUBLE_BUFFER_DISABLE    (0<<5)
268         #define PM3RD_MiscControl_PIXELDOUBLE_BUFFER_ENABLE     (1<<5)
269         #define PM3RD_MiscControl_VSB_OUTPUT_DISABLE            (0<<6)
270         #define PM3RD_MiscControl_VSB_OUTPUT_ENABLE             (1<<6)
271         #define PM3RD_MiscControl_STEREODOUBLE_BUFFER_DISABLE   (0<<7)
272         #define PM3RD_MiscControl_STEREODOUBLE_BUFFER_ENABLE    (1<<7)
273 #define PM3RD_SyncControl                                       0x001
274         #define PM3RD_SyncControl_HSYNC_ACTIVE_LOW              (0<<0)
275         #define PM3RD_SyncControl_HSYNC_ACTIVE_HIGH             (1<<0)
276         #define PM3RD_SyncControl_HSYNC_FORCE_ACTIVE            (3<<0)
277         #define PM3RD_SyncControl_HSYNC_FORCE_INACTIVE          (4<<0)
278         #define PM3RD_SyncControl_HSYNC_TRI_STATE               (2<<0)
279         #define PM3RD_SyncControl_VSYNC_ACTIVE_LOW              (0<<3)
280         #define PM3RD_SyncControl_VSYNC_ACTIVE_HIGH             (1<<3)
281         #define PM3RD_SyncControl_VSYNC_TRI_STATE               (2<<3)
282         #define PM3RD_SyncControl_VSYNC_FORCE_ACTIVE            (3<<3)
283         #define PM3RD_SyncControl_VSYNC_FORCE_INACTIVE          (4<<3)
284         #define PM3RD_SyncControl_HSYNC_OVERRIDE_SETBY_HSYNC    (0<<6)
285         #define PM3RD_SyncControl_HSYNC_OVERRIDE_FORCE_HIGH     (1<<6)
286         #define PM3RD_SyncControl_VSYNC_OVERRIDE_SETBY_VSYNC    (0<<7)
287         #define PM3RD_SyncControl_VSYNC_OVERRIDE_FORCE_HIGH     (1<<7)
288 #define PM3RD_DACControl                                        0x002
289         #define PM3RD_DACControl_DAC_POWER_ON                   (0<<0)
290         #define PM3RD_DACControl_DAC_POWER_OFF                  (1<<0)
291         #define PM3RD_DACControl_SYNC_ON_GREEN_DISABLE          (0<<3)
292         #define PM3RD_DACControl_SYNC_ON_GREEN_ENABLE           (1<<3)
293         #define PM3RD_DACControl_BLANK_RED_DAC_DISABLE          (0<<4)
294         #define PM3RD_DACControl_BLANK_RED_DAC_ENABLE           (1<<4)
295         #define PM3RD_DACControl_BLANK_GREEN_DAC_DISABLE        (0<<5)
296         #define PM3RD_DACControl_BLANK_GREEN_DAC_ENABLE         (1<<5)
297         #define PM3RD_DACControl_BLANK_BLUE_DAC_DISABLE         (0<<6)
298         #define PM3RD_DACControl_BLANK_BLUE_DAC_ENABLE          (1<<6)
299         #define PM3RD_DACControl_BLANK_PEDESTAL_DISABLE         (0<<7)
300         #define PM3RD_DACControl_BLANK_PEDESTAL_ENABLE          (1<<7)
301 #define PM3RD_PixelSize                                         0x003
302         #define PM3RD_PixelSize_24_BIT_PIXELS                   (4<<0)
303         #define PM3RD_PixelSize_32_BIT_PIXELS                   (2<<0)
304         #define PM3RD_PixelSize_16_BIT_PIXELS                   (1<<0)
305         #define PM3RD_PixelSize_8_BIT_PIXELS                    (0<<0)
306 #define PM3RD_ColorFormat                                       0x004
307         #define PM3RD_ColorFormat_LINEAR_COLOR_EXT_ENABLE       (1<<6)
308         #define PM3RD_ColorFormat_LINEAR_COLOR_EXT_DISABLE      (0<<6)
309         #define PM3RD_ColorFormat_COLOR_ORDER_BLUE_LOW          (1<<5)
310         #define PM3RD_ColorFormat_COLOR_ORDER_RED_LOW           (0<<5)
311         #define PM3RD_ColorFormat_COLOR_FORMAT_MASK             (0x1f<<0)
312         #define PM3RD_ColorFormat_8888_COLOR                    (0<<0)
313         #define PM3RD_ColorFormat_5551_FRONT_COLOR              (1<<0)
314         #define PM3RD_ColorFormat_4444_COLOR                    (2<<0)
315         #define PM3RD_ColorFormat_332_FRONT_COLOR               (5<<0)
316         #define PM3RD_ColorFormat_332_BACK_COLOR                (6<<0)
317         #define PM3RD_ColorFormat_2321_FRONT_COLOR              (9<<0)
318         #define PM3RD_ColorFormat_2321_BACK_COLOR               (10<<0)
319         #define PM3RD_ColorFormat_232_FRONTOFF_COLOR            (11<<0)
320         #define PM3RD_ColorFormat_232_BACKOFF_COLOR             (12<<0)
321         #define PM3RD_ColorFormat_5551_BACK_COLOR               (13<<0)
322         #define PM3RD_ColorFormat_CI8_COLOR                     (14<<0)
323         #define PM3RD_ColorFormat_565_FRONT_COLOR               (16<<0)
324         #define PM3RD_ColorFormat_565_BACK_COLOR                (17<<0)
325 #define PM3RD_CursorMode                                        0x005
326         #define PM3RD_CursorMode_CURSOR_DISABLE                 (0<<0)
327         #define PM3RD_CursorMode_CURSOR_ENABLE                  (1<<0)
328         #define PM3RD_CursorMode_FORMAT_64x64_2BPE_P0123        (0<<2)
329         #define PM3RD_CursorMode_FORMAT_32x32_2BPE_P0           (1<<2)
330         #define PM3RD_CursorMode_FORMAT_32x32_2BPE_P1           (2<<2)
331         #define PM3RD_CursorMode_FORMAT_32x32_2BPE_P2           (3<<2)
332         #define PM3RD_CursorMode_FORMAT_32x32_2BPE_P3           (4<<2)
333         #define PM3RD_CursorMode_FORMAT_32x32_4BPE_P01          (5<<2)
334         #define PM3RD_CursorMode_FORMAT_32x32_4BPE_P23          (6<<2)
335         #define PM3RD_CursorMode_TYPE_MS                        (0<<4)
336         #define PM3RD_CursorMode_TYPE_X                         (1<<4)
337         #define PM3RD_CursorMode_REVERSE_PIXEL_ORDER_DISABLE    (0<<6)
338         #define PM3RD_CursorMode_REVERSE_PIXEL_ORDER_ENABLE     (1<<6)
339         #define PM3RD_CursorMode_REVERSE_PIXEL_ORDER_3_COLOR    (2<<6)
340         #define PM3RD_CursorMode_REVERSE_PIXEL_ORDER_15_COLOR   (3<<6)
341 #define PM3RD_CursorControl                                     0x006
342         #define PM3RD_CursorControl_DOUBLE_X_DISABLED           (0<<0)
343         #define PM3RD_CursorControl_DOUBLE_X_ENABLED            (1<<0)
344         #define PM3RD_CursorControl_DOUBLE_Y_DISABLED           (0<<1)
345         #define PM3RD_CursorControl_DOUBLE_Y_ENABLED            (1<<1)
346         #define PM3RD_CursorControl_READBACK_POS_DISABLED       (0<<2)
347         #define PM3RD_CursorControl_READBACK_POS_ENABLED        (1<<2)
348
349 #define PM3RD_CursorXLow                                        0x007
350 #define PM3RD_CursorXHigh                                       0x008
351 #define PM3RD_CursorYLow                                        0x009
352 #define PM3RD_CursorYHigh                                       0x00a
353 #define PM3RD_CursorHotSpotX                                    0x00b
354 #define PM3RD_CursorHotSpotY                                    0x00c
355 #define PM3RD_OverlayKey                                        0x00d
356 #define PM3RD_Pan                                               0x00e
357         #define PM3RD_Pan_DISABLE                               (0<<0)
358         #define PM3RD_Pan_ENABLE                                (1<<0)
359         #define PM3RD_Pan_GATE_DISABLE                          (0<<1)
360         #define PM3RD_Pan_GATE_ENABLE                           (1<<1)
361 #define PM3RD_Sense                                             0x00f
362
363 #define PM3RD_CheckControl                                      0x018
364         #define PM3RD_CheckControl_PIXEL_DISABLED               (0<<0)
365         #define PM3RD_CheckControl_PIXEL_ENABLED                (1<<0)
366         #define PM3RD_CheckControl_LUT_DISABLED                 (0<<1)
367         #define PM3RD_CheckControl_LUT_ENABLED                  (1<<1)
368 #define PM3RD_CheckPixelRed                                     0x019
369 #define PM3RD_CheckPixelGreen                                   0x01a
370 #define PM3RD_CheckPixelBlue                                    0x01b
371 #define PM3RD_CheckLUTRed                                       0x01c
372 #define PM3RD_CheckLUTGreen                                     0x01d
373 #define PM3RD_CheckLUTBlue                                      0x01e
374 #define PM3RD_Scratch                                           0x01f
375
376 #define PM3RD_VideoOverlayControl                               0x020
377         #define PM3RD_VideoOverlayControl_DISABLE               (0<<0)
378         #define PM3RD_VideoOverlayControl_ENABLE                (1<<0)
379         #define PM3RD_VideoOverlayControl_MODE_MASK             (3<<1)
380         #define PM3RD_VideoOverlayControl_MODE_MAINKEY          (0<<1)
381         #define PM3RD_VideoOverlayControl_MODE_OVERLAYKEY       (1<<1)
382         #define PM3RD_VideoOverlayControl_MODE_ALWAYS           (2<<1)
383         #define PM3RD_VideoOverlayControl_MODE_BLEND            (3<<1)
384         #define PM3RD_VideoOverlayControl_DIRECTCOLOR_DISABLED  (0<<3)
385         #define PM3RD_VideoOverlayControl_DIRECTCOLOR_ENABLED   (1<<3)
386         #define PM3RD_VideoOverlayControl_BLENDSRC_MAIN         (0<<4)
387         #define PM3RD_VideoOverlayControl_BLENDSRC_REGISTER     (1<<4)
388         #define PM3RD_VideoOverlayControl_KEY_COLOR             (0<<5)
389         #define PM3RD_VideoOverlayControl_KEY_ALPHA             (1<<5)
390 #define PM3RD_VideoOverlayXStartLow                             0x021
391 #define PM3RD_VideoOverlayXStartHigh                            0x022
392 #define PM3RD_VideoOverlayYStartLow                             0x023
393 #define PM3RD_VideoOverlayYStartHigh                            0x024
394 #define PM3RD_VideoOverlayXEndLow                               0x025
395 #define PM3RD_VideoOverlayXEndHigh                              0x026
396 #define PM3RD_VideoOverlayYEndLow                               0x027
397 #define PM3RD_VideoOverlayYEndHigh                              0x028
398 #define PM3RD_VideoOverlayKeyR                                  0x029
399 #define PM3RD_VideoOverlayKeyG                                  0x02a
400 #define PM3RD_VideoOverlayKeyB                                  0x02b
401 #define PM3RD_VideoOverlayBlend                                 0x02c
402         #define PM3RD_VideoOverlayBlend_FACTOR_0_PERCENT        (0<<6)
403         #define PM3RD_VideoOverlayBlend_FACTOR_25_PERCENT       (1<<6)
404         #define PM3RD_VideoOverlayBlend_FACTOR_75_PERCENT       (2<<6)
405         #define PM3RD_VideoOverlayBlend_FACTOR_100_PERCENT      (3<<6)
406
407 #define PM3RD_DClkSetup1                                        0x1f0
408 #define PM3RD_DClkSetup2                                        0x1f1
409 #define PM3RD_KClkSetup1                                        0x1f2
410 #define PM3RD_KClkSetup2                                        0x1f3
411
412 #define PM3RD_DClkControl                                       0x200
413         #define PM3RD_DClkControl_SOURCE_PLL                    (0<<4)
414         #define PM3RD_DClkControl_SOURCE_VSA                    (1<<4)
415         #define PM3RD_DClkControl_SOURCE_VSB                    (2<<4)
416         #define PM3RD_DClkControl_SOURCE_EXT                    (3<<4)
417         #define PM3RD_DClkControl_STATE_RUN                     (2<<2)
418         #define PM3RD_DClkControl_STATE_HIGH                    (1<<2)
419         #define PM3RD_DClkControl_STATE_LOW                     (0<<2)
420         #define PM3RD_DClkControl_LOCKED                        (1<<1)
421         #define PM3RD_DClkControl_NOT_LOCKED                    (0<<1)
422         #define PM3RD_DClkControl_ENABLE                        (1<<0)
423         #define PM3RD_DClkControl_DISABLE                       (0<<0)
424 #define PM3RD_DClk0PreScale                                     0x201
425 #define PM3RD_DClk0FeedbackScale                                0x202
426 #define PM3RD_DClk0PostScale                                    0x203
427         #define PM3_REF_CLOCK                                   14318
428 #define PM3RD_DClk1PreScale                                     0x204
429 #define PM3RD_DClk1FeedbackScale                                0x205
430 #define PM3RD_DClk1PostScale                                    0x206
431 #define PM3RD_DClk2PreScale                                     0x207
432 #define PM3RD_DClk2FeedbackScale                                0x208
433 #define PM3RD_DClk2PostScale                                    0x209
434 #define PM3RD_DClk3PreScale                                     0x20a
435 #define PM3RD_DClk3FeedbackScale                                0x20b
436 #define PM3RD_DClk3PostScale                                    0x20c
437 #define PM3RD_KClkControl                                       0x20d
438         #define PM3RD_KClkControl_DISABLE                       (0<<0)
439         #define PM3RD_KClkControl_ENABLE                        (1<<0)
440         #define PM3RD_KClkControl_NOT_LOCKED                    (0<<1)
441         #define PM3RD_KClkControl_LOCKED                        (1<<1)
442         #define PM3RD_KClkControl_STATE_LOW                     (0<<2)
443         #define PM3RD_KClkControl_STATE_HIGH                    (1<<2)
444         #define PM3RD_KClkControl_STATE_RUN                     (2<<2)
445         #define PM3RD_KClkControl_STATE_LOW_POWER               (3<<2)
446         #define PM3RD_KClkControl_SOURCE_PCLK                   (0<<4)
447         #define PM3RD_KClkControl_SOURCE_HALF_PCLK              (1<<4)
448         #define PM3RD_KClkControl_SOURCE_PLL                    (2<<4)
449 #define PM3RD_KClkPreScale                                      0x20e
450 #define PM3RD_KClkFeedbackScale                                 0x20f
451 #define PM3RD_KClkPostScale                                     0x210
452 #define PM3RD_MClkControl                                       0x211
453         #define PM3RD_MClkControl_DISABLE                       (0<<0)
454         #define PM3RD_MClkControl_ENABLE                        (1<<0)
455         #define PM3RD_MClkControl_NOT_LOCKED                    (0<<1)
456         #define PM3RD_MClkControl_LOCKED                        (1<<1)
457         #define PM3RD_MClkControl_STATE_LOW                     (0<<2)
458         #define PM3RD_MClkControl_STATE_HIGH                    (1<<2)
459         #define PM3RD_MClkControl_STATE_RUN                     (2<<2)
460         #define PM3RD_MClkControl_STATE_LOW_POWER               (3<<2)
461         #define PM3RD_MClkControl_SOURCE_PCLK                   (0<<4)
462         #define PM3RD_MClkControl_SOURCE_HALF_PCLK              (1<<4)
463         #define PM3RD_MClkControl_SOURCE_HALF_EXT               (3<<4)
464         #define PM3RD_MClkControl_SOURCE_EXT                    (4<<4)
465         #define PM3RD_MClkControl_SOURCE_HALF_KCLK              (5<<4)
466         #define PM3RD_MClkControl_SOURCE_KCLK                   (6<<4)
467 #define PM3RD_MClkPreScale                                      0x212
468 #define PM3RD_MClkFeedbackScale                                 0x213
469 #define PM3RD_MClkPostScale                                     0x214
470 #define PM3RD_SClkControl                                       0x215
471         #define PM3RD_SClkControl_DISABLE                       (0<<0)
472         #define PM3RD_SClkControl_ENABLE                        (1<<0)
473         #define PM3RD_SClkControl_NOT_LOCKED                    (0<<1)
474         #define PM3RD_SClkControl_LOCKED                        (1<<1)
475         #define PM3RD_SClkControl_STATE_LOW                     (0<<2)
476         #define PM3RD_SClkControl_STATE_HIGH                    (1<<2)
477         #define PM3RD_SClkControl_STATE_RUN                     (2<<2)
478         #define PM3RD_SClkControl_STATE_LOW_POWER               (3<<2)
479         #define PM3RD_SClkControl_SOURCE_PCLK                   (0<<4)
480         #define PM3RD_SClkControl_SOURCE_HALF_PCLK              (1<<4)
481         #define PM3RD_SClkControl_SOURCE_HALF_EXT               (3<<4)
482         #define PM3RD_SClkControl_SOURCE_EXT                    (4<<4)
483         #define PM3RD_SClkControl_SOURCE_HALF_KCLK              (5<<4)
484         #define PM3RD_SClkControl_SOURCE_KCLK                   (6<<4)
485 #define PM3RD_SClkPreScale                                      0x216
486 #define PM3RD_SClkFeedbackScale                                 0x217
487 #define PM3RD_SClkPostScale                                     0x218
488
489 #define PM3RD_CursorPalette(p)                                  (0x303+(p))
490 #define PM3RD_CursorPattern(p)                                  (0x400+(p))
491 /******************************************************
492 *  GLINT Permedia3 Video Streaming Registers (0x5000) *
493 *******************************************************/
494
495 #define PM3VSConfiguration                                      0x5800
496
497 /**********************************************
498 *  GLINT Permedia3 Core Registers (0x8000+)   *
499 ***********************************************/
500 #define PM3AALineWidth                                          0x94c0
501 #define PM3AAPointsize                                          0x94a0
502 #define PM3AlphaBlendAlphaMode                                  0xafa8
503 #define PM3AlphaBlendAlphaModeAnd                               0xad30
504 #define PM3AlphaBlendAlphaModeOr                                0xad38
505 #define PM3AlphaBlendColorMode                                  0xafa0
506 #define PM3AlphaBlendColorModeAnd                               0xacb0
507 #define PM3AlphaBlendColorModeOr                                0xacb8
508 #define PM3AlphaDestColor                                       0xaf88
509 #define PM3AlphaSourceColor                                     0xaf80
510 #define PM3AlphaTestMode                                        0x8800
511 #define PM3AlphaTestModeAnd                                     0xabf0
512 #define PM3AlphaTestModeOr                                      0xabf8
513 #define PM3AntialiasMode                                        0x8808
514 #define PM3AntialiasModeAnd                                     0xac00
515 #define PM3AntialiasModeOr                                      0xac08
516 /* ... */
517 #define PM3BackgroundColor                                      0xb0c8
518 /* ... */
519 #define PM3ColorDDAMode                                         0x87e0
520 #define PM3ColorDDAModeAnd                                      0xabe0
521 #define PM3ColorDDAModeOr                                       0xabe8
522 #define PM3CommandInterrupt                                     0xa990
523 #define PM3ConstantColorDDA                                     0xafb0
524         #define PM3ConstantColorDDA_R(r)                ((r)&0xff)
525         #define PM3ConstantColorDDA_G(g)                (((g)&0xff)<<8)
526         #define PM3ConstantColorDDA_B(b)                (((b)&0xff)<<16)
527         #define PM3ConstantColorDDA_A(a)                (((a)&0xff)<<24)
528 #define PM3ContextData                                          0x8dd0
529 #define PM3ContextDump                                          0x8dc0
530 #define PM3ContextRestore                                       0x8dc8
531 #define PM3Continue                                             0x8058
532 #define PM3ContinueNewDom                                       0x8048
533 #define PM3ContinueNewLine                                      0x8040
534 #define PM3ContinueNewSub                                       0x8050
535 #define PM3Count                                                0x8030
536 /* ... */
537 #define PM3DeltaControl                                         0x9350
538 #define PM3DeltaControlAnd                                      0xab20
539 #define PM3DeltaControlOr                                       0xab28
540 #define PM3DeltaMode                                            0x9300
541 #define PM3DeltaModeAnd                                         0xaad0
542 #define PM3DeltaModeOr                                          0xaad8
543 /* ... */
544 #define PM3DitherMode                                           0x8818
545 #define PM3DitherModeAnd                                        0xacd0
546 #define PM3DitherModeOr                                         0xacd8
547 /* ... */
548 #define PM3dXDom                                                0x8008
549 #define PM3dXSub                                                0x8018
550 #define PM3dY                                                   0x8028
551 /* ... */
552 #define PM3FBBlockColor                                         0x8ac8
553 #define PM3FBBlockColor0                                        0xb060
554 #define PM3FBBlockColor1                                        0xb068
555 #define PM3FBBlockColor2                                        0xb070
556 #define PM3FBBlockColor3                                        0xb078
557 #define PM3FBBlockColorBack                                     0xb0a0
558 #define PM3FBBlockColorBack0                                    0xb080
559 #define PM3FBBlockColorBack1                                    0xb088
560 #define PM3FBBlockColorBack2                                    0xb090
561 #define PM3FBBlockColorBack3                                    0xb098
562 #define PM3FBColor                                              0x8a98
563 #define PM3FBDestReadBufferAddr0                                0xae80
564 #define PM3FBDestReadBufferAddr1                                0xae88
565 #define PM3FBDestReadBufferAddr2                                0xae90
566 #define PM3FBDestReadBufferAddr3                                0xae98
567 #define PM3FBDestReadBufferOffset0                              0xaea0
568 #define PM3FBDestReadBufferOffset1                              0xaea8
569 #define PM3FBDestReadBufferOffset2                              0xaeb0
570 #define PM3FBDestReadBufferOffset3                              0xaeb8
571         #define PM3FBDestReadBufferOffset_XOffset(x)    ((x)&0xffff)
572         #define PM3FBDestReadBufferOffset_YOffset(y)    (((y)&0xffff)<<16)
573 #define PM3FBDestReadBufferWidth0                               0xaec0
574 #define PM3FBDestReadBufferWidth1                               0xaec8
575 #define PM3FBDestReadBufferWidth2                               0xaed0
576 #define PM3FBDestReadBufferWidth3                               0xaed8
577         #define PM3FBDestReadBufferWidth_Width(w)       ((w)&0x0fff)
578
579 #define PM3FBDestReadEnables                                    0xaee8
580 #define PM3FBDestReadEnablesAnd                                 0xad20
581 #define PM3FBDestReadEnablesOr                                  0xad28
582         #define PM3FBDestReadEnables_E(e)               ((e)&0xff)
583         #define PM3FBDestReadEnables_E0                         1<<0
584         #define PM3FBDestReadEnables_E1                         1<<1
585         #define PM3FBDestReadEnables_E2                         1<<2
586         #define PM3FBDestReadEnables_E3                         1<<3
587         #define PM3FBDestReadEnables_E4                         1<<4
588         #define PM3FBDestReadEnables_E5                         1<<5
589         #define PM3FBDestReadEnables_E6                         1<<6
590         #define PM3FBDestReadEnables_E7                         1<<7
591         #define PM3FBDestReadEnables_R(r)               (((r)&0xff)<<8)
592         #define PM3FBDestReadEnables_R0                         1<<8
593         #define PM3FBDestReadEnables_R1                         1<<9
594         #define PM3FBDestReadEnables_R2                         1<<10
595         #define PM3FBDestReadEnables_R3                         1<<11
596         #define PM3FBDestReadEnables_R4                         1<<12
597         #define PM3FBDestReadEnables_R5                         1<<13
598         #define PM3FBDestReadEnables_R6                         1<<14
599         #define PM3FBDestReadEnables_R7                         1<<15
600         #define PM3FBDestReadEnables_ReferenceAlpha(a)  (((a)&0xff)<<24)
601
602 #define PM3FBDestReadMode                                       0xaee0
603 #define PM3FBDestReadModeAnd                                    0xac90
604 #define PM3FBDestReadModeOr                                     0xac98
605         #define PM3FBDestReadMode_ReadDisable                   0<<0
606         #define PM3FBDestReadMode_ReadEnable                    1<<0
607         #define PM3FBDestReadMode_StripePitch(sp)       (((sp)&0x7)<<2)
608         #define PM3FBDestReadMode_StripeHeight(sh)      (((sh)&0x7)<<7)
609         #define PM3FBDestReadMode_Enable0                       1<<8
610         #define PM3FBDestReadMode_Enable1                       1<<9
611         #define PM3FBDestReadMode_Enable2                       1<<10
612         #define PM3FBDestReadMode_Enable3                       1<<11
613         #define PM3FBDestReadMode_Layout0(l)            (((l)&0x3)<<12)
614         #define PM3FBDestReadMode_Layout1(l)            (((l)&0x3)<<14)
615         #define PM3FBDestReadMode_Layout2(l)            (((l)&0x3)<<16)
616         #define PM3FBDestReadMode_Layout3(l)            (((l)&0x3)<<18)
617         #define PM3FBDestReadMode_Origin0                       1<<20
618         #define PM3FBDestReadMode_Origin1                       1<<21
619         #define PM3FBDestReadMode_Origin2                       1<<22
620         #define PM3FBDestReadMode_Origin3                       1<<23
621         #define PM3FBDestReadMode_Blocking                      1<<24
622         #define PM3FBDestReadMode_UseReadEnabled                1<<26
623         #define PM3FBDestReadMode_AlphaFiltering                1<<27
624
625 #define PM3FBHardwareWriteMask                                  0x8ac0
626 #define PM3FBSoftwareWriteMask                                  0x8820
627 #define PM3FBData                                               0x8aa0
628 #define PM3FBSourceData                                         0x8aa8
629 #define PM3FBSourceReadBufferAddr                               0xaf08
630 #define PM3FBSourceReadBufferOffset                             0xaf10
631         #define PM3FBSourceReadBufferOffset_XOffset(x)  ((x)&0xffff)
632         #define PM3FBSourceReadBufferOffset_YOffset(y)  (((y)&0xffff)<<16)
633 #define PM3FBSourceReadBufferWidth                              0xaf18
634         #define PM3FBSourceReadBufferWidth_Width(w)     ((w)&0x0fff)
635 #define PM3FBSourceReadMode                                     0xaf00
636 #define PM3FBSourceReadModeAnd                                  0xaca0
637 #define PM3FBSourceReadModeOr                                   0xaca8
638         #define PM3FBSourceReadMode_ReadDisable                 (0<<0)
639         #define PM3FBSourceReadMode_ReadEnable                  (1<<0)
640         #define PM3FBSourceReadMode_StripePitch(sp)     (((sp)&0x7)<<2)
641         #define PM3FBSourceReadMode_StripeHeight(sh)    (((sh)&0x7)<<7)
642         #define PM3FBSourceReadMode_Layout(l)           (((l)&0x3)<<8)
643         #define PM3FBSourceReadMode_Origin                      1<<10
644         #define PM3FBSourceReadMode_Blocking                    1<<11
645         #define PM3FBSourceReadMode_UserTexelCoord              1<<13
646         #define PM3FBSourceReadMode_WrapXEnable                 1<<14
647         #define PM3FBSourceReadMode_WrapYEnable                 1<<15
648         #define PM3FBSourceReadMode_WrapX(w)            (((w)&0xf)<<16)
649         #define PM3FBSourceReadMode_WrapY(w)            (((w)&0xf)<<20)
650         #define PM3FBSourceReadMode_ExternalSourceData          1<<24
651 #define PM3FBWriteBufferAddr0                                   0xb000
652 #define PM3FBWriteBufferAddr1                                   0xb008
653 #define PM3FBWriteBufferAddr2                                   0xb010
654 #define PM3FBWriteBufferAddr3                                   0xb018
655
656 #define PM3FBWriteBufferOffset0                                 0xb020
657 #define PM3FBWriteBufferOffset1                                 0xb028
658 #define PM3FBWriteBufferOffset2                                 0xb030
659 #define PM3FBWriteBufferOffset3                                 0xb038
660         #define PM3FBWriteBufferOffset_XOffset(x)               ((x)&0xffff)
661         #define PM3FBWriteBufferOffset_YOffset(y)               (((y)&0xffff)<<16)
662
663 #define PM3FBWriteBufferWidth0                                  0xb040
664 #define PM3FBWriteBufferWidth1                                  0xb048
665 #define PM3FBWriteBufferWidth2                                  0xb050
666 #define PM3FBWriteBufferWidth3                                  0xb058
667         #define PM3FBWriteBufferWidth_Width(w)                  ((w)&0x0fff)
668
669 #define PM3FBWriteMode                                          0x8ab8
670 #define PM3FBWriteModeAnd                                       0xacf0
671 #define PM3FBWriteModeOr                                        0xacf8
672         #define PM3FBWriteMode_WriteDisable                     0<<0
673         #define PM3FBWriteMode_WriteEnable                      1<<0
674         #define PM3FBWriteMode_Replicate                        1<<4
675         #define PM3FBWriteMode_OpaqueSpan                       1<<5
676         #define PM3FBWriteMode_StripePitch(p)            (((p)&0x7)<<6)
677         #define PM3FBWriteMode_StripeHeight(h)           (((h)&0x7)<<9)
678         #define PM3FBWriteMode_Enable0                          1<<12
679         #define PM3FBWriteMode_Enable1                          1<<13
680         #define PM3FBWriteMode_Enable2                          1<<14
681         #define PM3FBWriteMode_Enable3                          1<<15
682         #define PM3FBWriteMode_Layout0(l)               (((l)&0x3)<<16)
683         #define PM3FBWriteMode_Layout1(l)               (((l)&0x3)<<18)
684         #define PM3FBWriteMode_Layout2(l)               (((l)&0x3)<<20)
685         #define PM3FBWriteMode_Layout3(l)               (((l)&0x3)<<22)
686         #define PM3FBWriteMode_Origin0                          1<<24
687         #define PM3FBWriteMode_Origin1                          1<<25
688         #define PM3FBWriteMode_Origin2                          1<<26
689         #define PM3FBWriteMode_Origin3                          1<<27
690 #define PM3ForegroundColor                                      0xb0c0
691 /* ... */
692 #define PM3GIDMode                                              0xb538
693 #define PM3GIDModeAnd                                           0xb5b0
694 #define PM3GIDModeOr                                            0xb5b8
695 /* ... */
696 #define PM3LBDestReadBufferAddr                                 0xb510
697 #define PM3LBDestReadBufferOffset                               0xb518
698 #define PM3LBDestReadEnables                                    0xb508
699 #define PM3LBDestReadEnablesAnd                                 0xb590
700 #define PM3LBDestReadEnablesOr                                  0xb598
701 #define PM3LBDestReadMode                                       0xb500
702 #define PM3LBDestReadModeAnd                                    0xb580
703 #define PM3LBDestReadModeOr                                     0xb588
704         #define PM3LBDestReadMode_Disable                       0<<0
705         #define PM3LBDestReadMode_Enable                        1<<0
706         #define PM3LBDestReadMode_StripePitch(p)                (((p)&0x7)<<2)
707         #define PM3LBDestReadMode_StripeHeight(h)               (((h)&0x7)<<5)
708         #define PM3LBDestReadMode_Layout                        1<<8
709         #define PM3LBDestReadMode_Origin                        1<<9
710         #define PM3LBDestReadMode_UserReadEnables               1<<10
711         #define PM3LBDestReadMode_Packed16                      1<<11
712         #define PM3LBDestReadMode_Width(w)                      (((w)&0xfff)<<12)
713 #define PM3LBReadFormat                                         0x8888
714         #define PM3LBReadFormat_DepthWidth(w)                   (((w)&0x3)<<0)
715         #define PM3LBReadFormat_StencilWidth(w)                 (((w)&0xf)<<2)
716         #define PM3LBReadFormat_StencilPosition(p)              (((p)&0x1f)<<6)
717         #define PM3LBReadFormat_FCPWidth(w)                     (((w)&0xf)<<11)
718         #define PM3LBReadFormat_FCPPosition(p)                  (((p)&0x1f)<<15)
719         #define PM3LBReadFormat_GIDWidth(w)                     (((w)&0x7)<<20)
720         #define PM3LBReadFormat_GIDPosition(p)                  (((p)&0x1f)<<23)
721 #define PM3LBSourceReadBufferAddr                               0xb528
722 #define PM3LBSourceReadBufferOffset                             0xb530
723 #define PM3LBSourceReadMode                                     0xb520
724 #define PM3LBSourceReadModeAnd                                  0xb5a0
725 #define PM3LBSourceReadModeOr                                   0xb5a8
726         #define PM3LBSourceReadMode_Enable                      1<<0
727         #define PM3LBSourceReadMode_StripePitch(p)              (((p)&0x7)<<2)
728         #define PM3LBSourceReadMode_StripeHeight(h)             (((h)&0x7)<<5)
729         #define PM3LBSourceReadMode_Layout                      1<<8
730         #define PM3LBSourceReadMode_Origin                      1<<9
731         #define PM3LBSourceReadMode_Packed16                    1<<10
732         #define PM3LBSourceReadMode_Width(w)                    (((w)&0xfff)<<11)
733 #define PM3LBStencil                                            0x88a8
734 #define PM3LBWriteBufferAddr                                    0xb540
735 #define PM3LBWriteBufferOffset                                  0xb548
736 #define PM3LBWriteFormat                                        0x88c8
737         #define PM3LBWriteFormat_DepthWidth(w)                  (((w)&0x3)<<0)
738         #define PM3LBWriteFormat_StencilWidth(w)                (((w)&0xf)<<2)
739         #define PM3LBWriteFormat_StencilPosition(p)             (((p)&0x1f)<<6)
740         #define PM3LBWriteFormat_GIDWidth(w)                    (((w)&0x7)<<20)
741         #define PM3LBWriteFormat_GIDPosition(p)                 (((p)&0x1f)<<23)
742 #define PM3LBWriteMode                                          0x88c0
743 #define PM3LBWriteModeAnd                                       0xac80
744 #define PM3LBWriteModeOr                                        0xac88
745         #define PM3LBWriteMode_WriteDisable                     0<<0
746         #define PM3LBWriteMode_WriteEnable                      1<<0
747         #define PM3LBWriteMode_StripePitch(p)                   (((p)&0x7)<<3)
748         #define PM3LBWriteMode_StripeHeight(h)                  (((h)&0x7)<<6)
749         #define PM3LBWriteMode_Layout                           1<<9
750         #define PM3LBWriteMode_Origin                           1<<10
751         #define PM3LBWriteMode_Packed16                         1<<11
752         #define PM3LBWriteMode_Width(w)                         (((w)&0xfff)<<12)
753 /* ... */
754 #define PM3LineStippleMode                                      0x81a8
755 #define PM3LineStippleModeAnd                                   0xabc0
756 #define PM3LineStippleModeOr                                    0xabc8
757 #define PM3LoadLineStippleCounters                              0x81b0
758 /* ... */
759 #define PM3LogicalOpMode                                        0x8828
760 #define PM3LogicalOpModeAnd                                     0xace0
761 #define PM3LogicalOpModeOr                                      0xace8
762         #define PM3LogicalOpMode_Disable                        (0<<0)
763         #define PM3LogicalOpMode_Enable                         (1<<0)
764         #define PM3LogicalOpMode_LogicOp(op)                    (((op)&0xf)<<1)
765         #define PM3LogicalOpMode_UseConstantWriteData_Disable   (0<<5)
766         #define PM3LogicalOpMode_UseConstantWriteData_Enable    (1<<5)
767         #define PM3LogicalOpMode_Background_Disable             (0<<6)
768         #define PM3LogicalOpMode_Background_Enable              (1<<6)
769         #define PM3LogicalOpMode_Background_LogicOp(op)         (((op)&0xf)<<7)
770         #define PM3LogicalOpMode_UseConstantSource_Disable      (0<<11)
771         #define PM3LogicalOpMode_UseConstantSource_Enable       (1<<11)
772
773 /* ... */
774 #define PM3LUT                                                  0x8e80
775 /* ... */
776 #define PM3LUT                                                  0x8e80
777 #define PM3LUTAddress                                           0x84d0
778 #define PM3LUTData                                              0x84c8
779 #define PM3LUTIndex                                             0x84c0
780 #define PM3LUTMode                                              0xb378
781 #define PM3LUTModeAnd                                           0xad70
782 #define PM3LUTModeOr                                            0xad78
783 #define PM3LUTTransfer                                          0x84d8
784 /* ... */
785 #define PM3PixelSize                                            0x80c0
786         #define PM3PixelSize_GLOBAL_32BIT                       (0<<0)
787         #define PM3PixelSize_GLOBAL_16BIT                       (1<<0)
788         #define PM3PixelSize_GLOBAL_8BIT                        (2<<0)
789         #define PM3PixelSize_RASTERIZER_32BIT                   (0<<2)
790         #define PM3PixelSize_RASTERIZER_16BIT                   (1<<2)
791         #define PM3PixelSize_RASTERIZER_8BIT                    (2<<2)
792         #define PM3PixelSize_SCISSOR_AND_STIPPLE_32BIT          (0<<4)
793         #define PM3PixelSize_SCISSOR_AND_STIPPLE_16BIT          (1<<4)
794         #define PM3PixelSize_SCISSOR_AND_STIPPLE_8BIT           (2<<4)
795         #define PM3PixelSize_TEXTURE_32BIT                      (0<<6)
796         #define PM3PixelSize_TEXTURE_16BIT                      (1<<6)
797         #define PM3PixelSize_TEXTURE_8BIT                       (2<<6)
798         #define PM3PixelSize_LUT_32BIT                          (0<<8)
799         #define PM3PixelSize_LUT_16BIT                          (1<<8)
800         #define PM3PixelSize_LUT_8BIT                           (2<<8)
801         #define PM3PixelSize_FRAMEBUFFER_32BIT                  (0<<10)
802         #define PM3PixelSize_FRAMEBUFFER_16BIT                  (1<<10)
803         #define PM3PixelSize_FRAMEBUFFER_8BIT                   (2<<10)
804         #define PM3PixelSize_LOGICAL_OP_32BIT                   (0<<12)
805         #define PM3PixelSize_LOGICAL_OP_16BIT                   (1<<12)
806         #define PM3PixelSize_LOGICAL_OP_8BIT                    (2<<12)
807         #define PM3PixelSize_LOCALBUFFER_32BIT                  (0<<14)
808         #define PM3PixelSize_LOCALBUFFER_16BIT                  (1<<14)
809         #define PM3PixelSize_LOCALBUFFER_8BIT                   (2<<14)
810         #define PM3PixelSize_SETUP_32BIT                        (0<<16)
811         #define PM3PixelSize_SETUP_16BIT                        (1<<16)
812         #define PM3PixelSize_SETUP_8BIT                         (2<<16)
813         #define PM3PixelSize_GLOBAL                             (0<<31)
814         #define PM3PixelSize_INDIVIDUAL                         (1<<31)
815 /* ... */
816 #define PM3Render                                               0x8038
817         #define PM3Render_AreaStipple_Disable                   (0<<0)
818         #define PM3Render_AreaStipple_Enable                    (1<<0)
819         #define PM3Render_LineStipple_Disable                   (0<<1)
820         #define PM3Render_LineStipple_Enable                    (1<<1)
821         #define PM3Render_ResetLine_Disable                     (0<<2)
822         #define PM3Render_ResetLine_Enable                      (1<<2)
823         #define PM3Render_FastFill_Disable                      (0<<3)
824         #define PM3Render_FastFill_Enable                       (1<<3)
825         #define PM3Render_Primitive_Line                        (0<<6)
826         #define PM3Render_Primitive_Trapezoid                   (1<<6)
827         #define PM3Render_Primitive_Point                       (2<<6)
828         #define PM3Render_Antialias_Disable                     (0<<8)
829         #define PM3Render_Antialias_Enable                      (1<<8)
830         #define PM3Render_Antialias_SubPixelRes_4x4             (0<<9)
831         #define PM3Render_Antialias_SubPixelRes_8x8             (1<<9)
832         #define PM3Render_UsePointTable_Disable                 (0<<10)
833         #define PM3Render_UsePointTable_Enable                  (1<<10)
834         #define PM3Render_SyncOnbitMask_Disable                 (0<<11)
835         #define PM3Render_SyncOnBitMask_Enable                  (1<<11)
836         #define PM3Render_SyncOnHostData_Disable                (0<<12)
837         #define PM3Render_SyncOnHostData_Enable                 (1<<12)
838         #define PM3Render_Texture_Disable                       (0<<13)
839         #define PM3Render_Texture_Enable                        (1<<13)
840         #define PM3Render_Fog_Disable                           (0<<14)
841         #define PM3Render_Fog_Enable                            (1<<14)
842         #define PM3Render_Coverage_Disable                      (0<<15)
843         #define PM3Render_Coverage_Enable                       (1<<15)
844         #define PM3Render_SubPixelCorrection_Disable            (0<<16)
845         #define PM3Render_SubPixelCorrection_Enable             (1<<16)
846         #define PM3Render_SpanOperation_Disable                 (0<<18)
847         #define PM3Render_SpanOperation_Enable                  (1<<18)
848         #define PM3Render_FBSourceRead_Disable                  (0<<27)
849         #define PM3Render_FBSourceRead_Enable                   (1<<27)
850 #define PM3RasterizerMode                                       0x80a0
851 #define PM3RasterizerModeAnd                                    0xaba0
852 #define PM3RasterizerModeOr                                     0xabb8
853 #define PM3RectangleHeight                                      0x94e0
854 #define PM3Render                                               0x8038
855 #define PM3RepeatLine                                           0x9328
856 #define PM3ResetPickResult                                      0x8c20
857 #define PM3RLEMask                                              0x8c48
858 #define PM3RouterMode                                           0x8840
859 #define PM3RStart                                               0x8780
860 #define PM3S1Start                                              0x8400
861 #define PM3aveLineStippleCounters                               0x81c0
862 #define PM3ScissorMaxXY                                         0x8190
863 #define PM3ScissorMinXY                                         0x8188
864 #define PM3ScissorMode                                          0x8180
865 #define PM3ScissorModeAnd                                       0xabb0
866 #define PM3ScissorModeOr                                        0xabb8
867 #define PM3ScreenSize                                           0x8198
868 #define PM3Security                                             0x8908
869 #define PM3SetLogicalTexturePage                                0xb360
870 #define PM3SizeOfFramebuffer                                    0xb0a8
871 #define PM3SStart                                               0x8388
872 #define PM3StartXDom                                            0x8000
873 #define PM3StartXSub                                            0x8010
874 #define PM3StartY                                               0x8020
875 /* ... */
876 #define PM3SpanColorMask                                        0x8168
877 /* ... */
878 #define PM3TextureApplicationMode                               0x8680
879 #define PM3TextureApplicationModeAnd                            0xac50
880 #define PM3TextureApplicationModeOr                             0xac58
881 #define PM3TextureBaseAddr                                      0x8500
882 #define PM3TextureCacheControl                                  0x8490
883 #define PM3TextureChromaLower0                                  0x84f0
884 #define PM3TextureChromaLower1                                  0x8608
885 #define PM3TextureChromaUpper0                                  0x84e8
886 #define PM3TextureChromaUpper1                                  0x8600
887 #define PM3TextureCompositeAlphaMode0                           0xb310
888 #define PM3TextureCompositeAlphaMode0And                        0xb390
889 #define PM3TextureCompositeAlphaMode0Or                         0xb398
890 #define PM3TextureCompositeAlphaMode1                           0xb320
891 #define PM3TextureCompositeAlphaMode1And                        0xb3b0
892 #define PM3TextureCompositeAlphaMode1Or                         0xb3b8
893 #define PM3TextureCompositeColorMode0                           0xb308
894 #define PM3TextureCompositeColorMode0And                        0xb380
895 #define PM3TextureCompositeColorMode0Or                         0xb388
896 #define PM3TextureCompositeColorMode1                           0xb318
897 #define PM3TextureCompositeColorMode1And                        0xb3a0
898 #define PM3TextureCompositeColorMode1Or                         0xb3a8
899 #define PM3TextureCompositeFactor0                              0xb328
900 #define PM3TextureCompositeFactor1                              0xb330
901 #define PM3TextureCompositeMode                                 0xb300
902 #define PM3TextureCoordMode                                     0x8380
903 #define PM3TextureCoordModeAnd                                  0xac20
904 #define PM3TextureCoordModeOr                                   0xac28
905 #define PM3TextureData                                          0x88e8
906 /*
907 #define PM3TextureDownloadControl                               0x0108
908 */
909 #define PM3TextureDownloadOffset                                0x88f0
910 #define PM3TextureEnvColor                                      0x8688
911 #define PM3TextureFilterMode                                    0x84e0
912 #define PM3TextureFilterModeAnd                                 0xad50
913 #define PM3TextureFilterModeOr                                  0xad58
914 #define PM3TextureIndexMode0                                    0xb338
915 #define PM3TextureIndexMode0And                                 0xb3c0
916 #define PM3TextureIndexMode0Or                                  0xb3c8
917 #define PM3TextureIndexMode1                                    0xb340
918 #define PM3TextureIndexMode1And                                 0xb3d0
919 #define PM3TextureIndexMode1Or                                  0xb3d8
920 /* ... */
921 #define PM3TextureMapSize                                       0xb428
922 #define PM3TextureMapWidth0                                     0x8580
923 #define PM3TextureMapWidth1                                     0x8588
924         #define PM3TextureMapWidth_Width(w)             ((w&0xfff)<<0)
925         #define PM3TextureMapWidth_BorderLayout                 (1<<12)
926         #define PM3TextureMapWidth_Layout_Linear                (0<<13)
927         #define PM3TextureMapWidth_Layout_Patch64               (1<<13)
928         #define PM3TextureMapWidth_Layout_Patch32_2             (2<<13)
929         #define PM3TextureMapWidth_Layout_Patch2                (3<<13)
930         #define PM3TextureMapWidth_HostTexture                  (1<<15)
931 #define PM3TextureReadMode0                                     0xb400
932 #define PM3TextureReadMode0And                                  0xac30
933 #define PM3TextureReadMode0Or                                   0xac38
934 #define PM3TextureReadMode1                                     0xb408
935 #define PM3TextureReadMode1And                                  0xad40
936 #define PM3TextureReadMode1Or                                   0xad48
937 /* ... */
938 #define PM3WaitForCompletion                                    0x80b8
939 #define PM3Window                                               0x8980
940         #define PM3Window_ForceLBUpdate                         1<<3
941         #define PM3Window_LBUpdateSource                        1<<4
942         #define PM3Window_FrameCount(c)                         (((c)&0xff)<<9)
943         #define PM3Window_StencilFCP                            1<<17
944         #define PM3Window_DepthFCP                              1<<18
945         #define PM3Window_OverrideWriteFiltering                1<<19
946 #define PM3WindowAnd                                            0xab80
947 #define PM3WindowOr                                             0xab88
948 #define PM3WindowOrigin                                         0x81c8
949 #define PM3XBias                                                0x9480
950 #define PM3YBias                                                0x9488
951 #define PM3YLimits                                              0x80a8
952 #define PM3UVMode                                               0x8f00
953 #define PM3ZFogBias                                             0x86b8
954 #define PM3ZStart                                               0xadd8
955 #define PM3ZStartL                                              0x89b8
956 #define PM3ZStartU                                              0x89b0
957
958
959 /**********************************************
960 *  GLINT Permedia3 2D setup Unit              *
961 ***********************************************/
962 #define PM3Config2D                                             0xb618
963         #define PM3Config2D_OpaqueSpan                          1<<0
964         #define PM3Config2D_MultiRXBlit                         1<<1
965         #define PM3Config2D_UserScissorEnable                   1<<2
966         #define PM3Config2D_FBDestReadEnable                    1<<3
967         #define PM3Config2D_AlphaBlendEnable                    1<<4
968         #define PM3Config2D_DitherEnable                        1<<5
969         #define PM3Config2D_ForegroundROPEnable                 1<<6
970         #define PM3Config2D_ForegroundROP(rop)          (((rop)&0xf)<<7)
971         #define PM3Config2D_BackgroundROPEnable                 1<<11
972         #define PM3Config2D_BackgroundROP(rop)          (((rop)&0xf)<<12)
973         #define PM3Config2D_UseConstantSource                   1<<16
974         #define PM3Config2D_FBWriteEnable                       1<<17
975         #define PM3Config2D_Blocking                            1<<18
976         #define PM3Config2D_ExternalSourceData                  1<<19
977         #define PM3Config2D_LUTModeEnable                       1<<20
978 #define PM3DownloadGlyphwidth                                   0xb658
979         #define PM3DownloadGlyphwidth_GlyphWidth(gw)    ((gw)&0xffff)
980 #define PM3DownloadTarget                                       0xb650
981         #define PM3DownloadTarget_TagName(tag)          ((tag)&0x1fff)
982 #define PM3GlyphData                                            0xb660
983 #define PM3GlyphPosition                                        0xb608
984         #define PM3GlyphPosition_XOffset(x)             ((x)&0xffff)
985         #define PM3GlyphPosition_YOffset(y)             (((y)&0xffff)<<16)
986 #define PM3Packed4Pixels                                        0xb668
987 #define PM3Packed8Pixels                                        0xb630
988 #define PM3Packed16Pixels                                       0xb638
989 #define PM3RectanglePosition                                    0xb600
990         #define PM3RectanglePosition_XOffset(x)         ((x)&0xffff)
991         #define PM3RectanglePosition_YOffset(y)         (((y)&0xffff)<<16)
992 #define PM3Render2D                                             0xb640
993         #define PM3Render2D_Width(w)                    ((w)&0x0fff)
994         #define PM3Render2D_Operation_Normal                    0<<12
995         #define PM3Render2D_Operation_SyncOnHostData            1<<12
996         #define PM3Render2D_Operation_SyncOnBitMask             2<<12
997         #define PM3Render2D_Operation_PatchOrderRendering       3<<12
998         #define PM3Render2D_FBSourceReadEnable                  1<<14
999         #define PM3Render2D_SpanOperation                       1<<15
1000         #define PM3Render2D_Height(h)                   (((h)&0x0fff)<<16)
1001         #define PM3Render2D_XPositive                           1<<28
1002         #define PM3Render2D_YPositive                           1<<29
1003         #define PM3Render2D_AreaStippleEnable                   1<<30
1004         #define PM3Render2D_TextureEnable                       1<<31
1005 #define PM3Render2DGlyph                                        0xb648
1006         #define PM3Render2DGlyph_Width(w)               ((w)&0x7f)
1007         #define PM3Render2DGlyph_Height(h)              (((h)&0x7f)<<7)
1008         #define PM3Render2DGlyph_XOffset(x)             (((x)&0x1ff)<<14)
1009         #define PM3Render2DGlyph_YOffset(y)             (((y)&0x1ff)<<23)
1010 #define PM3RenderPatchOffset                                    0xb610
1011         #define PM3RenderPatchOffset_XOffset(x)         ((x)&0xffff)
1012         #define PM3RenderPatchOffset_YOffset(y)         (((y)&0xffff)<<16)
1013 #define PM3RLCount                                              0xb678
1014         #define PM3RLCount_Count(c)                     ((c)&0x0fff)
1015 #define PM3RLData                                               0xb670
1016
1017 /**********************************************
1018 *  GLINT Permedia3 Alias Register             *
1019 ***********************************************/
1020 #define PM3FillBackgroundColor                                  0x8330
1021 #define PM3FillConfig2D0                                        0x8338
1022 #define PM3FillConfig2D1                                        0x8360
1023         #define PM3FillConfig2D_OpaqueSpan                      1<<0
1024         #define PM3FillConfig2D_MultiRXBlit                     1<<1
1025         #define PM3FillConfig2D_UserScissorEnable               1<<2
1026         #define PM3FillConfig2D_FBDestReadEnable                1<<3
1027         #define PM3FillConfig2D_AlphaBlendEnable                1<<4
1028         #define PM3FillConfig2D_DitherEnable                    1<<5
1029         #define PM3FillConfig2D_ForegroundROPEnable             1<<6
1030         #define PM3FillConfig2D_ForegroundROP(rop)              (((rop)&0xf)<<7)
1031         #define PM3FillConfig2D_BackgroundROPEnable             1<<11
1032         #define PM3FillConfig2D_BackgroundROP(rop)              (((rop)&0xf)<<12)
1033         #define PM3FillConfig2D_UseConstantSource               1<<16
1034         #define PM3FillConfig2D_FBWriteEnable                   1<<17
1035         #define PM3FillConfig2D_Blocking                        1<<18
1036         #define PM3FillConfig2D_ExternalSourceData              1<<19
1037         #define PM3FillConfig2D_LUTModeEnable                   1<<20
1038 #define PM3FillFBDestReadBufferAddr                             0x8310
1039 #define PM3FillFBSourceReadBufferAddr                           0x8308
1040 #define PM3FillFBSourceReadBufferOffset                         0x8340
1041         #define PM3FillFBSourceReadBufferOffset_XOffset(x)     ((x)&0xffff)
1042         #define PM3FillFBSourceReadBufferOffset_YOffset(y)      (((y)&0xffff)<<16)
1043 #define PM3FillFBWriteBufferAddr                                0x8300
1044 #define PM3FillForegroundColor0                                 0x8328
1045 #define PM3FillForegroundColor1                                 0x8358
1046 #define PM3FillGlyphPosition                                    0x8368
1047         #define PM3FillGlyphPosition_XOffset(x)                        ((x)&0xffff)
1048         #define PM3FillGlyphPosition_YOffset(y)                        (((y)&0xffff)<<16)
1049 #define PM3FillRectanglePosition                                0x8348
1050         #define PM3FillRectanglePosition_XOffset(x)            ((x)&0xffff)
1051         #define PM3FillRectanglePosition_YOffset(y)            (((y)&0xffff)<<16)
1052
1053 #define PM3_REGS_SIZE           0x10000
1054 #define PM3_MAX_PIXCLOCK        300000
1055 /* a few more useful registers & regs value... */
1056 #define PM3Sync 0x8c40
1057         #define PM3Sync_Tag 0x188
1058 #define PM3FilterMode 0x8c00
1059         #define PM3FilterModeSync 0x400
1060 #define PM3OutputFifo 0x2000
1061 #define PM3StatisticMode 0x8c08
1062 #define PM3AreaStippleMode 0x81a0
1063         #define AreaStipplePattern0                                     (0x8200)
1064         #define AreaStipplePattern1                                     (0x8208)
1065         #define AreaStipplePattern2                                     (0x8210)
1066         #define AreaStipplePattern3                                     (0x8218)
1067         #define AreaStipplePattern4                                     (0x8220)
1068         #define AreaStipplePattern5                                     (0x8228)
1069         #define AreaStipplePattern6                                     (0x8230)
1070         #define AreaStipplePattern7                                     (0x8238)
1071         #define AreaStipplePattern8                                     (0x8240)
1072         #define AreaStipplePattern9                                     (0x8248)
1073         #define AreaStipplePattern10                                    (0x8250)
1074         #define AreaStipplePattern11                                    (0x8258)
1075         #define AreaStipplePattern12                                    (0x8260)
1076         #define AreaStipplePattern13                                    (0x8268)
1077         #define AreaStipplePattern14                                    (0x8270)
1078         #define AreaStipplePattern15                                    (0x8278)
1079         #define AreaStipplePattern16                                    (0x8280)
1080         #define AreaStipplePattern17                                    (0x8288)
1081         #define AreaStipplePattern18                                    (0x8290)
1082         #define AreaStipplePattern19                                    (0x8298)
1083         #define AreaStipplePattern20                                    (0x82a0)
1084         #define AreaStipplePattern21                                    (0x82a8)
1085         #define AreaStipplePattern22                                    (0x82b0)
1086         #define AreaStipplePattern23                                    (0x82b8)
1087         #define AreaStipplePattern24                                    (0x82c0)
1088         #define AreaStipplePattern25                                    (0x82c8)
1089         #define AreaStipplePattern26                                    (0x82d0)
1090         #define AreaStipplePattern27                                    (0x82d8)
1091         #define AreaStipplePattern28                                    (0x82eo)
1092         #define AreaStipplePattern29                                    (0x82e8)
1093         #define AreaStipplePattern30                                    (0x82f0)
1094         #define AreaStipplePattern31                                    (0x82f8)
1095         #define AreaStipplePattern_indexed(i)             (0x8200 + ((i) * 0x8))
1096
1097 #define PM3DepthMode 0x89a0
1098 #define PM3StencilMode 0x8988
1099 #define PM3StencilData 0x8990
1100 #define PM3TextureReadMode 0x8670
1101 #define PM3FogMode 0x8690
1102 #define PM3ChromaTestMode 0x8f18
1103 #define PM3YUVMode 0x8f00
1104 #define PM3BitMaskPattern 0x8068
1105
1106 /* ***************************** */
1107 /* ***** pm3fb IOCTL const ***** */
1108 /* ***************************** */
1109 /* debug-only IOCTL */
1110 #define PM3FBIO_CLEARMEMORY 0x504D3300 /* 'PM3\000' */
1111 #define PM3FBIO_CLEARCMAP   0x504D3301 /* 'PM3\001' */
1112 /* common use IOCTL */
1113 #define PM3FBIO_RESETCHIP   0x504D33FF /* 'PM3\377' */
1114
1115 /* ***************************************** */
1116 /* ***** pm3fb useful define and macro ***** */
1117 /* ***************************************** */
1118
1119 /* max size of options */
1120 #define PM3_OPTIONS_SIZE 256
1121
1122 /* max size of font name */
1123 #define PM3_FONTNAME_SIZE 40
1124
1125 #endif /* PM3FB_H */