diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2008-12-24 14:39:58 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2008-12-24 14:39:58 +0000 |
commit | 2b0ce5d9b27db4045c475c43e054e15db4d11dab (patch) | |
tree | 40d9d4e46917c8af1fadc5f4cb2bdf406dd7feb4 /sys/arch | |
parent | 3813f581a0557aa32e41a78e4c620b4fba137354 (diff) |
It turns out the 8-bit tcx flavour has undocumented low-res video modes (soon
to be in tcx.4), which require a font swap and thus clearing the screen at
attach time if console. Add the necessary code for this.
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/sparc/dev/tcx.c | 42 |
1 files changed, 27 insertions, 15 deletions
diff --git a/sys/arch/sparc/dev/tcx.c b/sys/arch/sparc/dev/tcx.c index 1ac865036f9..68b9e0a0d41 100644 --- a/sys/arch/sparc/dev/tcx.c +++ b/sys/arch/sparc/dev/tcx.c @@ -1,4 +1,4 @@ -/* $OpenBSD: tcx.c,v 1.34 2008/12/24 13:40:39 miod Exp $ */ +/* $OpenBSD: tcx.c,v 1.35 2008/12/24 14:39:57 miod Exp $ */ /* $NetBSD: tcx.c,v 1.8 1997/07/29 09:58:14 fair Exp $ */ /* @@ -192,17 +192,21 @@ tcxattach(struct device *parent, struct device *self, void *args) vaddr_t thc_offset; pri = ca->ca_ra.ra_intr[0].int_pri; - printf(" pri %d", pri); + printf(" pri %d: ", pri); node = ca->ca_ra.ra_node; isconsole = node == fbnode; if (ca->ca_ra.ra_nreg < TCX_NREG) { - printf(": expected %d registers, got %d\n", + printf("expected %d registers, got %d\n", TCX_NREG, ca->ca_ra.ra_nreg); return; } + nam = getpropstring(node, "model"); + if (*nam != '\0') + printf("%s, ", nam); + /* * Copy the register address spaces needed for mmap operation. */ @@ -256,6 +260,10 @@ tcxattach(struct device *parent, struct device *self, void *args) (paddr_t)ca->ca_ra.ra_reg[TCX_REG_RDFB32].rr_paddr; } + printf("%dx%dx%d\n", + sc->sc_sunfb.sf_width, sc->sc_sunfb.sf_height, + sc->sc_cplane == 0 ? 8 : 24); + /* * Set up mappings for the acceleration code. This may fail. */ @@ -270,7 +278,20 @@ tcxattach(struct device *parent, struct device *self, void *args) sc->sc_sunfb.sf_ro.ri_hw = sc; sc->sc_sunfb.sf_ro.ri_bits = (void *)sc->sc_dfb8; - fbwscons_init(&sc->sc_sunfb, isconsole ? 0 : RI_CLEAR); + + /* + * If the framebuffer width is under 960 pixels, we will switch + * from the PROM font to the more adequate 8x16 font here. + * However, we need to adjust two things in this case: + * - the display row should be overrided from the current PROM metrics, + * to prevent us from overwriting the last few lines of text. + * - if the 80x34 screen would make a large margin appear around it, + * choose to clear the screen rather than keeping old prom output in + * the margins. + */ + fbwscons_init(&sc->sc_sunfb, + isconsole && sc->sc_sunfb.sf_width >= 12 * 80 ? 0 : RI_CLEAR); + fbwscons_setcolormap(&sc->sc_sunfb, tcx_setcolor); /* @@ -291,20 +312,11 @@ tcxattach(struct device *parent, struct device *self, void *args) intr_establish(pri, &sc->sc_ih, IPL_FB, self->dv_xname); if (isconsole) { - fbwscons_console_init(&sc->sc_sunfb, -1); + fbwscons_console_init(&sc->sc_sunfb, + sc->sc_sunfb.sf_width >= 12 * 80 ? -1 : 0); shutdownhook_establish(tcx_prom, sc); } - nam = getpropstring(node, "model"); - if (*nam != '\0') - printf(": %s\n%s", nam, self->dv_xname); - printf(": %dx%d, id %d, rev %d, sense %d\n", - sc->sc_sunfb.sf_width, sc->sc_sunfb.sf_height, - (sc->sc_thc->thc_config & THC_CFG_FBID) >> THC_CFG_FBID_SHIFT, - (sc->sc_thc->thc_config & THC_CFG_REV) >> THC_CFG_REV_SHIFT, - (sc->sc_thc->thc_config & THC_CFG_SENSE) >> THC_CFG_SENSE_SHIFT - ); - fbwscons_attach(&sc->sc_sunfb, &tcx_accessops, isconsole); } |