mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2026-05-05 09:57:21 +02:00
de9e2b3d88
Currently DIV_ROUND_CLOSEST() is only available for the kernel via include/linux/math.h. Expose it to userland as well by adding __KERNEL_DIV_ROUND_CLOSEST() as a common definition in uapi. Additionally, ensure it allows building ISO C applications by switching from the 'typeof' GNU extension to the ISO-friendly __typeof__. Reviewed-by: Nícolas F. R. A. Prado <nfraprado@collabora.com> Tested-by: Diederik de Haas <diederik@cknow-tech.com> Acked-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com> Signed-off-by: Cristian Ciocaltea <cristian.ciocaltea@collabora.com> Link: https://patch.msgid.link/20260303-rk3588-bgcolor-v8-1-fee377037ad1@collabora.com Signed-off-by: Daniel Stone <daniels@collabora.com>
72 lines
2.1 KiB
C
72 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
/* const.h: Macros for dealing with constants. */
|
|
|
|
#ifndef _UAPI_LINUX_CONST_H
|
|
#define _UAPI_LINUX_CONST_H
|
|
|
|
/* Some constant macros are used in both assembler and
|
|
* C code. Therefore we cannot annotate them always with
|
|
* 'UL' and other type specifiers unilaterally. We
|
|
* use the following macros to deal with this.
|
|
*
|
|
* Similarly, _AT() will cast an expression with a type in C, but
|
|
* leave it unchanged in asm.
|
|
*/
|
|
|
|
#ifdef __ASSEMBLY__
|
|
#define _AC(X,Y) X
|
|
#define _AT(T,X) X
|
|
#else
|
|
#define __AC(X,Y) (X##Y)
|
|
#define _AC(X,Y) __AC(X,Y)
|
|
#define _AT(T,X) ((T)(X))
|
|
#endif
|
|
|
|
#define _UL(x) (_AC(x, UL))
|
|
#define _ULL(x) (_AC(x, ULL))
|
|
|
|
#define _BITUL(x) (_UL(1) << (x))
|
|
#define _BITULL(x) (_ULL(1) << (x))
|
|
|
|
#if !defined(__ASSEMBLY__)
|
|
/*
|
|
* Missing asm support
|
|
*
|
|
* __BIT128() would not work in the asm code, as it shifts an
|
|
* 'unsigned __int128' data type as direct representation of
|
|
* 128 bit constants is not supported in the gcc compiler, as
|
|
* they get silently truncated.
|
|
*
|
|
* TODO: Please revisit this implementation when gcc compiler
|
|
* starts representing 128 bit constants directly like long
|
|
* and unsigned long etc. Subsequently drop the comment for
|
|
* GENMASK_U128() which would then start supporting asm code.
|
|
*/
|
|
#define _BIT128(x) ((unsigned __int128)(1) << (x))
|
|
#endif
|
|
|
|
#define __ALIGN_KERNEL(x, a) __ALIGN_KERNEL_MASK(x, (__typeof__(x))(a) - 1)
|
|
#define __ALIGN_KERNEL_MASK(x, mask) (((x) + (mask)) & ~(mask))
|
|
|
|
#define __KERNEL_DIV_ROUND_UP(n, d) (((n) + (d) - 1) / (d))
|
|
|
|
/*
|
|
* Divide positive or negative dividend by positive or negative divisor
|
|
* and round to closest integer. Result is undefined for negative
|
|
* divisors if the dividend variable type is unsigned and for negative
|
|
* dividends if the divisor variable type is unsigned.
|
|
*/
|
|
#define __KERNEL_DIV_ROUND_CLOSEST(x, divisor) \
|
|
({ \
|
|
__typeof__(x) __x = x; \
|
|
__typeof__(divisor) __d = divisor; \
|
|
\
|
|
(((__typeof__(x))-1) > 0 || \
|
|
((__typeof__(divisor))-1) > 0 || \
|
|
(((__x) > 0) == ((__d) > 0))) ? \
|
|
(((__x) + ((__d) / 2)) / (__d)) : \
|
|
(((__x) - ((__d) / 2)) / (__d)); \
|
|
})
|
|
|
|
#endif /* _UAPI_LINUX_CONST_H */
|