diff options
author | Tejun Heo <tj@kernel.org> | 2014-08-15 22:06:10 +0200 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2014-08-15 22:06:10 +0200 |
commit | 849f5169097e1ba35b90ac9df76b5bb6f9c0aabd (patch) | |
tree | d8dd8a5a10a143dd93178522108fa0da1dfd358e /mm | |
parent | percpu: fix pcpu_alloc_pages() failure path (diff) | |
download | linux-849f5169097e1ba35b90ac9df76b5bb6f9c0aabd.tar.xz 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
Diffstat (limited to 'mm')
-rw-r--r-- | mm/percpu-vm.c | 1 |
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; } |