📄 cpumask_arith.h
字号:
#ifndef __ASM_GENERIC_CPUMASK_ARITH_H#define __ASM_GENERIC_CPUMASK_ARITH_H/* * Arithmetic type -based cpu bitmaps. A single unsigned long is used * to contain the whole cpu bitmap. */#define cpu_set(cpu, map) set_bit(cpu, &(map))#define cpu_clear(cpu, map) clear_bit(cpu, &(map))#define cpu_isset(cpu, map) test_bit(cpu, &(map))#define cpu_test_and_set(cpu, map) test_and_set_bit(cpu, &(map))#define cpus_and(dst,src1,src2) do { dst = (src1) & (src2); } while (0)#define cpus_or(dst,src1,src2) do { dst = (src1) | (src2); } while (0)#define cpus_clear(map) do { map = 0; } while (0)#define cpus_complement(map) do { map = ~(map); } while (0)#define cpus_equal(map1, map2) ((map1) == (map2))#define cpus_empty(map) ((map) == 0)#define cpus_addr(map) (&(map))#if BITS_PER_LONG == 32#define cpus_weight(map) hweight32(map)#elif BITS_PER_LONG == 64#define cpus_weight(map) hweight64(map)#endif#define cpus_shift_right(dst, src, n) do { dst = (src) >> (n); } while (0)#define cpus_shift_left(dst, src, n) do { dst = (src) << (n); } while (0)#define any_online_cpu(map) \({ \ cpumask_t __tmp__; \ cpus_and(__tmp__, map, cpu_online_map); \ __tmp__ ? first_cpu(__tmp__) : NR_CPUS; \})#define CPU_MASK_ALL (~((cpumask_t)0) >> (8*sizeof(cpumask_t) - NR_CPUS))#define CPU_MASK_NONE ((cpumask_t)0)/* only ever use this for things that are _never_ used on large boxen */#define cpus_coerce(map) ((unsigned long)(map))#define cpus_promote(map) ({ map; })#define cpumask_of_cpu(cpu) ({ ((cpumask_t)1) << (cpu); })#define first_cpu(map) find_first_bit(&(map), NR_CPUS)#define next_cpu(cpu, map) find_next_bit(&(map), NR_CPUS, cpu + 1)#endif /* __ASM_GENERIC_CPUMASK_ARITH_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -