genfbvar.h revision 1.26 1 1.26 macallan /* $NetBSD: genfbvar.h,v 1.26 2021/01/27 22:42:53 macallan Exp $ */
2 1.1 macallan
3 1.1 macallan /*-
4 1.1 macallan * Copyright (c) 2007 Michael Lorenz
5 1.1 macallan * All rights reserved.
6 1.1 macallan *
7 1.1 macallan * Redistribution and use in source and binary forms, with or without
8 1.1 macallan * modification, are permitted provided that the following conditions
9 1.1 macallan * are met:
10 1.1 macallan * 1. Redistributions of source code must retain the above copyright
11 1.1 macallan * notice, this list of conditions and the following disclaimer.
12 1.1 macallan * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 macallan * notice, this list of conditions and the following disclaimer in the
14 1.1 macallan * documentation and/or other materials provided with the distribution.
15 1.1 macallan *
16 1.1 macallan * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 1.1 macallan * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 1.1 macallan * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 1.1 macallan * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 1.1 macallan * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 1.1 macallan * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 1.1 macallan * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 1.1 macallan * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 1.1 macallan * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 1.1 macallan * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 1.1 macallan * POSSIBILITY OF SUCH DAMAGE.
27 1.1 macallan */
28 1.1 macallan
29 1.1 macallan #ifndef GENFBVAR_H
30 1.1 macallan #define GENFBVAR_H
31 1.1 macallan
32 1.22 riastrad #ifdef _KERNEL_OPT
33 1.13 ahoka #include "opt_splash.h"
34 1.22 riastrad #endif
35 1.13 ahoka
36 1.1 macallan #include <sys/param.h>
37 1.1 macallan #include <sys/buf.h>
38 1.1 macallan #include <sys/conf.h>
39 1.1 macallan #include <sys/device.h>
40 1.1 macallan
41 1.5 ad #include <sys/bus.h>
42 1.2 macallan
43 1.1 macallan #include <dev/wscons/wsconsio.h>
44 1.1 macallan #include <dev/wscons/wsdisplayvar.h>
45 1.1 macallan #include <dev/rasops/rasops.h>
46 1.1 macallan
47 1.1 macallan #include <dev/wscons/wsdisplay_vconsvar.h>
48 1.22 riastrad #ifdef _KERNEL_OPT
49 1.15 macallan #include "opt_genfb.h"
50 1.22 riastrad #endif
51 1.1 macallan
52 1.13 ahoka #ifdef SPLASHSCREEN
53 1.13 ahoka #define GENFB_DISABLE_TEXT
54 1.13 ahoka #include <dev/splash/splash.h>
55 1.13 ahoka #endif
56 1.13 ahoka
57 1.26 macallan #if GENFB_GLYPHCACHE > 0
58 1.26 macallan #include <dev/wscons/wsdisplay_glyphcachevar.h>
59 1.26 macallan #endif
60 1.26 macallan
61 1.18 jmcneill struct genfb_softc;
62 1.18 jmcneill
63 1.1 macallan struct genfb_ops {
64 1.1 macallan int (*genfb_ioctl)(void *, void *, u_long, void *, int, struct lwp *);
65 1.1 macallan paddr_t (*genfb_mmap)(void *, void *, off_t, int);
66 1.8 jmcneill int (*genfb_borrow)(void *, bus_addr_t, bus_space_handle_t *);
67 1.24 riastrad int (*genfb_enable_polling)(void *);
68 1.24 riastrad int (*genfb_disable_polling)(void *);
69 1.1 macallan };
70 1.1 macallan
71 1.3 macallan struct genfb_colormap_callback {
72 1.3 macallan void *gcc_cookie;
73 1.3 macallan void (*gcc_set_mapreg)(void *, int, int, int, int);
74 1.3 macallan };
75 1.3 macallan
76 1.21 macallan /*
77 1.21 macallan * Integer parameter provider. Each callback shall return 0 on success,
78 1.21 macallan * and an error(2) number on failure. The gpc_upd_parameter callback is
79 1.21 macallan * optional (i.e. it can be NULL).
80 1.21 macallan *
81 1.21 macallan * This structure is used for backlight and brightness control. The
82 1.21 macallan * expected parameter range is:
83 1.21 macallan *
84 1.21 macallan * [0, 1] for backlight
85 1.21 macallan * [0, 255] for brightness
86 1.21 macallan */
87 1.21 macallan struct genfb_parameter_callback {
88 1.16 macallan void *gpc_cookie;
89 1.21 macallan int (*gpc_get_parameter)(void *, int *);
90 1.21 macallan int (*gpc_set_parameter)(void *, int);
91 1.21 macallan int (*gpc_upd_parameter)(void *, int);
92 1.16 macallan };
93 1.16 macallan
94 1.11 jmcneill struct genfb_pmf_callback {
95 1.14 dyoung bool (*gpc_suspend)(device_t, const pmf_qual_t *);
96 1.14 dyoung bool (*gpc_resume)(device_t, const pmf_qual_t *);
97 1.11 jmcneill };
98 1.11 jmcneill
99 1.18 jmcneill struct genfb_mode_callback {
100 1.18 jmcneill bool (*gmc_setmode)(struct genfb_softc *, int);
101 1.18 jmcneill };
102 1.18 jmcneill
103 1.1 macallan struct genfb_softc {
104 1.17 macallan device_t sc_dev;
105 1.1 macallan struct vcons_data vd;
106 1.1 macallan struct genfb_ops sc_ops;
107 1.1 macallan struct vcons_screen sc_console_screen;
108 1.1 macallan struct wsscreen_descr sc_defaultscreen_descr;
109 1.1 macallan const struct wsscreen_descr *sc_screens[1];
110 1.1 macallan struct wsscreen_list sc_screenlist;
111 1.3 macallan struct genfb_colormap_callback *sc_cmcb;
112 1.11 jmcneill struct genfb_pmf_callback *sc_pmfcb;
113 1.16 macallan struct genfb_parameter_callback *sc_backlight;
114 1.21 macallan struct genfb_parameter_callback *sc_brightness;
115 1.18 jmcneill struct genfb_mode_callback *sc_modecb;
116 1.16 macallan int sc_backlight_level, sc_backlight_on;
117 1.4 macallan void *sc_fbaddr; /* kva */
118 1.15 macallan void *sc_shadowfb;
119 1.25 nonaka bool sc_enable_shadowfb;
120 1.2 macallan bus_addr_t sc_fboffset; /* bus address */
121 1.1 macallan int sc_width, sc_height, sc_stride, sc_depth;
122 1.1 macallan size_t sc_fbsize;
123 1.1 macallan int sc_mode;
124 1.1 macallan u_char sc_cmap_red[256];
125 1.1 macallan u_char sc_cmap_green[256];
126 1.1 macallan u_char sc_cmap_blue[256];
127 1.10 jmcneill bool sc_want_clear;
128 1.13 ahoka #ifdef SPLASHSCREEN
129 1.13 ahoka struct splash_info sc_splash;
130 1.13 ahoka #endif
131 1.20 macallan struct wsdisplay_accessops sc_accessops;
132 1.26 macallan #if GENFB_GLYPHCACHE > 0
133 1.26 macallan /*
134 1.26 macallan * The generic glyphcache code makes a bunch of assumptions that are
135 1.26 macallan * true for most graphics hardware with a directly supported blitter.
136 1.26 macallan * For example it assume that
137 1.26 macallan * - VRAM access from the host is expensive
138 1.26 macallan * - copying data around in VRAM is cheap and can happen in parallel
139 1.26 macallan * to the host CPU
140 1.26 macallan * -> therefore we draw glyphs normally if we have to, so the ( assumed
141 1.26 macallan * to be hardware assisted ) driver supplied putchar() method doesn't
142 1.26 macallan * need to be glyphcache aware, then copy them away for later use
143 1.26 macallan * for genfb things are a bit different. On most hardware:
144 1.26 macallan * - VRAM access from the host is still expensive
145 1.26 macallan * - copying data around in VRAM is also expensive since we don't have
146 1.26 macallan * a blitter and VRAM is mapped uncached
147 1.26 macallan * - VRAM reads are usually slower than writes ( write combining and
148 1.26 macallan * such help writes but not reads, and VRAM might be behind an
149 1.26 macallan * asymmetric bus like AGP ) and must be avoided, both are much
150 1.26 macallan * slower than main memory
151 1.26 macallan * -> therefore we cache glyphs in main memory, no reason to map it
152 1.26 macallan * uncached, we draw into the cache first and then copy the glyph
153 1.26 macallan * into video memory to avoid framebuffer reads and to allow more
154 1.26 macallan * efficient write accesses than putchar() would offer
155 1.26 macallan * Because of this we can't use the generic code but we can recycle a
156 1.26 macallan * few data structures.
157 1.26 macallan */
158 1.26 macallan uint8_t *sc_cache;
159 1.26 macallan struct rasops_info sc_cache_ri;
160 1.26 macallan void (*sc_putchar)(void *, int, int, u_int, long);
161 1.26 macallan int sc_cache_cells;
162 1.26 macallan int sc_nbuckets; /* buckets allocated */
163 1.26 macallan gc_bucket *sc_buckets; /* we allocate as many as we can get into ram */
164 1.26 macallan int sc_attrmap[256]; /* mapping a colour attribute to a bucket */
165 1.26 macallan #endif
166 1.26 macallan
167 1.1 macallan };
168 1.1 macallan
169 1.7 jmcneill void genfb_cnattach(void);
170 1.9 jmcneill void genfb_disable(void);
171 1.7 jmcneill int genfb_is_console(void);
172 1.9 jmcneill int genfb_is_enabled(void);
173 1.2 macallan void genfb_init(struct genfb_softc *);
174 1.1 macallan int genfb_attach(struct genfb_softc *, struct genfb_ops *);
175 1.8 jmcneill int genfb_borrow(bus_addr_t, bus_space_handle_t *);
176 1.11 jmcneill void genfb_restore_palette(struct genfb_softc *);
177 1.19 jmcneill void genfb_enable_polling(device_t);
178 1.19 jmcneill void genfb_disable_polling(device_t);
179 1.1 macallan
180 1.1 macallan #endif /* GENFBVAR_H */
181