blob: 8ec3d1f4ce9a4d378d6042650177d4b32a9808e8 [file] [log] [blame]
Andi Kleen2aae9502007-07-21 17:10:01 +02001/*
2 * Copyright 2006 Andi Kleen, SUSE Labs.
3 * Subject to the GNU Public License, v.2
4 *
5 * Fast user context implementation of getcpu()
6 */
7
8#include <linux/kernel.h>
9#include <linux/getcpu.h>
Andi Kleen2aae9502007-07-21 17:10:01 +020010#include <linux/time.h>
Andi Kleen2aae9502007-07-21 17:10:01 +020011#include <asm/vgtod.h>
Andi Kleen2aae9502007-07-21 17:10:01 +020012
Steven Rostedt23adec52008-05-12 21:20:41 +020013notrace long
14__vdso_getcpu(unsigned *cpu, unsigned *node, struct getcpu_cache *unused)
Andi Kleen2aae9502007-07-21 17:10:01 +020015{
Glauber de Oliveira Costa8f12dea2008-01-30 13:31:06 +010016 unsigned int p;
Andi Kleen2aae9502007-07-21 17:10:01 +020017
Marcelo Tosatti51c19b42012-11-27 23:28:57 -020018 p = __getcpu();
19
Andi Kleen2aae9502007-07-21 17:10:01 +020020 if (cpu)
Marcelo Tosatti51c19b42012-11-27 23:28:57 -020021 *cpu = p & VGETCPU_CPU_MASK;
Andi Kleen2aae9502007-07-21 17:10:01 +020022 if (node)
23 *node = p >> 12;
24 return 0;
25}
26
27long getcpu(unsigned *cpu, unsigned *node, struct getcpu_cache *tcache)
28 __attribute__((weak, alias("__vdso_getcpu")));