ffbvar.h revision 1.3 1 1.3 heas /* $NetBSD: ffbvar.h,v 1.3 2004/07/19 01:04:35 heas Exp $ */
2 1.1 petrov /* $OpenBSD: creatorvar.h,v 1.6 2002/07/30 19:48:15 jason Exp $ */
3 1.1 petrov
4 1.1 petrov /*
5 1.1 petrov * Copyright (c) 2002 Jason L. Wright (jason (at) thought.net),
6 1.1 petrov * Federico G. Schwindt (fgsch (at) openbsd.org)
7 1.1 petrov * All rights reserved.
8 1.1 petrov *
9 1.1 petrov * Redistribution and use in source and binary forms, with or without
10 1.1 petrov * modification, are permitted provided that the following conditions
11 1.1 petrov * are met:
12 1.1 petrov * 1. Redistributions of source code must retain the above copyright
13 1.1 petrov * notice, this list of conditions and the following disclaimer.
14 1.1 petrov * 2. Redistributions in binary form must reproduce the above copyright
15 1.1 petrov * notice, this list of conditions and the following disclaimer in the
16 1.1 petrov * documentation and/or other materials provided with the distribution.
17 1.1 petrov * 3. All advertising materials mentioning features or use of this software
18 1.1 petrov * must display the following acknowledgement:
19 1.1 petrov * This product includes software developed by Jason L. Wright
20 1.1 petrov * 4. The name of the author may not be used to endorse or promote products
21 1.1 petrov * derived from this software without specific prior written permission.
22 1.1 petrov *
23 1.1 petrov * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
24 1.1 petrov * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25 1.1 petrov * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26 1.1 petrov * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
27 1.1 petrov * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
28 1.1 petrov * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
29 1.1 petrov * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 petrov * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
31 1.1 petrov * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32 1.1 petrov * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33 1.1 petrov * POSSIBILITY OF SUCH DAMAGE.
34 1.1 petrov */
35 1.1 petrov
36 1.1 petrov #define FFB_CREATOR 0
37 1.1 petrov #define FFB_AFB 1
38 1.1 petrov
39 1.1 petrov #define FFB_CFFLAG_NOACCEL 0x1
40 1.1 petrov
41 1.1 petrov struct ffb_softc {
42 1.1 petrov struct device sc_dv;
43 1.1 petrov bus_space_tag_t sc_bt;
44 1.1 petrov bus_space_handle_t sc_pixel_h;
45 1.2 heas bus_space_handle_t sc_dac_h;
46 1.1 petrov bus_space_handle_t sc_fbc_h;
47 1.1 petrov bus_addr_t sc_addrs[FFB_NREGS];
48 1.1 petrov bus_size_t sc_sizes[FFB_NREGS];
49 1.1 petrov int sc_height, sc_width, sc_linebytes, sc_depth;
50 1.1 petrov int sc_nscreens, sc_nreg;
51 1.1 petrov int sc_console;
52 1.1 petrov int sc_node;
53 1.1 petrov int sc_type;
54 1.3 heas u_int sc_dacrev;
55 1.1 petrov u_int sc_mode;
56 1.1 petrov struct rasops_info sc_rasops;
57 1.1 petrov int32_t sc_fifo_cache, sc_fg_cache;
58 1.1 petrov };
59 1.1 petrov
60 1.2 heas #define DAC_WRITE(sc,r,v) \
61 1.2 heas bus_space_write_4((sc)->sc_bt, (sc)->sc_dac_h, (r), (v))
62 1.2 heas #define DAC_READ(sc,r) \
63 1.2 heas bus_space_read_4((sc)->sc_bt, (sc)->sc_dac_h, (r))
64 1.1 petrov #define FBC_WRITE(sc,r,v) \
65 1.1 petrov bus_space_write_4((sc)->sc_bt, (sc)->sc_fbc_h, (r), (v))
66 1.1 petrov #define FBC_READ(sc,r) \
67 1.1 petrov bus_space_read_4((sc)->sc_bt, (sc)->sc_fbc_h, (r))
68 1.1 petrov
69 1.1 petrov void ffb_attach(struct ffb_softc *);
70