| #ifndef _ASM_X86_MICROCODE_H |
| #define _ASM_X86_MICROCODE_H |
| |
| struct cpu_signature { |
| unsigned int sig; |
| unsigned int pf; |
| unsigned int rev; |
| }; |
| |
| struct device; |
| |
| enum ucode_state { UCODE_ERROR, UCODE_OK, UCODE_NFOUND }; |
| |
| struct microcode_ops { |
| enum ucode_state (*request_microcode_user) (int cpu, |
| const void __user *buf, size_t size); |
| |
| enum ucode_state (*request_microcode_fw) (int cpu, |
| struct device *device); |
| |
| void (*microcode_fini_cpu) (int cpu); |
| |
| /* |
| * The generic 'microcode_core' part guarantees that |
| * the callbacks below run on a target cpu when they |
| * are being called. |
| * See also the "Synchronization" section in microcode_core.c. |
| */ |
| int (*apply_microcode) (int cpu); |
| int (*collect_cpu_info) (int cpu, struct cpu_signature *csig); |
| }; |
| |
| struct ucode_cpu_info { |
| struct cpu_signature cpu_sig; |
| int valid; |
| void *mc; |
| }; |
| extern struct ucode_cpu_info ucode_cpu_info[]; |
| |
| #ifdef CONFIG_MICROCODE_INTEL |
| extern struct microcode_ops * __init init_intel_microcode(void); |
| #else |
| static inline struct microcode_ops * __init init_intel_microcode(void) |
| { |
| return NULL; |
| } |
| #endif /* CONFIG_MICROCODE_INTEL */ |
| |
| #ifdef CONFIG_MICROCODE_AMD |
| extern struct microcode_ops * __init init_amd_microcode(void); |
| extern void __exit exit_amd_microcode(void); |
| |
| static inline void get_ucode_data(void *to, const u8 *from, size_t n) |
| { |
| memcpy(to, from, n); |
| } |
| |
| #else |
| static inline struct microcode_ops * __init init_amd_microcode(void) |
| { |
| return NULL; |
| } |
| static inline void __exit exit_amd_microcode(void) {} |
| #endif |
| |
| #endif /* _ASM_X86_MICROCODE_H */ |