diff options
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/sparc/dev/agten.c | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/sys/arch/sparc/dev/agten.c b/sys/arch/sparc/dev/agten.c index e28c6a1ff50..6ea6903f59a 100644 --- a/sys/arch/sparc/dev/agten.c +++ b/sys/arch/sparc/dev/agten.c @@ -1,4 +1,4 @@ -/* $OpenBSD: agten.c,v 1.3 2003/06/06 19:42:47 miod Exp $ */ +/* $OpenBSD: agten.c,v 1.4 2003/06/24 21:55:05 miod Exp $ */ /* * Copyright (c) 2002, 2003, Miodrag Vallat. * All rights reserved. @@ -78,6 +78,7 @@ #include <dev/rasops/rasops.h> #include <machine/fbvar.h> +#include <dev/ic/p9000.h> #include <dev/ic/ibm561reg.h> #include <sparc/dev/sbusvar.h> @@ -96,7 +97,7 @@ struct agten_softc { struct rom_reg sc_phys; /* physical address and */ off_t sc_physoffset; /* offset for frame buffer */ - volatile u_int32_t *sc_dac; + volatile u_int8_t *sc_p9100; struct agten_cmap sc_cmap; /* shadow color map */ volatile u_int32_t *sc_i128_fb; @@ -191,9 +192,9 @@ agtenattach(struct device *parent, struct device *self, void *args) (off_t)getpropint(node, "i128_fb_physaddr", 0x8000000); sc->sc_i128_fb = mapiodev(ca->ca_ra.ra_reg, sc->sc_physoffset, getpropint(node, "i128_fb_size", 0x400000)); - sc->sc_dac = mapiodev(ca->ca_ra.ra_reg, - getpropint(node, "p9100_reg_physaddr", 0x10a0000) + 0x200, - 0x800 - 0x200); + sc->sc_p9100 = mapiodev(ca->ca_ra.ra_reg, + getpropint(node, "p9100_reg_physaddr", 0x10a0000), + 0x4000); /* * For some reason the agten does not use the canonical name for @@ -437,7 +438,8 @@ ibm561_write(struct agten_softc *sc, u_int32_t reg, u_int32_t value) * For some design reason the IBM561 PaletteDac needs to be fed * values shifted left by 16 bits. What happened to simplicity? */ - sc->sc_dac[reg] = (value) << 16; + *(volatile u_int32_t *)(sc->sc_p9100 + P9100_RAMDAC_REGISTER(reg)) = + (value) << 16; } void |