Re: [PATCH v3 5/5] mm: enable CONFIG_MOVABLE_NODE on powerpc

From: Benjamin Herrenschmidt
Date: Mon Sep 26 2016 - 17:16:32 EST


On Sun, 2016-09-25 at 13:36 -0500, Reza Arbab wrote:
> To create a movable node, we need to hotplug all of its memory into
> ZONE_MOVABLE.
>
> Note that to do this, auto_online_blocks should be off. Since the memory
> will first be added to the default zone, we must explicitly use
> online_movable to online.
>
> Because such a node contains no normal memory, can_online_high_movable()
> will only allow us to do the onlining if CONFIG_MOVABLE_NODE is set.
> Enable the use of this config option on PPC64 platforms.

What is that business with a command line argument ? Do that mean that
we'll need some magic command line argument to properly handle LPC memory
on CAPI devices or GPUs ? If yes that's bad ... kernel arguments should
be a last resort.

We should have all the information we need from the device-tree.

Note also that we shouldn't need to create those nodes at boot time,
we need to add the ability to create the whole thing at runtime, we may know
that there's an NPU with an LPC window in the system but we won't know if it's
used until it is and for CAPI we just simply don't know until some PCI device
gets turned into CAPI mode and starts claiming LPC memory...

Ben.

> Signed-off-by: Reza Arbab <arbab@xxxxxxxxxxxxxxxxxx>
> ---
> ÂDocumentation/kernel-parameters.txt | 2 +-
> Âmm/KconfigÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂ| 2 +-
> Â2 files changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt
> index a4f4d69..3d8460d 100644
> --- a/Documentation/kernel-parameters.txt
> +++ b/Documentation/kernel-parameters.txt
> @@ -2344,7 +2344,7 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
> > Â that the amount of memory usable for all allocations
> > Â is not too small.
> Â
> > > - movable_node [KNL,X86] Boot-time switch to enable the effects
> > > + movable_node [KNL,X86,PPC] Boot-time switch to enable the effects
> > Â of CONFIG_MOVABLE_NODE=y. See mm/Kconfig for details.
> Â
> > > Â MTD_Partition= [MTD]
> diff --git a/mm/Kconfig b/mm/Kconfig
> index be0ee11..4b19cd3 100644
> --- a/mm/Kconfig
> +++ b/mm/Kconfig
> @@ -153,7 +153,7 @@ config MOVABLE_NODE
> > Â bool "Enable to assign a node which has only movable memory"
> > Â depends on HAVE_MEMBLOCK
> > Â depends on NO_BOOTMEM
> > - depends on X86_64
> > + depends on X86_64 || PPC64
> > Â depends on NUMA
> > Â default n
> > Â help