From eedcbe070ed694448d085ab2751855e6373dc882 Mon Sep 17 00:00:00 2001 From: Miod Vallat Date: Thu, 15 Mar 2012 18:57:23 +0000 Subject: uncached_base was introduced early in IP27 support, since these designs use subspaces in the CCA_NC uncached memory space. However, being coherent, there was never a need for bus_dma to use uncached addresses. This means that, on the only systems where uncached_base was not set to PHYS_TO_XKPHYS(0, CCA_NC), it was never used. Remove the variable, and replace PHYS_TO_UNCACHED() with PHYS_TO_XKPHYS(, CCA_NC). No functional change. --- sys/arch/loongson/loongson/bus_dma.c | 4 ++-- sys/arch/loongson/loongson/machdep.c | 5 +---- sys/arch/mips64/include/cpu.h | 5 +---- sys/arch/octeon/octeon/bus_dma.c | 4 ++-- sys/arch/octeon/octeon/machdep.c | 5 +---- sys/arch/sgi/dev/gbe.c | 18 +++++++++--------- sys/arch/sgi/sgi/bus_dma.c | 13 ++++++------- sys/arch/sgi/sgi/ip27_machdep.c | 3 +-- sys/arch/sgi/sgi/ip30_machdep.c | 12 +++--------- sys/arch/sgi/sgi/ip32_machdep.c | 4 +--- sys/arch/sgi/sgi/machdep.c | 3 +-- 11 files changed, 28 insertions(+), 48 deletions(-) diff --git a/sys/arch/loongson/loongson/bus_dma.c b/sys/arch/loongson/loongson/bus_dma.c index 6f71881a9e5..912acb0b585 100644 --- a/sys/arch/loongson/loongson/bus_dma.c +++ b/sys/arch/loongson/loongson/bus_dma.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bus_dma.c,v 1.7 2011/06/23 20:44:39 ariane Exp $ */ +/* $OpenBSD: bus_dma.c,v 1.8 2012/03/15 18:57:20 miod Exp $ */ /* * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -440,7 +440,7 @@ _dmamem_map(bus_dma_tag_t t, bus_dma_segment_t *segs, int nsegs, size_t size, if (nsegs == 1) { pa = (*t->_device_to_pa)(segs[0].ds_addr); if (flags & BUS_DMA_COHERENT) - *kvap = (caddr_t)PHYS_TO_UNCACHED(pa); + *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_NC); else *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_CACHED); return (0); diff --git a/sys/arch/loongson/loongson/machdep.c b/sys/arch/loongson/loongson/machdep.c index 8b631db101b..6b822bf40f2 100644 --- a/sys/arch/loongson/loongson/machdep.c +++ b/sys/arch/loongson/loongson/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.33 2011/07/21 20:36:12 miod Exp $ */ +/* $OpenBSD: machdep.c,v 1.34 2012/03/15 18:57:20 miod Exp $ */ /* * Copyright (c) 2009, 2010 Miodrag Vallat. @@ -105,7 +105,6 @@ vm_map_t phys_map; int safepri = 0; caddr_t msgbufbase; -vaddr_t uncached_base; int physmem; /* Max supported memory, changes to actual. */ int ncpu = 1; /* At least one CPU in the system. */ @@ -461,8 +460,6 @@ mips_init(int32_t argc, int32_t argv, int32_t envp, int32_t cv, } else memhi = 0; - uncached_base = PHYS_TO_XKPHYS(0, CCA_NC); - switch (loongson_ver) { case 0x2e: loongson2e_setup(memlo, memhi); diff --git a/sys/arch/mips64/include/cpu.h b/sys/arch/mips64/include/cpu.h index 548434d5e07..26da2d06345 100644 --- a/sys/arch/mips64/include/cpu.h +++ b/sys/arch/mips64/include/cpu.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.h,v 1.72 2011/06/24 19:47:48 naddy Exp $ */ +/* $OpenBSD: cpu.h,v 1.73 2012/03/15 18:57:22 miod Exp $ */ /*- * Copyright (c) 1992, 1993 @@ -100,8 +100,6 @@ #define SP_SPECIAL 2UL /* Memory Special space */ #define SP_NC 3UL /* Memory Uncached space */ -extern vaddr_t uncached_base; - #define XKSSSEG_BASE 0x4000000000000000UL #define XKPHYS_BASE 0x8000000000000000UL #define XKSSEG_BASE 0xc000000000000000UL @@ -110,7 +108,6 @@ extern vaddr_t uncached_base; #define PHYS_TO_XKPHYS(x,c) ((paddr_t)(x) | XKPHYS_BASE | ((c) << 59)) #define PHYS_TO_XKPHYS_UNCACHED(x,s) \ (PHYS_TO_XKPHYS(x, CCA_NC) | ((s) << 57)) -#define PHYS_TO_UNCACHED(x) ((paddr_t)(x) | uncached_base) #define IS_XKPHYS(va) (((va) >> 62) == 2) #define XKPHYS_TO_CCA(x) (((x) >> 59) & 0x07) #define XKPHYS_TO_SP(x) (((x) >> 57) & 0x03) diff --git a/sys/arch/octeon/octeon/bus_dma.c b/sys/arch/octeon/octeon/bus_dma.c index fb1be02b36f..c5b29beaef2 100644 --- a/sys/arch/octeon/octeon/bus_dma.c +++ b/sys/arch/octeon/octeon/bus_dma.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bus_dma.c,v 1.3 2011/06/23 20:44:39 ariane Exp $ */ +/* $OpenBSD: bus_dma.c,v 1.4 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -445,7 +445,7 @@ _dmamem_map(bus_dma_tag_t t, bus_dma_segment_t *segs, int nsegs, size_t size, if (nsegs == 1) { pa = (*t->_device_to_pa)(segs[0].ds_addr); if (flags & BUS_DMA_COHERENT) - *kvap = (caddr_t)PHYS_TO_UNCACHED(pa); + *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_NC); else *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_CACHED); return (0); diff --git a/sys/arch/octeon/octeon/machdep.c b/sys/arch/octeon/octeon/machdep.c index 3b4441a959a..1c5ab1f26db 100644 --- a/sys/arch/octeon/octeon/machdep.c +++ b/sys/arch/octeon/octeon/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.15 2011/06/26 22:40:00 deraadt Exp $ */ +/* $OpenBSD: machdep.c,v 1.16 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2009, 2010 Miodrag Vallat. @@ -172,7 +172,6 @@ vm_map_t phys_map; int safepri = 0; caddr_t msgbufbase; -vaddr_t uncached_base; int physmem; /* Max supported memory, changes to actual. */ int ncpu = 1; /* At least one CPU in the system. */ @@ -372,8 +371,6 @@ mips_init(__register_t a0, __register_t a1, __register_t a2 __unused, */ boothowto = RB_AUTOBOOT; - uncached_base = PHYS_TO_XKPHYS(0, CCA_NC); - octeon_memory_init(boot_info); /* diff --git a/sys/arch/sgi/dev/gbe.c b/sys/arch/sgi/dev/gbe.c index f4ab42da94b..ba51267e4c0 100644 --- a/sys/arch/sgi/dev/gbe.c +++ b/sys/arch/sgi/dev/gbe.c @@ -1,4 +1,4 @@ -/* $OpenBSD: gbe.c,v 1.13 2010/12/26 15:41:00 miod Exp $ */ +/* $OpenBSD: gbe.c,v 1.14 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2007, 2008, 2009 Joel Sing @@ -225,8 +225,8 @@ gbe_attach(struct device *parent, struct device *self, void *aux) * We've already been setup via gbe_cnattach(). */ - gsc->ioh = PHYS_TO_UNCACHED(GBE_BASE); - gsc->re_ioh = PHYS_TO_UNCACHED(RE_BASE); + gsc->ioh = PHYS_TO_XKPHYS(GBE_BASE, CCA_NC); + gsc->re_ioh = PHYS_TO_XKPHYS(RE_BASE, CCA_NC); gsc->rev = bus_space_read_4(gsc->iot, gsc->ioh, GBE_CTRL_STAT) & 0xf; @@ -1275,7 +1275,7 @@ gbe_cnprobe(bus_space_tag_t iot, bus_addr_t addr) int val, width, height; /* Setup bus space mapping. */ - ioh = PHYS_TO_UNCACHED(addr); + ioh = PHYS_TO_XKPHYS(addr, CCA_NC); /* Determine resolution configured by firmware. */ val = bus_space_read_4(iot, ioh, GBE_VT_HCMAP); @@ -1309,8 +1309,8 @@ gbe_cnattach(bus_space_tag_t iot, bus_addr_t addr) /* Setup bus space mapping. */ gsc->iot = iot; - gsc->ioh = PHYS_TO_UNCACHED(addr); - gsc->re_ioh = PHYS_TO_UNCACHED(RE_BASE); + gsc->ioh = PHYS_TO_XKPHYS(addr, CCA_NC); + gsc->re_ioh = PHYS_TO_XKPHYS(RE_BASE, CCA_NC); /* Determine GBE revision. */ gsc->rev = bus_space_read_4(gsc->iot, gsc->ioh, GBE_CTRL_STAT) & 0xf; @@ -1337,7 +1337,7 @@ gbe_cnattach(bus_space_tag_t iot, bus_addr_t addr) va = pmap_steal_memory(gbe_consdata.tm_size + 65536, NULL, NULL); pmap_extract(pmap_kernel(), va, &pa); gbe_consdata.tm_phys = ((pa >> 16) + 1) << 16; - gbe_consdata.tm = (caddr_t)PHYS_TO_UNCACHED(gbe_consdata.tm_phys); + gbe_consdata.tm = (caddr_t)PHYS_TO_XKPHYS(gbe_consdata.tm_phys, CCA_NC); /* * Steal memory for framebuffer - 64KB aligned and coherent. @@ -1345,7 +1345,7 @@ gbe_cnattach(bus_space_tag_t iot, bus_addr_t addr) va = pmap_steal_memory(gbe_consdata.fb_size + 65536, NULL, NULL); pmap_extract(pmap_kernel(), va, &pa); gbe_consdata.fb_phys = ((pa >> 16) + 1) << 16; - gbe_consdata.fb = (caddr_t)PHYS_TO_UNCACHED(gbe_consdata.fb_phys); + gbe_consdata.fb = (caddr_t)PHYS_TO_XKPHYS(gbe_consdata.fb_phys, CCA_NC); /* * Steal memory for rasops tile - 64KB aligned and coherent. @@ -1353,7 +1353,7 @@ gbe_cnattach(bus_space_tag_t iot, bus_addr_t addr) va = pmap_steal_memory(GBE_TILE_SIZE + 65536, NULL, NULL); pmap_extract(pmap_kernel(), va, &pa); gbe_consdata.ro_phys = ((pa >> 16) + 1) << 16; - gbe_consdata.ro = (caddr_t)PHYS_TO_UNCACHED(gbe_consdata.ro_phys); + gbe_consdata.ro = (caddr_t)PHYS_TO_XKPHYS(gbe_consdata.ro_phys, CCA_NC); /* * Setup GBE hardware. diff --git a/sys/arch/sgi/sgi/bus_dma.c b/sys/arch/sgi/sgi/bus_dma.c index 35d877dcf47..520b9a3139f 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.22 2011/06/23 20:44:39 ariane Exp $ */ +/* $OpenBSD: bus_dma.c,v 1.23 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -437,16 +437,13 @@ _dmamem_map(bus_dma_tag_t t, bus_dma_segment_t *segs, int nsegs, size_t size, bus_addr_t addr; int curseg, error; -#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); + *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_NC); else +#endif *kvap = (caddr_t)PHYS_TO_XKPHYS(pa, CCA_CACHED); return (0); } @@ -476,9 +473,11 @@ _dmamem_map(bus_dma_tag_t t, bus_dma_segment_t *segs, int nsegs, size_t size, return (error); } +#ifndef TGT_COHERENT if (flags & BUS_DMA_COHERENT) pmap_page_cache(PHYS_TO_VM_PAGE(pa), PV_UNCACHED); +#endif } pmap_update(pmap_kernel()); } diff --git a/sys/arch/sgi/sgi/ip27_machdep.c b/sys/arch/sgi/sgi/ip27_machdep.c index 53f86514aec..ec256704296 100644 --- a/sys/arch/sgi/sgi/ip27_machdep.c +++ b/sys/arch/sgi/sgi/ip27_machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip27_machdep.c,v 1.53 2011/04/05 14:43:10 miod Exp $ */ +/* $OpenBSD: ip27_machdep.c,v 1.54 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2008, 2009 Miodrag Vallat. @@ -119,7 +119,6 @@ ip27_setup() nmi_t *nmi; static char unknown_model[20]; - uncached_base = PHYS_TO_XKPHYS_UNCACHED(0, SP_NC); io_base = PHYS_TO_XKPHYS_UNCACHED(0, SP_IO); ip35 = sys_config.system_type == SGI_IP35; diff --git a/sys/arch/sgi/sgi/ip30_machdep.c b/sys/arch/sgi/sgi/ip30_machdep.c index 76ef31c4d62..f3b9ced3547 100644 --- a/sys/arch/sgi/sgi/ip30_machdep.c +++ b/sys/arch/sgi/sgi/ip30_machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip30_machdep.c,v 1.47 2011/05/30 22:25:22 oga Exp $ */ +/* $OpenBSD: ip30_machdep.c,v 1.48 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2008, 2009 Miodrag Vallat. @@ -96,12 +96,6 @@ ip30_setup() struct ip30_gda *gda; #endif - /* - * Although being r10k/r12k based, the uncached spaces are - * apparently not used in this design. - */ - uncached_base = PHYS_TO_XKPHYS(0, CCA_NC); - /* * Scan for memory. ARCBios reports up to 1GB of memory as available, * and anything after is reported as reserved. @@ -258,13 +252,13 @@ ip30_autoconf(struct device *parent) paddr_t ip30_widget_short(int16_t nasid, u_int widget) { - return ((uint64_t)(widget) << 24) | (1ULL << 28) | uncached_base; + return PHYS_TO_XKPHYS((uint64_t)(widget) << 24) | (1ULL << 28), CCA_NC); } paddr_t ip30_widget_long(int16_t nasid, u_int widget) { - return ((uint64_t)(widget) << 36) | uncached_base; + return PHYS_TO_XKPHYS((uint64_t)(widget) << 36, CCA_NC); } paddr_t diff --git a/sys/arch/sgi/sgi/ip32_machdep.c b/sys/arch/sgi/sgi/ip32_machdep.c index 927b9020897..e3760cbd031 100644 --- a/sys/arch/sgi/sgi/ip32_machdep.c +++ b/sys/arch/sgi/sgi/ip32_machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip32_machdep.c,v 1.16 2011/05/30 22:25:22 oga Exp $ */ +/* $OpenBSD: ip32_machdep.c,v 1.17 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -115,8 +115,6 @@ ip32_setup() { u_long cpuspeed; - uncached_base = PHYS_TO_XKPHYS(0, CCA_NC); - crime_configure_memory(); /* R12K O2s must run with DSD on. */ diff --git a/sys/arch/sgi/sgi/machdep.c b/sys/arch/sgi/sgi/machdep.c index eb6f75a5c4e..4b511712f04 100644 --- a/sys/arch/sgi/sgi/machdep.c +++ b/sys/arch/sgi/sgi/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.112 2011/06/26 22:40:00 deraadt Exp $ */ +/* $OpenBSD: machdep.c,v 1.113 2012/03/15 18:57:22 miod Exp $ */ /* * Copyright (c) 2003-2004 Opsycon AB (www.opsycon.se / www.opsycon.com) @@ -100,7 +100,6 @@ vm_map_t phys_map; int safepri = 0; caddr_t msgbufbase; -vaddr_t uncached_base; int physmem; /* Max supported memory, changes to actual. */ int rsvdmem; /* Reserved memory not usable. */ -- cgit v1.2.3