-
Notifications
You must be signed in to change notification settings - Fork 232
Likwid Memsweeper
To utilize the parallel memory bandwidth available on ccNUMA systems it is necessary to load data mainly from local memory seen from the threads point of view. While the operating system usually decides where a page is placed on Linux the default page placement policy is first touch. This means that a memory page is placed in the NUMA memory domain the thread which writes first to the page runs in. By this software has explicit control where the data is placed.
Still first touch is only a hint where you want the page to be placed, the operating system still can decide to place it elsewhere. This can for example happen if the local NUMA domain is already full and there is space free in a remote domain. This frequently happens if you or another user has accessed a large file. To speed up subsequent access to files Linux maintains a so called file buffer cache, which can consume a large part of the available memory. This may cause your data to be placed in a remote domain even if you have employed correct first touch placement.
There are multiple solutions to this problem. Root can execute a command to
drop the file buffer cache. You can use numactl tools or the belonging library
to enforce page placement. Still there is some danger here if you use no swap.
You can also allocate almost all of the physical memory and write to it which
will also cause the file buffer cache to be dropped. This is exactly what
likwid-memsweeper is doing. It allows you to clean up all or some of the ccNUMA
domains on a compute node in a safe and convenient way. This functionality is
also available as an option (-S
) to likwid-pin.
An advantage of likwid-memsweeper compared to numactl or other tools is the cleaning of the last level cache. This reduces the number of cache misses caused by cache lines loaded by other applications.
-h Help message
-v Version information
-c <list> Specify NUMA domain ID to clean up
You can get a help message with
$ likwid-memsweeper -h
To cleanup all ccNUMA domains of a node call:
$ likwid-memsweeper
To cleanup a specific ccNUMA domains call:
$ likwid-memsweeper -c 0
-
Applications
-
Config files
-
Daemons
-
Architectures
- Available counter options
- AMD
- Intel
- Intel Atom
- Intel Pentium M
- Intel Core2
- Intel Nehalem
- Intel NehalemEX
- Intel Westmere
- Intel WestmereEX
- Intel Xeon Phi (KNC)
- Intel Silvermont & Airmont
- Intel Goldmont
- Intel SandyBridge
- Intel SandyBridge EP/EN
- Intel IvyBridge
- Intel IvyBridge EP/EN/EX
- Intel Haswell
- Intel Haswell EP/EN/EX
- Intel Broadwell
- Intel Broadwell D
- Intel Broadwell EP
- Intel Skylake
- Intel Coffeelake
- Intel Kabylake
- Intel Xeon Phi (KNL)
- Intel Skylake X
- Intel Cascadelake SP/AP
- Intel Tigerlake
- Intel Icelake
- Intel Icelake X
- Intel SappireRapids
- Intel GraniteRapids
- Intel SierraForrest
- ARM
- POWER
-
Tutorials
-
Miscellaneous
-
Contributing