mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 fe055896c0
			
		
	
	
		fe055896c0
		
	
	
	
	
		
			
			Merge the early loader functionality into the driver proper. The diff is huge but logically, it is simply moving code from the _early.c files into the main driver. Signed-off-by: Borislav Petkov <bp@suse.de> Cc: Andy Lutomirski <luto@amacapital.net> Cc: Arjan van de Ven <arjan@linux.intel.com> Cc: Borislav Petkov <bp@alien8.de> Cc: Brian Gerst <brgerst@gmail.com> Cc: Dave Jones <davej@codemonkey.org.uk> Cc: Denys Vlasenko <dvlasenk@redhat.com> Cc: H. Peter Anvin <hpa@zytor.com> Cc: Len Brown <len.brown@intel.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Tony Luck <tony.luck@intel.com> Link: http://lkml.kernel.org/r/1445334889-300-3-git-send-email-bp@alien8.de Signed-off-by: Ingo Molnar <mingo@kernel.org>
		
			
				
	
	
		
			81 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #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[0];
 | |
| };
 | |
| 
 | |
| static inline u16 find_equiv_id(struct equiv_cpu_entry *equiv_cpu_table,
 | |
| 				unsigned int sig)
 | |
| {
 | |
| 	int i = 0;
 | |
| 
 | |
| 	if (!equiv_cpu_table)
 | |
| 		return 0;
 | |
| 
 | |
| 	while (equiv_cpu_table[i].installed_cpu != 0) {
 | |
| 		if (sig == equiv_cpu_table[i].installed_cpu)
 | |
| 			return equiv_cpu_table[i].equiv_cpu;
 | |
| 
 | |
| 		i++;
 | |
| 	}
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| extern int __apply_microcode_amd(struct microcode_amd *mc_amd);
 | |
| extern int apply_microcode_amd(int cpu);
 | |
| extern enum ucode_state load_microcode_amd(int cpu, u8 family, const u8 *data, size_t size);
 | |
| 
 | |
| #define PATCH_MAX_SIZE PAGE_SIZE
 | |
| extern u8 amd_ucode_patch[PATCH_MAX_SIZE];
 | |
| 
 | |
| #ifdef CONFIG_MICROCODE_AMD
 | |
| extern void __init load_ucode_amd_bsp(unsigned int family);
 | |
| extern void load_ucode_amd_ap(void);
 | |
| extern int __init save_microcode_in_initrd_amd(void);
 | |
| void reload_ucode_amd(void);
 | |
| #else
 | |
| static inline void __init load_ucode_amd_bsp(unsigned int family) {}
 | |
| static inline void load_ucode_amd_ap(void) {}
 | |
| static inline int __init save_microcode_in_initrd_amd(void) { return -EINVAL; }
 | |
| void reload_ucode_amd(void) {}
 | |
| #endif
 | |
| 
 | |
| extern bool check_current_patch_level(u32 *rev, bool early);
 | |
| #endif /* _ASM_X86_MICROCODE_AMD_H */
 |