| /* |
| * 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 |