58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _ASM_X86_MICROCODE_AMD_H
 | |
| #define _ASM_X86_MICROCODE_AMD_H
 | |
| 
 | |
| #include <asm/microcode.h>
 | |
| 
 | |
| #define UCODE_MAGIC			0x00414d44
 | |
| #define UCODE_EQUIV_CPU_TABLE_TYPE	0x00000000
 | |
| #define UCODE_UCODE_TYPE		0x00000001
 | |
| 
 | |
| #define SECTION_HDR_SIZE		8
 | |
| #define CONTAINER_HDR_SZ		12
 | |
| 
 | |
| struct equiv_cpu_entry {
 | |
| 	u32	installed_cpu;
 | |
| 	u32	fixed_errata_mask;
 | |
| 	u32	fixed_errata_compare;
 | |
| 	u16	equiv_cpu;
 | |
| 	u16	res;
 | |
| } __attribute__((packed));
 | |
| 
 | |
| struct microcode_header_amd {
 | |
| 	u32	data_code;
 | |
| 	u32	patch_id;
 | |
| 	u16	mc_patch_data_id;
 | |
| 	u8	mc_patch_data_len;
 | |
| 	u8	init_flag;
 | |
| 	u32	mc_patch_data_checksum;
 | |
| 	u32	nb_dev_id;
 | |
| 	u32	sb_dev_id;
 | |
| 	u16	processor_rev_id;
 | |
| 	u8	nb_rev_id;
 | |
| 	u8	sb_rev_id;
 | |
| 	u8	bios_api_rev;
 | |
| 	u8	reserved1[3];
 | |
| 	u32	match_reg[8];
 | |
| } __attribute__((packed));
 | |
| 
 | |
| struct microcode_amd {
 | |
| 	struct microcode_header_amd	hdr;
 | |
| 	unsigned int			mpb[];
 | |
| };
 | |
| 
 | |
| #define PATCH_MAX_SIZE (3 * PAGE_SIZE)
 | |
| 
 | |
| #ifdef CONFIG_MICROCODE_AMD
 | |
| extern void load_ucode_amd_early(unsigned int cpuid_1_eax);
 | |
| extern int __init save_microcode_in_initrd_amd(unsigned int family);
 | |
| void reload_ucode_amd(unsigned int cpu);
 | |
| #else
 | |
| static inline void load_ucode_amd_early(unsigned int cpuid_1_eax) {}
 | |
| static inline int __init
 | |
| save_microcode_in_initrd_amd(unsigned int family) { return -EINVAL; }
 | |
| static inline void reload_ucode_amd(unsigned int cpu) {}
 | |
| #endif
 | |
| 
 | |
| #endif /* _ASM_X86_MICROCODE_AMD_H */
 |