xref: /linux/Documentation/mm/damon/index.rst (revision d7bf4786b5250b0e490a937d1f8a16ee3a54adbe)
1.. SPDX-License-Identifier: GPL-2.0
2
3==========================
4DAMON: Data Access MONitor
5==========================
6
7DAMON is a Linux kernel subsystem that provides a framework for data access
8monitoring and the monitoring results based system operations.  The core
9monitoring :ref:`mechanisms <damon_design_monitoring>` of DAMON make it
10
11 - *accurate* (the monitoring output is useful enough for DRAM level memory
12   management; It might not appropriate for CPU Cache levels, though),
13 - *light-weight* (the monitoring overhead is low enough to be applied online),
14   and
15 - *scalable* (the upper-bound of the overhead is in constant range regardless
16   of the size of target workloads).
17
18Using this framework, therefore, the kernel can operate system in an
19access-aware fashion.  Because the features are also exposed to the :doc:`user
20space </admin-guide/mm/damon/index>`, users who have special information about
21their workloads can write personalized applications for better understanding
22and optimizations of their workloads and systems.
23
24For easier development of such systems, DAMON provides a feature called
25:ref:`DAMOS <damon_design_damos>` (DAMon-based Operation Schemes) in addition
26to the monitoring.  Using the feature, DAMON users in both kernel and :doc:`user
27spaces </admin-guide/mm/damon/index>` can do access-aware system operations
28with no code but simple configurations.
29
30.. toctree::
31   :maxdepth: 2
32
33   faq
34   design
35   api
36   maintainer-profile
37
38To utilize and control DAMON from the user-space, please refer to the
39administration :doc:`guide </admin-guide/mm/damon/index>`.
40
41If you prefer academic papers for reading and citations, please use the papers
42from `HPDC'22 <https://dl.acm.org/doi/abs/10.1145/3502181.3531466>`_ and
43`Middleware19 Industry <https://dl.acm.org/doi/abs/10.1145/3366626.3368125>`_ .
44Note that those cover DAMON implementations in Linux v5.16 and v5.15,
45respectively.
46