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