Contributors: 19
Author Tokens Token Proportion Commits Commit Proportion
Andrew Morton 68 24.82% 4 13.79%
Juergen Gross 66 24.09% 2 6.90%
David Daney 47 17.15% 2 6.90%
Linus Torvalds (pre-git) 21 7.66% 2 6.90%
Rusty Russell 14 5.11% 4 13.79%
Christoph Hellwig 14 5.11% 1 3.45%
Eric W. Biedermann 9 3.28% 1 3.45%
Paul E. McKenney 7 2.55% 1 3.45%
Nadav Amit 6 2.19% 1 3.45%
Rik Van Riel 6 2.19% 1 3.45%
Jan Kara 4 1.46% 1 3.45%
Ingo Molnar 4 1.46% 2 6.90%
Frédéric Weisbecker 2 0.73% 1 3.45%
Bhaskar Chowdhury 1 0.36% 1 3.45%
Leonardo Brás 1 0.36% 1 3.45%
Jens Axboe 1 0.36% 1 3.45%
Sebastian Andrzej Siewior 1 0.36% 1 3.45%
Thomas Gleixner 1 0.36% 1 3.45%
Paul Gortmaker 1 0.36% 1 3.45%
Total 274 29

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
// SPDX-License-Identifier: GPL-2.0-only
/*
 * Uniprocessor-only support functions.  The counterpart to kernel/smp.c
 */

#include <linux/interrupt.h>
#include <linux/kernel.h>
#include <linux/export.h>
#include <linux/smp.h>
#include <linux/hypervisor.h>

int smp_call_function_single(int cpu, void (*func) (void *info), void *info,
				int wait)
{
	unsigned long flags;

	if (cpu != 0)
		return -ENXIO;

	local_irq_save(flags);
	func(info);
	local_irq_restore(flags);

	return 0;
}
EXPORT_SYMBOL(smp_call_function_single);

int smp_call_function_single_async(int cpu, call_single_data_t *csd)
{
	unsigned long flags;

	local_irq_save(flags);
	csd->func(csd->info);
	local_irq_restore(flags);
	return 0;
}
EXPORT_SYMBOL(smp_call_function_single_async);

/*
 * Preemption is disabled here to make sure the cond_func is called under the
 * same conditions in UP and SMP.
 */
void on_each_cpu_cond_mask(smp_cond_func_t cond_func, smp_call_func_t func,
			   void *info, bool wait, const struct cpumask *mask)
{
	unsigned long flags;

	preempt_disable();
	if ((!cond_func || cond_func(0, info)) && cpumask_test_cpu(0, mask)) {
		local_irq_save(flags);
		func(info);
		local_irq_restore(flags);
	}
	preempt_enable();
}
EXPORT_SYMBOL(on_each_cpu_cond_mask);

int smp_call_on_cpu(unsigned int cpu, int (*func)(void *), void *par, bool phys)
{
	int ret;

	if (cpu != 0)
		return -ENXIO;

	if (phys)
		hypervisor_pin_vcpu(0);
	ret = func(par);
	if (phys)
		hypervisor_pin_vcpu(-1);

	return ret;
}
EXPORT_SYMBOL_GPL(smp_call_on_cpu);