Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/wsfb support anti-aliased fonts in 8 bit, generate a...
details: https://anonhg.NetBSD.org/src/rev/5c6800fa6cc8
branches: trunk
changeset: 772472:5c6800fa6cc8
user: macallan <macallan%NetBSD.org@localhost>
date: Wed Jan 04 20:18:28 2012 +0000
description:
support anti-aliased fonts in 8 bit, generate an appropriate colour map
diffstat:
sys/dev/wsfb/genfb.c | 64 +++++++++++++++++++++++++++++++++++++++++++--------
1 files changed, 53 insertions(+), 11 deletions(-)
diffs (145 lines):
diff -r d45f3d51edb9 -r 5c6800fa6cc8 sys/dev/wsfb/genfb.c
--- a/sys/dev/wsfb/genfb.c Wed Jan 04 20:17:05 2012 +0000
+++ b/sys/dev/wsfb/genfb.c Wed Jan 04 20:18:28 2012 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: genfb.c,v 1.44 2011/12/28 18:37:58 macallan Exp $ */
+/* $NetBSD: genfb.c,v 1.45 2012/01/04 20:18:28 macallan Exp $ */
/*-
* Copyright (c) 2007 Michael Lorenz
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: genfb.c,v 1.44 2011/12/28 18:37:58 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: genfb.c,v 1.45 2012/01/04 20:18:28 macallan Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -74,6 +74,7 @@
static int genfb_getcmap(struct genfb_softc *, struct wsdisplay_cmap *);
static int genfb_putpalreg(struct genfb_softc *, uint8_t, uint8_t,
uint8_t, uint8_t);
+static void genfb_init_palette(struct genfb_softc *);
static void genfb_brightness_up(device_t);
static void genfb_brightness_down(device_t);
@@ -196,9 +197,9 @@
struct rasops_info *ri;
uint16_t crow;
long defattr;
- int i, j;
bool console;
#ifdef SPLASHSCREEN
+ int i, j;
int error = ENXIO;
#endif
@@ -280,14 +281,9 @@
if (sc->sc_want_clear)
(*ri->ri_ops.eraserows)(ri, 0, ri->ri_rows, defattr);
+#ifdef SPLASHSCREEN
j = 0;
for (i = 0; i < min(1 << sc->sc_depth, 256); i++) {
-#ifndef SPLASHSCREEN
- sc->sc_cmap_red[i] = rasops_cmap[j];
- sc->sc_cmap_green[i] = rasops_cmap[j + 1];
- sc->sc_cmap_blue[i] = rasops_cmap[j + 2];
- j += 3;
-#else
if (i >= SPLASH_CMAP_OFFSET &&
i < SPLASH_CMAP_OFFSET + SPLASH_CMAP_SIZE) {
splash_get_cmap(i,
@@ -300,11 +296,9 @@
sc->sc_cmap_blue[i] = rasops_cmap[j + 2];
}
j += 3;
-#endif
}
genfb_restore_palette(sc);
-#ifdef SPLASHSCREEN
sc->sc_splash.si_depth = sc->sc_depth;
sc->sc_splash.si_bits = sc->sc_console_screen.scr_ri.ri_bits;
sc->sc_splash.si_hwbits = sc->sc_fbaddr;
@@ -317,10 +311,12 @@
SPLASH_F_CENTER|SPLASH_F_FILL);
if (error) {
SCREEN_ENABLE_DRAWING(&sc->sc_console_screen);
+ genfb_init_palette(sc);
vcons_replay_msgbuf(&sc->sc_console_screen);
}
}
#else
+ genfb_init_palette(sc);
vcons_replay_msgbuf(&sc->sc_console_screen);
#endif
@@ -406,6 +402,7 @@
SPLASH_F_CENTER|SPLASH_F_FILL);
} else {
SCREEN_ENABLE_DRAWING(&sc->sc_console_screen);
+ genfb_init_palette(sc);
}
vcons_redraw_screen(ms);
return 0;
@@ -513,6 +510,10 @@
if (ri->ri_depth == 32)
ri->ri_flg |= RI_ENABLE_ALPHA;
+ if (ri->ri_depth == 8)
+ ri->ri_flg |= RI_ENABLE_ALPHA | RI_8BIT_IS_RGB;
+
+
rasops_init(ri, sc->sc_height / 8, sc->sc_width / 8);
ri->ri_caps = WSSCREEN_WSCOLORS;
@@ -605,6 +606,47 @@
}
}
+static void
+genfb_init_palette(struct genfb_softc *sc)
+{
+ int i, j, tmp;
+
+ if (sc->sc_depth == 8) {
+ /* generate an r3g3b2 colour map */
+ for (i = 0; i < 256; i++) {
+ tmp = i & 0xe0;
+ /*
+ * replicate bits so 0xe0 maps to a red value of 0xff
+ * in order to make white look actually white
+ */
+ tmp |= (tmp >> 3) | (tmp >> 6);
+ sc->sc_cmap_red[i] = tmp;
+
+ tmp = (i & 0x1c) << 3;
+ tmp |= (tmp >> 3) | (tmp >> 6);
+ sc->sc_cmap_green[i] = tmp;
+
+ tmp = (i & 0x03) << 6;
+ tmp |= tmp >> 2;
+ tmp |= tmp >> 4;
+ sc->sc_cmap_blue[i] = tmp;
+
+ genfb_putpalreg(sc, i, sc->sc_cmap_red[i],
+ sc->sc_cmap_green[i],
+ sc->sc_cmap_blue[i]);
+ }
+ } else {
+ /* steal rasops' ANSI cmap */
+ j = 0;
+ for (i = 0; i < 256; i++) {
+ sc->sc_cmap_red[i] = rasops_cmap[j];
+ sc->sc_cmap_green[i] = rasops_cmap[j + 1];
+ sc->sc_cmap_blue[i] = rasops_cmap[j + 2];
+ j += 3;
+ }
+ }
+}
+
static int
genfb_putpalreg(struct genfb_softc *sc, uint8_t idx, uint8_t r, uint8_t g,
uint8_t b)
Home |
Main Index |
Thread Index |
Old Index