Linux Kernel
3.7.1
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
File List
Globals
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
arch
x86
vdso
vgetcpu.c
Go to the documentation of this file.
1
/*
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
>
14
15
notrace
long
16
__vdso_getcpu
(
unsigned
*
cpu
,
unsigned
*
node
,
struct
getcpu_cache
*
unused
)
17
{
18
unsigned
int
p
;
19
20
if
(
VVAR
(vgetcpu_mode) == VGETCPU_RDTSCP) {
21
/* Load per CPU data from RDTSCP */
22
native_read_tscp(&p);
23
}
else
{
24
/* Load per CPU data from GDT */
25
asm
(
"lsl %1,%0"
:
"=r"
(
p
) :
"r"
(
__PER_CPU_SEG
));
26
}
27
if
(cpu)
28
*cpu = p & 0xfff;
29
if
(node)
30
*node = p >> 12;
31
return
0;
32
}
33
34
long
getcpu
(
unsigned
*
cpu
,
unsigned
*
node
,
struct
getcpu_cache
*
tcache
)
35
__attribute__
((weak,
alias
(
"__vdso_getcpu"
)));
Generated on Thu Jan 10 2013 13:21:53 for Linux Kernel by
1.8.2