1 /* 2 * Copyright (c) 2023 Nordic Semiconductor ASA 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #ifndef NSI_COMMON_SRC_NSI_TASKS_H 8 #define NSI_COMMON_SRC_NSI_TASKS_H 9 10 #include "nsi_utils.h" 11 12 #ifdef __cplusplus 13 extern "C" { 14 #endif 15 16 #define NSITASK_PRE_BOOT_1_LEVEL 0 17 #define NSITASK_PRE_BOOT_2_LEVEL 1 18 #define NSITASK_HW_INIT_LEVEL 2 19 #define NSITASK_PRE_BOOT_3_LEVEL 3 20 #define NSITASK_FIRST_SLEEP_LEVEL 4 21 #define NSITASK_ON_EXIT_PRE_LEVEL 5 22 #define NSITASK_ON_EXIT_POST_LEVEL 6 23 24 /** 25 * NSI_TASK 26 * 27 * Register a function to be called at particular moments 28 * during the Native Simulator execution. 29 * 30 * There is 5 choices for when the function will be called (level): 31 * * PRE_BOOT_1: Will be called before the command line parameters are parsed, 32 * or the HW models are initialized 33 * 34 * * PRE_BOOT_2: Will be called after the command line parameters are parsed, 35 * but before the HW models are initialized 36 * 37 * * HW_INIT: Will be called during HW models initialization 38 * 39 * * PRE_BOOT_3: Will be called after the HW models initialization, right before 40 * the "CPUs are booted" and embedded SW in them is started. 41 * 42 * * FIRST_SLEEP: Will be called after the 1st time all CPUs are sent to sleep 43 * 44 * * ON_EXIT_PRE: Will be called during termination of the runner 45 * execution, as a first set. 46 * 47 * * ON_EXIT_POST: Will be called during termination of the runner 48 * execution, as the very last set before the program returns. 49 * 50 * The function must take no parameters and return nothing. 51 */ 52 #define NSI_TASK(fn, level, prio) \ 53 static void (* const NSI_CONCAT(__nsi_task_, fn))(void) \ 54 __attribute__((__used__)) NSI_NOASAN \ 55 __attribute__((__section__(".nsi_" #level NSI_STRINGIFY(prio) "_task")))\ 56 = fn; \ 57 /* Let's cross-check the macro level is a valid one, so we don't silently drop it */ \ 58 _Static_assert(NSITASK_##level##_LEVEL >= 0, \ 59 "Using a non pre-defined level, it will be dropped") 60 61 /** 62 * @brief Run the set of special native tasks corresponding to the given level 63 * 64 * @param level One of NSITASK_*_LEVEL as defined in soc.h 65 */ 66 void nsi_run_tasks(int level); 67 68 #ifdef __cplusplus 69 } 70 #endif 71 72 #endif /* NSI_COMMON_SRC_NSI_TASKS_H */ 73