Typedefs | |
typedef void(* | mbed_mem_trace_cb_t) (uint8_t op, void *res, void *caller,...) |
Type of the callback used by the memory tracer. More... | |
Functions | |
void | mbed_mem_trace_set_callback (mbed_mem_trace_cb_t cb) |
Set the callback used by the memory tracer (use NULL for disable tracing). More... | |
void | mbed_mem_trace_disable () |
Disable the memory trace output by disabling the callback function. More... | |
void | mbed_mem_trace_enable () |
Re-enable the memory trace output with the cb in use when disable was called. More... | |
void | mbed_mem_trace_lock () |
Trace lock. More... | |
void | mbed_mem_trace_unlock () |
Trace unlock. More... | |
void * | mbed_mem_trace_malloc (void *res, size_t size, void *caller) |
Trace a call to 'malloc'. More... | |
void * | mbed_mem_trace_realloc (void *res, void *ptr, size_t size, void *caller) |
Trace a call to 'realloc'. More... | |
void * | mbed_mem_trace_calloc (void *res, size_t num, size_t size, void *caller) |
Trace a call to 'calloc'. More... | |
void | mbed_mem_trace_free (void *ptr, void *caller) |
Trace a call to 'free'. More... | |
void | mbed_mem_trace_default_callback (uint8_t op, void *res, void *caller,...) |
Default memory trace callback. More... | |
typedef void(* mbed_mem_trace_cb_t) (uint8_t op, void *res, void *caller,...) |
Type of the callback used by the memory tracer.
This callback is called when a memory allocation operation (malloc, realloc, calloc, free) is called and tracing is enabled for that memory allocation function.
op | the ID of the operation (MBED_MEM_TRACE_MALLOC, MBED_MEM_TRACE_REALLOC, MBED_MEM_TRACE_CALLOC or MBED_MEM_TRACE_FREE). |
res | the result that the memory operation returned (NULL for 'free'). |
caller | the caller of the memory operation. Note that the value of 'caller' might be unreliable. |
The rest of the parameters passed 'mbed_mem_trace_cb_t' are the same as the memory operations that triggered its call (see 'man malloc' for details):
Definition at line 69 of file mbed_mem_trace.h.
void* mbed_mem_trace_calloc | ( | void * | res, |
size_t | num, | ||
size_t | size, | ||
void * | caller | ||
) |
Trace a call to 'calloc'.
res | the result of running 'calloc'. |
num | the 'nmemb' argument given to 'calloc'. |
size | the 'size' argument given to 'calloc'. |
caller | the caller of the memory operation. |
void mbed_mem_trace_default_callback | ( | uint8_t | op, |
void * | res, | ||
void * | caller, | ||
... | |||
) |
Default memory trace callback.
DO NOT CALL DIRECTLY. It is meant to be used as the second argument of 'mbed_mem_trace_setup'.
The default callback outputs trace data using 'printf', in a format that's easily parsable by an external tool. For each memory operation, the callback outputs a line that begins with "#<op>:<0xresult>;<0xcaller>-":
op | identifies the memory operation ('m' for 'malloc', 'r' for 'realloc', 'c' for 'calloc' and 'f' for 'free'). |
res | (base 16) is the result of the memory operation. This is always NULL for 'free', since 'free' doesn't return anything. |
caller | (base 16) is the caller of the memory operation. Note that the value of 'caller' might be unreliable. |
The rest of the output depends on the operation being traced:
Examples:
void mbed_mem_trace_disable | ( | ) |
Disable the memory trace output by disabling the callback function.
void mbed_mem_trace_enable | ( | ) |
Re-enable the memory trace output with the cb in use when disable was called.
void mbed_mem_trace_free | ( | void * | ptr, |
void * | caller | ||
) |
Trace a call to 'free'.
ptr | the 'ptr' argument given to 'free'. |
caller | the caller of the memory operation. |
void mbed_mem_trace_lock | ( | ) |
Trace lock.
void* mbed_mem_trace_malloc | ( | void * | res, |
size_t | size, | ||
void * | caller | ||
) |
Trace a call to 'malloc'.
res | the result of running 'malloc'. |
size | the 'size' argument given to 'malloc'. |
caller | the caller of the memory operation. |
void* mbed_mem_trace_realloc | ( | void * | res, |
void * | ptr, | ||
size_t | size, | ||
void * | caller | ||
) |
Trace a call to 'realloc'.
res | the result of running 'realloc'. |
ptr | the 'ptr' argument given to 'realloc'. |
size | the 'size' argument given to 'realloc'. |
caller | the caller of the memory operation. |
void mbed_mem_trace_set_callback | ( | mbed_mem_trace_cb_t | cb | ) |
Set the callback used by the memory tracer (use NULL for disable tracing).
cb | the callback to call on each memory operation. |
void mbed_mem_trace_unlock | ( | ) |
Trace unlock.