Provided by: util-linux_2.31.1-0.4ubuntu3.7_amd64 bug

NAME

       chmem - configure memory

SYNOPSIS

       chmem [-h] [-V] [-v] [-e|-d] [SIZE|RANGE|-b BLOCKRANGE] [-z ZONE]

DESCRIPTION

       The chmem command sets a particular size or range of memory online or offline.

       ‐ Specify  SIZE  as  <size>[m|M|g|G].  With  m or M, <size> specifies the memory size in MiB (1024 x 1024
         bytes). With g or G, <size> specifies the memory size in GiB (1024 x 1024 x 1024  bytes).  The  default
         unit is MiB.

       ‐ Specify RANGE in the form 0x<start>-0x<end> as shown in the output of the lsmem command. <start> is the
         hexadecimal address of the first byte and <end> is the hexadecimal address of  the  last  byte  in  the
         memory range.

       ‐ Specify  BLOCKRANGE  in the form <first>-<last> or <block> as shown in the output of the lsmem command.
         <first> is the number of the first memory block and <last> is the number of the last  memory  block  in
         the  memory  range.  Alternatively  a  single  block can be specified. BLOCKRANGE requires the --blocks
         option.

       ‐ Specify ZONE as the name of a memory zone, as shown in the output of the lsmem -o +ZONES  command.  The
         output  shows  one  or more valid memory zones for each memory range. If multiple zones are shown, then
         the memory range currently belongs to the first zone. By default, chmem will set memory online  to  the
         zone  Movable,  if  this is among the valid zones. This default can be changed by specifying the --zone
         option with another valid zone.  For memory ballooning, it is recommended to select  the  zone  Movable
         for  memory  online  and offline, if possible. Memory in this zone is much more likely to be able to be
         offlined again, but it cannot be used for arbitrary kernel allocations, only for migratable pages (e.g.
         anonymous and page cache pages).  Use the --help option to see all available zones.

       SIZE  and  RANGE  must  be  aligned  to  the Linux memory block size, as shown in the output of the lsmem
       command.

       Setting memory online can fail for various reasons. On virtualized systems it can fail if the  hypervisor
       does  not  have  enough memory left, for example because memory was overcommitted. Setting memory offline
       can fail if Linux cannot free the memory. If only part of the requested  memory  can  be  set  online  or
       offline, a message tells you how much memory was set online or offline instead of the requested amount.

       When setting memory online chmem starts with the lowest memory block numbers. When setting memory offline
       chmem starts with the highest memory block numbers.

OPTIONS

       -b, --blocks
              Use a BLOCKRANGE parameter instead of RANGE or SIZE for the --enable and --disable options.

       -d, --disable
              Set the specified RANGE, SIZE, or BLOCKRANGE of memory offline.

       -e, --enable
              Set the specified RANGE, SIZE, or BLOCKRANGE of memory online.

       -z, --zone
              Select the memory ZONE where to set the specified RANGE, SIZE, or BLOCKRANGE of memory  online  or
              offline. By default, memory will be set online to the zone Movable, if possible.

       -h, --help
              Print a short help text, then exit.

       -v, --verbose
              Verbose mode. Causes chmem to print debugging messages about it's progress.

       -V, --version
              Print the version number, then exit.

RETURN CODES

       chmem has the following return codes:

       0      success

       1      failure

       64     partial success

EXAMPLES

       chmem --enable 1024
              This command requests 1024 MiB of memory to be set online.

       chmem -e 2g
              This command requests 2 GiB of memory to be set online.

       chmem --disable 0x00000000e4000000-0x00000000f3ffffff
              This  command  requests  the  memory  range  starting  with  0x00000000e4000000  and  ending  with
              0x00000000f3ffffff to be set offline.

       chmem -b -d 10
              This command requests the memory block number 10 to be set offline.

SEE ALSO

       lsmem(1)

AVAILABILITY

       The chmem command is part of the util-linux package and is available from Linux Kernel Archive  ⟨https://
       www.kernel.org/pub/linux/utils/util-linux/⟩.