#include <linux/kernel.h> #include <linux/bitops.h> #include <linux/cpumask.h> #include <linux/module.h> int __first_cpu(const cpumask_t *srcp) { return min_t(int, NR_CPUS, find_first_bit(srcp->bits, NR_CPUS)); } EXPORT_SYMBOL(__first_cpu); int __next_cpu(int n, const cpumask_t *srcp) { return min_t(int, NR_CPUS, find_next_bit(srcp->bits, NR_CPUS, n+1)); } EXPORT_SYMBOL(__next_cpu); /* * Find the highest possible smp_processor_id() * * Note: if we're prepared to assume that cpu_possible_map never changes * (reasonable) then this function should cache its return value. */ int highest_possible_processor_id(void) { unsigned int cpu; unsigned highest = 0; for_each_cpu_mask(cpu, cpu_possible_map) highest = cpu; return highest; } EXPORT_SYMBOL(highest_possible_processor_id); int __any_online_cpu(const cpumask_t *mask) { int cpu; for_each_cpu_mask(cpu, *mask) { if (cpu_online(cpu)) break; } return cpu; } EXPORT_SYMBOL(__any_online_cpu);