Zephyr Project API 4.3.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
util_macro.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011-2014, Wind River Systems, Inc.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
16
17#ifndef ZEPHYR_INCLUDE_SYS_UTIL_MACROS_H_
18#define ZEPHYR_INCLUDE_SYS_UTIL_MACROS_H_
19
20#ifdef __cplusplus
21extern "C" {
22#endif
23
28
29/*
30 * Most of the eldritch implementation details for all the macrobatics
31 * below (APIs like IS_ENABLED(), COND_CODE_1(), etc.) are hidden away
32 * in this file.
33 */
35
36#ifndef BIT
37#if defined(_ASMLANGUAGE)
38#define BIT(n) (1 << (n))
39#else
44#define BIT(n) (1UL << (n))
45#endif
46#endif
47
49#define BIT64(_n) (1ULL << (_n))
50
60#define WRITE_BIT(var, bit, set) \
61 do { \
62 __typeof__(var) __mask = ((__typeof__(var))1U << (bit)); \
63 if (set) { \
64 (var) |= __mask; \
65 } else { \
66 (var) &= ~__mask; \
67 } \
68 } while (0)
69
74#define BIT_MASK(n) (BIT(n) - 1UL)
75
80#define BIT64_MASK(n) (BIT64(n) - 1ULL)
81
83#define IS_POWER_OF_TWO(x) (((x) != 0U) && (((x) & ((x) - 1U)) == 0U))
84
93#define IS_SHIFTED_BIT_MASK(m, s) (!(((m) >> (s)) & (((m) >> (s)) + 1U)))
94
100#define IS_BIT_MASK(m) IS_SHIFTED_BIT_MASK(m, 0)
101
108#define IS_BIT_SET(value, bit) ((((value) >> (bit)) & (0x1)) != 0)
109
111#define LSB_GET(value) ((value) & -(value))
112
117#define FIELD_GET(mask, value) (((value) & (mask)) / LSB_GET(mask))
118
124#define FIELD_PREP(mask, value) (((value) * LSB_GET(mask)) & (mask))
125
154#define IS_ENABLED(config_macro) Z_IS_ENABLED1(config_macro)
155/* INTERNAL: the first pass above is just to expand any existing
156 * macros, we need the macro value to be e.g. a literal "1" at
157 * expansion time in the next macro, not "(1)", etc... Standard
158 * recursive expansion does not work.
159 */
160
209#define COND_CODE_1(_flag, _if_1_code, _else_code) \
210 Z_COND_CODE_1(_flag, _if_1_code, _else_code)
211
225#define COND_CODE_0(_flag, _if_0_code, _else_code) \
226 Z_COND_CODE_0(_flag, _if_0_code, _else_code)
227
250#define COND_CASE_1(...) \
251 Z_COND_CASE_1(__VA_ARGS__)
252
278#define IF_ENABLED(_flag, _code) \
279 COND_CODE_1(_flag, _code, ())
280
302#define IF_DISABLED(_flag, _code) \
303 COND_CODE_1(_flag, (), _code)
304
332#define IS_EMPTY(...) Z_IS_EMPTY_(__VA_ARGS__)
333
353#define IS_EQ(a, b) Z_IS_EQ(a, b)
354
382#define LIST_DROP_EMPTY(...) \
383 Z_LIST_DROP_FIRST(FOR_EACH(Z_LIST_NO_EMPTIES, (), __VA_ARGS__))
384
402#define EMPTY
403
412#define IDENTITY(V) V
413
422#define GET_ARG_N(N, ...) UTIL_CAT(Z_GET_ARG_, N)(__VA_ARGS__)
423
432#define GET_ARGS_LESS_N(N, ...) UTIL_CAT(Z_GET_ARGS_LESS_, N)(__VA_ARGS__)
433
442#define GET_ARGS_FIRST_N(N, ...) UTIL_CAT(Z_GET_ARGS_FIRST_, N)(__VA_ARGS__)
443
455#define UTIL_OR(a, b) COND_CODE_1(UTIL_BOOL(a), (a), (b))
456
468#define UTIL_AND(a, b) COND_CODE_1(UTIL_BOOL(a), (b), (0))
469
476#define UTIL_INC(x) UTIL_PRIMITIVE_CAT(Z_UTIL_INC_, x)
477
484#define UTIL_DEC(x) UTIL_PRIMITIVE_CAT(Z_UTIL_DEC_, x)
485
490#define UTIL_X2(y) UTIL_PRIMITIVE_CAT(Z_UTIL_X2_, y)
491
492
519#define LISTIFY(LEN, F, sep, ...) UTIL_CAT(Z_UTIL_LISTIFY_, LEN)(F, sep, __VA_ARGS__)
520
542#define FOR_EACH(F, sep, ...) \
543 Z_FOR_EACH(F, sep, REVERSE_ARGS(__VA_ARGS__))
544
597#define FOR_EACH_NONEMPTY_TERM(F, term, ...) \
598 COND_CODE_0( \
599 /* are there zero non-empty arguments ? */ \
600 NUM_VA_ARGS_LESS_1(LIST_DROP_EMPTY(__VA_ARGS__, _)), \
601 /* if so, expand to nothing */ \
602 (), \
603 /* otherwise, expand to: */ \
604 (/* FOR_EACH() on nonempty elements, */ \
605 FOR_EACH(F, term, LIST_DROP_EMPTY(__VA_ARGS__)) \
606 /* plus a final terminator */ \
607 __DEBRACKET term \
608 ))
609
634#define FOR_EACH_IDX(F, sep, ...) \
635 Z_FOR_EACH_IDX(F, sep, REVERSE_ARGS(__VA_ARGS__))
636
662#define FOR_EACH_FIXED_ARG(F, sep, fixed_arg, ...) \
663 Z_FOR_EACH_FIXED_ARG(F, sep, fixed_arg, REVERSE_ARGS(__VA_ARGS__))
664
690#define FOR_EACH_IDX_FIXED_ARG(F, sep, fixed_arg, ...) \
691 Z_FOR_EACH_IDX_FIXED_ARG(F, sep, fixed_arg, REVERSE_ARGS(__VA_ARGS__))
692
697#define REVERSE_ARGS(...) \
698 Z_FOR_EACH_ENGINE(Z_FOR_EACH_EXEC, (,), Z_BYPASS, _, __VA_ARGS__)
699
708#define NUM_VA_ARGS_LESS_1(...) \
709 NUM_VA_ARGS_LESS_1_IMPL(__VA_ARGS__, 63, 62, 61, \
710 60, 59, 58, 57, 56, 55, 54, 53, 52, 51, \
711 50, 49, 48, 47, 46, 45, 44, 43, 42, 41, \
712 40, 39, 38, 37, 36, 35, 34, 33, 32, 31, \
713 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, \
714 20, 19, 18, 17, 16, 15, 14, 13, 12, 11, \
715 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, ~)
716
725#define NUM_VA_ARGS(...) \
726 COND_CODE_1(IS_EMPTY(__VA_ARGS__), (0), (UTIL_INC(NUM_VA_ARGS_LESS_1(__VA_ARGS__))))
727
748#define MACRO_MAP_CAT(...) MACRO_MAP_CAT_(__VA_ARGS__)
749
763#define MACRO_MAP_CAT_N(N, ...) MACRO_MAP_CAT_N_(N, __VA_ARGS__)
764
768
769#ifdef __cplusplus
770}
771#endif
772
773#endif /* ZEPHYR_INCLUDE_SYS_UTIL_MACROS_H_ */
Misc utilities.