ffbvar.h revision 1.13 1 1.13 macallan /* $NetBSD: ffbvar.h,v 1.13 2011/12/22 05:08:05 macallan 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.8 martin #include <dev/wscons/wsdisplay_vconsvar.h>
37 1.10 jdc #include <dev/videomode/videomode.h>
38 1.10 jdc #include <dev/videomode/edidvar.h>
39 1.10 jdc #include <dev/videomode/edidreg.h>
40 1.10 jdc
41 1.10 jdc #include <dev/i2c/i2cvar.h>
42 1.10 jdc #include <dev/i2c/i2c_bitbang.h>
43 1.8 martin
44 1.1 petrov #define FFB_CREATOR 0
45 1.1 petrov #define FFB_AFB 1
46 1.1 petrov
47 1.1 petrov #define FFB_CFFLAG_NOACCEL 0x1
48 1.1 petrov
49 1.10 jdc #define EDID_DATA_LEN 128
50 1.10 jdc
51 1.1 petrov struct ffb_softc {
52 1.11 christos device_t sc_dev;
53 1.4 martin struct fbdevice sc_fb;
54 1.1 petrov bus_space_tag_t sc_bt;
55 1.2 heas bus_space_handle_t sc_dac_h;
56 1.1 petrov bus_space_handle_t sc_fbc_h;
57 1.13 macallan bus_space_handle_t sc_sfb32_h;
58 1.13 macallan uint32_t *sc_sfb32;
59 1.1 petrov bus_addr_t sc_addrs[FFB_NREGS];
60 1.1 petrov bus_size_t sc_sizes[FFB_NREGS];
61 1.1 petrov int sc_height, sc_width, sc_linebytes, sc_depth;
62 1.1 petrov int sc_nscreens, sc_nreg;
63 1.1 petrov int sc_console;
64 1.1 petrov int sc_node;
65 1.1 petrov int sc_type;
66 1.3 heas u_int sc_dacrev;
67 1.10 jdc uint8_t sc_edid_data[EDID_DATA_LEN];
68 1.10 jdc struct edid_info sc_edid_info;
69 1.8 martin u_int sc_locked;
70 1.8 martin int sc_mode;
71 1.8 martin int sc_accel, sc_needredraw;
72 1.9 macallan int32_t sc_fifo_cache, sc_fg_cache, sc_bg_cache;
73 1.10 jdc const char *sc_conf;
74 1.9 macallan
75 1.10 jdc /* I2C stuff */
76 1.10 jdc struct i2c_controller sc_i2c;
77 1.10 jdc
78 1.5 macallan /* virtual console stuff */
79 1.8 martin struct vcons_data vd;
80 1.1 petrov };
81 1.1 petrov
82 1.2 heas #define DAC_WRITE(sc,r,v) \
83 1.2 heas bus_space_write_4((sc)->sc_bt, (sc)->sc_dac_h, (r), (v))
84 1.2 heas #define DAC_READ(sc,r) \
85 1.2 heas bus_space_read_4((sc)->sc_bt, (sc)->sc_dac_h, (r))
86 1.1 petrov #define FBC_WRITE(sc,r,v) \
87 1.1 petrov bus_space_write_4((sc)->sc_bt, (sc)->sc_fbc_h, (r), (v))
88 1.1 petrov #define FBC_READ(sc,r) \
89 1.1 petrov bus_space_read_4((sc)->sc_bt, (sc)->sc_fbc_h, (r))
90 1.1 petrov
91 1.12 jdc void ffb_attach(device_t);
92