summaryrefslogtreecommitdiff
path: root/sys/dev/ic
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2005-01-23 16:53:22 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2005-01-23 16:53:22 +0000
commitc9029b1288d19d03daaa0122f369a66ca5a3ea50 (patch)
tree537e9b4c278534644bfccda71dbacec1c905f845 /sys/dev/ic
parente1b475c44e3ea78de9c4936b6ca33526af430278 (diff)
Two sti(4) changes necessary for hp300:
- specify which microcode bank (pa or m68k) to use at attachment time. - compensate for broken 8.02 m68k code which reports wrong frame buffer offset. ok mickey@
Diffstat (limited to 'sys/dev/ic')
-rw-r--r--sys/dev/ic/sti.c68
-rw-r--r--sys/dev/ic/stireg.h9
-rw-r--r--sys/dev/ic/stivar.h4
3 files changed, 54 insertions, 27 deletions
diff --git a/sys/dev/ic/sti.c b/sys/dev/ic/sti.c
index c31b0544e56..f46ba58b8a2 100644
--- a/sys/dev/ic/sti.c
+++ b/sys/dev/ic/sti.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sti.c,v 1.38 2005/01/05 23:04:25 miod Exp $ */
+/* $OpenBSD: sti.c,v 1.39 2005/01/23 16:53:21 miod Exp $ */
/*
* Copyright (c) 2000-2003 Michael Shalayeff
@@ -121,8 +121,9 @@ int sti_fetchfonts(struct sti_softc *sc, struct sti_inqconfout *cfg,
void sti_attach_deferred(void *);
void
-sti_attach_common(sc)
+sti_attach_common(sc, codebase)
struct sti_softc *sc;
+ u_int codebase;
{
struct sti_inqconfout cfg;
struct sti_einqconfout ecfg;
@@ -130,6 +131,7 @@ sti_attach_common(sc)
struct sti_dd *dd;
struct sti_cfg *cc;
int error, size, i;
+ int geometry_kluge = 0;
sc->sc_devtype = bus_space_read_1(sc->memt, sc->romh, 3);
@@ -170,25 +172,30 @@ sti_attach_common(sc)
dd->dd_eddst[2]= bus_space_read_1(sc->memt, sc->romh, 0xdf);
dd->dd_cfbaddr = parseword(0xe0) & ~3;
- dd->dd_pacode[0x0] = parseword(0x100) & ~3;
- dd->dd_pacode[0x1] = parseword(0x110) & ~3;
- dd->dd_pacode[0x2] = parseword(0x120) & ~3;
- dd->dd_pacode[0x3] = parseword(0x130) & ~3;
- dd->dd_pacode[0x4] = parseword(0x140) & ~3;
- dd->dd_pacode[0x5] = parseword(0x150) & ~3;
- dd->dd_pacode[0x6] = parseword(0x160) & ~3;
- dd->dd_pacode[0x7] = parseword(0x170) & ~3;
- dd->dd_pacode[0x8] = parseword(0x180) & ~3;
- dd->dd_pacode[0x9] = parseword(0x190) & ~3;
- dd->dd_pacode[0xa] = parseword(0x1a0) & ~3;
- dd->dd_pacode[0xb] = parseword(0x1b0) & ~3;
- dd->dd_pacode[0xc] = parseword(0x1c0) & ~3;
- dd->dd_pacode[0xd] = parseword(0x1d0) & ~3;
- dd->dd_pacode[0xe] = parseword(0x1e0) & ~3;
- dd->dd_pacode[0xf] = parseword(0x1f0) & ~3;
- } else /* STI_DEVTYPE4 */
+ codebase <<= 2;
+ dd->dd_pacode[0x0] = parseword(codebase + 0x000) & ~3;
+ dd->dd_pacode[0x1] = parseword(codebase + 0x010) & ~3;
+ dd->dd_pacode[0x2] = parseword(codebase + 0x020) & ~3;
+ dd->dd_pacode[0x3] = parseword(codebase + 0x030) & ~3;
+ dd->dd_pacode[0x4] = parseword(codebase + 0x040) & ~3;
+ dd->dd_pacode[0x5] = parseword(codebase + 0x050) & ~3;
+ dd->dd_pacode[0x6] = parseword(codebase + 0x060) & ~3;
+ dd->dd_pacode[0x7] = parseword(codebase + 0x070) & ~3;
+ dd->dd_pacode[0x8] = parseword(codebase + 0x080) & ~3;
+ dd->dd_pacode[0x9] = parseword(codebase + 0x090) & ~3;
+ dd->dd_pacode[0xa] = parseword(codebase + 0x0a0) & ~3;
+ dd->dd_pacode[0xb] = parseword(codebase + 0x0b0) & ~3;
+ dd->dd_pacode[0xc] = parseword(codebase + 0x0c0) & ~3;
+ dd->dd_pacode[0xd] = parseword(codebase + 0x0d0) & ~3;
+ dd->dd_pacode[0xe] = parseword(codebase + 0x0e0) & ~3;
+ dd->dd_pacode[0xf] = parseword(codebase + 0x0f0) & ~3;
+ } else { /* STI_DEVTYPE4 */
bus_space_read_region_4(sc->memt, sc->romh, 0, (u_int32_t *)dd,
sizeof(*dd) / 4);
+ /* fix pacode... */
+ bus_space_read_region_4(sc->memt, sc->romh, codebase,
+ (u_int32_t *)dd->dd_pacode, sizeof(dd->dd_pacode) / 4);
+ }
#ifdef STIDEBUG
printf("dd:\n"
@@ -330,6 +337,22 @@ sti_attach_common(sc)
return;
}
+ /*
+ * Older (rev 8.02) boards report wrong offset values,
+ * similar to the displayable area size, at least in m68k mode.
+ * Attempt to detect this and adjust here.
+ */
+ if (cfg.owidth == cfg.width &&
+ cfg.oheight == cfg.height)
+ geometry_kluge = 1;
+
+ if (geometry_kluge) {
+ sc->sc_cfg.oscr_width = cfg.owidth =
+ cfg.fbwidth - cfg.width;
+ sc->sc_cfg.oscr_height = cfg.oheight =
+ cfg.fbheight - cfg.height;
+ }
+
if ((error = sti_init(sc, STI_TEXTMODE))) {
printf(": can not initialize (%d)\n", error);
return;
@@ -897,8 +920,7 @@ sti_copyrows(v, srcrow, dstrow, nrows)
struct sti_softc *sc = v;
struct sti_font *fp = &sc->sc_curfont;
- sti_bmove(sc, sc->sc_cfg.oscr_width, srcrow * fp->height,
- sc->sc_cfg.oscr_width, dstrow * fp->height,
+ sti_bmove(sc, 0, srcrow * fp->height, 0, dstrow * fp->height,
nrows * fp->height, sc->sc_cfg.scr_width, bmf_copy);
}
@@ -911,8 +933,7 @@ sti_eraserows(v, srcrow, nrows, attr)
struct sti_softc *sc = v;
struct sti_font *fp = &sc->sc_curfont;
- sti_bmove(sc, sc->sc_cfg.oscr_width, srcrow * fp->height,
- sc->sc_cfg.oscr_width, srcrow * fp->height,
+ sti_bmove(sc, 0, srcrow * fp->height, 0, srcrow * fp->height,
nrows * fp->height, sc->sc_cfg.scr_width, bmf_clear);
}
@@ -928,4 +949,3 @@ sti_alloc_attr(v, fg, bg, flags, pattr)
return 0;
}
-
diff --git a/sys/dev/ic/stireg.h b/sys/dev/ic/stireg.h
index f1b14289950..efe9979b2d3 100644
--- a/sys/dev/ic/stireg.h
+++ b/sys/dev/ic/stireg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: stireg.h,v 1.8 2003/08/19 02:52:38 mickey Exp $ */
+/* $OpenBSD: stireg.h,v 1.9 2005/01/23 16:53:21 miod Exp $ */
/*
* Copyright (c) 2000 Michael Shalayeff
@@ -54,6 +54,13 @@
#define STI_END 13
#define STI_CODECNT 16
+#define STI_CODEBASE_MAIN 0x40
+#define STI_CODEBASE_ALT 0x80
+
+#define STI_CODEBASE_PA STI_CODEBASE_MAIN
+#define STI_CODEBASE_M68K STI_CODEBASE_ALT
+#define STI_CODEBASE_PA64 STI_CODEBASE_ALT
+
/* sti returns */
#define STI_OK 0
#define STI_FAIL -1
diff --git a/sys/dev/ic/stivar.h b/sys/dev/ic/stivar.h
index dff06edbc5a..ddf9ec2223b 100644
--- a/sys/dev/ic/stivar.h
+++ b/sys/dev/ic/stivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: stivar.h,v 1.15 2003/12/16 06:07:13 mickey Exp $ */
+/* $OpenBSD: stivar.h,v 1.16 2005/01/23 16:53:21 miod Exp $ */
/*
* Copyright (c) 2000-2003 Michael Shalayeff
@@ -74,7 +74,7 @@ struct sti_softc {
sti_util_t util;
};
-void sti_attach_common(struct sti_softc *sc);
+void sti_attach_common(struct sti_softc *sc, u_int codebase);
int sti_intr(void *v);
#endif /* _IC_STIVAR_H_ */