Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
cputype.h
Go to the documentation of this file.
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