Reviewed-by: Pavel Tatashin <pavel.tatas...@microsoft.com>

On 8/21/18 6:44 AM, David Hildenbrand wrote:
> Let's perform all checking + offlining + removing under
> device_hotplug_lock, so nobody can mess with these devices via
> sysfs concurrently.
> 
> Cc: Benjamin Herrenschmidt <b...@kernel.crashing.org>
> Cc: Paul Mackerras <pau...@samba.org>
> Cc: Michael Ellerman <m...@ellerman.id.au>
> Cc: Rashmica Gupta <rashmic...@gmail.com>
> Cc: Balbir Singh <bsinghar...@gmail.com>
> Cc: Michael Neuling <mi...@neuling.org>
> Signed-off-by: David Hildenbrand <da...@redhat.com>
> ---
>  arch/powerpc/platforms/powernv/memtrace.c | 10 ++++++++--
>  1 file changed, 8 insertions(+), 2 deletions(-)
> 
> diff --git a/arch/powerpc/platforms/powernv/memtrace.c 
> b/arch/powerpc/platforms/powernv/memtrace.c
> index ef7181d4fe68..473e59842ec5 100644
> --- a/arch/powerpc/platforms/powernv/memtrace.c
> +++ b/arch/powerpc/platforms/powernv/memtrace.c
> @@ -74,9 +74,13 @@ static bool memtrace_offline_pages(u32 nid, u64 start_pfn, 
> u64 nr_pages)
>  {
>       u64 end_pfn = start_pfn + nr_pages - 1;
>  
> +     lock_device_hotplug();
> +
>       if (walk_memory_range(start_pfn, end_pfn, NULL,
> -         check_memblock_online))
> +         check_memblock_online)) {
> +             unlock_device_hotplug();
>               return false;
> +     }
>  
>       walk_memory_range(start_pfn, end_pfn, (void *)MEM_GOING_OFFLINE,
>                         change_memblock_state);
> @@ -84,14 +88,16 @@ static bool memtrace_offline_pages(u32 nid, u64 
> start_pfn, u64 nr_pages)
>       if (offline_pages(start_pfn, nr_pages)) {
>               walk_memory_range(start_pfn, end_pfn, (void *)MEM_ONLINE,
>                                 change_memblock_state);
> +             unlock_device_hotplug();
>               return false;
>       }
>  
>       walk_memory_range(start_pfn, end_pfn, (void *)MEM_OFFLINE,
>                         change_memblock_state);
>  
> -     remove_memory(nid, start_pfn << PAGE_SHIFT, nr_pages << PAGE_SHIFT);
> +     __remove_memory(nid, start_pfn << PAGE_SHIFT, nr_pages << PAGE_SHIFT);
>  
> +     unlock_device_hotplug();
>       return true;
>  }
>  
> 

Reply via email to