Add the DragonFly cvs id and perform general cleanups on cvs/rcs/sccs ids. Most
[dragonfly.git] / sys / dev / drm / r128 / r128.h
1 /* r128.h -- ATI Rage 128 DRM template customization -*- linux-c -*-
2  * Created: Wed Feb 14 16:07:10 2001 by gareth@valinux.com
3  *
4  * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
5  * All Rights Reserved.
6  *
7  * Permission is hereby granted, free of charge, to any person obtaining a
8  * copy of this software and associated documentation files (the "Software"),
9  * to deal in the Software without restriction, including without limitation
10  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11  * and/or sell copies of the Software, and to permit persons to whom the
12  * Software is furnished to do so, subject to the following conditions:
13  *
14  * The above copyright notice and this permission notice (including the next
15  * paragraph) shall be included in all copies or substantial portions of the
16  * Software.
17  *
18  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
21  * VA LINUX SYSTEMS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
22  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
23  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
24  * OTHER DEALINGS IN THE SOFTWARE.
25  *
26  * Authors:
27  *    Gareth Hughes <gareth@valinux.com>
28  *
29  * $FreeBSD: src/sys/dev/drm/r128.h,v 1.2.2.1 2003/04/26 07:05:29 anholt Exp $
30  * $DragonFly: src/sys/dev/drm/r128/Attic/r128.h,v 1.2 2003/06/17 04:28:24 dillon Exp $
31  */
32
33 #ifndef __R128_H__
34 #define __R128_H__
35
36 /* This remains constant for all DRM template files.
37  */
38 #define DRM(x) r128_##x
39
40 /* General customization:
41  */
42 #define __HAVE_AGP              1
43 #define __MUST_HAVE_AGP         0
44 #define __HAVE_MTRR             1
45 #define __HAVE_CTX_BITMAP       1
46 #define __HAVE_SG               1
47 #define __HAVE_PCI_DMA          1
48
49 #define DRIVER_AUTHOR           "Gareth Hughes, VA Linux Systems Inc."
50
51 #define DRIVER_NAME             "r128"
52 #define DRIVER_DESC             "ATI Rage 128"
53 #define DRIVER_DATE             "20021029"
54
55 #define DRIVER_MAJOR            2
56 #define DRIVER_MINOR            3
57 #define DRIVER_PATCHLEVEL       0
58
59
60 #define DRIVER_IOCTLS                                                       \
61    [DRM_IOCTL_NR(DRM_IOCTL_DMA)]             = { r128_cce_buffers,  1, 0 }, \
62    [DRM_IOCTL_NR(DRM_IOCTL_R128_INIT)]       = { r128_cce_init,     1, 1 }, \
63    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_START)]  = { r128_cce_start,    1, 1 }, \
64    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_STOP)]   = { r128_cce_stop,     1, 1 }, \
65    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_RESET)]  = { r128_cce_reset,    1, 1 }, \
66    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_IDLE)]   = { r128_cce_idle,     1, 0 }, \
67    [DRM_IOCTL_NR(DRM_IOCTL_R128_RESET)]      = { r128_engine_reset, 1, 0 }, \
68    [DRM_IOCTL_NR(DRM_IOCTL_R128_FULLSCREEN)] = { r128_fullscreen,   1, 0 }, \
69    [DRM_IOCTL_NR(DRM_IOCTL_R128_SWAP)]       = { r128_cce_swap,     1, 0 }, \
70    [DRM_IOCTL_NR(DRM_IOCTL_R128_CLEAR)]      = { r128_cce_clear,    1, 0 }, \
71    [DRM_IOCTL_NR(DRM_IOCTL_R128_VERTEX)]     = { r128_cce_vertex,   1, 0 }, \
72    [DRM_IOCTL_NR(DRM_IOCTL_R128_INDICES)]    = { r128_cce_indices,  1, 0 }, \
73    [DRM_IOCTL_NR(DRM_IOCTL_R128_BLIT)]       = { r128_cce_blit,     1, 0 }, \
74    [DRM_IOCTL_NR(DRM_IOCTL_R128_DEPTH)]      = { r128_cce_depth,    1, 0 }, \
75    [DRM_IOCTL_NR(DRM_IOCTL_R128_STIPPLE)]    = { r128_cce_stipple,  1, 0 }, \
76    [DRM_IOCTL_NR(DRM_IOCTL_R128_INDIRECT)]   = { r128_cce_indirect, 1, 1 }, \
77    [DRM_IOCTL_NR(DRM_IOCTL_R128_GETPARAM)]   = { r128_getparam, 1, 0 },
78
79 /* Driver customization:
80  */
81 #define DRIVER_PRERELEASE() do {                                        \
82         if ( dev->dev_private ) {                                       \
83                 drm_r128_private_t *dev_priv = dev->dev_private;        \
84                 if ( dev_priv->page_flipping ) {                        \
85                         r128_do_cleanup_pageflip( dev );                \
86                 }                                                       \
87         }                                                               \
88 } while (0)
89
90 #define DRIVER_PRETAKEDOWN() do {                                       \
91         if ( dev->dev_private ) r128_do_cleanup_cce( dev );             \
92 } while (0)
93
94 /* DMA customization:
95  */
96 #define __HAVE_DMA              1
97 #define __HAVE_DMA_IRQ          1
98 #define __HAVE_VBL_IRQ          1
99 #define __HAVE_SHARED_IRQ       1
100
101 #if 0
102 /* GH: Remove this for now... */
103 #define __HAVE_DMA_QUIESCENT    1
104 #define DRIVER_DMA_QUIESCENT() do {                                     \
105         drm_r128_private_t *dev_priv = dev->dev_private;                \
106         return r128_do_cce_idle( dev_priv );                            \
107 } while (0)
108 #endif
109
110 /* Buffer customization:
111  */
112 #define DRIVER_BUF_PRIV_T       drm_r128_buf_priv_t
113
114 #define DRIVER_AGP_BUFFERS_MAP( dev )                                   \
115         ((drm_r128_private_t *)((dev)->dev_private))->buffers
116
117 #endif