1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- #ifndef __ASM_X86_PROCESSOR_H
- #define __ASM_X86_PROCESSOR_H
- #include <asm/processor-flags.h>
- #include <asm/page.h>
- #include <asm/system.h>
- static inline void native_cpuid(unsigned int *eax, unsigned int *ebx,
- unsigned int *ecx, unsigned int *edx)
- {
- /* ecx is often an input as well as an output. */
- __asm__("cpuid"
- : "=a" (*eax),
- "=b" (*ebx),
- "=c" (*ecx),
- "=d" (*edx)
- : "0" (*eax), "2" (*ecx));
- }
- static inline void load_cr3(pgd_t *pgdir)
- {
- write_cr3(__pa(pgdir));
- }
- #ifdef CONFIG_X86_32
- # include "processor_32.h"
- #else
- # include "processor_64.h"
- #endif
- #ifndef CONFIG_PARAVIRT
- #define __cpuid native_cpuid
- #endif
- /*
- * Generic CPUID function
- * clear %ecx since some cpus (Cyrix MII) do not set or clear %ecx
- * resulting in stale register contents being returned.
- */
- static inline void cpuid(unsigned int op,
- unsigned int *eax, unsigned int *ebx,
- unsigned int *ecx, unsigned int *edx)
- {
- *eax = op;
- *ecx = 0;
- __cpuid(eax, ebx, ecx, edx);
- }
- /* Some CPUID calls want 'count' to be placed in ecx */
- static inline void cpuid_count(unsigned int op, int count,
- unsigned int *eax, unsigned int *ebx,
- unsigned int *ecx, unsigned int *edx)
- {
- *eax = op;
- *ecx = count;
- __cpuid(eax, ebx, ecx, edx);
- }
- /*
- * CPUID functions returning a single datum
- */
- static inline unsigned int cpuid_eax(unsigned int op)
- {
- unsigned int eax, ebx, ecx, edx;
- cpuid(op, &eax, &ebx, &ecx, &edx);
- return eax;
- }
- static inline unsigned int cpuid_ebx(unsigned int op)
- {
- unsigned int eax, ebx, ecx, edx;
- cpuid(op, &eax, &ebx, &ecx, &edx);
- return ebx;
- }
- static inline unsigned int cpuid_ecx(unsigned int op)
- {
- unsigned int eax, ebx, ecx, edx;
- cpuid(op, &eax, &ebx, &ecx, &edx);
- return ecx;
- }
- static inline unsigned int cpuid_edx(unsigned int op)
- {
- unsigned int eax, ebx, ecx, edx;
- cpuid(op, &eax, &ebx, &ecx, &edx);
- return edx;
- }
- #endif
|