mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 23:03:57 -04:00
The cache parameter of getcpu() is useless nowadays for various reasons. * It is never passed by userspace for either the vDSO or syscalls. * It is never used by the kernel. * It could not be made to work on the current vDSO architecture. * The structure definition is not part of the UAPI headers. * vdso_getcpu() is superseded by restartable sequences in any case. Remove the struct and its header. As a side-effect this gets rid of an unwanted inclusion of the linux/ header namespace from vDSO code. [ tglx: Adapt to s390 upstream changes */ Signed-off-by: Thomas Weißschuh <thomas.weissschuh@linutronix.de> Signed-off-by: Thomas Gleixner <tglx@kernel.org> Acked-by: Arnd Bergmann <arnd@arndb.de> Acked-by: Heiko Carstens <hca@linux.ibm.com> # s390 Link: https://patch.msgid.link/20251230-getcpu_cache-v3-1-fb9c5f880ebe@linutronix.de
54 lines
1.1 KiB
C
54 lines
1.1 KiB
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* vdso_test_getcpu.c: Sample code to test parse_vdso.c and vDSO getcpu()
|
|
*
|
|
* Copyright (c) 2020 Arm Ltd
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
#include <elf.h>
|
|
#include <stdio.h>
|
|
#include <sys/auxv.h>
|
|
#include <sys/time.h>
|
|
|
|
#include "kselftest.h"
|
|
#include "parse_vdso.h"
|
|
#include "vdso_config.h"
|
|
#include "vdso_call.h"
|
|
|
|
typedef long (*getcpu_t)(unsigned int *, unsigned int *, void *);
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
const char *version = versions[VDSO_VERSION];
|
|
const char **name = (const char **)&names[VDSO_NAMES];
|
|
unsigned long sysinfo_ehdr;
|
|
unsigned int cpu, node;
|
|
getcpu_t get_cpu;
|
|
long ret;
|
|
|
|
sysinfo_ehdr = getauxval(AT_SYSINFO_EHDR);
|
|
if (!sysinfo_ehdr) {
|
|
printf("AT_SYSINFO_EHDR is not present!\n");
|
|
return KSFT_SKIP;
|
|
}
|
|
|
|
vdso_init_from_sysinfo_ehdr(getauxval(AT_SYSINFO_EHDR));
|
|
|
|
get_cpu = (getcpu_t)vdso_sym(version, name[4]);
|
|
if (!get_cpu) {
|
|
printf("Could not find %s\n", name[4]);
|
|
return KSFT_SKIP;
|
|
}
|
|
|
|
ret = VDSO_CALL(get_cpu, 3, &cpu, &node, 0);
|
|
if (ret == 0) {
|
|
printf("Running on CPU %u node %u\n", cpu, node);
|
|
} else {
|
|
printf("%s failed\n", name[4]);
|
|
return KSFT_FAIL;
|
|
}
|
|
|
|
return 0;
|
|
}
|