Skip to content

Commit

Permalink
cyclic: Add documentation
Browse files Browse the repository at this point in the history
Add documentation for the cyclic function infrastructure, including the
cyclic command.

Signed-off-by: Stefan Roese <sr@denx.de>
Reviewed-by: Simon Glass <sjg@chromium.org>
  • Loading branch information
stroese authored and trini committed Sep 13, 2022
1 parent 5ee0fa7 commit 00275f5
Show file tree
Hide file tree
Showing 4 changed files with 97 additions and 0 deletions.
50 changes: 50 additions & 0 deletions doc/develop/cyclic.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
.. SPDX-License-Identifier: GPL-2.0+
Cyclic functions
================

The cyclic function execution infrastruture provides a way to periodically
execute code, e.g. every 100ms. Examples for such functions might be LED
blinking etc. The functions that are hooked into this cyclic list should
be small timewise as otherwise the execution of the other code that relies
on a high frequent polling (e.g. UART rx char ready check) might be
delayed too much. To detect cyclic functions with a too long execution
time, the Kconfig option `CONFIG_CYCLIC_MAX_CPU_TIME_US` is introduced,
which configures the max allowed time for such a cyclic function. If it's
execution time exceeds this time, this cyclic function will get removed
from the cyclic list.

Registering a cyclic function
-----------------------------

To register a cyclic function, use something like this::

static void cyclic_demo(void *ctx)
{
/* Just a small dummy delay here */
udelay(10);
}
int board_init(void)
{
struct cyclic_info *cyclic;
/* Register demo cyclic function */
cyclic = cyclic_register(cyclic_demo, 10 * 1000, "cyclic_demo", NULL);
if (!cyclic)
printf("Registering of cyclic_demo failed\n");
return 0;
}

This will register the function `cyclic_demo()` to be periodically
executed all 10ms.

How is this cyclic functionality integrated / executed?
--------------------------------------------------------

The cyclic infrastructure integrates the main function responsible for
calling all registered cyclic functions cyclic_run() into the common
WATCHDOG_RESET macro. This guarantees that cyclic_run() is executed
very often, which is necessary for the cyclic functions to get scheduled
and executed at their configured periods.
1 change: 1 addition & 0 deletions doc/develop/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ Implementation
ci_testing
commands
config_binding
cyclic
devicetree/index
distro
driver-model/index
Expand Down
45 changes: 45 additions & 0 deletions doc/usage/cmd/cyclic.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
.. SPDX-License-Identifier: GPL-2.0+
cyclic command
==============

Synopsis
--------

::

cyclic list

Description
-----------

The cyclic list command provides a list of the currently registered
cyclic functions.

This shows the following information:

Function
Function name

cpu-time
Total time spent in this cyclic function.

Frequency
Frequency of execution of this function, e.g. 100 times/s for a
pediod of 10ms.


See :doc:`../../develop/cyclic` for more information on cyclic functions.

Example
-------

::

=> cyclic list
function: cyclic_demo, cpu-time: 52906 us, frequency: 99.20 times/s

Configuration
-------------

The cyclic command is only available if CONFIG_CMD_CYCLIC=y.
1 change: 1 addition & 0 deletions doc/usage/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ Shell commands
cmd/bootz
cmd/cbsysinfo
cmd/conitrace
cmd/cyclic
cmd/dm
cmd/echo
cmd/env
Expand Down

0 comments on commit 00275f5

Please sign in to comment.