Commit b6356a01 authored by Suman Anna's avatar Suman Anna Committed by Ohad Ben-Cohen

remoteproc: free carveout memories only after unmapping them

It is not preferable to have the allocated pages for carveout
memories freed before they are unmapped. The code that deals
with the cleanup of carveout memories is therefore moved after
the corresponding mapping entries were cleaned up.

This is mostly a no-op since the remote processors are already
stopped when the cleanup function is called, but this will make
the cleanup code follow the exact reverse path of allocation.
Signed-off-by: default avatarSuman Anna <s-anna@ti.com>
Signed-off-by: default avatarOhad Ben-Cohen <ohad@wizery.com>
parent e4760363
...@@ -762,13 +762,6 @@ static void rproc_resource_cleanup(struct rproc *rproc) ...@@ -762,13 +762,6 @@ static void rproc_resource_cleanup(struct rproc *rproc)
kfree(entry); kfree(entry);
} }
/* clean up carveout allocations */
list_for_each_entry_safe(entry, tmp, &rproc->carveouts, node) {
dma_free_coherent(dev->parent, entry->len, entry->va, entry->dma);
list_del(&entry->node);
kfree(entry);
}
/* clean up iommu mapping entries */ /* clean up iommu mapping entries */
list_for_each_entry_safe(entry, tmp, &rproc->mappings, node) { list_for_each_entry_safe(entry, tmp, &rproc->mappings, node) {
size_t unmapped; size_t unmapped;
...@@ -783,6 +776,13 @@ static void rproc_resource_cleanup(struct rproc *rproc) ...@@ -783,6 +776,13 @@ static void rproc_resource_cleanup(struct rproc *rproc)
list_del(&entry->node); list_del(&entry->node);
kfree(entry); kfree(entry);
} }
/* clean up carveout allocations */
list_for_each_entry_safe(entry, tmp, &rproc->carveouts, node) {
dma_free_coherent(dev->parent, entry->len, entry->va, entry->dma);
list_del(&entry->node);
kfree(entry);
}
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment