diff options
author | David Gibson <david@gibson.dropbear.id.au> | 2016-02-08 22:32:40 -0500 |
---|---|---|
committer | Michael Ellerman <mpe@ellerman.id.au> | 2016-03-01 06:04:17 -0500 |
commit | abd0a0e7914a1137973119ac3b3cace26e8ffa96 (patch) | |
tree | b490f957a794320ef5d1938ae776c19aa94be285 | |
parent | 446957ba5127141ee007fc61509e24a9e60853d9 (diff) |
powerpc/mm: Clean up error handling for htab_remove_mapping
Currently, the only error that htab_remove_mapping() can report is -EINVAL,
if removal of bolted HPTEs isn't implemeted for this platform. We make
a few clean ups to the handling of this:
* EINVAL isn't really the right code - there's nothing wrong with the
function's arguments - use ENODEV instead
* We were also printing a warning message, but that's a decision better
left up to the callers, so remove it
* One caller is vmemmap_remove_mapping(), which will just BUG_ON() on
error, making the warning message redundant, so no change is needed
there.
* The other caller is remove_section_mapping(). This is called in the
memory hot remove path at a point after vmemmap_remove_mapping() so
if hpte_removebolted isn't implemented, we'd expect to have already
BUG()ed anyway. Put a WARN_ON() here, in lieu of a printk() since this
really shouldn't be happening.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Reviewed-by: Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
-rw-r--r-- | arch/powerpc/mm/hash_utils_64.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/arch/powerpc/mm/hash_utils_64.c b/arch/powerpc/mm/hash_utils_64.c index 47a0bc12cb65..70490c41e14e 100644 --- a/arch/powerpc/mm/hash_utils_64.c +++ b/arch/powerpc/mm/hash_utils_64.c | |||
@@ -273,11 +273,8 @@ int htab_remove_mapping(unsigned long vstart, unsigned long vend, | |||
273 | shift = mmu_psize_defs[psize].shift; | 273 | shift = mmu_psize_defs[psize].shift; |
274 | step = 1 << shift; | 274 | step = 1 << shift; |
275 | 275 | ||
276 | if (!ppc_md.hpte_removebolted) { | 276 | if (!ppc_md.hpte_removebolted) |
277 | printk(KERN_WARNING "Platform doesn't implement " | 277 | return -ENODEV; |
278 | "hpte_removebolted\n"); | ||
279 | return -EINVAL; | ||
280 | } | ||
281 | 278 | ||
282 | for (vaddr = vstart; vaddr < vend; vaddr += step) | 279 | for (vaddr = vstart; vaddr < vend; vaddr += step) |
283 | ppc_md.hpte_removebolted(vaddr, psize, ssize); | 280 | ppc_md.hpte_removebolted(vaddr, psize, ssize); |
@@ -641,8 +638,10 @@ int create_section_mapping(unsigned long start, unsigned long end) | |||
641 | 638 | ||
642 | int remove_section_mapping(unsigned long start, unsigned long end) | 639 | int remove_section_mapping(unsigned long start, unsigned long end) |
643 | { | 640 | { |
644 | return htab_remove_mapping(start, end, mmu_linear_psize, | 641 | int rc = htab_remove_mapping(start, end, mmu_linear_psize, |
645 | mmu_kernel_ssize); | 642 | mmu_kernel_ssize); |
643 | WARN_ON(rc < 0); | ||
644 | return rc; | ||
646 | } | 645 | } |
647 | #endif /* CONFIG_MEMORY_HOTPLUG */ | 646 | #endif /* CONFIG_MEMORY_HOTPLUG */ |
648 | 647 | ||