grfvar.h revision 1.15 1 1.15 briggs /* $NetBSD: grfvar.h,v 1.15 1997/05/01 03:34:08 briggs Exp $ */
2 1.3 cgd
3 1.1 briggs /*
4 1.1 briggs * Copyright (c) 1988 University of Utah.
5 1.1 briggs * Copyright (c) 1990 The Regents of the University of California.
6 1.1 briggs * All rights reserved.
7 1.1 briggs *
8 1.1 briggs * This code is derived from software contributed to Berkeley by
9 1.1 briggs * the Systems Programming Group of the University of Utah Computer
10 1.1 briggs * Science Department.
11 1.1 briggs *
12 1.1 briggs * Redistribution and use in source and binary forms, with or without
13 1.1 briggs * modification, are permitted provided that the following conditions
14 1.1 briggs * are met:
15 1.1 briggs * 1. Redistributions of source code must retain the above copyright
16 1.1 briggs * notice, this list of conditions and the following disclaimer.
17 1.1 briggs * 2. Redistributions in binary form must reproduce the above copyright
18 1.1 briggs * notice, this list of conditions and the following disclaimer in the
19 1.1 briggs * documentation and/or other materials provided with the distribution.
20 1.1 briggs * 3. All advertising materials mentioning features or use of this software
21 1.1 briggs * must display the following acknowledgement:
22 1.1 briggs * This product includes software developed by the University of
23 1.1 briggs * California, Berkeley and its contributors.
24 1.1 briggs * 4. Neither the name of the University nor the names of its contributors
25 1.1 briggs * may be used to endorse or promote products derived from this software
26 1.1 briggs * without specific prior written permission.
27 1.1 briggs *
28 1.1 briggs * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29 1.1 briggs * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30 1.1 briggs * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31 1.1 briggs * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32 1.1 briggs * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 1.1 briggs * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34 1.1 briggs * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35 1.1 briggs * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36 1.1 briggs * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37 1.1 briggs * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38 1.1 briggs * SUCH DAMAGE.
39 1.1 briggs *
40 1.1 briggs * from: Utah $Hdr: grfvar.h 1.9 91/01/21$
41 1.1 briggs *
42 1.3 cgd * @(#)grfvar.h 7.3 (Berkeley) 5/7/91
43 1.1 briggs */
44 1.1 briggs
45 1.7 briggs #define CARD_NAME_LEN 64
46 1.10 scottr
47 1.10 scottr /*
48 1.10 scottr * State info, per hardware instance.
49 1.10 scottr */
50 1.10 scottr struct grfbus_softc {
51 1.7 briggs struct device sc_dev;
52 1.7 briggs nubus_slot sc_slot;
53 1.6 briggs
54 1.14 briggs bus_space_tag_t sc_tag;
55 1.14 briggs bus_space_handle_t sc_regh;
56 1.14 briggs bus_space_handle_t sc_fbh;
57 1.14 briggs
58 1.7 briggs struct grfmode curr_mode; /* hardware desc(for ioctl) */
59 1.14 briggs u_int32_t card_id; /* DrHW value for nubus cards */
60 1.14 briggs u_int32_t cli_offset; /* Offset of byte to clear intr */
61 1.14 briggs /* for cards where that's suff. */
62 1.15 briggs unsigned char cli_value; /* Value to write at cli_offset */
63 1.7 briggs nubus_dir board_dir; /* Nubus dir for curr board */
64 1.10 scottr };
65 1.10 scottr
66 1.10 scottr /*
67 1.10 scottr * State info, per grf instance.
68 1.10 scottr */
69 1.10 scottr struct grf_softc {
70 1.10 scottr struct device sc_dev; /* device glue */
71 1.10 scottr
72 1.10 scottr int sc_flags; /* software flags */
73 1.10 scottr struct grfmode *sc_grfmode; /* forwarded ... */
74 1.10 scottr nubus_slot *sc_slot;
75 1.9 briggs /* mode-change on/off/mode function */
76 1.10 scottr int (*sc_mode) __P((struct grf_softc *, int, void *));
77 1.9 briggs /* map virtual addr to physical addr */
78 1.10 scottr caddr_t (*sc_phys) __P((struct grf_softc *, vm_offset_t));
79 1.10 scottr };
80 1.10 scottr
81 1.10 scottr /*
82 1.10 scottr * Attach grf and ite semantics to Mac video hardware.
83 1.10 scottr */
84 1.10 scottr struct grfbus_attach_args {
85 1.10 scottr char *ga_name; /* name of semantics to attach */
86 1.10 scottr struct grfmode *ga_grfmode; /* forwarded ... */
87 1.10 scottr nubus_slot *ga_slot;
88 1.10 scottr int (*ga_mode) __P((struct grf_softc *, int, void *));
89 1.10 scottr caddr_t (*ga_phys) __P((struct grf_softc *, vm_offset_t));
90 1.1 briggs };
91 1.1 briggs
92 1.9 briggs typedef caddr_t (*grf_phys_t) __P((struct grf_softc *gp, vm_offset_t addr));
93 1.9 briggs
94 1.1 briggs /* flags */
95 1.1 briggs #define GF_ALIVE 0x01
96 1.1 briggs #define GF_OPEN 0x02
97 1.1 briggs #define GF_EXCLUDE 0x04
98 1.1 briggs #define GF_WANTED 0x08
99 1.1 briggs #define GF_BSDOPEN 0x10
100 1.1 briggs #define GF_HPUXOPEN 0x20
101 1.1 briggs
102 1.1 briggs /* requests to mode routine */
103 1.1 briggs #define GM_GRFON 1
104 1.1 briggs #define GM_GRFOFF 2
105 1.7 briggs #define GM_CURRMODE 3
106 1.7 briggs #define GM_LISTMODES 4
107 1.7 briggs #define GM_NEWMODE 5
108 1.1 briggs
109 1.1 briggs /* minor device interpretation */
110 1.1 briggs #define GRFUNIT(d) ((d) & 0x7)
111 1.1 briggs
112 1.7 briggs /*
113 1.7 briggs * Nubus image data structure. This is the equivalent of a PixMap in
114 1.7 briggs * MacOS programming parlance. One of these structures exists for each
115 1.7 briggs * video mode that a quickdraw compatible card can fit in.
116 1.7 briggs */
117 1.7 briggs struct image_data {
118 1.7 briggs u_int32_t size;
119 1.7 briggs u_int32_t offset;
120 1.7 briggs u_int16_t rowbytes;
121 1.7 briggs u_int16_t top;
122 1.7 briggs u_int16_t left;
123 1.7 briggs u_int16_t bottom;
124 1.7 briggs u_int16_t right;
125 1.7 briggs u_int16_t version;
126 1.7 briggs u_int16_t packType;
127 1.7 briggs u_int32_t packSize;
128 1.7 briggs u_int32_t hRes;
129 1.7 briggs u_int32_t vRes;
130 1.7 briggs u_int16_t pixelType;
131 1.7 briggs u_int16_t pixelSize;
132 1.7 briggs u_int16_t cmpCount;
133 1.7 briggs u_int16_t cmpSize;
134 1.7 briggs u_int32_t planeBytes;
135 1.7 briggs };
136 1.7 briggs
137 1.7 briggs #define VID_PARAMS 1
138 1.7 briggs #define VID_TABLE_OFFSET 2
139 1.7 briggs #define VID_PAGE_CNT 3
140 1.7 briggs #define VID_DEV_TYPE 4
141 1.9 briggs
142 1.9 briggs int grfopen __P((dev_t dev, int flag, int mode, struct proc *p));
143 1.9 briggs int grfclose __P((dev_t dev, int flag, int mode, struct proc *p));
144 1.9 briggs int grfioctl __P((dev_t, int, caddr_t, int, struct proc *p));
145 1.13 scottr int grfpoll __P((dev_t dev, int events, struct proc *p));
146 1.9 briggs int grfmmap __P((dev_t dev, int off, int prot));
147 1.9 briggs int grfon __P((dev_t dev));
148 1.9 briggs int grfoff __P((dev_t dev));
149 1.9 briggs int grfaddr __P((struct grf_softc *gp, register int off));
150 1.9 briggs int grfmap __P((dev_t dev, caddr_t *addrp, struct proc *p));
151 1.9 briggs int grfunmap __P((dev_t dev, caddr_t addr, struct proc *p));
152 1.10 scottr
153 1.11 scottr void grf_establish __P((struct grfbus_softc *, nubus_slot *,
154 1.10 scottr int (*)(struct grf_softc *, int, void *),
155 1.10 scottr caddr_t (*)(struct grf_softc *, vm_offset_t)));
156 1.12 scottr int grfbusprint __P((void *, const char *));
157