diff options
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/sgi/include/bus.h | 5 | ||||
-rw-r--r-- | sys/arch/sgi/sgi/bus_dma.c | 51 |
2 files changed, 15 insertions, 41 deletions
diff --git a/sys/arch/sgi/include/bus.h b/sys/arch/sgi/include/bus.h index b5a3ba91fbd..de61e1fad1a 100644 --- a/sys/arch/sgi/include/bus.h +++ b/sys/arch/sgi/include/bus.h @@ -1,4 +1,4 @@ -/* $OpenBSD: bus.h,v 1.13 2009/04/20 00:42:06 oga Exp $ */ +/* $OpenBSD: bus.h,v 1.14 2009/05/24 17:31:05 miod Exp $ */ /* * Copyright (c) 2003-2004 Opsycon AB Sweden. All rights reserved. @@ -341,8 +341,9 @@ typedef struct machine_bus_dmamap *bus_dmamap_t; */ struct machine_bus_dma_segment { bus_addr_t ds_addr; /* DMA address */ - bus_addr_t ds_vaddr; /* CPU address */ bus_size_t ds_len; /* length of transfer */ + + bus_addr_t _ds_vaddr; /* CPU address */ }; typedef struct machine_bus_dma_segment bus_dma_segment_t; diff --git a/sys/arch/sgi/sgi/bus_dma.c b/sys/arch/sgi/sgi/bus_dma.c index 0170d4a7a5f..a3969275f41 100644 --- a/sys/arch/sgi/sgi/bus_dma.c +++ b/sys/arch/sgi/sgi/bus_dma.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bus_dma.c,v 1.12 2009/05/08 20:55:20 miod Exp $ */ +/* $OpenBSD: bus_dma.c,v 1.13 2009/05/24 17:31:07 miod Exp $ */ /* * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -172,7 +172,7 @@ _dmamap_load(t, map, buf, buflen, p, flags) map->dm_segs[seg].ds_addr = (*t->_pa_to_device)(curaddr); map->dm_segs[seg].ds_len = sgsize; - map->dm_segs[seg].ds_vaddr = (vaddr_t)vaddr; + map->dm_segs[seg]._ds_vaddr = (vaddr_t)vaddr; first = 0; } else { if (curaddr == lastaddr && @@ -188,7 +188,7 @@ _dmamap_load(t, map, buf, buflen, p, flags) map->dm_segs[seg].ds_addr = (*t->_pa_to_device)(curaddr); map->dm_segs[seg].ds_len = sgsize; - map->dm_segs[seg].ds_vaddr = (vaddr_t)vaddr; + map->dm_segs[seg]._ds_vaddr = (vaddr_t)vaddr; } } @@ -249,7 +249,7 @@ _dmamap_load_mbuf(t, map, m, flags) } map->dm_segs[i].ds_addr = (*t->_pa_to_device)(pa); - map->dm_segs[i].ds_vaddr = vaddr; + map->dm_segs[i]._ds_vaddr = vaddr; map->dm_segs[i].ds_len = incr; i++; vaddr += incr; @@ -371,7 +371,7 @@ _dmamap_sync(t, map, addr, size, op) bus_size_t ssize; ssize = map->dm_segs[curseg].ds_len; - vaddr = map->dm_segs[curseg].ds_vaddr; + vaddr = map->dm_segs[curseg]._ds_vaddr; if (addr != 0) { if (addr >= ssize) { @@ -440,36 +440,8 @@ _dmamem_alloc(t, size, alignment, boundary, segs, nsegs, rsegs, flags) int *rsegs; int flags; { - vaddr_t low; - vaddr_t high; - - /* - * Limit bus_dma'able memory to the first 2GB of physical memory. - * XXX This should be lifted if flags & BUS_DMA_64BIT for - * XXX drivers which do not need 32 bit DMA on IP27/30/35. - */ - switch (sys_config.system_type) { -#if defined(TGT_OCTANE) - case SGI_OCTANE: - low = IP30_MEMORY_BASE; - high = (2U << 30) - 1 + IP30_MEMORY_BASE; - break; -#endif -#if defined(TGT_ORIGIN200) || defined(TGT_ORIGIN2000) - case SGI_O200: - case SGI_O300: - low = 0; - high = (2U << 30) - 1; - break; -#endif - default: - low = 0; - high = (vaddr_t)-1; - break; - } - return _dmamem_alloc_range(t, size, alignment, boundary, - segs, nsegs, rsegs, flags, low, high); + segs, nsegs, rsegs, flags, (vaddr_t)0, (vaddr_t)-1); } /* @@ -521,13 +493,16 @@ _dmamem_map(t, segs, nsegs, size, kvap, flags) bus_addr_t addr; int curseg; +#ifdef TGT_COHERENT + if (ISSET(flags, BUS_DMA_COHERENT)) + CLR(flags, BUS_DMA_COHERENT); +#endif + if (nsegs == 1) { pa = (*t->_device_to_pa)(segs[0].ds_addr); -#ifndef TGT_COHERENT if (flags & BUS_DMA_COHERENT) *kvap = (caddr_t)PHYS_TO_UNCACHED(pa); else -#endif *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_CACHED); return (0); } @@ -549,10 +524,8 @@ _dmamem_map(t, segs, nsegs, size, kvap, flags) pmap_enter(pmap_kernel(), va, pa, VM_PROT_READ | VM_PROT_WRITE, VM_PROT_READ | VM_PROT_WRITE | PMAP_WIRED); - segs[curseg].ds_vaddr = va; - if (flags & BUS_DMA_COHERENT && - sys_config.system_type == SGI_O2) + if (flags & BUS_DMA_COHERENT) pmap_page_cache(PHYS_TO_VM_PAGE(pa), PV_UNCACHED); } |