1 /* 2 * Copyright (c) 2023 Nordic Semiconductor ASA 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #include "bs_tracing.h" 8 #include "bs_types.h" 9 #include "bstests.h" 10 11 #define BS_SECONDS(dur_sec) ((bs_time_t)dur_sec * USEC_PER_SEC) 12 #define TEST_TIMEOUT_SIMULATED BS_SECONDS(60) 13 14 extern enum bst_result_t bst_result; 15 16 #define DECLARE_FLAG(flag) extern atomic_t flag 17 #define DEFINE_FLAG(flag) atomic_t flag = (atomic_t)false 18 #define SET_FLAG(flag) (void)atomic_set(&flag, (atomic_t)true) 19 #define UNSET_FLAG(flag) (void)atomic_set(&flag, (atomic_t)false) 20 21 #define WAIT_FOR_VAL(var, val) \ 22 while (atomic_get(&var) != val) { \ 23 (void)k_sleep(K_MSEC(1)); \ 24 } 25 #define WAIT_FOR_FLAG(flag) \ 26 while (!(bool)atomic_get(&flag)) { \ 27 (void)k_sleep(K_MSEC(1)); \ 28 } 29 #define WAIT_FOR_FLAG_UNSET(flag) \ 30 while ((bool)atomic_get(&flag)) { \ 31 (void)k_sleep(K_MSEC(1)); \ 32 } 33 #define TAKE_FLAG(flag) \ 34 while (!(bool)atomic_cas(&flag, true, false)) { \ 35 (void)k_sleep(K_MSEC(1)); \ 36 } 37 38 #define ASSERT(expr, ...) \ 39 do { \ 40 if (!(expr)) { \ 41 FAIL(__VA_ARGS__); \ 42 } \ 43 } while (0) 44 45 #define FAIL(...) \ 46 do { \ 47 bst_result = Failed; \ 48 bs_trace_error_time_line(__VA_ARGS__); \ 49 } while (0) 50 51 #define PASS(...) \ 52 do { \ 53 bst_result = Passed; \ 54 bs_trace_info_time(1, __VA_ARGS__); \ 55 } while (0) 56