microcode.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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,
  14. struct device *device);
  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. static inline void get_ucode_data(void *to, const u8 *from, size_t n)
  43. {
  44. memcpy(to, from, n);
  45. }
  46. #else
  47. static inline struct microcode_ops * __init init_amd_microcode(void)
  48. {
  49. return NULL;
  50. }
  51. static inline void __exit exit_amd_microcode(void) {}
  52. #endif
  53. #endif /* _ASM_X86_MICROCODE_H */