bitops.h
来自「linux 内核源代码」· C头文件 代码 · 共 76 行
H
76 行
#ifndef _LINUX_BITOPS_H#define _LINUX_BITOPS_H#include <asm/types.h>#ifdef __KERNEL__#define BIT(nr) (1UL << (nr))#define BIT_MASK(nr) (1UL << ((nr) % BITS_PER_LONG))#define BIT_WORD(nr) ((nr) / BITS_PER_LONG)#define BITS_TO_LONGS(nr) DIV_ROUND_UP(nr, BITS_PER_LONG)#define BITS_PER_BYTE 8#endif/* * Include this here because some architectures need generic_ffs/fls in * scope */#include <asm/bitops.h>#define for_each_bit(bit, addr, size) \ for ((bit) = find_first_bit((addr), (size)); \ (bit) < (size); \ (bit) = find_next_bit((addr), (size), (bit) + 1))static __inline__ int get_bitmask_order(unsigned int count){ int order; order = fls(count); return order; /* We could be slightly more clever with -1 here... */}static __inline__ int get_count_order(unsigned int count){ int order; order = fls(count) - 1; if (count & (count - 1)) order++; return order;}static inline unsigned long hweight_long(unsigned long w){ return sizeof(w) == 4 ? hweight32(w) : hweight64(w);}/** * rol32 - rotate a 32-bit value left * @word: value to rotate * @shift: bits to roll */static inline __u32 rol32(__u32 word, unsigned int shift){ return (word << shift) | (word >> (32 - shift));}/** * ror32 - rotate a 32-bit value right * @word: value to rotate * @shift: bits to roll */static inline __u32 ror32(__u32 word, unsigned int shift){ return (word >> shift) | (word << (32 - shift));}static inline unsigned fls_long(unsigned long l){ if (sizeof(l) == 4) return fls(l); return fls64(l);}#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?