[PATCH v3 6/6] Documentation: coresight: Update coresight configuration docs
Mathieu Poirier
mathieu.poirier at linaro.org
Fri Nov 26 10:26:22 PST 2021
On Wed, Nov 24, 2021 at 08:00:38PM +0000, Mike Leach wrote:
> Update the CoreSight System Configuration document to cover the
> use of loadable modules to add configurations and features
> to the system.
>
> Signed-off-by: Mike Leach <mike.leach at linaro.org>
> ---
> .../trace/coresight/coresight-config.rst | 62 ++++++++++++++++++-
> 1 file changed, 59 insertions(+), 3 deletions(-)
>
> diff --git a/Documentation/trace/coresight/coresight-config.rst b/Documentation/trace/coresight/coresight-config.rst
> index 6ed13398ca2c..6d5ffa6f7347 100644
> --- a/Documentation/trace/coresight/coresight-config.rst
> +++ b/Documentation/trace/coresight/coresight-config.rst
> @@ -155,14 +155,14 @@ follows::
> autofdo
> $ cd autofdo/
> $ ls
> - description preset1 preset3 preset5 preset7 preset9
> - feature_refs preset2 preset4 preset6 preset8
> + description feature_refs preset1 preset3 preset5 preset7 preset9
> + enable preset preset2 preset4 preset6 preset8
> $ cat description
> Setup ETMs with strobing for autofdo
> $ cat feature_refs
> strobing
>
> -Each preset declared has a preset<n> subdirectory declared. The values for
> +Each preset declared has a 'preset<n>' subdirectory declared. The values for
> the preset can be examined::
>
> $ cat preset1/values
> @@ -170,6 +170,9 @@ the preset can be examined::
> $ cat preset2/values
> strobing.window = 0x1388 strobing.period = 0x4
>
> +The 'enable' and 'preset' files allow the control of a configuration when
> +using CoreSight with sysfs.
> +
> The features referenced by the configuration can be examined in the features
> directory::
>
> @@ -236,3 +239,56 @@ A preset to override the current parameter values can also be selected::
>
> When configurations are selected in this way, then the trace sink used is
> automatically selected.
> +
> +Using Configurations in sysfs
> +=============================
> +
> +Coresight can be controlled using sysfs. When this is in use then a configuration
> +can be made active for the devices that are used in the sysfs session.
> +
> +In a configuration there are 'enable' and 'preset' files.
> +
> +To enable a configuration for use with sysfs::
> +
> + $ cd configurations/autofdo
> + $ echo 1 > enable
> +
> +This will then use any default parameter values in the features - which can be
> +adjusted as described above.
> +
> +To use a preset<n> set of parameter values::
> +
> + $ echo 3 > preset
> +
> +This will select preset3 for the configuration.
> +The valid values for preset are 0 - to deselect presets, and any value of
> +<n> where a preset<n> sub-directory is present.
> +
> +Note that the active sysfs configuration is a global parameter, therefore
> +only a single configuration can be active for sysfs at any one time.
> +Attempting to enable a second configuration will result in an error.
> +Additionally, attempting to disable the configuration while in use will
> +also result in an error.
> +
> +The use of the active configuration by sysfs is independent of the configuration
> +used in perf.
> +
Shouldn't all instances in the above section be configfs rather than sysfs? If
so should I make the changes?
I have your patchset on stanby in my local coresight-next tree - just let me
know.
Thanks,
Mathieu
> +
> +Creating and Loading Custom Configurations
> +==========================================
> +
> +Custom configurations and / or features can be dynamically loaded into the
> +system by using a loadable module.
> +
> +An example of a custom configuration is found in ./samples/coresight.
> +
> +This creates a new configuration that uses the existing built in
> +strobing feature, but provides a different set of presets.
> +
> +When the module is loaded, then the configuration appears in the configfs
> +file system and is selectable in the same way as the built in configuration
> +described above.
> +
> +Configurations can use previously loaded features. The system will ensure
> +that it is not possible to unload a feature that is currently in use, by
> +enforcing the unload order as the strict reverse of the load order.
> --
> 2.17.1
>
More information about the linux-arm-kernel
mailing list