Zephyr Project API
3.3.0
A Scalable Open Source RTOS
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
17
#ifndef ZEPHYR_INCLUDE_SYS_UTIL_MACROS_H_
18
#define ZEPHYR_INCLUDE_SYS_UTIL_MACROS_H_
19
20
#ifdef __cplusplus
21
extern
"C"
{
22
#endif
23
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
*/
34
#include <
zephyr/sys/util_internal.h
>
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
61
#define WRITE_BIT(var, bit, set) \
62
((var) = (set) ? ((var) | BIT(bit)) : ((var) & ~BIT(bit)))
63
68
#define BIT_MASK(n) (BIT(n) - 1UL)
69
74
#define BIT64_MASK(n) (BIT64(n) - 1ULL)
75
84
#define IS_SHIFTED_BIT_MASK(m, s) (!(((m) >> (s)) & (((m) >> (s)) + 1U)))
85
91
#define IS_BIT_MASK(m) IS_SHIFTED_BIT_MASK(m, 0)
92
121
#define IS_ENABLED(config_macro) Z_IS_ENABLED1(config_macro)
122
/* INTERNAL: the first pass above is just to expand any existing
123
* macros, we need the macro value to be e.g. a literal "1" at
124
* expansion time in the next macro, not "(1)", etc... Standard
125
* recursive expansion does not work.
126
*/
127
176
#define COND_CODE_1(_flag, _if_1_code, _else_code) \
177
Z_COND_CODE_1(_flag, _if_1_code, _else_code)
178
192
#define COND_CODE_0(_flag, _if_0_code, _else_code) \
193
Z_COND_CODE_0(_flag, _if_0_code, _else_code)
194
220
#define IF_ENABLED(_flag, _code) \
221
COND_CODE_1(_flag, _code, ())
222
250
#define IS_EMPTY(...) Z_IS_EMPTY_(__VA_ARGS__)
251
259
#define IS_EQ(a, b) Z_IS_EQ(a, b)
260
288
#define LIST_DROP_EMPTY(...) \
289
Z_LIST_DROP_FIRST(FOR_EACH(Z_LIST_NO_EMPTIES, (), __VA_ARGS__))
290
308
#define EMPTY
309
318
#define IDENTITY(V) V
319
328
#define GET_ARG_N(N, ...) Z_GET_ARG_##N(__VA_ARGS__)
329
338
#define GET_ARGS_LESS_N(N, ...) Z_GET_ARGS_LESS_##N(__VA_ARGS__)
339
351
#define UTIL_OR(a, b) COND_CODE_1(UTIL_BOOL(a), (a), (b))
352
364
#define UTIL_AND(a, b) COND_CODE_1(UTIL_BOOL(a), (b), (0))
365
392
#define LISTIFY(LEN, F, sep, ...) UTIL_CAT(Z_UTIL_LISTIFY_, LEN)(F, sep, __VA_ARGS__)
393
415
#define FOR_EACH(F, sep, ...) \
416
Z_FOR_EACH(F, sep, REVERSE_ARGS(__VA_ARGS__))
417
470
#define FOR_EACH_NONEMPTY_TERM(F, term, ...) \
471
COND_CODE_0( \
472
/* are there zero non-empty arguments ? */
\
473
NUM_VA_ARGS_LESS_1(LIST_DROP_EMPTY(__VA_ARGS__, _)), \
474
/* if so, expand to nothing */
\
475
(), \
476
/* otherwise, expand to: */
\
477
(
/* FOR_EACH() on nonempty elements, */
\
478
FOR_EACH(F, term, LIST_DROP_EMPTY(__VA_ARGS__)) \
479
/* plus a final terminator */
\
480
__DEBRACKET term \
481
))
482
507
#define FOR_EACH_IDX(F, sep, ...) \
508
Z_FOR_EACH_IDX(F, sep, REVERSE_ARGS(__VA_ARGS__))
509
535
#define FOR_EACH_FIXED_ARG(F, sep, fixed_arg, ...) \
536
Z_FOR_EACH_FIXED_ARG(F, sep, fixed_arg, REVERSE_ARGS(__VA_ARGS__))
537
563
#define FOR_EACH_IDX_FIXED_ARG(F, sep, fixed_arg, ...) \
564
Z_FOR_EACH_IDX_FIXED_ARG(F, sep, fixed_arg, REVERSE_ARGS(__VA_ARGS__))
565
570
#define REVERSE_ARGS(...) \
571
Z_FOR_EACH_ENGINE(Z_FOR_EACH_EXEC, (,), Z_BYPASS, _, __VA_ARGS__)
572
579
#define NUM_VA_ARGS_LESS_1(...) \
580
NUM_VA_ARGS_LESS_1_IMPL(__VA_ARGS__, 63, 62, 61, \
581
60, 59, 58, 57, 56, 55, 54, 53, 52, 51, \
582
50, 49, 48, 47, 46, 45, 44, 43, 42, 41, \
583
40, 39, 38, 37, 36, 35, 34, 33, 32, 31, \
584
30, 29, 28, 27, 26, 25, 24, 23, 22, 21, \
585
20, 19, 18, 17, 16, 15, 14, 13, 12, 11, \
586
10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, ~)
587
608
#define MACRO_MAP_CAT(...) MACRO_MAP_CAT_(__VA_ARGS__)
609
623
#define MACRO_MAP_CAT_N(N, ...) MACRO_MAP_CAT_N_(N, __VA_ARGS__)
624
629
#ifdef __cplusplus
630
}
631
#endif
632
633
#endif
/* ZEPHYR_INCLUDE_SYS_UTIL_MACROS_H_ */
util_internal.h
Misc utilities.
include
zephyr
sys
util_macro.h
Generated on Fri Jun 9 2023 14:09:43 for Zephyr Project API by
1.9.2