1 /* $NetBSD: bt_subr.c,v 1.13 2009/04/18 14:58:04 tsutsui Exp $ */
5 * The Regents of the University of California. All rights reserved.
7 * This software was developed by the Computer Systems Engineering group
8 * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
9 * contributed to Berkeley.
11 * All advertising materials mentioning features or use of this software
12 * must display the following acknowledgement:
13 * This product includes software developed by the University of
14 * California, Lawrence Berkeley Laboratory.
16 * Redistribution and use in source and binary forms, with or without
17 * modification, are permitted provided that the following conditions
19 * 1. Redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer.
21 * 2. Redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution.
24 * 3. Neither the name of the University nor the names of its contributors
25 * may be used to endorse or promote products derived from this software
26 * without specific prior written permission.
28 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
40 * @(#)bt_subr.c 8.2 (Berkeley) 1/21/94
43 #include <sys/cdefs.h>
44 __KERNEL_RCSID(0, "$NetBSD: bt_subr.c,v 1.13 2009/04/18 14:58:04 tsutsui Exp $");
46 #include <sys/param.h>
47 #include <sys/systm.h>
49 #include <sys/errno.h>
50 #include <sys/malloc.h>
52 #include <uvm/uvm_extern.h>
54 #include <dev/sun/fbio.h>
56 #include <dev/sun/btreg.h>
57 #include <dev/sun/btvar.h>
60 * Common code for dealing with Brooktree video DACs.
61 * (Contains some software-only code as well, since the colormap
62 * ioctls are shared between the cgthree and cgsix drivers.)
66 * Implement an FBIOGETCMAP-like ioctl.
69 bt_getcmap(struct fbcmap
*p
, union bt_cmap
*cm
, int cmsize
, int uspace
)
71 u_int i
, start
, count
;
73 u_char
*cp
, *r
, *g
, *b
;
78 if (start
>= cmsize
|| count
> cmsize
- start
)
82 /* Allocate temporary buffer for color values */
83 cbuf
= malloc(3 * count
* sizeof(char), M_TEMP
, M_WAITOK
);
88 /* Direct access in kernel space */
94 /* Copy colors from BT map to fbcmap */
95 for (cp
= &cm
->cm_map
[start
][0], i
= 0; i
< count
; cp
+= 3, i
++) {
102 error
= copyout(r
, p
->red
, count
);
105 error
= copyout(g
, p
->green
, count
);
108 error
= copyout(b
, p
->blue
, count
);
121 * Implement the software portion of an FBIOPUTCMAP-like ioctl.
124 bt_putcmap(struct fbcmap
*p
, union bt_cmap
*cm
, int cmsize
, int uspace
)
126 u_int i
, start
, count
;
128 u_char
*cp
, *r
, *g
, *b
;
133 if (start
>= cmsize
|| count
> cmsize
- start
)
137 /* Allocate temporary buffer for color values */
138 cbuf
= malloc(3 * count
* sizeof(char), M_TEMP
, M_WAITOK
);
142 error
= copyin(p
->red
, r
, count
);
145 error
= copyin(p
->green
, g
, count
);
148 error
= copyin(p
->blue
, b
, count
);
152 /* Direct access in kernel space */
158 /* Copy colors from fbcmap to BT map */
159 for (cp
= &cm
->cm_map
[start
][0], i
= 0; i
< count
; cp
+= 3, i
++) {
173 * Initialize the color map to the default state:
175 * - 0 is white (PROM uses entry 0 for background)
176 * - all other entries are black (PROM uses entry 255 for foreground)
179 bt_initcmap(union bt_cmap
*cm
, int cmsize
)
184 cp
= &cm
->cm_map
[0][0];
185 cp
[0] = cp
[1] = cp
[2] = 0xff;
187 for (i
= 1, cp
= &cm
->cm_map
[i
][0]; i
< cmsize
; cp
+= 3, i
++)
188 cp
[0] = cp
[1] = cp
[2] = 0;
193 * Setup an ANSI map at offset 1, for rasops;
194 * see dev/fb.c for usage (XXX - this should
195 * be replaced by more general colormap handling)
197 extern u_char rasops_cmap
[];
198 memcpy(&cm
->cm_map
[1][0], rasops_cmap
, 3*16);
205 bt_loadcmap_packed256(struct fbdevice
*fb
, volatile struct bt_regs
*bt
, int start
, int ncolors
)
210 struct cmap
*cm
= &fb
->fb_cmap
;
212 count
= BT_D4M3(start
+ ncolors
- 1) - BT_D4M3(start
) + 3;
213 bt
= &sc
->sc_fbc
->fbc_dac
;
214 bt
->bt_addr
= BT_D4M4(start
);
217 * Figure out where to start in the RGB arrays
218 * See btreg.h for the way RGB triplets are packed into 4-byte words.
220 c
[0] = &cm
->red
[(4 * count
) / 3];
221 c
[1] = &cm
->green
[(4 * count
) / 3];
222 c
[2] = &cm
->blue
[(4 * count
) / 3];
224 i
= (4 * count
) % 3; /* This much of the last triplet is already in
225 the last packed word */
232 while (--count
>= 0) {
236 * Retrieve four colormap entries, pack them into
237 * a 32-bit word and write to the hardware register.
239 for (i
= 0; i
< 4; i
++) {
241 v
|= *cp
++ << (8 * i
);