Module Name:    src
Committed By:   macallan
Date:           Wed Jan  4 20:18:29 UTC 2012

Modified Files:
        src/sys/dev/wsfb: genfb.c

Log Message:
support anti-aliased fonts in 8 bit, generate an appropriate colour map


To generate a diff of this commit:
cvs rdiff -u -r1.44 -r1.45 src/sys/dev/wsfb/genfb.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/dev/wsfb/genfb.c
diff -u src/sys/dev/wsfb/genfb.c:1.44 src/sys/dev/wsfb/genfb.c:1.45
--- src/sys/dev/wsfb/genfb.c:1.44	Wed Dec 28 18:37:58 2011
+++ src/sys/dev/wsfb/genfb.c	Wed Jan  4 20:18:28 2012
@@ -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_putcmap(struct genfb_so
 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 @@ genfb_attach(struct genfb_softc *sc, str
 	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 @@ genfb_attach(struct genfb_softc *sc, str
 	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 @@ genfb_attach(struct genfb_softc *sc, str
 			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 @@ genfb_attach(struct genfb_softc *sc, str
 		    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 @@ genfb_ioctl(void *v, void *vs, u_long cm
 						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 @@ genfb_init_screen(void *cookie, struct v
 	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 @@ genfb_restore_palette(struct genfb_softc
 	}
 }
 
+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)

Reply via email to