summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/sbus/cgsix.c30
1 files changed, 21 insertions, 9 deletions
diff --git a/sys/dev/sbus/cgsix.c b/sys/dev/sbus/cgsix.c
index 20f54ae0766..01ce615c433 100644
--- a/sys/dev/sbus/cgsix.c
+++ b/sys/dev/sbus/cgsix.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cgsix.c,v 1.27 2002/08/02 16:13:07 millert Exp $ */
+/* $OpenBSD: cgsix.c,v 1.28 2002/08/05 22:12:32 miod Exp $ */
/*
* Copyright (c) 2001 Jason L. Wright (jason@thought.net)
@@ -87,7 +87,7 @@ void cgsix_loadcmap_immediate(struct cgsix_softc *, u_int, u_int);
void cgsix_loadcmap_deferred(struct cgsix_softc *, u_int, u_int);
void cgsix_setcolor(struct cgsix_softc *, u_int,
u_int8_t, u_int8_t, u_int8_t);
-void cgsix_reset(struct cgsix_softc *);
+void cgsix_reset(struct cgsix_softc *, u_int32_t);
void cgsix_hardreset(struct cgsix_softc *);
void cgsix_burner(void *, u_int, u_int);
int cgsix_intr(void *);
@@ -143,6 +143,7 @@ cgsixattach(parent, self, aux)
struct wsemuldisplaydev_attach_args waa;
int console, i;
long defattr;
+ u_int32_t fhc, rev;
sc->sc_bustag = sa->sa_bustag;
sc->sc_paddr = sbus_bus_addr(sa->sa_bustag, sa->sa_slot, sa->sa_offset);
@@ -209,7 +210,9 @@ cgsixattach(parent, self, aux)
console = cgsix_is_console(sa->sa_node);
- cgsix_reset(sc);
+ fhc = FHC_READ(sc);
+ rev = (fhc & FHC_REV_MASK) >> FHC_REV_SHIFT;
+ cgsix_reset(sc, rev);
/* grab the current palette */
BT_WRITE(sc, BT_ADDR, 0);
@@ -241,6 +244,15 @@ cgsixattach(parent, self, aux)
a2int(getpropstring(optionsnode, "screen-#rows"), 34),
a2int(getpropstring(optionsnode, "screen-#columns"), 80));
+ /*
+ * Old rev. cg6 cards do not like the current acceleration code.
+ *
+ * Some hints from Sun point out at timing and cache problems, which
+ * will be investigated later.
+ */
+ if (rev < 5)
+ sc->sc_dev.dv_cfdata->cf_flags &= ~CG6_CFFLAG_NOACCEL;
+
if ((sc->sc_dev.dv_cfdata->cf_flags & CG6_CFFLAG_NOACCEL) == 0) {
sc->sc_rasops.ri_hw = sc;
sc->sc_rasops.ri_ops.copyrows = cgsix_ras_copyrows;
@@ -596,10 +608,11 @@ cgsix_setcolor(sc, index, r, g, b)
}
void
-cgsix_reset(sc)
+cgsix_reset(sc, fhcrev)
struct cgsix_softc *sc;
+ u_int32_t fhcrev;
{
- u_int32_t fhc, rev;
+ u_int32_t fhc;
/* hide the cursor, just in case */
THC_WRITE(sc, CG6_THC_CURSXY, THC_CURSOFF);
@@ -608,18 +621,17 @@ cgsix_reset(sc)
TEC_WRITE(sc, CG6_TEC_CLIP, 0);
TEC_WRITE(sc, CG6_TEC_VDC, 0);
- fhc = FHC_READ(sc);
- rev = (fhc & FHC_REV_MASK) >> FHC_REV_SHIFT;
/* take core of hardware bugs in old revisions */
- if (rev < 5) {
+ if (fhcrev < 5) {
/*
* Keep current resolution; set cpu to 68020, set test
* window (size 1Kx1K), and for rev 1, disable dest cache.
*/
+ fhc = FHC_READ(sc);
fhc &= FHC_RES_MASK;
fhc |= FHC_CPU_68020 | FHC_TEST |
(11 << FHC_TESTX_SHIFT) | (11 << FHC_TESTY_SHIFT);
- if (rev < 2)
+ if (fhcrev < 2)
fhc |= FHC_DST_DISABLE;
FHC_WRITE(sc, fhc);
}