blob: 5463ad558573de5424d4d654e0cfdc20263930dd [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>
10#include <linux/jiffies.h>
11#include <linux/time.h>
12#include <asm/vsyscall.h>
13#include <asm/vgtod.h>
Andi Kleen2aae9502007-07-21 17:10:01 +020014
Steven Rostedt23adec52008-05-12 21:20:41 +020015notrace long
16__vdso_getcpu(unsigned *cpu, unsigned *node, struct getcpu_cache *unused)
Andi Kleen2aae9502007-07-21 17:10:01 +020017{
Glauber de Oliveira Costa8f12dea2008-01-30 13:31:06 +010018 unsigned int p;
Andi Kleen2aae9502007-07-21 17:10:01 +020019
Andy Lutomirski8c49d9a2011-05-23 09:31:24 -040020 if (VVAR(vgetcpu_mode) == VGETCPU_RDTSCP) {
Andi Kleen2aae9502007-07-21 17:10:01 +020021 /* Load per CPU data from RDTSCP */
Glauber de Oliveira Costa8f12dea2008-01-30 13:31:06 +010022 native_read_tscp(&p);
Andi Kleen2aae9502007-07-21 17:10:01 +020023 } else {
24 /* Load per CPU data from GDT */
25 asm("lsl %1,%0" : "=r" (p) : "r" (__PER_CPU_SEG));
26 }
Andi Kleen2aae9502007-07-21 17:10:01 +020027 if (cpu)
28 *cpu = p & 0xfff;
29 if (node)
30 *node = p >> 12;
31 return 0;
32}
33
34long getcpu(unsigned *cpu, unsigned *node, struct getcpu_cache *tcache)
35 __attribute__((weak, alias("__vdso_getcpu")));