xref: /openbmc/linux/Documentation/admin-guide/mm/memory-hotplug.rst (revision dee6da22efac451d361f5224a60be2796d847b51)
16bf53999SMike Rapoport.. _admin_guide_memory_hotplug:
26bf53999SMike Rapoport
36bf53999SMike Rapoport==============
46bf53999SMike RapoportMemory Hotplug
56bf53999SMike Rapoport==============
66bf53999SMike Rapoport
76bf53999SMike Rapoport:Created:							Jul 28 2007
8*dee6da22SDavid Hildenbrand:Updated: Add some details about locking internals:		Aug 20 2018
96bf53999SMike Rapoport
106bf53999SMike RapoportThis document is about memory hotplug including how-to-use and current status.
116bf53999SMike RapoportBecause Memory Hotplug is still under development, contents of this text will
126bf53999SMike Rapoportbe changed often.
136bf53999SMike Rapoport
146bf53999SMike Rapoport.. contents:: :local:
156bf53999SMike Rapoport
166bf53999SMike Rapoport.. note::
176bf53999SMike Rapoport
186bf53999SMike Rapoport    (1) x86_64's has special implementation for memory hotplug.
196bf53999SMike Rapoport        This text does not describe it.
206bf53999SMike Rapoport    (2) This text assumes that sysfs is mounted at ``/sys``.
216bf53999SMike Rapoport
226bf53999SMike Rapoport
236bf53999SMike RapoportIntroduction
246bf53999SMike Rapoport============
256bf53999SMike Rapoport
266bf53999SMike RapoportPurpose of memory hotplug
276bf53999SMike Rapoport-------------------------
286bf53999SMike Rapoport
296bf53999SMike RapoportMemory Hotplug allows users to increase/decrease the amount of memory.
306bf53999SMike RapoportGenerally, there are two purposes.
316bf53999SMike Rapoport
326bf53999SMike Rapoport(A) For changing the amount of memory.
336bf53999SMike Rapoport    This is to allow a feature like capacity on demand.
346bf53999SMike Rapoport(B) For installing/removing DIMMs or NUMA-nodes physically.
356bf53999SMike Rapoport    This is to exchange DIMMs/NUMA-nodes, reduce power consumption, etc.
366bf53999SMike Rapoport
376bf53999SMike Rapoport(A) is required by highly virtualized environments and (B) is required by
386bf53999SMike Rapoporthardware which supports memory power management.
396bf53999SMike Rapoport
406bf53999SMike RapoportLinux memory hotplug is designed for both purpose.
416bf53999SMike Rapoport
426bf53999SMike RapoportPhases of memory hotplug
436bf53999SMike Rapoport------------------------
446bf53999SMike Rapoport
456bf53999SMike RapoportThere are 2 phases in Memory Hotplug:
466bf53999SMike Rapoport
476bf53999SMike Rapoport  1) Physical Memory Hotplug phase
486bf53999SMike Rapoport  2) Logical Memory Hotplug phase.
496bf53999SMike Rapoport
506bf53999SMike RapoportThe First phase is to communicate hardware/firmware and make/erase
516bf53999SMike Rapoportenvironment for hotplugged memory. Basically, this phase is necessary
526bf53999SMike Rapoportfor the purpose (B), but this is good phase for communication between
536bf53999SMike Rapoporthighly virtualized environments too.
546bf53999SMike Rapoport
556bf53999SMike RapoportWhen memory is hotplugged, the kernel recognizes new memory, makes new memory
566bf53999SMike Rapoportmanagement tables, and makes sysfs files for new memory's operation.
576bf53999SMike Rapoport
586bf53999SMike RapoportIf firmware supports notification of connection of new memory to OS,
596bf53999SMike Rapoportthis phase is triggered automatically. ACPI can notify this event. If not,
606bf53999SMike Rapoport"probe" operation by system administration is used instead.
616bf53999SMike Rapoport(see :ref:`memory_hotplug_physical_mem`).
626bf53999SMike Rapoport
636bf53999SMike RapoportLogical Memory Hotplug phase is to change memory state into
646bf53999SMike Rapoportavailable/unavailable for users. Amount of memory from user's view is
656bf53999SMike Rapoportchanged by this phase. The kernel makes all memory in it as free pages
666bf53999SMike Rapoportwhen a memory range is available.
676bf53999SMike Rapoport
686bf53999SMike RapoportIn this document, this phase is described as online/offline.
696bf53999SMike Rapoport
706bf53999SMike RapoportLogical Memory Hotplug phase is triggered by write of sysfs file by system
716bf53999SMike Rapoportadministrator. For the hot-add case, it must be executed after Physical Hotplug
726bf53999SMike Rapoportphase by hand.
736bf53999SMike Rapoport(However, if you writes udev's hotplug scripts for memory hotplug, these
746bf53999SMike Rapoportphases can be execute in seamless way.)
756bf53999SMike Rapoport
766bf53999SMike RapoportUnit of Memory online/offline operation
776bf53999SMike Rapoport---------------------------------------
786bf53999SMike Rapoport
796bf53999SMike RapoportMemory hotplug uses SPARSEMEM memory model which allows memory to be divided
806bf53999SMike Rapoportinto chunks of the same size. These chunks are called "sections". The size of
816bf53999SMike Rapoporta memory section is architecture dependent. For example, power uses 16MiB, ia64
826bf53999SMike Rapoportuses 1GiB.
836bf53999SMike Rapoport
846bf53999SMike RapoportMemory sections are combined into chunks referred to as "memory blocks". The
856bf53999SMike Rapoportsize of a memory block is architecture dependent and represents the logical
866bf53999SMike Rapoportunit upon which memory online/offline operations are to be performed. The
876bf53999SMike Rapoportdefault size of a memory block is the same as memory section size unless an
886bf53999SMike Rapoportarchitecture specifies otherwise. (see :ref:`memory_hotplug_sysfs_files`.)
896bf53999SMike Rapoport
906bf53999SMike RapoportTo determine the size (in bytes) of a memory block please read this file::
916bf53999SMike Rapoport
926bf53999SMike Rapoport  /sys/devices/system/memory/block_size_bytes
936bf53999SMike Rapoport
946bf53999SMike RapoportKernel Configuration
956bf53999SMike Rapoport====================
966bf53999SMike Rapoport
976bf53999SMike RapoportTo use memory hotplug feature, kernel must be compiled with following
986bf53999SMike Rapoportconfig options.
996bf53999SMike Rapoport
1006bf53999SMike Rapoport- For all memory hotplug:
1016bf53999SMike Rapoport    - Memory model -> Sparse Memory  (``CONFIG_SPARSEMEM``)
1026bf53999SMike Rapoport    - Allow for memory hot-add       (``CONFIG_MEMORY_HOTPLUG``)
1036bf53999SMike Rapoport
1046bf53999SMike Rapoport- To enable memory removal, the following are also necessary:
1056bf53999SMike Rapoport    - Allow for memory hot remove    (``CONFIG_MEMORY_HOTREMOVE``)
1066bf53999SMike Rapoport    - Page Migration                 (``CONFIG_MIGRATION``)
1076bf53999SMike Rapoport
1086bf53999SMike Rapoport- For ACPI memory hotplug, the following are also necessary:
1096bf53999SMike Rapoport    - Memory hotplug (under ACPI Support menu) (``CONFIG_ACPI_HOTPLUG_MEMORY``)
1106bf53999SMike Rapoport    - This option can be kernel module.
1116bf53999SMike Rapoport
1126bf53999SMike Rapoport- As a related configuration, if your box has a feature of NUMA-node hotplug
1136bf53999SMike Rapoport  via ACPI, then this option is necessary too.
1146bf53999SMike Rapoport
1156bf53999SMike Rapoport    - ACPI0004,PNP0A05 and PNP0A06 Container Driver (under ACPI Support menu)
1166bf53999SMike Rapoport      (``CONFIG_ACPI_CONTAINER``).
1176bf53999SMike Rapoport
1186bf53999SMike Rapoport     This option can be kernel module too.
1196bf53999SMike Rapoport
1206bf53999SMike Rapoport
1216bf53999SMike Rapoport.. _memory_hotplug_sysfs_files:
1226bf53999SMike Rapoport
1236bf53999SMike Rapoportsysfs files for memory hotplug
1246bf53999SMike Rapoport==============================
1256bf53999SMike Rapoport
1266bf53999SMike RapoportAll memory blocks have their device information in sysfs.  Each memory block
1276bf53999SMike Rapoportis described under ``/sys/devices/system/memory`` as::
1286bf53999SMike Rapoport
1296bf53999SMike Rapoport	/sys/devices/system/memory/memoryXXX
1306bf53999SMike Rapoport
1316bf53999SMike Rapoportwhere XXX is the memory block id.
1326bf53999SMike Rapoport
1336bf53999SMike RapoportFor the memory block covered by the sysfs directory.  It is expected that all
1346bf53999SMike Rapoportmemory sections in this range are present and no memory holes exist in the
1356bf53999SMike Rapoportrange. Currently there is no way to determine if there is a memory hole, but
1366bf53999SMike Rapoportthe existence of one should not affect the hotplug capabilities of the memory
1376bf53999SMike Rapoportblock.
1386bf53999SMike Rapoport
1396bf53999SMike RapoportFor example, assume 1GiB memory block size. A device for a memory starting at
1406bf53999SMike Rapoport0x100000000 is ``/sys/device/system/memory/memory4``::
1416bf53999SMike Rapoport
1426bf53999SMike Rapoport	(0x100000000 / 1Gib = 4)
1436bf53999SMike Rapoport
1446bf53999SMike RapoportThis device covers address range [0x100000000 ... 0x140000000)
1456bf53999SMike Rapoport
1466bf53999SMike RapoportUnder each memory block, you can see 5 files:
1476bf53999SMike Rapoport
1486bf53999SMike Rapoport- ``/sys/devices/system/memory/memoryXXX/phys_index``
1496bf53999SMike Rapoport- ``/sys/devices/system/memory/memoryXXX/phys_device``
1506bf53999SMike Rapoport- ``/sys/devices/system/memory/memoryXXX/state``
1516bf53999SMike Rapoport- ``/sys/devices/system/memory/memoryXXX/removable``
1526bf53999SMike Rapoport- ``/sys/devices/system/memory/memoryXXX/valid_zones``
1536bf53999SMike Rapoport
1546bf53999SMike Rapoport=================== ============================================================
1556bf53999SMike Rapoport``phys_index``      read-only and contains memory block id, same as XXX.
1566bf53999SMike Rapoport``state``           read-write
1576bf53999SMike Rapoport
1586bf53999SMike Rapoport                    - at read:  contains online/offline state of memory.
1596bf53999SMike Rapoport                    - at write: user can specify "online_kernel",
1606bf53999SMike Rapoport
1616bf53999SMike Rapoport                    "online_movable", "online", "offline" command
1626bf53999SMike Rapoport                    which will be performed on all sections in the block.
1636bf53999SMike Rapoport``phys_device``     read-only: designed to show the name of physical memory
1646bf53999SMike Rapoport                    device.  This is not well implemented now.
1656bf53999SMike Rapoport``removable``       read-only: contains an integer value indicating
1666bf53999SMike Rapoport                    whether the memory block is removable or not
1676bf53999SMike Rapoport                    removable.  A value of 1 indicates that the memory
1686bf53999SMike Rapoport                    block is removable and a value of 0 indicates that
1696bf53999SMike Rapoport                    it is not removable. A memory block is removable only if
1706bf53999SMike Rapoport                    every section in the block is removable.
1716bf53999SMike Rapoport``valid_zones``     read-only: designed to show which zones this memory block
1726bf53999SMike Rapoport		    can be onlined to.
1736bf53999SMike Rapoport
1746bf53999SMike Rapoport		    The first column shows it`s default zone.
1756bf53999SMike Rapoport
1766bf53999SMike Rapoport		    "memory6/valid_zones: Normal Movable" shows this memoryblock
1776bf53999SMike Rapoport		    can be onlined to ZONE_NORMAL by default and to ZONE_MOVABLE
1786bf53999SMike Rapoport		    by online_movable.
1796bf53999SMike Rapoport
1806bf53999SMike Rapoport		    "memory7/valid_zones: Movable Normal" shows this memoryblock
1816bf53999SMike Rapoport		    can be onlined to ZONE_MOVABLE by default and to ZONE_NORMAL
1826bf53999SMike Rapoport		    by online_kernel.
1836bf53999SMike Rapoport=================== ============================================================
1846bf53999SMike Rapoport
1856bf53999SMike Rapoport.. note::
1866bf53999SMike Rapoport
1876bf53999SMike Rapoport  These directories/files appear after physical memory hotplug phase.
1886bf53999SMike Rapoport
1896bf53999SMike RapoportIf CONFIG_NUMA is enabled the memoryXXX/ directories can also be accessed
1906bf53999SMike Rapoportvia symbolic links located in the ``/sys/devices/system/node/node*`` directories.
1916bf53999SMike Rapoport
1926bf53999SMike RapoportFor example::
1936bf53999SMike Rapoport
1946bf53999SMike Rapoport	/sys/devices/system/node/node0/memory9 -> ../../memory/memory9
1956bf53999SMike Rapoport
1966bf53999SMike RapoportA backlink will also be created::
1976bf53999SMike Rapoport
1986bf53999SMike Rapoport	/sys/devices/system/memory/memory9/node0 -> ../../node/node0
1996bf53999SMike Rapoport
2006bf53999SMike Rapoport.. _memory_hotplug_physical_mem:
2016bf53999SMike Rapoport
2026bf53999SMike RapoportPhysical memory hot-add phase
2036bf53999SMike Rapoport=============================
2046bf53999SMike Rapoport
2056bf53999SMike RapoportHardware(Firmware) Support
2066bf53999SMike Rapoport--------------------------
2076bf53999SMike Rapoport
2086bf53999SMike RapoportOn x86_64/ia64 platform, memory hotplug by ACPI is supported.
2096bf53999SMike Rapoport
2106bf53999SMike RapoportIn general, the firmware (ACPI) which supports memory hotplug defines
2116bf53999SMike Rapoportmemory class object of _HID "PNP0C80". When a notify is asserted to PNP0C80,
2126bf53999SMike RapoportLinux's ACPI handler does hot-add memory to the system and calls a hotplug udev
2136bf53999SMike Rapoportscript. This will be done automatically.
2146bf53999SMike Rapoport
2156bf53999SMike RapoportBut scripts for memory hotplug are not contained in generic udev package(now).
2166bf53999SMike RapoportYou may have to write it by yourself or online/offline memory by hand.
2176bf53999SMike RapoportPlease see :ref:`memory_hotplug_how_to_online_memory` and
2186bf53999SMike Rapoport:ref:`memory_hotplug_how_to_offline_memory`.
2196bf53999SMike Rapoport
2206bf53999SMike RapoportIf firmware supports NUMA-node hotplug, and defines an object _HID "ACPI0004",
2216bf53999SMike Rapoport"PNP0A05", or "PNP0A06", notification is asserted to it, and ACPI handler
2226bf53999SMike Rapoportcalls hotplug code for all of objects which are defined in it.
2236bf53999SMike RapoportIf memory device is found, memory hotplug code will be called.
2246bf53999SMike Rapoport
2256bf53999SMike RapoportNotify memory hot-add event by hand
2266bf53999SMike Rapoport-----------------------------------
2276bf53999SMike Rapoport
2286bf53999SMike RapoportOn some architectures, the firmware may not notify the kernel of a memory
2296bf53999SMike Rapoporthotplug event.  Therefore, the memory "probe" interface is supported to
2306bf53999SMike Rapoportexplicitly notify the kernel.  This interface depends on
2316bf53999SMike RapoportCONFIG_ARCH_MEMORY_PROBE and can be configured on powerpc, sh, and x86
2326bf53999SMike Rapoportif hotplug is supported, although for x86 this should be handled by ACPI
2336bf53999SMike Rapoportnotification.
2346bf53999SMike Rapoport
2356bf53999SMike RapoportProbe interface is located at::
2366bf53999SMike Rapoport
2376bf53999SMike Rapoport	/sys/devices/system/memory/probe
2386bf53999SMike Rapoport
2396bf53999SMike RapoportYou can tell the physical address of new memory to the kernel by::
2406bf53999SMike Rapoport
2416bf53999SMike Rapoport	% echo start_address_of_new_memory > /sys/devices/system/memory/probe
2426bf53999SMike Rapoport
2436bf53999SMike RapoportThen, [start_address_of_new_memory, start_address_of_new_memory +
2446bf53999SMike Rapoportmemory_block_size] memory range is hot-added. In this case, hotplug script is
2456bf53999SMike Rapoportnot called (in current implementation). You'll have to online memory by
2466bf53999SMike Rapoportyourself.  Please see :ref:`memory_hotplug_how_to_online_memory`.
2476bf53999SMike Rapoport
2486bf53999SMike RapoportLogical Memory hot-add phase
2496bf53999SMike Rapoport============================
2506bf53999SMike Rapoport
2516bf53999SMike RapoportState of memory
2526bf53999SMike Rapoport---------------
2536bf53999SMike Rapoport
2546bf53999SMike RapoportTo see (online/offline) state of a memory block, read 'state' file::
2556bf53999SMike Rapoport
2566bf53999SMike Rapoport	% cat /sys/device/system/memory/memoryXXX/state
2576bf53999SMike Rapoport
2586bf53999SMike Rapoport
2596bf53999SMike Rapoport- If the memory block is online, you'll read "online".
2606bf53999SMike Rapoport- If the memory block is offline, you'll read "offline".
2616bf53999SMike Rapoport
2626bf53999SMike Rapoport
2636bf53999SMike Rapoport.. _memory_hotplug_how_to_online_memory:
2646bf53999SMike Rapoport
2656bf53999SMike RapoportHow to online memory
2666bf53999SMike Rapoport--------------------
2676bf53999SMike Rapoport
2686bf53999SMike RapoportWhen the memory is hot-added, the kernel decides whether or not to "online"
2696bf53999SMike Rapoportit according to the policy which can be read from "auto_online_blocks" file::
2706bf53999SMike Rapoport
2716bf53999SMike Rapoport	% cat /sys/devices/system/memory/auto_online_blocks
2726bf53999SMike Rapoport
2736bf53999SMike RapoportThe default depends on the CONFIG_MEMORY_HOTPLUG_DEFAULT_ONLINE kernel config
2746bf53999SMike Rapoportoption. If it is disabled the default is "offline" which means the newly added
2756bf53999SMike Rapoportmemory is not in a ready-to-use state and you have to "online" the newly added
2766bf53999SMike Rapoportmemory blocks manually. Automatic onlining can be requested by writing "online"
2776bf53999SMike Rapoportto "auto_online_blocks" file::
2786bf53999SMike Rapoport
2796bf53999SMike Rapoport	% echo online > /sys/devices/system/memory/auto_online_blocks
2806bf53999SMike Rapoport
2816bf53999SMike RapoportThis sets a global policy and impacts all memory blocks that will subsequently
2826bf53999SMike Rapoportbe hotplugged. Currently offline blocks keep their state. It is possible, under
2836bf53999SMike Rapoportcertain circumstances, that some memory blocks will be added but will fail to
2846bf53999SMike Rapoportonline. User space tools can check their "state" files
2856bf53999SMike Rapoport(``/sys/devices/system/memory/memoryXXX/state``) and try to online them manually.
2866bf53999SMike Rapoport
2876bf53999SMike RapoportIf the automatic onlining wasn't requested, failed, or some memory block was
2886bf53999SMike Rapoportofflined it is possible to change the individual block's state by writing to the
2896bf53999SMike Rapoport"state" file::
2906bf53999SMike Rapoport
2916bf53999SMike Rapoport	% echo online > /sys/devices/system/memory/memoryXXX/state
2926bf53999SMike Rapoport
2936bf53999SMike RapoportThis onlining will not change the ZONE type of the target memory block,
2946bf53999SMike RapoportIf the memory block doesn't belong to any zone an appropriate kernel zone
2956bf53999SMike Rapoport(usually ZONE_NORMAL) will be used unless movable_node kernel command line
2966bf53999SMike Rapoportoption is specified when ZONE_MOVABLE will be used.
2976bf53999SMike Rapoport
2986bf53999SMike RapoportYou can explicitly request to associate it with ZONE_MOVABLE by::
2996bf53999SMike Rapoport
3006bf53999SMike Rapoport	% echo online_movable > /sys/devices/system/memory/memoryXXX/state
3016bf53999SMike Rapoport
3026bf53999SMike Rapoport.. note:: current limit: this memory block must be adjacent to ZONE_MOVABLE
3036bf53999SMike Rapoport
3046bf53999SMike RapoportOr you can explicitly request a kernel zone (usually ZONE_NORMAL) by::
3056bf53999SMike Rapoport
3066bf53999SMike Rapoport	% echo online_kernel > /sys/devices/system/memory/memoryXXX/state
3076bf53999SMike Rapoport
3086bf53999SMike Rapoport.. note:: current limit: this memory block must be adjacent to ZONE_NORMAL
3096bf53999SMike Rapoport
3106bf53999SMike RapoportAn explicit zone onlining can fail (e.g. when the range is already within
3116bf53999SMike Rapoportand existing and incompatible zone already).
3126bf53999SMike Rapoport
3136bf53999SMike RapoportAfter this, memory block XXX's state will be 'online' and the amount of
3146bf53999SMike Rapoportavailable memory will be increased.
3156bf53999SMike Rapoport
3166bf53999SMike RapoportThis may be changed in future.
3176bf53999SMike Rapoport
3186bf53999SMike RapoportLogical memory remove
3196bf53999SMike Rapoport=====================
3206bf53999SMike Rapoport
3216bf53999SMike RapoportMemory offline and ZONE_MOVABLE
3226bf53999SMike Rapoport-------------------------------
3236bf53999SMike Rapoport
3246bf53999SMike RapoportMemory offlining is more complicated than memory online. Because memory offline
3256bf53999SMike Rapoporthas to make the whole memory block be unused, memory offline can fail if
3266bf53999SMike Rapoportthe memory block includes memory which cannot be freed.
3276bf53999SMike Rapoport
3286bf53999SMike RapoportIn general, memory offline can use 2 techniques.
3296bf53999SMike Rapoport
3306bf53999SMike Rapoport(1) reclaim and free all memory in the memory block.
3316bf53999SMike Rapoport(2) migrate all pages in the memory block.
3326bf53999SMike Rapoport
3336bf53999SMike RapoportIn the current implementation, Linux's memory offline uses method (2), freeing
3346bf53999SMike Rapoportall  pages in the memory block by page migration. But not all pages are
3356bf53999SMike Rapoportmigratable. Under current Linux, migratable pages are anonymous pages and
3366bf53999SMike Rapoportpage caches. For offlining a memory block by migration, the kernel has to
3376bf53999SMike Rapoportguarantee that the memory block contains only migratable pages.
3386bf53999SMike Rapoport
3396bf53999SMike RapoportNow, a boot option for making a memory block which consists of migratable pages
3406bf53999SMike Rapoportis supported. By specifying "kernelcore=" or "movablecore=" boot option, you can
3416bf53999SMike Rapoportcreate ZONE_MOVABLE...a zone which is just used for movable pages.
3426bf53999SMike Rapoport(See also Documentation/admin-guide/kernel-parameters.rst)
3436bf53999SMike Rapoport
3446bf53999SMike RapoportAssume the system has "TOTAL" amount of memory at boot time, this boot option
3456bf53999SMike Rapoportcreates ZONE_MOVABLE as following.
3466bf53999SMike Rapoport
3476bf53999SMike Rapoport1) When kernelcore=YYYY boot option is used,
3486bf53999SMike Rapoport   Size of memory not for movable pages (not for offline) is YYYY.
3496bf53999SMike Rapoport   Size of memory for movable pages (for offline) is TOTAL-YYYY.
3506bf53999SMike Rapoport
3516bf53999SMike Rapoport2) When movablecore=ZZZZ boot option is used,
3526bf53999SMike Rapoport   Size of memory not for movable pages (not for offline) is TOTAL - ZZZZ.
3536bf53999SMike Rapoport   Size of memory for movable pages (for offline) is ZZZZ.
3546bf53999SMike Rapoport
3556bf53999SMike Rapoport.. note::
3566bf53999SMike Rapoport
3576bf53999SMike Rapoport   Unfortunately, there is no information to show which memory block belongs
3586bf53999SMike Rapoport   to ZONE_MOVABLE. This is TBD.
3596bf53999SMike Rapoport
3606bf53999SMike Rapoport.. _memory_hotplug_how_to_offline_memory:
3616bf53999SMike Rapoport
3626bf53999SMike RapoportHow to offline memory
3636bf53999SMike Rapoport---------------------
3646bf53999SMike Rapoport
3656bf53999SMike RapoportYou can offline a memory block by using the same sysfs interface that was used
3666bf53999SMike Rapoportin memory onlining::
3676bf53999SMike Rapoport
3686bf53999SMike Rapoport	% echo offline > /sys/devices/system/memory/memoryXXX/state
3696bf53999SMike Rapoport
3706bf53999SMike RapoportIf offline succeeds, the state of the memory block is changed to be "offline".
3716bf53999SMike RapoportIf it fails, some error core (like -EBUSY) will be returned by the kernel.
3726bf53999SMike RapoportEven if a memory block does not belong to ZONE_MOVABLE, you can try to offline
3736bf53999SMike Rapoportit.  If it doesn't contain 'unmovable' memory, you'll get success.
3746bf53999SMike Rapoport
3756bf53999SMike RapoportA memory block under ZONE_MOVABLE is considered to be able to be offlined
3766bf53999SMike Rapoporteasily.  But under some busy state, it may return -EBUSY. Even if a memory
3776bf53999SMike Rapoportblock cannot be offlined due to -EBUSY, you can retry offlining it and may be
3786bf53999SMike Rapoportable to offline it (or not). (For example, a page is referred to by some kernel
3796bf53999SMike Rapoportinternal call and released soon.)
3806bf53999SMike Rapoport
3816bf53999SMike RapoportConsideration:
3826bf53999SMike Rapoport  Memory hotplug's design direction is to make the possibility of memory
3836bf53999SMike Rapoport  offlining higher and to guarantee unplugging memory under any situation. But
3846bf53999SMike Rapoport  it needs more work. Returning -EBUSY under some situation may be good because
3856bf53999SMike Rapoport  the user can decide to retry more or not by himself. Currently, memory
3866bf53999SMike Rapoport  offlining code does some amount of retry with 120 seconds timeout.
3876bf53999SMike Rapoport
3886bf53999SMike RapoportPhysical memory remove
3896bf53999SMike Rapoport======================
3906bf53999SMike Rapoport
3916bf53999SMike RapoportNeed more implementation yet....
3926bf53999SMike Rapoport - Notification completion of remove works by OS to firmware.
3936bf53999SMike Rapoport - Guard from remove if not yet.
3946bf53999SMike Rapoport
395*dee6da22SDavid Hildenbrand
396*dee6da22SDavid HildenbrandLocking Internals
397*dee6da22SDavid Hildenbrand=================
398*dee6da22SDavid Hildenbrand
399*dee6da22SDavid HildenbrandWhen adding/removing memory that uses memory block devices (i.e. ordinary RAM),
400*dee6da22SDavid Hildenbrandthe device_hotplug_lock should be held to:
401*dee6da22SDavid Hildenbrand
402*dee6da22SDavid Hildenbrand- synchronize against online/offline requests (e.g. via sysfs). This way, memory
403*dee6da22SDavid Hildenbrand  block devices can only be accessed (.online/.state attributes) by user
404*dee6da22SDavid Hildenbrand  space once memory has been fully added. And when removing memory, we
405*dee6da22SDavid Hildenbrand  know nobody is in critical sections.
406*dee6da22SDavid Hildenbrand- synchronize against CPU hotplug and similar (e.g. relevant for ACPI and PPC)
407*dee6da22SDavid Hildenbrand
408*dee6da22SDavid HildenbrandEspecially, there is a possible lock inversion that is avoided using
409*dee6da22SDavid Hildenbranddevice_hotplug_lock when adding memory and user space tries to online that
410*dee6da22SDavid Hildenbrandmemory faster than expected:
411*dee6da22SDavid Hildenbrand
412*dee6da22SDavid Hildenbrand- device_online() will first take the device_lock(), followed by
413*dee6da22SDavid Hildenbrand  mem_hotplug_lock
414*dee6da22SDavid Hildenbrand- add_memory_resource() will first take the mem_hotplug_lock, followed by
415*dee6da22SDavid Hildenbrand  the device_lock() (while creating the devices, during bus_add_device()).
416*dee6da22SDavid Hildenbrand
417*dee6da22SDavid HildenbrandAs the device is visible to user space before taking the device_lock(), this
418*dee6da22SDavid Hildenbrandcan result in a lock inversion.
419*dee6da22SDavid Hildenbrand
420*dee6da22SDavid Hildenbrandonlining/offlining of memory should be done via device_online()/
421*dee6da22SDavid Hildenbranddevice_offline() - to make sure it is properly synchronized to actions
422*dee6da22SDavid Hildenbrandvia sysfs. Holding device_hotplug_lock is advised (to e.g. protect online_type)
423*dee6da22SDavid Hildenbrand
424*dee6da22SDavid HildenbrandWhen adding/removing/onlining/offlining memory or adding/removing
425*dee6da22SDavid Hildenbrandheterogeneous/device memory, we should always hold the mem_hotplug_lock in
426*dee6da22SDavid Hildenbrandwrite mode to serialise memory hotplug (e.g. access to global/zone
427*dee6da22SDavid Hildenbrandvariables).
428*dee6da22SDavid Hildenbrand
429*dee6da22SDavid HildenbrandIn addition, mem_hotplug_lock (in contrast to device_hotplug_lock) in read
430*dee6da22SDavid Hildenbrandmode allows for a quite efficient get_online_mems/put_online_mems
431*dee6da22SDavid Hildenbrandimplementation, so code accessing memory can protect from that memory
432*dee6da22SDavid Hildenbrandvanishing.
433*dee6da22SDavid Hildenbrand
434*dee6da22SDavid Hildenbrand
4356bf53999SMike RapoportFuture Work
4366bf53999SMike Rapoport===========
4376bf53999SMike Rapoport
4386bf53999SMike Rapoport  - allowing memory hot-add to ZONE_MOVABLE. maybe we need some switch like
4396bf53999SMike Rapoport    sysctl or new control file.
4406bf53999SMike Rapoport  - showing memory block and physical device relationship.
4416bf53999SMike Rapoport  - test and make it better memory offlining.
4426bf53999SMike Rapoport  - support HugeTLB page migration and offlining.
4436bf53999SMike Rapoport  - memmap removing at memory offline.
4446bf53999SMike Rapoport  - physical remove memory.
445