summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/ic/sti.c129
-rw-r--r--sys/dev/ic/stivar.h9
2 files changed, 109 insertions, 29 deletions
diff --git a/sys/dev/ic/sti.c b/sys/dev/ic/sti.c
index a427dc03efc..2b31c0b6543 100644
--- a/sys/dev/ic/sti.c
+++ b/sys/dev/ic/sti.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sti.c,v 1.22 2003/02/17 22:41:31 mickey Exp $ */
+/* $OpenBSD: sti.c,v 1.23 2003/02/18 09:39:45 miod Exp $ */
/*
* Copyright (c) 2000-2003 Michael Shalayeff
@@ -119,8 +119,9 @@ enum sti_bmove_funcs {
int sti_init(struct sti_softc *sc, int mode);
int sti_inqcfg(struct sti_softc *sc, struct sti_inqconfout *out);
void sti_bmove(struct sti_softc *sc, int, int, int, int, int, int,
- enum sti_bmove_funcs);
-int sti_fetchfonts(struct sti_softc *sc, u_int32_t addr);
+ enum sti_bmove_funcs);
+int sti_fetchfonts(struct sti_softc *sc, struct sti_inqconfout *cfg,
+ u_int32_t addr);
void sti_attach_deferred(void *);
void
@@ -321,7 +322,7 @@ sti_attach_common(sc)
sc->sc_dev.dv_xname, cfg.fbwidth, cfg.fbheight,
cfg.width, cfg.height, cfg.bpp, cfg.owidth, cfg.oheight);
- if ((error = sti_fetchfonts(sc, dd->dd_fntaddr))) {
+ if ((error = sti_fetchfonts(sc, &cfg, dd->dd_fntaddr))) {
printf("%s: cannot fetch fonts (%d)\n",
sc->sc_dev.dv_xname, error);
return;
@@ -370,11 +371,19 @@ sti_attach_deferred(void *v)
}
int
-sti_fetchfonts(struct sti_softc *sc, u_int32_t addr)
+sti_fetchfonts(struct sti_softc *sc, struct sti_inqconfout *cfg, u_int32_t addr)
{
struct sti_font *fp = &sc->sc_curfont;
- int size;
+ int uc, size;
+ struct {
+ struct sti_unpmvflags flags;
+ struct sti_unpmvin in;
+ struct sti_unpmvout out;
+ } a;
+ /*
+ * Get the first PROM font in memory
+ */
do {
if (sc->sc_devtype == STI_DEVTYPE1) {
fp->first = parseshort(addr + 0x00);
@@ -414,6 +423,40 @@ sti_fetchfonts(struct sti_softc *sc, u_int32_t addr)
addr = NULL; /* fp->next */
} while (addr);
+ /*
+ * If there is enough room in the off-screen framebuffer memory,
+ * display all the characters there in order to display them
+ * faster with blkmv operations rather than unpmv later on.
+ */
+ if (size <= cfg->fbheight *
+ (cfg->fbwidth - cfg->width - cfg->owidth)) {
+ bzero(&a, sizeof(a));
+ a.flags.flags = STI_UNPMVF_WAIT;
+ a.in.fg_colour = STI_COLOUR_WHITE;
+ a.in.bg_colour = STI_COLOUR_BLACK;
+ a.in.font_addr = sc->sc_romfont;
+
+ sc->sc_fontmaxcol = cfg->fbheight / fp->height;
+ sc->sc_fontbase = cfg->width + cfg->owidth;
+ for (uc = fp->first; uc <= fp->last; uc++) {
+ a.in.x = ((uc - fp->first) / sc->sc_fontmaxcol) *
+ fp->width + sc->sc_fontbase;
+ a.in.y = ((uc - fp->first) % sc->sc_fontmaxcol) *
+ fp->height;
+ a.in.index = uc;
+
+ (*sc->unpmv)(&a.flags, &a.in, &a.out, &sc->sc_cfg);
+ if (a.out.errno) {
+ printf("%s: unpmv %d returned %d\n",
+ sc->sc_dev.dv_xname, uc, a.out.errno);
+ return (0);
+ }
+ }
+
+ free(sc->sc_romfont, M_DEVBUF);
+ sc->sc_romfont = NULL;
+ }
+
return (0);
}
@@ -638,7 +681,6 @@ sti_mapchar(v, uni, index)
return 1;
}
-/* TODO reimplement w/ blkmv and font in the fb mem per doc suggest */
void
sti_putchar(v, row, col, uc, attr)
void *v;
@@ -648,24 +690,57 @@ sti_putchar(v, row, col, uc, attr)
{
struct sti_softc *sc = v;
struct sti_font *fp = &sc->sc_curfont;
- struct {
- struct sti_unpmvflags flags;
- struct sti_unpmvin in;
- struct sti_unpmvout out;
- } a;
- bzero(&a, sizeof(a));
+ if (sc->sc_romfont != NULL) {
+ /*
+ * Font is in memory, use unpmv
+ */
+ struct {
+ struct sti_unpmvflags flags;
+ struct sti_unpmvin in;
+ struct sti_unpmvout out;
+ } a;
- a.flags.flags = STI_UNPMVF_WAIT;
- /* XXX does not handle text attributes */
- a.in.fg_colour = STI_COLOUR_WHITE;
- a.in.bg_colour = STI_COLOUR_BLACK;
- a.in.x = col * fp->width;
- a.in.y = row * fp->height;
- a.in.font_addr = sc->sc_romfont;
- a.in.index = uc;
+ bzero(&a, sizeof(a));
- (*sc->unpmv)(&a.flags, &a.in, &a.out, &sc->sc_cfg);
+ a.flags.flags = STI_UNPMVF_WAIT;
+ /* XXX does not handle text attributes */
+ a.in.fg_colour = STI_COLOUR_WHITE;
+ a.in.bg_colour = STI_COLOUR_BLACK;
+ a.in.x = col * fp->width;
+ a.in.y = row * fp->height;
+ a.in.font_addr = sc->sc_romfont;
+ a.in.index = uc;
+
+ (*sc->unpmv)(&a.flags, &a.in, &a.out, &sc->sc_cfg);
+ } else {
+ /*
+ * Font is in frame buffer, use blkmv
+ */
+ struct {
+ struct sti_blkmvflags flags;
+ struct sti_blkmvin in;
+ struct sti_blkmvout out;
+ } a;
+
+ bzero(&a, sizeof(a));
+
+ a.flags.flags = STI_BLKMVF_WAIT;
+ /* XXX does not handle text attributes */
+ a.in.fg_colour = STI_COLOUR_WHITE;
+ a.in.bg_colour = STI_COLOUR_BLACK;
+
+ a.in.srcx = ((uc - fp->first) / sc->sc_fontmaxcol) *
+ fp->width + sc->sc_fontbase;
+ a.in.srcy = ((uc - fp->first) % sc->sc_fontmaxcol) *
+ fp->height;
+ a.in.dstx = col * fp->width;
+ a.in.dsty = row * fp->height;
+ a.in.height = fp->height;
+ a.in.width = fp->width;
+
+ (*sc->blkmv)(&a.flags, &a.in, &a.out, &sc->sc_cfg);
+ }
}
void
@@ -705,8 +780,9 @@ sti_copyrows(v, srcrow, dstrow, nrows)
struct sti_softc *sc = v;
struct sti_font *fp = &sc->sc_curfont;
- sti_bmove(sc, 0, srcrow * fp->height, 0, dstrow * fp->height,
- nrows * fp->height, sc->sc_cfg.fb_width, bmf_copy);
+ sti_bmove(sc, sc->sc_cfg.oscr_width, srcrow * fp->height,
+ sc->sc_cfg.oscr_width, dstrow * fp->height,
+ nrows * fp->height, sc->sc_cfg.scr_width, bmf_copy);
}
void
@@ -718,8 +794,9 @@ sti_eraserows(v, srcrow, nrows, attr)
struct sti_softc *sc = v;
struct sti_font *fp = &sc->sc_curfont;
- sti_bmove(sc, 0, srcrow * fp->height, 0, srcrow * fp->height,
- nrows * fp->height, sc->sc_cfg.fb_width, bmf_clear);
+ sti_bmove(sc, sc->sc_cfg.oscr_width, srcrow * fp->height,
+ sc->sc_cfg.oscr_width, srcrow * fp->height,
+ nrows * fp->height, sc->sc_cfg.scr_width, bmf_clear);
}
int
diff --git a/sys/dev/ic/stivar.h b/sys/dev/ic/stivar.h
index 8c673411224..c7ab2017090 100644
--- a/sys/dev/ic/stivar.h
+++ b/sys/dev/ic/stivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: stivar.h,v 1.8 2003/02/11 19:11:51 miod Exp $ */
+/* $OpenBSD: stivar.h,v 1.9 2003/02/18 09:39:45 miod Exp $ */
/*
* Copyright (c) 2000-2003 Michael Shalayeff
@@ -52,11 +52,14 @@ struct sti_softc {
struct sti_dd sc_dd; /* in word format */
struct sti_font sc_curfont;
- void *sc_romfont;
struct sti_cfg sc_cfg;
struct sti_ecfg sc_ecfg;
- vaddr_t sc_code;
+ void *sc_romfont; /* ROM font copy, either in memory... */
+ u_int sc_fontmaxcol; /* ...or in off-screen frame buffer */
+ u_int sc_fontbase;
+
+ vaddr_t sc_code;
sti_init_t init;
sti_mgmt_t mgmt;