blob: ea92c41a41a8dcb1f249a14fc7d75347b6d91e1b [file] [log] [blame]
/*
* Copyright 2017, Data61
* Commonwealth Scientific and Industrial Research Organisation (CSIRO)
* ABN 41 687 119 230.
*
* This software may be distributed and modified according to the terms of
* the BSD 2-Clause license. Note that NO WARRANTY is provided.
* See "LICENSE_BSD2.txt" for details.
*
* @TAG(DATA61_BSD)
*/
#include <autoconf.h>
#include <sel4debug/gen_config.h>
#include <sel4debug/debug.h>
#include <sel4debug/instrumentation.h>
#ifdef CONFIG_LIBSEL4DEBUG_FUNCTION_INSTRUMENTATION_TRACE
/* Function entry and exit printing. Useful for low effort tracing of
* execution.
*
* Enable this in your app by including:
* NK_CFLAGS += -finstrument-functions \
* -finstrument-functions-exclude-function-list=seL4_MessageInfo_get_length
* If you don't exclude seL4_MessageInfo_get_length, you will most likely find
* that __seL4_*WithMRs will not function correctly because calls to
* seL4_MessageInfo_get_length will be instrumented and clobber necessary
* registers for the following syscall.
*/
void __cyg_profile_func_enter(void *func, void *caller)
{
debug_safe_printf("ENTER: %p called from %p\n", func, caller);
}
void __cyg_profile_func_exit(void *func, void *caller)
{
debug_safe_printf("EXIT: %p returning to %p\n", func, caller);
}
#endif