summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2002-07-25 19:03:26 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2002-07-25 19:03:26 +0000
commit48bbde10e0385b5b1c97150234d637538444f51b (patch)
tree184767c4451f5e6d0cd0930b704ab371c059b844
parentc7866a5b25f02593194ade0e26348772eb9dd911 (diff)
Rework the color usage in wsemul_sun displays, to match SunOS and Solaris
text mode colors. This means black text on white background, even for the kernel messages. Initially based on a patch from jason@, then some tinkering by me.
-rw-r--r--sys/dev/wscons/wsdisplayvar.h16
-rw-r--r--sys/dev/wscons/wsemul_sun.c22
2 files changed, 30 insertions, 8 deletions
diff --git a/sys/dev/wscons/wsdisplayvar.h b/sys/dev/wscons/wsdisplayvar.h
index 867a5e90349..3b13326aa62 100644
--- a/sys/dev/wscons/wsdisplayvar.h
+++ b/sys/dev/wscons/wsdisplayvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: wsdisplayvar.h,v 1.13 2002/03/27 18:54:09 jbm Exp $ */
+/* $OpenBSD: wsdisplayvar.h,v 1.14 2002/07/25 19:03:25 miod Exp $ */
/* $NetBSD: wsdisplayvar.h,v 1.14.4.1 2000/06/30 16:27:53 simonb Exp $ */
/*
@@ -66,14 +66,20 @@ struct wsdisplay_emulops {
void (*eraserows)(void *c, int row, int nrows, long);
int (*alloc_attr)(void *c, int fg, int bg, int flags, long *);
/* fg / bg values. Made identical to ANSI terminal color codes. */
+/* XXX should be #if NWSEMUL_SUN > 1 */
+#if defined(__sparc__) || defined(__sparc64__)
+#define WSCOL_WHITE wscol_white
+#define WSCOL_BLACK wscol_black
+#else
#define WSCOL_BLACK 0
+#define WSCOL_WHITE 7
+#endif
#define WSCOL_RED 1
#define WSCOL_GREEN 2
#define WSCOL_BROWN 3
#define WSCOL_BLUE 4
#define WSCOL_MAGENTA 5
#define WSCOL_CYAN 6
-#define WSCOL_WHITE 7
/* flag values: */
#define WSATTR_REVERSE 1
#define WSATTR_HILIT 2
@@ -83,6 +89,12 @@ struct wsdisplay_emulops {
/* XXX need a free_attr() ??? */
};
+/* XXX should be #if NWSEMUL_SUN > 1 */
+#if defined(__sparc__) || defined(__sparc64__)
+extern int wscol_white, wscol_black;
+extern int wskernel_fg, wskernel_bg;
+#endif
+
#define WSSCREEN_NAME_SIZE 16
struct wsscreen_descr {
diff --git a/sys/dev/wscons/wsemul_sun.c b/sys/dev/wscons/wsemul_sun.c
index bc7fcf54632..da531ebf086 100644
--- a/sys/dev/wscons/wsemul_sun.c
+++ b/sys/dev/wscons/wsemul_sun.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: wsemul_sun.c,v 1.5 2002/05/30 18:25:44 fgsch Exp $ */
+/* $OpenBSD: wsemul_sun.c,v 1.6 2002/07/25 19:03:25 miod Exp $ */
/* $NetBSD: wsemul_sun.c,v 1.11 2000/01/05 11:19:36 drochner Exp $ */
/*
@@ -109,6 +109,16 @@ struct wsemul_sun_emuldata wsemul_sun_console_emuldata;
#define COLS_LEFT (edp->ncols - edp->ccol - 1)
#define ROWS_LEFT (edp->nrows - edp->crow - 1)
+/*
+ * wscons color codes
+ * To compensate for Sun color choices on older framebuffers, these need to
+ * be variables.
+ */
+int wscol_white = 0; /* 0 */
+int wscol_black = 7; /* 255 */
+int wskernel_bg = 7; /* 0 */
+int wskernel_fg = 0; /* 255 */
+
void *
wsemul_sun_cnattach(type, cookie, ccol, crow, defattr)
const struct wsscreen_descr *type;
@@ -131,10 +141,10 @@ wsemul_sun_cnattach(type, cookie, ccol, crow, defattr)
edp->curattr = edp->defattr = defattr;
#ifndef WS_KERNEL_FG
-#define WS_KERNEL_FG WSCOL_WHITE
+#define WS_KERNEL_FG wskernel_bg
#endif
#ifndef WS_KERNEL_BG
-#define WS_KERNEL_BG WSCOL_BLACK
+#define WS_KERNEL_BG wskernel_fg
#endif
#ifndef WS_KERNEL_COLATTR
#define WS_KERNEL_COLATTR 0
@@ -204,7 +214,7 @@ wsemul_sun_attach(console, type, cookie, ccol, crow, cbcookie, defattr)
/* XXX This assumes that the default attribute is wob. */
if ((!(edp->scrcapabilities & WSSCREEN_WSCOLORS) ||
(*edp->emulops->alloc_attr)(edp->emulcookie,
- WSCOL_BLACK, WSCOL_WHITE,
+ WSCOL_WHITE, WSCOL_BLACK,
WSATTR_WSCOLORS,
&edp->bowattr)) &&
(!(edp->scrcapabilities & WSSCREEN_REVERSE) ||
@@ -362,7 +372,7 @@ wsemul_sun_control(edp, c)
src, dst, edp->ncols - dst);
}
(*edp->emulops->erasecols)(edp->emulcookie, edp->crow,
- src, dst - src, edp->curattr);
+ src, n, edp->curattr);
break;
case 'A': /* "Cursor Up (CUU)" */
@@ -434,7 +444,7 @@ wsemul_sun_control(edp, c)
src, dst, edp->ncols - src);
}
(*edp->emulops->erasecols)(edp->emulcookie, edp->crow,
- dst + edp->ncols - src, src - dst, edp->curattr);
+ edp->ncols - n, n, edp->curattr);
break;
case 'm': /* "Select Graphic Rendition (SGR)" */