Merge branch 'kvm-updates/2.6.39' of git://git.kernel.org/pub/scm/virt/kvm/kvm
[pandora-kernel.git] / arch / unicore32 / include / asm / cputype.h
1 /*
2  * linux/arch/unicore32/include/asm/cputype.h
3  *
4  * Code specific to PKUnity SoC and UniCore ISA
5  *
6  * Copyright (C) 2001-2010 GUAN Xue-tao
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License version 2 as
10  * published by the Free Software Foundation.
11  */
12 #ifndef __UNICORE_CPUTYPE_H__
13 #define __UNICORE_CPUTYPE_H__
14
15 #include <linux/stringify.h>
16
17 #define CPUID_CPUID     0
18 #define CPUID_CACHETYPE 1
19
20 #define read_cpuid(reg)                                                 \
21         ({                                                              \
22                 unsigned int __val;                                     \
23                 asm("movc       %0, p0.c0, #" __stringify(reg)          \
24                     : "=r" (__val)                                      \
25                     :                                                   \
26                     : "cc");                                            \
27                 __val;                                                  \
28         })
29
30 #define uc32_cpuid              read_cpuid(CPUID_CPUID)
31 #define uc32_cachetype          read_cpuid(CPUID_CACHETYPE)
32
33 #endif