OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [drivers/] [char/] [drm/] [i810.h] - Blame information for rev 1765

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
/* i810.h -- Intel i810/i815 DRM template customization -*- linux-c -*-
2
 * Created: Thu Feb 15 00:01:12 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
 
30
#ifndef __I810_H__
31
#define __I810_H__
32
 
33
/* This remains constant for all DRM template files.
34
 */
35
#define DRM(x) i810_##x
36
 
37
/* General customization:
38
 */
39
#define __HAVE_AGP              1
40
#define __MUST_HAVE_AGP         1
41
#define __HAVE_MTRR             1
42
#define __HAVE_CTX_BITMAP       1
43
 
44
#define DRIVER_AUTHOR           "VA Linux Systems Inc."
45
 
46
#define DRIVER_NAME             "i810"
47
#define DRIVER_DESC             "Intel i810"
48
#define DRIVER_DATE             "20020211"
49
 
50
/* Interface history
51
 *
52
 * 1.1   - XFree86 4.1
53
 * 1.2   - XvMC interfaces
54
 *       - XFree86 4.2
55
 * 1.2.1 - Disable copying code (leave stub ioctls for backwards compatibility)
56
 *       - Remove requirement for interrupt (leave stubs again)
57
 */
58
#define DRIVER_MAJOR            1
59
#define DRIVER_MINOR            2
60
#define DRIVER_PATCHLEVEL       1
61
 
62
#define DRIVER_IOCTLS                                                       \
63
        [DRM_IOCTL_NR(DRM_IOCTL_I810_INIT)]   = { i810_dma_init,    1, 1 }, \
64
        [DRM_IOCTL_NR(DRM_IOCTL_I810_VERTEX)] = { i810_dma_vertex,  1, 0 }, \
65
        [DRM_IOCTL_NR(DRM_IOCTL_I810_CLEAR)]  = { i810_clear_bufs,  1, 0 }, \
66
        [DRM_IOCTL_NR(DRM_IOCTL_I810_FLUSH)]  = { i810_flush_ioctl, 1, 0 }, \
67
        [DRM_IOCTL_NR(DRM_IOCTL_I810_GETAGE)] = { i810_getage,      1, 0 }, \
68
        [DRM_IOCTL_NR(DRM_IOCTL_I810_GETBUF)] = { i810_getbuf,      1, 0 }, \
69
        [DRM_IOCTL_NR(DRM_IOCTL_I810_SWAP)]   = { i810_swap_bufs,   1, 0 }, \
70
        [DRM_IOCTL_NR(DRM_IOCTL_I810_COPY)]   = { i810_copybuf,     1, 0 }, \
71
        [DRM_IOCTL_NR(DRM_IOCTL_I810_DOCOPY)] = { i810_docopy,      1, 0 }, \
72
        [DRM_IOCTL_NR(DRM_IOCTL_I810_OV0INFO)] = { i810_ov0_info,   1, 0 }, \
73
        [DRM_IOCTL_NR(DRM_IOCTL_I810_FSTATUS)] = { i810_fstatus,    1, 0 }, \
74
        [DRM_IOCTL_NR(DRM_IOCTL_I810_OV0FLIP)] = { i810_ov0_flip,   1, 0 }, \
75
        [DRM_IOCTL_NR(DRM_IOCTL_I810_MC)]      = { i810_dma_mc,     1, 1 }, \
76
        [DRM_IOCTL_NR(DRM_IOCTL_I810_RSTATUS)] = { i810_rstatus,    1, 0 }
77
 
78
 
79
#define __HAVE_COUNTERS         4
80
#define __HAVE_COUNTER6         _DRM_STAT_IRQ
81
#define __HAVE_COUNTER7         _DRM_STAT_PRIMARY
82
#define __HAVE_COUNTER8         _DRM_STAT_SECONDARY
83
#define __HAVE_COUNTER9         _DRM_STAT_DMA
84
 
85
/* Driver customization:
86
 */
87
#define __HAVE_RELEASE          1
88
#define DRIVER_RELEASE() do {                                           \
89
        i810_reclaim_buffers( dev, priv->pid );                         \
90
} while (0)
91
 
92
/* DMA customization:
93
 */
94
#define __HAVE_DMA              1
95
#define __HAVE_DMA_QUEUE        1
96
#define __HAVE_DMA_WAITLIST     1
97
#define __HAVE_DMA_RECLAIM      1
98
 
99
#define __HAVE_DMA_QUIESCENT    1
100
#define DRIVER_DMA_QUIESCENT() do {                                     \
101
        i810_dma_quiescent( dev );                                      \
102
} while (0)
103
 
104
/* Don't need an irq any more.  The template code will make sure that
105
 * a noop stub is generated for compatibility.
106
 */
107
#define __HAVE_DMA_IRQ          0
108
 
109
/* Buffer customization:
110
 */
111
 
112
#define DRIVER_BUF_PRIV_T       drm_i810_buf_priv_t
113
 
114
#define DRIVER_AGP_BUFFERS_MAP( dev )                                   \
115
        ((drm_i810_private_t *)((dev)->dev_private))->buffer_map
116
 
117
#endif

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.