Go to most recent revision |
Blame |
Compare with Previous |
Last modification |
View Log
| RSS feed
#ifndef __ASM_GENERIC_CPUMASK_UP_H
#define __ASM_GENERIC_CPUMASK_UP_H
#define cpus_coerce(map) (map)
#define cpu_set(cpu, map) do { (void)(cpu); cpus_coerce(map) = 1UL; } while (0)
#define cpu_clear(cpu, map) do { (void)(cpu); cpus_coerce(map) = 0UL; } while (0)
#define cpu_isset(cpu, map) ((void)(cpu), cpus_coerce(map) != 0UL)
#define cpu_test_and_set(cpu, map) ((void)(cpu), test_and_set_bit(0, &(map)))
#define cpus_and(dst, src1, src2) \
do { \
if (cpus_coerce(src1) && cpus_coerce(src2)) \
cpus_coerce(dst) = 1UL; \
else \
cpus_coerce(dst) = 0UL; \
} while (0)
#define cpus_or(dst, src1, src2) \
do { \
if (cpus_coerce(src1) || cpus_coerce(src2)) \
cpus_coerce(dst) = 1UL; \
else \
cpus_coerce(dst) = 0UL; \
} while (0)
#define cpus_clear(map) do { cpus_coerce(map) = 0UL; } while (0)
#define cpus_complement(map) \
do { \
cpus_coerce(map) = !cpus_coerce(map); \
} while (0)
#define cpus_equal(map1, map2) (cpus_coerce(map1) == cpus_coerce(map2))
#define cpus_empty(map) (cpus_coerce(map) == 0UL)
#define cpus_weight(map) (cpus_coerce(map) ? 1UL : 0UL)
#define cpus_shift_right(d, s, n) do { cpus_coerce(d) = 0UL; } while (0)
#define cpus_shift_left(d, s, n) do { cpus_coerce(d) = 0UL; } while (0)
#define first_cpu(map) (cpus_coerce(map) ? 0 : 1)
#define next_cpu(cpu, map) 1
/* only ever use this for things that are _never_ used on large boxen */
#define cpus_promote(map) \
({ \
cpumask_t __tmp__; \
cpus_coerce(__tmp__) = map; \
__tmp__; \
})
#define cpumask_of_cpu(cpu) ((void)(cpu), cpus_promote(1))
#define any_online_cpu(map) (cpus_coerce(map) ? 0 : 1)
/*
* um, these need to be usable as static initializers
*/
#define CPU_MASK_ALL 1UL
#define CPU_MASK_NONE 0UL
#endif /* __ASM_GENERIC_CPUMASK_UP_H */