summaryrefslogtreecommitdiff
path: root/sys/arch/mvme68k
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/mvme68k')
-rw-r--r--sys/arch/mvme68k/mvme68k/autoconf.c76
1 files changed, 30 insertions, 46 deletions
diff --git a/sys/arch/mvme68k/mvme68k/autoconf.c b/sys/arch/mvme68k/mvme68k/autoconf.c
index 8fcfcbd093b..1c9b954cf1c 100644
--- a/sys/arch/mvme68k/mvme68k/autoconf.c
+++ b/sys/arch/mvme68k/mvme68k/autoconf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: autoconf.c,v 1.15 2001/12/10 00:58:04 miod Exp $ */
+/* $OpenBSD: autoconf.c,v 1.16 2002/01/16 23:19:31 miod Exp $ */
/*
* Copyright (c) 1995 Theo de Raadt
@@ -79,15 +79,10 @@
* and the drivers are initialized.
*/
-#undef TRY_EXTENT
-
#include <sys/param.h>
#include <sys/systm.h>
-#ifdef TRY_EXTENT
#include <sys/extent.h>
-#else
-#include <sys/map.h>
-#endif
+#include <sys/malloc.h>
#include <sys/buf.h>
#include <sys/dkstat.h>
#include <sys/conf.h>
@@ -104,13 +99,13 @@
struct device *parsedisk __P((char *, int, int, dev_t *));
void setroot __P((void));
-/* XXX must be allocated statically because of early console init */
-#ifdef TRY_EXTENT
-static char iomap_space[EXTENT_FIXED_STORAGE_SIZE(EIOMAPSIZE / 16)];
-struct extent *iomap_extent;
-#else
-struct map extiomap[EIOMAPSIZE/16];
-#endif
+/*
+ * XXX some storage space must be allocated statically because of
+ * early console init
+ */
+char extiospace[EXTENT_FIXED_STORAGE_SIZE(EIOMAPSIZE / 16)];
+
+struct extent *extio;
extern void *extiobase;
void mainbus_attach __P((struct device *, struct device *, void *));
@@ -191,16 +186,9 @@ cpu_configure()
init_sir();
-#ifdef TRY_EXTENT
- iomap_extent = extent_create("iomap", &iomap_space,
- iomap_space + EXTENT_FIXED_STORAGE_SIZE(EIOMAPSIZE / 16),
- M_DEVBUF, &iomap_space, EXTENT_FIXED_STORAGE_SIZE(EIOMAPSIZE / 16),
- EX_NOWAIT);
- if (iomap_extent == NULL)
- panic("cpu_configure: extent_create failed");
-#else
- rminit(extiomap, (long)EIOMAPSIZE, (long)1, "extio", EIOMAPSIZE/16);
-#endif
+ extio = extent_create("extio",
+ (u_long)extiobase, (u_long)extiobase + ctob(EIOMAPSIZE),
+ M_DEVBUF, extiospace, sizeof(extiospace), EX_NOWAIT);
if (config_rootfound("mainbus", NULL) == NULL)
panic("autoconfig failed, no root");
@@ -219,32 +207,25 @@ mapiodev(pa, size)
void *pa;
int size;
{
- int ix, npf, offset;
- void *kva;
-#ifdef TRY_EXTENT
int error;
-#endif
+ void *kva;
- size = roundup(size, NBPG);
- offset = (int)pa & PGOFSET;
- pa = (void *)((int)pa & ~PGOFSET);
+ if (size == 0)
+ return NULL;
#ifdef DEBUG
if (((int)pa & PGOFSET) || (size & PGOFSET))
- panic("mapiodev: unaligned");
-#endif
- npf = btoc(size);
-#ifdef TRY_EXTENT
- error = extent_alloc(iomap_extent, npf, EX_NOALIGN, 0, EX_NOBOUNDARY,
- EX_NOWAIT, &ix);
-#else
- ix = rmalloc(extiomap, npf);
+ panic("mapiodev: unaligned");
#endif
- if (ix == 0)
- return (0);
- kva = extiobase + ctob(ix-1);
+
+ error = extent_alloc(extio, size, EX_NOALIGN, 0, EX_NOBOUNDARY,
+ EX_NOWAIT | EX_MALLOCOK, (u_long *)&kva);
+
+ if (error != 0)
+ return NULL;
+
physaccess(kva, pa, size, PG_RW|PG_CI);
- return (kva + offset);
+ return (kva);
}
void
@@ -252,7 +233,7 @@ unmapiodev(kva, size)
void *kva;
int size;
{
- int ix;
+ int error;
#ifdef DEBUG
if (((int)kva & PGOFSET) || (size & PGOFSET))
@@ -261,8 +242,11 @@ unmapiodev(kva, size)
panic("unmapiodev: bad address");
#endif
physunaccess(kva, size);
- ix = btoc(kva - extiobase) + 1;
- rmfree(extiomap, btoc(size), ix);
+
+ error = extent_free(extio, (u_long)kva, size, EX_NOWAIT);
+
+ if (error != 0)
+ printf("unmapiodev: extent_free failed\n");
}
/*