From c40358ff0dde891b11ab474ec8aa4c37b2746be3 Mon Sep 17 00:00:00 2001 From: buxiasen Date: Wed, 21 Aug 2024 11:19:28 +0800 Subject: [PATCH] pm: update document, add pm_idle interface for not-smp case Signed-off-by: buxiasen --- .../drivers/special/power/pm/index.rst | 24 +++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/Documentation/components/drivers/special/power/pm/index.rst b/Documentation/components/drivers/special/power/pm/index.rst index fdaed82885..72b3fdc24c 100644 --- a/Documentation/components/drivers/special/power/pm/index.rst +++ b/Documentation/components/drivers/special/power/pm/index.rst @@ -221,9 +221,33 @@ All PM interfaces are declared in the file ``include/nuttx/power/pm.h``. completes the entire state change unless interrupts are disabled throughout the state change. +.. c:function:: void pm_idle(pm_idle_handler_t handler) + + This function provide standard pm idle work flow for up_idle. + Called from the chip bsp and should only focus on handle the system + state changed. + + :param handler: The execution after PM_IDLE_DOMAIN state changed + + :return: + None + Callbacks ========= +.. c:typedef::pm_idle_handler_t + + This type declare is provide for pm_idle interface. + Handle the pm low power action and execution for not SMP case. + Possible execution for long time because of WFI inside. + + .. code-block:: c + + typedef void (*pm_idle_handler_t)(enum pm_state_e); + + :param pm_state_e: + Indicate the new system power state. + .. c:struct:: pm_callback_s This struct includes the pointers to the driver