2021-09-20 11:37:03 +05:30
|
|
|
/*
|
2023-12-24 21:37:45 +01:00
|
|
|
* SPDX-FileCopyrightText: 2015-2024 Espressif Systems (Shanghai) CO LTD
|
2021-09-20 11:37:03 +05:30
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2021-08-04 10:56:37 +08:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2022-03-24 13:45:19 +08:00
|
|
|
#include "sdkconfig.h"
|
2021-08-04 10:56:37 +08:00
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
|
2023-09-21 17:17:49 +08:00
|
|
|
/*
|
|
|
|
* This header contains private API used by various ESP-IDF debugging features (e.g., esp_gdbstub).
|
|
|
|
*/
|
|
|
|
|
2023-08-28 18:23:50 +08:00
|
|
|
/* *INDENT-OFF* */
|
2021-08-04 10:56:37 +08:00
|
|
|
#ifdef __cplusplus
|
2023-08-28 18:23:50 +08:00
|
|
|
extern "C" {
|
2021-08-04 10:56:37 +08:00
|
|
|
#endif
|
2023-08-28 18:23:50 +08:00
|
|
|
/* *INDENT-ON* */
|
2021-08-04 10:56:37 +08:00
|
|
|
|
2023-09-21 18:07:13 +08:00
|
|
|
/* -------------------------------------------------- Task Snapshot ------------------------------------------------- */
|
|
|
|
|
2021-08-04 10:56:37 +08:00
|
|
|
/**
|
2022-03-24 13:45:19 +08:00
|
|
|
* @brief Task Snapshot structure
|
|
|
|
*
|
|
|
|
* - Used with the uxTaskGetSnapshotAll() function to save memory snapshot of each task in the system.
|
|
|
|
* - We need this structure because TCB_t is defined (hidden) in tasks.c.
|
2021-08-04 10:56:37 +08:00
|
|
|
*/
|
|
|
|
typedef struct xTASK_SNAPSHOT
|
|
|
|
{
|
2023-08-28 18:23:50 +08:00
|
|
|
void * pxTCB; /*!< Address of the task control block. */
|
|
|
|
StackType_t * pxTopOfStack; /*!< Points to the location of the last item placed on the tasks stack. */
|
|
|
|
StackType_t * pxEndOfStack; /*!< Points to the end of the stack. pxTopOfStack < pxEndOfStack, stack grows hi2lo
|
|
|
|
* pxTopOfStack > pxEndOfStack, stack grows lo2hi*/
|
2021-08-04 10:56:37 +08:00
|
|
|
} TaskSnapshot_t;
|
|
|
|
|
2022-03-24 13:45:19 +08:00
|
|
|
/**
|
2023-12-24 21:37:45 +01:00
|
|
|
* @brief Task Snapshot iterator
|
2022-03-24 13:45:19 +08:00
|
|
|
*
|
2023-12-24 21:37:45 +01:00
|
|
|
* Used in xTaskGetNext(). Must be zero/null initialized on the first call.
|
|
|
|
*/
|
|
|
|
typedef struct TaskIterator
|
|
|
|
{
|
|
|
|
UBaseType_t uxCurrentListIndex; /**< Current task list index being traversed. */
|
|
|
|
ListItem_t * pxNextListItem; /**< Next task list item will being traversed. */
|
|
|
|
TaskHandle_t pxTaskHandle; /**< Current task handle being traversed. */
|
|
|
|
} TaskIterator_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the next task using the task iterator.
|
|
|
|
*
|
|
|
|
* This function retrieves the next task in the traversal sequence.
|
|
|
|
*
|
|
|
|
* @param xIterator Pointer to the task iterator structure.
|
|
|
|
*
|
|
|
|
* @return Index of the current task list. Returns -1 if all tasks have been traversed.
|
|
|
|
*
|
|
|
|
* @note The task iterator keeps track of the current state during task traversal,
|
|
|
|
* including the index of the current task list and the pointer of the next task list item.
|
|
|
|
* When all tasks have been traversed, this function returns -1.
|
|
|
|
* If a broken or corrupted task is encountered, the task handle is set to NULL.
|
2022-03-24 13:45:19 +08:00
|
|
|
*
|
2021-08-04 10:56:37 +08:00
|
|
|
*/
|
2023-12-24 21:37:45 +01:00
|
|
|
int xTaskGetNext( TaskIterator_t * xIterator );
|
2021-08-04 10:56:37 +08:00
|
|
|
|
2022-03-24 13:45:19 +08:00
|
|
|
/**
|
|
|
|
* @brief Fill a TaskSnapshot_t structure for specified task.
|
|
|
|
*
|
|
|
|
* - This function is used by the panic handler to get the snapshot of a particular task.
|
|
|
|
*
|
|
|
|
* @note This function should only be called when FreeRTOS is no longer running (e.g., during a panic) as this function
|
2023-03-13 23:09:18 +08:00
|
|
|
* does not acquire any locks.
|
2022-03-24 13:45:19 +08:00
|
|
|
* @param[in] pxTask Task's handle
|
|
|
|
* @param[out] pxTaskSnapshot Snapshot of the task
|
2022-05-09 15:47:13 +05:30
|
|
|
* @return pdTRUE if operation was successful else pdFALSE
|
2021-08-04 10:56:37 +08:00
|
|
|
*/
|
2023-08-28 18:23:50 +08:00
|
|
|
BaseType_t vTaskGetSnapshot( TaskHandle_t pxTask,
|
|
|
|
TaskSnapshot_t * pxTaskSnapshot );
|
2021-08-04 10:56:37 +08:00
|
|
|
|
2022-03-24 13:45:19 +08:00
|
|
|
/**
|
|
|
|
* @brief Fill an array of TaskSnapshot_t structures for every task in the system
|
|
|
|
*
|
|
|
|
* - This function is used by the panic handler to get a snapshot of all tasks in the system
|
|
|
|
*
|
|
|
|
* @note This function should only be called when FreeRTOS is no longer running (e.g., during a panic) as this function
|
2023-03-13 23:09:18 +08:00
|
|
|
* does not acquire any locks.
|
2022-03-24 13:45:19 +08:00
|
|
|
* @param[out] pxTaskSnapshotArray Array of TaskSnapshot_t structures filled by this function
|
|
|
|
* @param[in] uxArrayLength Length of the provided array
|
2023-06-01 17:57:08 -07:00
|
|
|
* @param[out] pxTCBSize Size of the a task's TCB structure (can be set to NULL)
|
2022-03-24 13:45:19 +08:00
|
|
|
* @return UBaseType_t
|
|
|
|
*/
|
2023-08-28 18:23:50 +08:00
|
|
|
UBaseType_t uxTaskGetSnapshotAll( TaskSnapshot_t * const pxTaskSnapshotArray,
|
|
|
|
const UBaseType_t uxArrayLength,
|
|
|
|
UBaseType_t * const pxTCBSize );
|
2022-03-24 13:45:19 +08:00
|
|
|
|
2023-09-21 18:07:13 +08:00
|
|
|
/* ----------------------------------------------------- Misc ----------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get a void pointer to the current TCB of a particular core
|
|
|
|
*
|
|
|
|
* @note This function provides no guarantee that the return TCB will still be the current task (or that the task still
|
|
|
|
* exists) when it returns. It is the caller's responsibility to ensure that the task does not get scheduled or deleted.
|
|
|
|
* @param xCoreID The core to query
|
|
|
|
* @return Void pointer to current TCB
|
|
|
|
*/
|
|
|
|
void * pvTaskGetCurrentTCBForCore( BaseType_t xCoreID );
|
|
|
|
|
2023-08-28 18:23:50 +08:00
|
|
|
/* *INDENT-OFF* */
|
2021-08-04 10:56:37 +08:00
|
|
|
#ifdef __cplusplus
|
2023-08-28 18:23:50 +08:00
|
|
|
}
|
2021-08-04 10:56:37 +08:00
|
|
|
#endif
|
2023-08-28 18:23:50 +08:00
|
|
|
/* *INDENT-ON* */
|