Home | History | Annotate | Line # | Download | only in wsfb
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