summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorJason Wright <jason@cvs.openbsd.org>2002-06-04 21:50:08 +0000
committerJason Wright <jason@cvs.openbsd.org>2002-06-04 21:50:08 +0000
commit64e1347957658ba023888b80144d866fa0ff5e89 (patch)
treee5d616b3673cf673c3e5c62522f5bdc5cf53a0e5 /sys/arch
parent435473f0bc70ffb44fb82b023a4d11300e4ff0be (diff)
Convert vgafb from rcons to rasops
If depth is 24, select rasops32 (and make sure the stride is right)
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc64/conf/files.sparc6410
-rw-r--r--sys/arch/sparc64/dev/vgafb.c114
2 files changed, 61 insertions, 63 deletions
diff --git a/sys/arch/sparc64/conf/files.sparc64 b/sys/arch/sparc64/conf/files.sparc64
index f01cb1e6783..5f8ca3830ea 100644
--- a/sys/arch/sparc64/conf/files.sparc64
+++ b/sys/arch/sparc64/conf/files.sparc64
@@ -1,4 +1,4 @@
-# $OpenBSD: files.sparc64,v 1.34 2002/06/03 16:35:55 fgsch Exp $
+# $OpenBSD: files.sparc64,v 1.35 2002/06/04 21:50:07 jason Exp $
# $NetBSD: files.sparc64,v 1.50 2001/08/10 20:53:50 eeh Exp $
# maxpartitions must be first item in files.${ARCH}
@@ -23,6 +23,8 @@ file arch/sparc64/dev/uperf.c uperf needs-flag
include "dev/sun/files.sun"
include "dev/wscons/files.wscons"
+include "dev/rasops/files.rasops"
+include "dev/wsfont/files.wsfont"
include "dev/sbus/files.sbus"
include "dev/i2o/files.i2o"
include "dev/mii/files.mii"
@@ -37,10 +39,6 @@ file arch/sparc64/sparc64/netbsd_machdep.c compat_netbsd
attach sbus at mainbus
file arch/sparc64/dev/sbus.c sbus
-# Raster operations
-include "dev/rasops/files.rasops"
-include "dev/wsfont/files.wsfont"
-
device creator: wsemuldisplaydev, rasops8, rasops16, rasops24, rasops32
attach creator at mainbus
file arch/sparc64/dev/creator.c creator
@@ -54,7 +52,7 @@ file arch/sparc64/dev/pci_machdep.c psycho
attach hme at pci with hme_pci
file dev/pci/if_hme_pci.c hme_pci
-device vgafb: wsemuldisplaydev, wsrasteremulops, wsemul_sun
+device vgafb: wsemuldisplaydev, rasops8, rasops16, rasops24, rasops32, wsemul_sun
attach vgafb at pci
file arch/sparc64/dev/vgafb.c vgafb
diff --git a/sys/arch/sparc64/dev/vgafb.c b/sys/arch/sparc64/dev/vgafb.c
index 7a149be7188..29f58dadeee 100644
--- a/sys/arch/sparc64/dev/vgafb.c
+++ b/sys/arch/sparc64/dev/vgafb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vgafb.c,v 1.17 2002/04/15 17:43:30 jason Exp $ */
+/* $OpenBSD: vgafb.c,v 1.18 2002/06/04 21:50:07 jason Exp $ */
/*
* Copyright (c) 2001 Jason L. Wright (jason@thought.net)
@@ -56,11 +56,10 @@
#include <dev/wscons/wsconsio.h>
#include <dev/wscons/wsdisplayvar.h>
#include <dev/wscons/wscons_raster.h>
-#include <dev/rcons/raster.h>
+#include <dev/rasops/rasops.h>
struct vgafb_softc {
struct device sc_dev;
- struct sbusdev sc_sd;
int sc_nscreens;
int sc_width, sc_height, sc_depth, sc_linebytes;
int sc_node, sc_ofhandle;
@@ -72,24 +71,12 @@ struct vgafb_softc {
pci_chipset_tag_t sc_pci_chip;
u_int8_t *sc_rom_ptr;
int sc_has_rom;
- struct rcons sc_rcons;
- struct raster sc_raster;
int sc_console;
u_int sc_mode;
u_int8_t sc_cmap_red[256];
u_int8_t sc_cmap_green[256];
u_int8_t sc_cmap_blue[256];
-};
-
-struct wsdisplay_emulops vgafb_emulops = {
- rcons_cursor,
- rcons_mapchar,
- rcons_putchar,
- rcons_copycols,
- rcons_erasecols,
- rcons_copyrows,
- rcons_eraserows,
- rcons_alloc_attr
+ struct rasops_info sc_rasops;
};
struct wsscreen_descr vgafb_stdscreen = {
@@ -203,48 +190,61 @@ vgafbattach(parent, self, aux)
if (vgafb_mapregs(sc, pa))
return;
- sc->sc_rcons.rc_sp = &sc->sc_raster;
- sc->sc_raster.width = sc->sc_width;
- sc->sc_raster.height = sc->sc_height;
- sc->sc_raster.depth = sc->sc_depth;
- sc->sc_raster.linelongs = sc->sc_linebytes / 4;
- sc->sc_raster.pixels = (void *)bus_space_vaddr(sc->sc_mem_t, sc->sc_mem_h);
-
- if (sc->sc_console == 0 ||
- romgetcursoraddr(&sc->sc_rcons.rc_crowp, &sc->sc_rcons.rc_ccolp)) {
- sc->sc_rcons.rc_crow = sc->sc_rcons.rc_ccol = -1;
- sc->sc_rcons.rc_crowp = &sc->sc_rcons.rc_crow;
- sc->sc_rcons.rc_ccolp = &sc->sc_rcons.rc_ccol;
+ if (sc->sc_depth == 24) {
+ /* Depth is 24, but rasops really wants bpp */
+ sc->sc_rasops.ri_depth = 32;
+ /* PROM gets linebytes wrong, ignore it. */
+ sc->sc_rasops.ri_stride =
+ (sc->sc_rasops.ri_depth / 8) * sc->sc_width;
+ } else {
+ sc->sc_rasops.ri_depth = sc->sc_depth;
+ sc->sc_rasops.ri_stride = sc->sc_linebytes;
}
- sc->sc_rcons.rc_maxcol =
- a2int(getpropstring(optionsnode, "screen-#columns"), 80);
- sc->sc_rcons.rc_maxrow =
- a2int(getpropstring(optionsnode, "screen-#rows"), 34);
+ sc->sc_rasops.ri_flg = RI_CENTER;
+ sc->sc_rasops.ri_bits = (void *)bus_space_vaddr(sc->sc_mem_t,
+ sc->sc_mem_h);
+ sc->sc_rasops.ri_width = sc->sc_width;
+ sc->sc_rasops.ri_height = sc->sc_height;
+ sc->sc_rasops.ri_hw = sc;
- rcons_init(&sc->sc_rcons,
- sc->sc_rcons.rc_maxrow, sc->sc_rcons.rc_maxcol);
+ rasops_init(&sc->sc_rasops,
+ a2int(getpropstring(optionsnode, "screen-#rows"), 34),
+ a2int(getpropstring(optionsnode, "screen-#columns"), 80));
- vgafb_stdscreen.nrows = sc->sc_rcons.rc_maxrow;
- vgafb_stdscreen.ncols = sc->sc_rcons.rc_maxcol;
- vgafb_stdscreen.textops = &vgafb_emulops;
- rcons_alloc_attr(&sc->sc_rcons, 0, 0, 0, &defattr);
+ vgafb_stdscreen.nrows = sc->sc_rasops.ri_rows;
+ vgafb_stdscreen.ncols = sc->sc_rasops.ri_cols;
+ vgafb_stdscreen.textops = &sc->sc_rasops.ri_ops;
+ sc->sc_rasops.ri_ops.alloc_attr(&sc->sc_rasops,
+ WSCOL_WHITE, WSCOL_BLACK, WSATTR_WSCOLORS, &defattr);
printf("\n");
if (sc->sc_console) {
+ int *ccolp, *crowp;
+
sc->sc_ofhandle = OF_stdout();
- vgafb_setcolor(sc, WSCOL_BLACK, 0, 0, 0);
- vgafb_setcolor(sc, 255, 255, 255, 255);
- vgafb_setcolor(sc, WSCOL_RED, 255, 0, 0);
- vgafb_setcolor(sc, WSCOL_GREEN, 0, 255, 0);
- vgafb_setcolor(sc, WSCOL_BROWN, 154, 85, 46);
- vgafb_setcolor(sc, WSCOL_BLUE, 0, 0, 255);
- vgafb_setcolor(sc, WSCOL_MAGENTA, 255, 255, 0);
- vgafb_setcolor(sc, WSCOL_CYAN, 0, 255, 255);
- vgafb_setcolor(sc, WSCOL_WHITE, 255, 255, 255);
- wsdisplay_cnattach(&vgafb_stdscreen, &sc->sc_rcons,
- *sc->sc_rcons.rc_ccolp, *sc->sc_rcons.rc_crowp, defattr);
+
+ if (sc->sc_depth == 8) {
+ vgafb_setcolor(sc, WSCOL_BLACK, 0, 0, 0);
+ vgafb_setcolor(sc, 255, 255, 255, 255);
+ vgafb_setcolor(sc, WSCOL_RED, 255, 0, 0);
+ vgafb_setcolor(sc, WSCOL_GREEN, 0, 255, 0);
+ vgafb_setcolor(sc, WSCOL_BROWN, 154, 85, 46);
+ vgafb_setcolor(sc, WSCOL_BLUE, 0, 0, 255);
+ vgafb_setcolor(sc, WSCOL_MAGENTA, 255, 255, 0);
+ vgafb_setcolor(sc, WSCOL_CYAN, 0, 255, 255);
+ vgafb_setcolor(sc, WSCOL_WHITE, 255, 255, 255);
+ }
+
+ if (romgetcursoraddr(&crowp, &ccolp))
+ ccolp = crowp = NULL;
+ if (ccolp != NULL)
+ sc->sc_rasops.ri_ccol = *ccolp;
+ if (crowp != NULL)
+ sc->sc_rasops.ri_crow = *crowp;
+ wsdisplay_cnattach(&vgafb_stdscreen, &sc->sc_rasops,
+ sc->sc_rasops.ri_ccol, sc->sc_rasops.ri_crow, defattr);
}
waa.console = sc->sc_console;
@@ -278,11 +278,11 @@ vgafb_ioctl(v, cmd, data, flags, p)
wdf = (void *)data;
wdf->height = sc->sc_height;
wdf->width = sc->sc_width;
- wdf->depth = sc->sc_depth;
+ wdf->depth = sc->sc_rasops.ri_depth;
wdf->cmsize = 256;
break;
case WSDISPLAYIO_LINEBYTES:
- *(u_int *)data = sc->sc_linebytes;
+ *(u_int *)data = sc->sc_rasops.ri_stride;
break;
case WSDISPLAYIO_GETCMAP:
@@ -386,10 +386,11 @@ vgafb_alloc_screen(v, type, cookiep, curxp, curyp, attrp)
if (sc->sc_nscreens > 0)
return (ENOMEM);
- *cookiep = &sc->sc_rcons;
- *curyp = *sc->sc_rcons.rc_crowp;
- *curxp = *sc->sc_rcons.rc_ccolp;
- rcons_alloc_attr(&sc->sc_rcons, 0, 0, 0, attrp);
+ *cookiep = &sc->sc_rasops;
+ *curyp = 0;
+ *curxp = 0;
+ sc->sc_rasops.ri_ops.alloc_attr(&sc->sc_rasops,
+ WSCOL_WHITE, WSCOL_BLACK, WSATTR_WSCOLORS, attrp);
sc->sc_nscreens++;
return (0);
}
@@ -619,8 +620,7 @@ vgafb_mapregs(sc, pa)
if (hasmem)
continue;
if (bus_space_map2(pa->pa_memt, SBUS_BUS_SPACE,
- ba, bs, 0, NULL,
- &sc->sc_mem_h)) {
+ ba, bs, 0, NULL, &sc->sc_mem_h)) {
printf(": can't map mem space\n");
continue;
}