summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2011-04-23 19:35:58 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2011-04-23 19:35:58 +0000
commita7bf1fa5939c5e24cd20a849c6d30a5cad41a6dc (patch)
treeff95599928230f20b94bab22ee9f6aecb485cd3e /sys/arch
parente7b9cd9e3e621b9fe002d9dbcfd0d9db961cab34 (diff)
Partially revert 1.23, by removing the code which tries to pick the best
possible DMA window. This breaks systems which have physical memory contiguous to the selected DMA window. A fix is in the works, in the meantime the spice^WDMA should flow.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sgi/sgi/sginode.c68
1 files changed, 6 insertions, 62 deletions
diff --git a/sys/arch/sgi/sgi/sginode.c b/sys/arch/sgi/sgi/sginode.c
index 093bbf91a7b..73c7a6ad5c7 100644
--- a/sys/arch/sgi/sgi/sginode.c
+++ b/sys/arch/sgi/sgi/sginode.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sginode.c,v 1.25 2011/04/21 18:16:57 miod Exp $ */
+/* $OpenBSD: sginode.c,v 1.26 2011/04/23 19:35:57 miod Exp $ */
/*
* Copyright (c) 2008, 2009, 2011 Miodrag Vallat.
*
@@ -43,7 +43,7 @@
#include <sys/systm.h>
#include <sys/proc.h>
-#include <uvm/uvm.h>
+#include <uvm/uvm_extern.h>
#include <machine/cpu.h>
#include <machine/memconf.h>
@@ -64,8 +64,6 @@
void kl_add_memory_ip27(int16_t, int16_t *, unsigned int);
void kl_add_memory_ip35(int16_t, int16_t *, unsigned int);
-void kl_dma_select(paddr_t, psize_t);
-
int kl_first_pass_board(lboard_t *, void *);
int kl_first_pass_comp(klinfo_t *, void *);
@@ -476,29 +474,9 @@ kl_get_console()
}
/*
- * Pick the given window as the DMAable memory window, if it contains more
- * memory than our former choice. Expects the base address to be aligned on
- * a 2GB boundary.
- */
-void
-kl_dma_select(paddr_t base, psize_t size)
-{
- static psize_t maxsize = 0;
-
- if (size > maxsize) {
- maxsize = size;
- dma_constraint.ucr_low = base;
- dma_constraint.ucr_high = base + ((1UL << 31) - 1);
- }
-}
-
-/*
* Process memory bank information.
* There are two different routines, because IP27 and IP35 do not
* layout memory the same way.
- *
- * This is the opportunity to pick the largest populated 2GB window on a
- * 2GB boundary, as our DMA window.
*/
/*
@@ -513,25 +491,11 @@ kl_add_memory_ip27(int16_t nasid, int16_t *sizes, unsigned int cnt)
paddr_t basepa;
uint64_t fp, lp, np;
unsigned int seg, nmeg;
- paddr_t twogseg;
- psize_t twogcnt;
basepa = (paddr_t)nasid << kl_n_shift;
-
- /* note we know kl_n_shift > 31, so 2GB windows can not span nodes */
- twogseg = basepa >> 31;
- twogcnt = 0;
-
while (cnt-- != 0) {
nmeg = *sizes++;
for (seg = 0; seg < 4; basepa += (1 << 27), seg++) {
- /* did we cross a 2GB boundary? */
- if ((basepa >> 31) != twogseg) {
- kl_dma_select(twogseg << 31, twogcnt);
- twogseg = basepa >> 31;
- twogcnt = 0;
- }
-
if (nmeg <= 128)
np = seg == 0 ? nmeg : 0;
else
@@ -558,11 +522,10 @@ kl_add_memory_ip27(int16_t nasid, int16_t *sizes, unsigned int cnt)
physmem += atop(32 << 20);
}
- twogcnt += ptoa(lp - fp);
-
if (memrange_register(fp, lp,
~(atop(1UL << kl_n_shift) - 1),
- VM_FREELIST_DEFAULT) != 0) {
+ lp <= atop(2UL << 30) ?
+ VM_FREELIST_DEFAULT : VM_FREELIST_DMA32) != 0) {
/*
* We could hijack the smallest segment here.
* But is it really worth doing?
@@ -573,8 +536,6 @@ kl_add_memory_ip27(int16_t nasid, int16_t *sizes, unsigned int cnt)
}
}
}
-
- kl_dma_select(twogseg << 31, twogcnt);
}
/*
@@ -586,23 +547,9 @@ kl_add_memory_ip35(int16_t nasid, int16_t *sizes, unsigned int cnt)
{
paddr_t basepa;
uint64_t fp, lp, np;
- paddr_t twogseg;
- psize_t twogcnt;
basepa = (paddr_t)nasid << kl_n_shift;
-
- /* note we know kl_n_shift > 31, so 2GB windows can not span nodes */
- twogseg = basepa >> 31;
- twogcnt = 0;
-
while (cnt-- != 0) {
- /* did we cross a 2GB boundary? */
- if ((basepa >> 31) != twogseg) {
- kl_dma_select(twogseg << 31, twogcnt);
- twogseg = basepa >> 31;
- twogcnt = 0;
- }
-
np = *sizes++;
if (np != 0) {
DB_PRF(("IP35 memory from %p to %p (%u MB)\n",
@@ -624,11 +571,10 @@ kl_add_memory_ip35(int16_t nasid, int16_t *sizes, unsigned int cnt)
physmem += atop(64 << 20);
}
- twogcnt += ptoa(lp - fp);
-
if (memrange_register(fp, lp,
~(atop(1UL << kl_n_shift) - 1),
- VM_FREELIST_DEFAULT) != 0) {
+ lp <= atop(2UL << 30) ?
+ VM_FREELIST_DEFAULT : VM_FREELIST_DMA32) != 0) {
/*
* We could hijack the smallest segment here.
* But is it really worth doing?
@@ -640,8 +586,6 @@ kl_add_memory_ip35(int16_t nasid, int16_t *sizes, unsigned int cnt)
}
basepa += 1UL << 30; /* 1 GB */
}
-
- kl_dma_select(twogseg << 31, twogcnt);
}
/*