summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2014-08-15 16:06:10 -0400
committerTejun Heo <tj@kernel.org>2014-08-15 16:06:10 -0400
commit849f5169097e1ba35b90ac9df76b5bb6f9c0aabd (patch)
treed8dd8a5a10a143dd93178522108fa0da1dfd358e
parentf0d279654dea22b7a6ad34b9334aee80cda62cde (diff)
downloadblackbird-op-linux-849f5169097e1ba35b90ac9df76b5bb6f9c0aabd.tar.gz
blackbird-op-linux-849f5169097e1ba35b90ac9df76b5bb6f9c0aabd.zip
percpu: perform tlb flush after pcpu_map_pages() failure
If pcpu_map_pages() fails midway, it unmaps the already mapped pages. Currently, it doesn't flush tlb after the partial unmapping. This may be okay in most cases as the established mapping hasn't been used at that point but it can go wrong and when it goes wrong it'd be extremely difficult to track down. Flush tlb after the partial unmapping. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: stable@vger.kernel.org
-rw-r--r--mm/percpu-vm.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/mm/percpu-vm.c b/mm/percpu-vm.c
index 8d9bb2c00c68..51108165f829 100644
--- a/mm/percpu-vm.c
+++ b/mm/percpu-vm.c
@@ -272,6 +272,7 @@ err:
__pcpu_unmap_pages(pcpu_chunk_addr(chunk, tcpu, page_start),
page_end - page_start);
}
+ pcpu_post_unmap_tlb_flush(chunk, page_start, page_end);
return err;
}
OpenPOWER on IntegriCloud