microcode.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #ifndef _ASM_X86_MICROCODE_H
  2. #define _ASM_X86_MICROCODE_H
  3. struct cpu_signature {
  4. unsigned int sig;
  5. unsigned int pf;
  6. unsigned int rev;
  7. };
  8. struct device;
  9. enum ucode_state { UCODE_ERROR, UCODE_OK, UCODE_NFOUND };
  10. struct microcode_ops {
  11. enum ucode_state (*request_microcode_user) (int cpu,
  12. const void __user *buf, size_t size);
  13. enum ucode_state (*request_microcode_fw) (int cpu, struct device *,
  14. bool refresh_fw);
  15. void (*microcode_fini_cpu) (int cpu);
  16. /*
  17. * The generic 'microcode_core' part guarantees that
  18. * the callbacks below run on a target cpu when they
  19. * are being called.
  20. * See also the "Synchronization" section in microcode_core.c.
  21. */
  22. int (*apply_microcode) (int cpu);
  23. int (*collect_cpu_info) (int cpu, struct cpu_signature *csig);
  24. };
  25. struct ucode_cpu_info {
  26. struct cpu_signature cpu_sig;
  27. int valid;
  28. void *mc;
  29. };
  30. extern struct ucode_cpu_info ucode_cpu_info[];
  31. #ifdef CONFIG_MICROCODE_INTEL
  32. extern struct microcode_ops * __init init_intel_microcode(void);
  33. #else
  34. static inline struct microcode_ops * __init init_intel_microcode(void)
  35. {
  36. return NULL;
  37. }
  38. #endif /* CONFIG_MICROCODE_INTEL */
  39. #ifdef CONFIG_MICROCODE_AMD
  40. extern struct microcode_ops * __init init_amd_microcode(void);
  41. extern void __exit exit_amd_microcode(void);
  42. #else
  43. static inline struct microcode_ops * __init init_amd_microcode(void)
  44. {
  45. return NULL;
  46. }
  47. static inline void __exit exit_amd_microcode(void) {}
  48. #endif
  49. #endif /* _ASM_X86_MICROCODE_H */