summaryrefslogtreecommitdiff
path: root/sys/arch/hppa/dev
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>1999-07-13 21:13:56 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>1999-07-13 21:13:56 +0000
commit428055fb92bfe8fa64e33e7d030c0f86f2a5e348 (patch)
treed36f4c36199edf88dfa364b5bff27279862e721e /sys/arch/hppa/dev
parente6835c832e7dac40d6a1bf278eb0ca847a6e51ed (diff)
update
Diffstat (limited to 'sys/arch/hppa/dev')
-rw-r--r--sys/arch/hppa/dev/sti.c43
1 files changed, 33 insertions, 10 deletions
diff --git a/sys/arch/hppa/dev/sti.c b/sys/arch/hppa/dev/sti.c
index 90b04af7230..b90c7fec196 100644
--- a/sys/arch/hppa/dev/sti.c
+++ b/sys/arch/hppa/dev/sti.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sti.c,v 1.1 1998/12/31 03:20:44 mickey Exp $ */
+/* $OpenBSD: sti.c,v 1.2 1999/07/13 21:13:55 mickey Exp $ */
/*
* Copyright (c) 1998 Michael Shalayeff
@@ -30,7 +30,7 @@
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
-#define STIDEBUG
+#undef STIDEBUG
#include <sys/param.h>
#include <sys/systm.h>
@@ -52,6 +52,8 @@
#include <hppa/dev/cpudevs.h>
+#define STI_SIZE 0x1000000
+
struct sti_softc {
struct device sc_dev;
@@ -63,7 +65,7 @@ struct sti_softc {
int sc_attr;
struct sti_config sti_config;
struct sti_fontcfg sti_fontcfg;
- vm_offset_t sc_code; /* code region allocated */
+ vaddr_t sc_code; /* code region allocated */
void (*sti_init) __P((struct sti_initflags *,
struct sti_initin *,
struct sti_initout *,
@@ -122,8 +124,7 @@ struct wscons_emulfuncs sti_emulfuncs = {
sti_set_attr
};
-u_int stiload __P((vm_offset_t dst, vm_offset_t scode,
- vm_offset_t ecode, int t));
+u_int stiload __P((vaddr_t dst, vaddr_t scode, vaddr_t ecode, int t));
int sti_init __P((struct sti_softc *sc, int mode));
int sti_inqcfg __P((struct sti_softc *sc, struct sti_inquireout *out));
void sti_bmove __P((struct sti_softc *sc, int, int, int, int, int, int,
@@ -138,6 +139,7 @@ stiprobe(parent, match, aux)
void *match, *aux;
{
register struct confargs *ca = aux;
+ bus_space_handle_t ioh, rioh;
u_int rom;
u_char devtype;
int rv = 0;
@@ -147,15 +149,25 @@ stiprobe(parent, match, aux)
ca->ca_type.iodc_sv_model != HPPA_FIO_SGC))
return 0;
+ if (bus_space_map(ca->ca_iot, ca->ca_hpa, STI_SIZE, 0, &ioh))
+ return 0;
+
/*
* Locate STI ROM.
* On some machines it may not be part of the HPA space.
*/
- if (!PAGE0->pd_resv2[1])
+ if (!PAGE0->pd_resv2[1]) {
rom = ca->ca_hpa;
- else
+ rioh = ioh;
+ } else
rom = PAGE0->pd_resv2[1];
+ if (rom != ca->ca_hpa &&
+ bus_space_map(ca->ca_iot, rom, IOMOD_HPASIZE, 0, &rioh)) {
+ bus_space_unmap(ca->ca_iot, ioh, STI_SIZE);
+ return 0;
+ }
+
devtype = STI_DEVTYP(STI_TYPE_BWGRF, rom);
if ((ca->ca_type.iodc_sv_model == HPPA_FIO_SGC &&
STI_ID_HI(STI_TYPE_BWGRF, ca->ca_hpa) == STI_ID_FDDI) ||
@@ -166,6 +178,9 @@ stiprobe(parent, match, aux)
} else
rv = 1;
+ bus_space_unmap(ca->ca_iot, ioh, STI_SIZE);
+ if (ioh != rioh)
+ bus_space_unmap(ca->ca_iot, rioh, IOMOD_HPASIZE);
return rv;
}
@@ -265,6 +280,7 @@ stiattach(parent, self, aux)
struct device *parent, *self;
void *aux;
{
+ bus_space_handle_t ioh;
struct wscons_attach_args waa;
struct sti_inquireout cfg;
register struct sti_softc *sc = (void *)self;
@@ -273,6 +289,9 @@ stiattach(parent, self, aux)
register u_int dt, addr;
int error;
+ if (bus_space_map(ca->ca_iot, ca->ca_hpa, STI_SIZE, 0, &ioh))
+ return;
+
sc->sc_regs = ca->ca_hpa;
if (!PAGE0->pd_resv2[1])
sc->sc_rom = ca->ca_hpa;
@@ -293,7 +312,8 @@ stiattach(parent, self, aux)
u_int t;
t = STI_EADDR(dt, sc->sc_rom) - STI_IGADDR(dt, sc->sc_rom);
t = hppa_round_page(t);
- if (!(sc->sc_code = kmem_malloc(kmem_map, t, 0))) {
+ if (!(sc->sc_code = uvm_km_kmemalloc(kmem_map,
+ uvmexp.kmem_object, t, 0))) {
printf(": cannot allocate %d bytes for code\n", t);
return;
} else
@@ -332,6 +352,9 @@ stiattach(parent, self, aux)
register u_int *p;
register u_int *q = (u_int *)STI_MMAP(dt, sc->sc_rom);
+#ifdef STIDEBUG
+ printf ("stregions @%p:\n", q);
+#endif
for (p = sc->sti_config.regions;
p < &sc->sti_config.regions[STI_REGIONS]; p++) {
struct sti_region r;
@@ -417,10 +440,10 @@ stiattach(parent, self, aux)
u_int
stiload(dst, scode, ecode, t)
- vm_offset_t dst, scode, ecode;
+ vaddr_t dst, scode, ecode;
int t;
{
- vm_offset_t sdst = dst;
+ vaddr_t sdst = dst;
#ifdef STIDEBUG
printf("stiload(%x, %x, %x, %d)\n", dst, scode, ecode, t);