mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

The generic storage implementation provides the same features as the custom one. However it can be shared between architectures, making maintenance easier. Co-developed-by: Nam Cao <namcao@linutronix.de> Signed-off-by: Nam Cao <namcao@linutronix.de> Signed-off-by: Thomas Weißschuh <thomas.weissschuh@linutronix.de> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Link: https://lore.kernel.org/all/20250204-vdso-store-rng-v3-10-13a4669dfc8c@linutronix.de
37 lines
631 B
C
37 lines
631 B
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Fast user context implementation of getcpu()
|
|
*/
|
|
|
|
#include <asm/vdso.h>
|
|
#include <linux/getcpu.h>
|
|
|
|
static __always_inline int read_cpu_id(void)
|
|
{
|
|
int cpu_id;
|
|
|
|
__asm__ __volatile__(
|
|
" rdtime.d $zero, %0\n"
|
|
: "=r" (cpu_id)
|
|
:
|
|
: "memory");
|
|
|
|
return cpu_id;
|
|
}
|
|
|
|
extern
|
|
int __vdso_getcpu(unsigned int *cpu, unsigned int *node, struct getcpu_cache *unused);
|
|
int __vdso_getcpu(unsigned int *cpu, unsigned int *node, struct getcpu_cache *unused)
|
|
{
|
|
int cpu_id;
|
|
|
|
cpu_id = read_cpu_id();
|
|
|
|
if (cpu)
|
|
*cpu = cpu_id;
|
|
|
|
if (node)
|
|
*node = vdso_u_arch_data.pdata[cpu_id].node;
|
|
|
|
return 0;
|
|
}
|