Commit d31f5626 authored by SeongJae Park's avatar SeongJae Park Committed by Andrew Morton

Docs/mm/damon/design: add links to sections of DAMON sysfs interface usage doc

Readers of the design document would wonder how they can configure and use
specific DAMON features.  Add links to sections of DAMON sysfs interface
usage document that provides the answers for easier browsing.

Link: https://lkml.kernel.org/r/20240701192706.51415-8-sj@kernel.orgSigned-off-by: default avatarSeongJae Park <sj@kernel.org>
Cc: Jonathan Corbet <corbet@lwn.net>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent ce15e8fe
...@@ -16,6 +16,9 @@ called DAMON ``context``. DAMON executes each context with a kernel thread ...@@ -16,6 +16,9 @@ called DAMON ``context``. DAMON executes each context with a kernel thread
called ``kdamond``. Multiple kdamonds could run in parallel, for different called ``kdamond``. Multiple kdamonds could run in parallel, for different
types of monitoring. types of monitoring.
To know how user-space can do the configurations and start/stop DAMON, refer to
:ref:`DAMON sysfs interface <sysfs_interface>` documentation.
Overall Architecture Overall Architecture
==================== ====================
...@@ -71,6 +74,10 @@ describe how those work. ...@@ -71,6 +74,10 @@ describe how those work.
- fvaddr: Monitor fixed virtual address ranges - fvaddr: Monitor fixed virtual address ranges
- paddr: Monitor the physical address space of the system - paddr: Monitor the physical address space of the system
To know how user-space can do the configuration via :ref:`DAMON sysfs interface
<sysfs_interface>`, refer to :ref:`operations <sysfs_context>` file part of the
documentation.
.. _damon_design_vaddr_target_regions_construction: .. _damon_design_vaddr_target_regions_construction:
...@@ -143,6 +150,10 @@ monitoring attributes, ``sampling interval``, ``aggregation interval``, ...@@ -143,6 +150,10 @@ monitoring attributes, ``sampling interval``, ``aggregation interval``,
``update interval``, ``minimum number of regions``, and ``maximum number of ``update interval``, ``minimum number of regions``, and ``maximum number of
regions``. regions``.
To know how user-space can set the attributes via :ref:`DAMON sysfs interface
<sysfs_interface>`, refer to :ref:`monitoring_attrs <sysfs_monitoring_attrs>`
part of the documentation.
Access Frequency Monitoring Access Frequency Monitoring
~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~
...@@ -246,6 +257,11 @@ and applies it to monitoring operations-related data structures such as the ...@@ -246,6 +257,11 @@ and applies it to monitoring operations-related data structures such as the
abstracted monitoring target memory area only for each of a user-specified time abstracted monitoring target memory area only for each of a user-specified time
interval (``update interval``). interval (``update interval``).
User-space can get the monitoring results via DAMON sysfs interface and/or
tracepoints. For more details, please refer to the documentations for
:ref:`DAMOS tried regions <sysfs_schemes_tried_regions>` and :ref:`tracepoint`,
respectively.
.. _damon_design_damos: .. _damon_design_damos:
...@@ -286,6 +302,10 @@ the access pattern of interest, and applies the user-desired operation actions ...@@ -286,6 +302,10 @@ the access pattern of interest, and applies the user-desired operation actions
to the regions, for every user-specified time interval called to the regions, for every user-specified time interval called
``apply_interval``. ``apply_interval``.
To know how user-space can set ``apply_interval`` via :ref:`DAMON sysfs
interface <sysfs_interface>`, refer to :ref:`apply_interval_us <sysfs_scheme>`
part of the documentation.
.. _damon_design_damos_action: .. _damon_design_damos_action:
...@@ -334,6 +354,10 @@ Applying the actions except ``stat`` to a region is considered as changing the ...@@ -334,6 +354,10 @@ Applying the actions except ``stat`` to a region is considered as changing the
region's characteristics. Hence, DAMOS resets the age of regions when any such region's characteristics. Hence, DAMOS resets the age of regions when any such
actions are applied to those. actions are applied to those.
To know how user-space can set the action via :ref:`DAMON sysfs interface
<sysfs_interface>`, refer to :ref:`action <sysfs_scheme>` part of the
documentation.
.. _damon_design_damos_access_pattern: .. _damon_design_damos_access_pattern:
...@@ -347,6 +371,10 @@ interest by setting minimum and maximum values of the three properties. If a ...@@ -347,6 +371,10 @@ interest by setting minimum and maximum values of the three properties. If a
region's three properties are in the ranges, DAMOS classifies it as one of the region's three properties are in the ranges, DAMOS classifies it as one of the
regions that the scheme is having an interest in. regions that the scheme is having an interest in.
To know how user-space can set the access pattern via :ref:`DAMON sysfs
interface <sysfs_interface>`, refer to :ref:`access_pattern
<sysfs_access_pattern>` part of the documentation.
.. _damon_design_damos_quotas: .. _damon_design_damos_quotas:
...@@ -366,6 +394,10 @@ feature called quotas. It lets users specify an upper limit of time that DAMOS ...@@ -366,6 +394,10 @@ feature called quotas. It lets users specify an upper limit of time that DAMOS
can use for applying the action, and/or a maximum bytes of memory regions that can use for applying the action, and/or a maximum bytes of memory regions that
the action can be applied within a user-specified time duration. the action can be applied within a user-specified time duration.
To know how user-space can set the basic quotas via :ref:`DAMON sysfs interface
<sysfs_interface>`, refer to :ref:`quotas <sysfs_quotas>` part of the
documentation.
.. _damon_design_damos_quotas_prioritization: .. _damon_design_damos_quotas_prioritization:
...@@ -393,6 +425,10 @@ information to the underlying mechanism. Nevertheless, how and even whether ...@@ -393,6 +425,10 @@ information to the underlying mechanism. Nevertheless, how and even whether
the weight will be respected are up to the underlying prioritization mechanism the weight will be respected are up to the underlying prioritization mechanism
implementation. implementation.
To know how user-space can set the prioritization weights via :ref:`DAMON sysfs
interface <sysfs_interface>`, refer to :ref:`weights <sysfs_quotas>` part of
the documentation.
.. _damon_design_damos_quotas_auto_tuning: .. _damon_design_damos_quotas_auto_tuning:
...@@ -422,6 +458,10 @@ Currently, two ``target_metric`` are provided. ...@@ -422,6 +458,10 @@ Currently, two ``target_metric`` are provided.
DAMOS does the measurement on its own, so only ``target_value`` need to be DAMOS does the measurement on its own, so only ``target_value`` need to be
set by users at the initial time. In other words, DAMOS does self-feedback. set by users at the initial time. In other words, DAMOS does self-feedback.
To know how user-space can set the tuning goal metric, the target value, and/or
the current value via :ref:`DAMON sysfs interface <sysfs_interface>`, refer to
:ref:`quota goals <sysfs_schemes_quota_goals>` part of the documentation.
.. _damon_design_damos_watermarks: .. _damon_design_damos_watermarks:
...@@ -444,6 +484,10 @@ is activated. If all schemes are deactivated by the watermarks, the monitoring ...@@ -444,6 +484,10 @@ is activated. If all schemes are deactivated by the watermarks, the monitoring
is also deactivated. In this case, the DAMON worker thread only periodically is also deactivated. In this case, the DAMON worker thread only periodically
checks the watermarks and therefore incurs nearly zero overhead. checks the watermarks and therefore incurs nearly zero overhead.
To know how user-space can set the watermarks via :ref:`DAMON sysfs interface
<sysfs_interface>`, refer to :ref:`watermarks <sysfs_watermarks>` part of the
documentation.
.. _damon_design_damos_filters: .. _damon_design_damos_filters:
...@@ -490,6 +534,10 @@ Below types of filters are currently supported. ...@@ -490,6 +534,10 @@ Below types of filters are currently supported.
- Applied to pages that belonging to a given DAMON monitoring target. - Applied to pages that belonging to a given DAMON monitoring target.
- Handled by the core logic. - Handled by the core logic.
To know how user-space can set the watermarks via :ref:`DAMON sysfs interface
<sysfs_interface>`, refer to :ref:`filters <sysfs_filters>` part of the
documentation.
Application Programming Interface Application Programming Interface
--------------------------------- ---------------------------------
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment