ARM: dma-api: fix max_pfn off-by-one error in __dma_supported()
[linux/fpc-iii.git] / arch / x86 / boot / bitops.h
blob02e1dea11d94bd397a8cc152b77783f7ece06017
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /* -*- linux-c -*- ------------------------------------------------------- *
4 * Copyright (C) 1991, 1992 Linus Torvalds
5 * Copyright 2007 rPath, Inc. - All Rights Reserved
7 * ----------------------------------------------------------------------- */
9 /*
10 * Very simple bitops for the boot code.
13 #ifndef BOOT_BITOPS_H
14 #define BOOT_BITOPS_H
15 #define _LINUX_BITOPS_H /* Inhibit inclusion of <linux/bitops.h> */
17 #include <linux/types.h>
18 #include <asm/asm.h>
20 static inline bool constant_test_bit(int nr, const void *addr)
22 const u32 *p = (const u32 *)addr;
23 return ((1UL << (nr & 31)) & (p[nr >> 5])) != 0;
25 static inline bool variable_test_bit(int nr, const void *addr)
27 bool v;
28 const u32 *p = (const u32 *)addr;
30 asm("btl %2,%1" CC_SET(c) : CC_OUT(c) (v) : "m" (*p), "Ir" (nr));
31 return v;
34 #define test_bit(nr,addr) \
35 (__builtin_constant_p(nr) ? \
36 constant_test_bit((nr),(addr)) : \
37 variable_test_bit((nr),(addr)))
39 static inline void set_bit(int nr, void *addr)
41 asm("btsl %1,%0" : "+m" (*(u32 *)addr) : "Ir" (nr));
44 #endif /* BOOT_BITOPS_H */