| /* |
| * Copyright 2017, Data61, CSIRO (ABN 41 687 119 230) |
| * |
| * SPDX-License-Identifier: BSD-2-Clause |
| */ |
| |
| #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 |