microcode_amd.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #ifndef _ASM_X86_MICROCODE_AMD_H
  2. #define _ASM_X86_MICROCODE_AMD_H
  3. #include <asm/microcode.h>
  4. #define UCODE_MAGIC 0x00414d44
  5. #define UCODE_EQUIV_CPU_TABLE_TYPE 0x00000000
  6. #define UCODE_UCODE_TYPE 0x00000001
  7. #define SECTION_HDR_SIZE 8
  8. #define CONTAINER_HDR_SZ 12
  9. struct equiv_cpu_entry {
  10. u32 installed_cpu;
  11. u32 fixed_errata_mask;
  12. u32 fixed_errata_compare;
  13. u16 equiv_cpu;
  14. u16 res;
  15. } __attribute__((packed));
  16. struct microcode_header_amd {
  17. u32 data_code;
  18. u32 patch_id;
  19. u16 mc_patch_data_id;
  20. u8 mc_patch_data_len;
  21. u8 init_flag;
  22. u32 mc_patch_data_checksum;
  23. u32 nb_dev_id;
  24. u32 sb_dev_id;
  25. u16 processor_rev_id;
  26. u8 nb_rev_id;
  27. u8 sb_rev_id;
  28. u8 bios_api_rev;
  29. u8 reserved1[3];
  30. u32 match_reg[8];
  31. } __attribute__((packed));
  32. struct microcode_amd {
  33. struct microcode_header_amd hdr;
  34. unsigned int mpb[0];
  35. };
  36. static inline u16 find_equiv_id(struct equiv_cpu_entry *equiv_cpu_table,
  37. unsigned int sig)
  38. {
  39. int i = 0;
  40. if (!equiv_cpu_table)
  41. return 0;
  42. while (equiv_cpu_table[i].installed_cpu != 0) {
  43. if (sig == equiv_cpu_table[i].installed_cpu)
  44. return equiv_cpu_table[i].equiv_cpu;
  45. i++;
  46. }
  47. return 0;
  48. }
  49. extern int __apply_microcode_amd(struct microcode_amd *mc_amd);
  50. extern int apply_microcode_amd(int cpu);
  51. extern enum ucode_state load_microcode_amd(int cpu, u8 family, const u8 *data, size_t size);
  52. #define PATCH_MAX_SIZE PAGE_SIZE
  53. #ifdef CONFIG_MICROCODE_AMD
  54. extern void __init load_ucode_amd_bsp(unsigned int family);
  55. extern void load_ucode_amd_ap(void);
  56. extern int __init save_microcode_in_initrd_amd(void);
  57. void reload_ucode_amd(void);
  58. #else
  59. static inline void __init load_ucode_amd_bsp(unsigned int family) {}
  60. static inline void load_ucode_amd_ap(void) {}
  61. static inline int __init save_microcode_in_initrd_amd(void) { return -EINVAL; }
  62. void reload_ucode_amd(void) {}
  63. #endif
  64. extern bool check_current_patch_level(u32 *rev, bool early);
  65. #endif /* _ASM_X86_MICROCODE_AMD_H */