1 #ifndef _ASM_X86_MICROCODE_H
2 #define _ASM_X86_MICROCODE_H
12 enum ucode_state
{ UCODE_ERROR
, UCODE_OK
, UCODE_NFOUND
};
14 struct microcode_ops
{
15 enum ucode_state (*request_microcode_user
) (int cpu
,
16 const void __user
*buf
, size_t size
);
18 enum ucode_state (*request_microcode_fw
) (int cpu
,
19 struct device
*device
);
21 void (*microcode_fini_cpu
) (int cpu
);
24 * The generic 'microcode_core' part guarantees that
25 * the callbacks below run on a target cpu when they
27 * See also the "Synchronization" section in microcode_core.c.
29 int (*apply_microcode
) (int cpu
);
30 int (*collect_cpu_info
) (int cpu
, struct cpu_signature
*csig
);
33 struct ucode_cpu_info
{
34 struct cpu_signature cpu_sig
;
38 extern struct ucode_cpu_info ucode_cpu_info
[];
40 #ifdef CONFIG_MICROCODE_INTEL
41 extern struct microcode_ops
* __init
init_intel_microcode(void);
43 static inline struct microcode_ops
* __init
init_intel_microcode(void)
47 #endif /* CONFIG_MICROCODE_INTEL */
49 #ifdef CONFIG_MICROCODE_AMD
50 extern struct microcode_ops
* __init
init_amd_microcode(void);
52 static inline void get_ucode_data(void *to
, const u8
*from
, size_t n
)
58 static inline struct microcode_ops
* __init
init_amd_microcode(void)
64 #endif /* _ASM_X86_MICROCODE_H */