summaryrefslogtreecommitdiffstats
path: root/sys/mips
diff options
context:
space:
mode:
authoradrian <adrian@FreeBSD.org>2016-02-11 06:24:34 +0000
committeradrian <adrian@FreeBSD.org>2016-02-11 06:24:34 +0000
commit826ad6942ab5b3817c8db1224cca78a583ed7dd4 (patch)
tree5e93fbfa9debd0acc4a8eccbbefbe21f72a88809 /sys/mips
parent452683395797bdcc86c301dd63d49d97b11b545c (diff)
downloadFreeBSD-src-826ad6942ab5b3817c8db1224cca78a583ed7dd4.zip
FreeBSD-src-826ad6942ab5b3817c8db1224cca78a583ed7dd4.tar.gz
Make bus_space_generic properly map/unmap memory (using pmap_mapdev and
pmap_unmapdev respectively) so that resources are properly managed. This is work originally done by kan@. Stanislav picked it up as part of his Mediatek SoC work. Tested: * Carambola2, AR933x SoC Submitted by: Stanislav Galabov <sgalabov@gmail.com> Reviewed by: kan Differential Revision: https://reviews.freebsd.org/D5184
Diffstat (limited to 'sys/mips')
-rw-r--r--sys/mips/mips/bus_space_generic.c11
-rw-r--r--sys/mips/mips/nexus.c26
2 files changed, 24 insertions, 13 deletions
diff --git a/sys/mips/mips/bus_space_generic.c b/sys/mips/mips/bus_space_generic.c
index d82d97e..b57a739 100644
--- a/sys/mips/mips/bus_space_generic.c
+++ b/sys/mips/mips/bus_space_generic.c
@@ -228,20 +228,21 @@ bus_space_tag_t mips_bus_space_generic = &generic_space;
int
generic_bs_map(void *t __unused, bus_addr_t addr,
- bus_size_t size __unused, int flags __unused,
+ bus_size_t size, int flags __unused,
bus_space_handle_t *bshp)
{
- *bshp = addr;
+ *bshp = (bus_space_handle_t)pmap_mapdev((vm_paddr_t)addr,
+ (vm_size_t)size);
return (0);
}
void
-generic_bs_unmap(void *t __unused, bus_space_handle_t bh __unused,
- bus_size_t size __unused)
+generic_bs_unmap(void *t __unused, bus_space_handle_t bh,
+ bus_size_t size)
{
- /* Do nothing */
+ pmap_unmapdev((vm_offset_t)bh, (vm_size_t)size);
}
int
diff --git a/sys/mips/mips/nexus.c b/sys/mips/mips/nexus.c
index 6ab0da3..f781248 100644
--- a/sys/mips/mips/nexus.c
+++ b/sys/mips/mips/nexus.c
@@ -415,6 +415,7 @@ nexus_activate_resource(device_t bus, device_t child, int type, int rid,
void *vaddr;
vm_paddr_t paddr;
vm_size_t psize;
+ int err;
/*
* If this is a memory resource, use pmap_mapdev to map it.
@@ -422,10 +423,14 @@ nexus_activate_resource(device_t bus, device_t child, int type, int rid,
if (type == SYS_RES_MEMORY || type == SYS_RES_IOPORT) {
paddr = rman_get_start(r);
psize = rman_get_size(r);
- vaddr = pmap_mapdev(paddr, psize);
-
- rman_set_virtual(r, vaddr);
rman_set_bustag(r, mips_bus_space_generic);
+ err = bus_space_map(rman_get_bustag(r), paddr, psize, 0,
+ (bus_space_handle_t *)&vaddr);
+ if (err != 0) {
+ rman_deactivate_resource(r);
+ return (err);
+ }
+ rman_set_virtual(r, vaddr);
rman_set_bushandle(r, (bus_space_handle_t)(uintptr_t)vaddr);
}
@@ -436,11 +441,16 @@ static int
nexus_deactivate_resource(device_t bus, device_t child, int type, int rid,
struct resource *r)
{
- vm_offset_t va;
-
- if (type == SYS_RES_MEMORY) {
- va = (vm_offset_t)rman_get_virtual(r);
- pmap_unmapdev(va, rman_get_size(r));
+ bus_space_handle_t vaddr;
+ bus_size_t psize;
+
+ vaddr = rman_get_bushandle(r);
+
+ if (type == SYS_RES_MEMORY && vaddr != 0) {
+ psize = (bus_size_t)rman_get_size(r);
+ bus_space_unmap(rman_get_bustag(r), vaddr, psize);
+ rman_set_virtual(r, NULL);
+ rman_set_bushandle(r, 0);
}
return (rman_deactivate_resource(r));
OpenPOWER on IntegriCloud