/* * Percepio Trace Recorder for Tracealyzer v4.10.3 * Copyright 2023 Percepio AB * www.percepio.com * * SPDX-License-Identifier: Apache-2.0 */ /** * @file * * @brief Public trace heap APIs. */ #ifndef TRC_HEAP_H #define TRC_HEAP_H #ifndef TRC_USE_HEAPS #define TRC_USE_HEAPS 1 #endif #if (TRC_USE_TRACEALYZER_RECORDER == 1) && (TRC_CFG_RECORDER_MODE == TRC_RECORDER_MODE_STREAMING) && (TRC_USE_HEAPS == 1) #include #ifdef __cplusplus extern "C" { #endif #define TRC_HEAP_STATE_INDEX_CURRENT 0u #define TRC_HEAP_STATE_INDEX_HIGHWATERMARK 1u #define TRC_HEAP_STATE_INDEX_MAX 2u /** * @defgroup trace_heap_apis Trace Heap APIs * @ingroup trace_recorder_apis * @{ */ /** * @brief Creates trace heap. * * @param[in] szName Name. * @param[in] uxCurrent Current level. * @param[in] uxHighWaterMark High water mark * @param[in] uxMax Maximum level. * @param[out] pxHeapHandle Pointer to uninitialized trace heap handle. * @return traceResult */ traceResult xTraceHeapCreate(const char *szName, TraceUnsignedBaseType_t uxCurrent, TraceUnsignedBaseType_t uxHighWaterMark, TraceUnsignedBaseType_t uxMax, TraceHeapHandle_t *pxHeapHandle); /** * @brief Signals trace heap alloc. * * @param[in] xHeapHandle Trace heap handle. * @param[in] pvAddress Address. * @param[in] uxSize Size. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ traceResult xTraceHeapAlloc(TraceHeapHandle_t xHeapHandle, void *pvAddress, TraceUnsignedBaseType_t uxSize); /** * @brief Signals trace heap free. * * @param[in] xHeapHandle Trace heap handle. * @param[in] pvAddress Address. * @param[in] uxSize Size. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ traceResult xTraceHeapFree(TraceHeapHandle_t xHeapHandle, void* pvAddress, TraceUnsignedBaseType_t uxSize); /** * @brief Gets trace heap current allocation size. * * @param[in] xHeapHandle Trace heap handle. * @param[out] puxCurrent Current. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ #define xTraceHeapGetCurrent(xHeapHandle, puxCurrent) xTraceEntryGetState(xHeapHandle, TRC_HEAP_STATE_INDEX_CURRENT, puxCurrent) /** * @brief Sets trace heap current allocation size. * * @param[in] xHeapHandle Trace heap handle. * @param[in] uxCurrent Current. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ #define xTraceHeapSetCurrent(xHeapHandle, uxCurrent) xTraceEntrySetState(xHeapHandle, TRC_HEAP_STATE_INDEX_CURRENT, uxCurrent) /** * @brief Gets trace heap high water mark. * * @param[in] xHeapHandle Trace heap handle. * @param[out] puxHighWaterMark High water mark. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ #define xTraceHeapGetHighWaterMark(xHeapHandle, puxHighWaterMark) xTraceEntryGetState(xHeapHandle, TRC_HEAP_STATE_INDEX_HIGHWATERMARK, puxHighWaterMark) /** * @brief Sets trace heap high water mark. * * @param[in] xHeapHandle Trace heap handle. * @param[in] uxHighWaterMark High water mark. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ #define xTraceHeapSetHighWaterMark(xHeapHandle, uxHighWaterMark) xTraceEntrySetState(xHeapHandle, TRC_HEAP_STATE_INDEX_HIGHWATERMARK, uxHighWaterMark) /** * @brief Gets trace heap max size. * * @param[in] xHeapHandle Trace heap handle. * @param[out] puxMax Max. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ #define xTraceHeapGetMax(xHeapHandle, puxMax) xTraceEntryGetState(xHeapHandle, TRC_HEAP_STATE_INDEX_MAX, puxMax) /** * @brief Sets trace heap max size. * * @param[in] xHeapHandle Trace heap handle. * @param[in] uxMax Max heap size. * * @retval TRC_FAIL Failure * @retval TRC_SUCCESS Success */ #define xTraceHeapSetMax(xHeapHandle, uxMax) xTraceEntrySetState(xHeapHandle, TRC_HEAP_STATE_INDEX_MAX, uxMax) /** @} */ #ifdef __cplusplus } #endif #else #define xTraceHeapCreate(__szName, __uxCurrent, __uxHighWaterMark, __uxMax, __pxHeapHandle) TRC_COMMA_EXPR_TO_STATEMENT_EXPR_6((void)(__szName), (void)(__uxCurrent), (void)(__uxHighWaterMark), (void)(__uxMax), (void)(__pxHeapHandle), TRC_SUCCESS) #define xTraceHeapAlloc(__xHeapHandle, __pvAddress, __uxSize) TRC_COMMA_EXPR_TO_STATEMENT_EXPR_4((void)(__xHeapHandle), (void)(__pvAddress), (void)(__uxSize), TRC_SUCCESS) #define xTraceHeapFree(__xHeapHandle, __pvAddress, __uxSize) TRC_COMMA_EXPR_TO_STATEMENT_EXPR_4((void)(__xHeapHandle), (void)(__pvAddress), (void)(__uxSize), TRC_SUCCESS) #define xTraceHeapGetCurrent(__xHeapHandle, __puxCurrent) TRC_COMMA_EXPR_TO_STATEMENT_EXPR_3((void)(__xHeapHandle), (void)(__puxCurrent), TRC_SUCCESS) #define xTraceHeapGetHighWaterMark(__xHeapHandle, __puxHighWaterMark) TRC_COMMA_EXPR_TO_STATEMENT_EXPR_3((void)(__xHeapHandle), (void)(__puxHighWaterMark), TRC_SUCCESS) #define xTraceHeapGetMax(__xHeapHandle, __puxMax) TRC_COMMA_EXPR_TO_STATEMENT_EXPR_3((void)(__xHeapHandle), (void)(__puxMax), TRC_SUCCESS) #endif #endif