diff options
author | Felix Fietkau <nbd@nbd.name> | 2024-05-07 12:18:08 +0200 |
---|---|---|
committer | Felix Fietkau <nbd@nbd.name> | 2024-05-07 12:50:27 +0200 |
commit | c3d4598c0129671d534e5556d25b00229fc22095 (patch) | |
tree | 44051efd2465adb32953ad904dc5aab720c6f722 /tools/include/asm/bitsperlong.h | |
parent | 931b2bafa7a60eb722082a889740e94a7fef7e8c (diff) |
tools: add more linux include files to fix x86 build on macos
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Diffstat (limited to 'tools/include/asm/bitsperlong.h')
-rw-r--r-- | tools/include/asm/bitsperlong.h | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/tools/include/asm/bitsperlong.h b/tools/include/asm/bitsperlong.h new file mode 100644 index 0000000000..75f320fa91 --- /dev/null +++ b/tools/include/asm/bitsperlong.h @@ -0,0 +1,27 @@ +/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ +#ifndef __ASM_GENERIC_BITS_PER_LONG +#define __ASM_GENERIC_BITS_PER_LONG + +#ifndef __BITS_PER_LONG +/* + * In order to keep safe and avoid regression, only unify uapi + * bitsperlong.h for some archs which are using newer toolchains + * that have the definitions of __CHAR_BIT__ and __SIZEOF_LONG__. + * See the following link for more info: + * https://lore.kernel.org/linux-arch/b9624545-2c80-49a1-ac3c-39264a591f7b@app.fastmail.com/ + */ +#if defined(__CHAR_BIT__) && defined(__SIZEOF_LONG__) +#define __BITS_PER_LONG (__CHAR_BIT__ * __SIZEOF_LONG__) +#else +/* + * There seems to be no way of detecting this automatically from user + * space, so 64 bit architectures should override this in their + * bitsperlong.h. In particular, an architecture that supports + * both 32 and 64 bit user space must not rely on CONFIG_64BIT + * to decide it, but rather check a compiler provided macro. + */ +#define __BITS_PER_LONG 32 +#endif +#endif + +#endif /* __ASM_GENERIC_BITS_PER_LONG */ |