xref: /rk3399_ARM-atf/include/plat/marvell/armada/common/mvebu.h (revision 9935047b2086faa3bf3ccf0b95a76510eb5a160b)
1*a2847172SGrzegorz Jaszczyk /*
2*a2847172SGrzegorz Jaszczyk  * Copyright (C)  2018 Marvell International Ltd.
3*a2847172SGrzegorz Jaszczyk  *
4*a2847172SGrzegorz Jaszczyk  * SPDX-License-Identifier:     BSD-3-Clause
5*a2847172SGrzegorz Jaszczyk  * https://spdx.org/licenses
6*a2847172SGrzegorz Jaszczyk  */
7*a2847172SGrzegorz Jaszczyk 
8*a2847172SGrzegorz Jaszczyk #ifndef MVEBU_H
9*a2847172SGrzegorz Jaszczyk #define MVEBU_H
10*a2847172SGrzegorz Jaszczyk 
11*a2847172SGrzegorz Jaszczyk /* Use this functions only when printf is allowed */
12*a2847172SGrzegorz Jaszczyk #define debug_enter()	VERBOSE("----> Enter %s\n", __func__)
13*a2847172SGrzegorz Jaszczyk #define debug_exit()	VERBOSE("<---- Exit  %s\n", __func__)
14*a2847172SGrzegorz Jaszczyk 
15*a2847172SGrzegorz Jaszczyk /* Macro for testing alignment. Positive if number is NOT aligned */
16*a2847172SGrzegorz Jaszczyk #define IS_NOT_ALIGN(number, align)	((number) & ((align) - 1))
17*a2847172SGrzegorz Jaszczyk 
18*a2847172SGrzegorz Jaszczyk /* Macro for alignment up. For example, ALIGN_UP(0x0330, 0x20) = 0x0340 */
19*a2847172SGrzegorz Jaszczyk #define ALIGN_UP(number, align) (((number) & ((align) - 1)) ? \
20*a2847172SGrzegorz Jaszczyk 		(((number) + (align)) & ~((align)-1)) : (number))
21*a2847172SGrzegorz Jaszczyk 
22*a2847172SGrzegorz Jaszczyk /* Macro for testing whether a number is a power of 2. Positive if so */
23*a2847172SGrzegorz Jaszczyk #define IS_POWER_OF_2(number)	((number) != 0 && \
24*a2847172SGrzegorz Jaszczyk 				(((number) & ((number) - 1)) == 0))
25*a2847172SGrzegorz Jaszczyk 
26*a2847172SGrzegorz Jaszczyk /*
27*a2847172SGrzegorz Jaszczyk  * Macro for ronding up to next power of 2
28*a2847172SGrzegorz Jaszczyk  * it is done by count leading 0 (clz assembly opcode) and see msb set bit.
29*a2847172SGrzegorz Jaszczyk  * then you can shift it left and get number which power of 2
30*a2847172SGrzegorz Jaszczyk  * Note: this Macro is for 32 bit number
31*a2847172SGrzegorz Jaszczyk  */
32*a2847172SGrzegorz Jaszczyk #define ROUND_UP_TO_POW_OF_2(number)	(1 << \
33*a2847172SGrzegorz Jaszczyk 					(32 - __builtin_clz((number) - 1)))
34*a2847172SGrzegorz Jaszczyk 
35*a2847172SGrzegorz Jaszczyk #define _1MB_				(1024ULL * 1024ULL)
36*a2847172SGrzegorz Jaszczyk #define _1GB_				(_1MB_ * 1024ULL)
37*a2847172SGrzegorz Jaszczyk #define _2GB_				(2 * _1GB_)
38*a2847172SGrzegorz Jaszczyk 
39*a2847172SGrzegorz Jaszczyk #endif /* MVEBU_H */
40