blob: 209492849566cefc56305cd8e976fbf4a25d7527 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Jacob Shina76096a2013-05-30 14:09:18 -05002#ifndef _ASM_X86_MICROCODE_AMD_H
3#define _ASM_X86_MICROCODE_AMD_H
4
5#include <asm/microcode.h>
6
7#define UCODE_MAGIC 0x00414d44
8#define UCODE_EQUIV_CPU_TABLE_TYPE 0x00000000
9#define UCODE_UCODE_TYPE 0x00000001
10
11#define SECTION_HDR_SIZE 8
12#define CONTAINER_HDR_SZ 12
13
14struct equiv_cpu_entry {
15 u32 installed_cpu;
16 u32 fixed_errata_mask;
17 u32 fixed_errata_compare;
18 u16 equiv_cpu;
19 u16 res;
20} __attribute__((packed));
21
22struct microcode_header_amd {
23 u32 data_code;
24 u32 patch_id;
25 u16 mc_patch_data_id;
26 u8 mc_patch_data_len;
27 u8 init_flag;
28 u32 mc_patch_data_checksum;
29 u32 nb_dev_id;
30 u32 sb_dev_id;
31 u16 processor_rev_id;
32 u8 nb_rev_id;
33 u8 sb_rev_id;
34 u8 bios_api_rev;
35 u8 reserved1[3];
36 u32 match_reg[8];
37} __attribute__((packed));
38
39struct microcode_amd {
40 struct microcode_header_amd hdr;
41 unsigned int mpb[0];
42};
43
Borislav Petkov5335ba52013-11-29 14:58:44 +010044#define PATCH_MAX_SIZE PAGE_SIZE
Borislav Petkov5335ba52013-11-29 14:58:44 +010045
Borislav Petkovfe055892015-10-20 11:54:45 +020046#ifdef CONFIG_MICROCODE_AMD
Andy Shevchenko7b179b82015-06-04 18:55:28 +020047extern void __init load_ucode_amd_bsp(unsigned int family);
Borislav Petkovb3763a62016-10-25 11:55:16 +020048extern void load_ucode_amd_ap(unsigned int family);
49extern int __init save_microcode_in_initrd_amd(unsigned int family);
Borislav Petkovfbae4ba2014-12-03 17:21:41 +010050void reload_ucode_amd(void);
Jacob Shin757885e2013-05-30 14:09:19 -050051#else
Andy Shevchenko7b179b82015-06-04 18:55:28 +020052static inline void __init load_ucode_amd_bsp(unsigned int family) {}
Borislav Petkovb3763a62016-10-25 11:55:16 +020053static inline void load_ucode_amd_ap(unsigned int family) {}
54static inline int __init
55save_microcode_in_initrd_amd(unsigned int family) { return -EINVAL; }
Borislav Petkovfbae4ba2014-12-03 17:21:41 +010056void reload_ucode_amd(void) {}
Jacob Shin757885e2013-05-30 14:09:19 -050057#endif
Jacob Shina76096a2013-05-30 14:09:18 -050058#endif /* _ASM_X86_MICROCODE_AMD_H */