1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ 2 /* const.h: Macros for dealing with constants. */ 3 4 #ifndef _UAPI_LINUX_CONST_H 5 #define _UAPI_LINUX_CONST_H 6 7 /* Some constant macros are used in both assembler and 8 * C code. Therefore we cannot annotate them always with 9 * 'UL' and other type specifiers unilaterally. We 10 * use the following macros to deal with this. 11 * 12 * Similarly, _AT() will cast an expression with a type in C, but 13 * leave it unchanged in asm. 14 */ 15 16 #ifdef __ASSEMBLY__ 17 #define _AC(X,Y) X 18 #define _AT(T,X) X 19 #else 20 #define __AC(X,Y) (X##Y) 21 #define _AC(X,Y) __AC(X,Y) 22 #define _AT(T,X) ((T)(X)) 23 #endif 24 25 #define _UL(x) (_AC(x, UL)) 26 #define _ULL(x) (_AC(x, ULL)) 27 28 #define _BITUL(x) (_UL(1) << (x)) 29 #define _BITULL(x) (_ULL(1) << (x)) 30 31 #if !defined(__ASSEMBLY__) 32 /* 33 * Missing asm support 34 * 35 * __BIT128() would not work in the asm code, as it shifts an 36 * 'unsigned __init128' data type as direct representation of 37 * 128 bit constants is not supported in the gcc compiler, as 38 * they get silently truncated. 39 * 40 * TODO: Please revisit this implementation when gcc compiler 41 * starts representing 128 bit constants directly like long 42 * and unsigned long etc. Subsequently drop the comment for 43 * GENMASK_U128() which would then start supporting asm code. 44 */ 45 #define _BIT128(x) ((unsigned __int128)(1) << (x)) 46 #endif 47 48 #define __ALIGN_KERNEL(x, a) __ALIGN_KERNEL_MASK(x, (__typeof__(x))(a) - 1) 49 #define __ALIGN_KERNEL_MASK(x, mask) (((x) + (mask)) & ~(mask)) 50 51 #define __KERNEL_DIV_ROUND_UP(n, d) (((n) + (d) - 1) / (d)) 52 53 #endif /* _UAPI_LINUX_CONST_H */ 54