{nb,soc}/intel: Use get_current_microcode_rev() for ucode version
This patch removes all redundant read microcode version implementation from SoC directory and refer from cpu/intel/microcode/microcode.c file. TEST=Able to get correct microcode version. Change-Id: Icb905b18d85f1c5b68fac6905f3c65e95bffa2da Signed-off-by: Subrata Banik <subrata.banik@intel.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/44175 Reviewed-by: Arthur Heymans <arthur@aheymans.xyz> Reviewed-by: Angel Pons <th3fanbus@gmail.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
053b972a2a
commit
b7db12bf7e
8 changed files with 17 additions and 60 deletions
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <southbridge/intel/lynxpoint/pch.h>
|
#include <southbridge/intel/lynxpoint/pch.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
|
@ -14,7 +15,6 @@ static void report_cpu_info(void)
|
||||||
u32 i, index, cpu_id, cpu_feature_flag;
|
u32 i, index, cpu_id, cpu_feature_flag;
|
||||||
char cpu_string[50], *cpu_name = cpu_string; /* 48 bytes are reported */
|
char cpu_string[50], *cpu_name = cpu_string; /* 48 bytes are reported */
|
||||||
int vt, txt, aes;
|
int vt, txt, aes;
|
||||||
msr_t microcode_ver;
|
|
||||||
const char *mode[] = {"NOT ", ""};
|
const char *mode[] = {"NOT ", ""};
|
||||||
|
|
||||||
index = 0x80000000;
|
index = 0x80000000;
|
||||||
|
@ -35,13 +35,9 @@ static void report_cpu_info(void)
|
||||||
while (cpu_name[0] == ' ')
|
while (cpu_name[0] == ' ')
|
||||||
cpu_name++;
|
cpu_name++;
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(IA32_BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(IA32_BIOS_SIGN_ID);
|
|
||||||
printk(BIOS_DEBUG, "CPU id(%x) ucode:%08x %s\n", cpu_id,
|
printk(BIOS_DEBUG, "CPU id(%x) ucode:%08x %s\n", cpu_id,
|
||||||
microcode_ver.hi, cpu_name);
|
get_current_microcode_rev(), cpu_name);
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <cpu/x86/name.h>
|
#include <cpu/x86/name.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
|
@ -64,18 +65,12 @@ static void report_cpu_info(void)
|
||||||
{
|
{
|
||||||
uint32_t i, cpu_id, cpu_feature_flag;
|
uint32_t i, cpu_id, cpu_feature_flag;
|
||||||
char cpu_name[49];
|
char cpu_name[49];
|
||||||
msr_t microcode_ver;
|
|
||||||
const char *support = "Supported";
|
const char *support = "Supported";
|
||||||
const char *no_support = "Not Supported";
|
const char *no_support = "Not Supported";
|
||||||
const char *cpu_type = "Unknown";
|
const char *cpu_type = "Unknown";
|
||||||
|
|
||||||
fill_processor_name(cpu_name);
|
fill_processor_name(cpu_name);
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(IA32_BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(IA32_BIOS_SIGN_ID);
|
|
||||||
|
|
||||||
/* Look for string to match the name */
|
/* Look for string to match the name */
|
||||||
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
||||||
|
@ -86,7 +81,8 @@ static void report_cpu_info(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
printk(BIOS_INFO, "CPU: %s\n", cpu_name);
|
printk(BIOS_INFO, "CPU: %s\n", cpu_name);
|
||||||
printk(BIOS_INFO, "CPU: ID %x, %s, ucode: %08x\n", cpu_id, cpu_type, microcode_ver.hi);
|
printk(BIOS_INFO, "CPU: ID %x, %s, ucode: %08x\n", cpu_id, cpu_type,
|
||||||
|
get_current_microcode_rev());
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
printk(BIOS_INFO, "CPU: AES %s, TXT %s, VT %s\n",
|
printk(BIOS_INFO, "CPU: AES %s, TXT %s, VT %s\n",
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <soc/cpu.h>
|
#include <soc/cpu.h>
|
||||||
#include <soc/pch.h>
|
#include <soc/pch.h>
|
||||||
|
@ -76,7 +77,6 @@ static void report_cpu_info(void)
|
||||||
u32 i, index, cpu_id, cpu_feature_flag;
|
u32 i, index, cpu_id, cpu_feature_flag;
|
||||||
char cpu_string[50], *cpu_name = cpu_string; /* 48 bytes are reported */
|
char cpu_string[50], *cpu_name = cpu_string; /* 48 bytes are reported */
|
||||||
int vt, txt, aes;
|
int vt, txt, aes;
|
||||||
msr_t microcode_ver;
|
|
||||||
const char *mode[] = {"NOT ", ""};
|
const char *mode[] = {"NOT ", ""};
|
||||||
const char *cpu_type = "Unknown";
|
const char *cpu_type = "Unknown";
|
||||||
|
|
||||||
|
@ -98,11 +98,7 @@ static void report_cpu_info(void)
|
||||||
while (cpu_name[0] == ' ')
|
while (cpu_name[0] == ' ')
|
||||||
cpu_name++;
|
cpu_name++;
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(IA32_BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(IA32_BIOS_SIGN_ID);
|
|
||||||
|
|
||||||
/* Look for string to match the name */
|
/* Look for string to match the name */
|
||||||
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
||||||
|
@ -114,7 +110,7 @@ static void report_cpu_info(void)
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
||||||
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
||||||
cpu_id, cpu_type, microcode_ver.hi);
|
cpu_id, cpu_type, get_current_microcode_rev());
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <cpu/x86/name.h>
|
#include <cpu/x86/name.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
|
@ -12,8 +13,6 @@
|
||||||
#include <soc/pch.h>
|
#include <soc/pch.h>
|
||||||
#include <soc/pci_devs.h>
|
#include <soc/pci_devs.h>
|
||||||
|
|
||||||
#define BIOS_SIGN_ID 0x8B
|
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
u32 cpuid;
|
u32 cpuid;
|
||||||
const char *name;
|
const char *name;
|
||||||
|
@ -170,17 +169,11 @@ static void report_cpu_info(void)
|
||||||
u32 i, cpu_id, cpu_feature_flag;
|
u32 i, cpu_id, cpu_feature_flag;
|
||||||
char cpu_name[49];
|
char cpu_name[49];
|
||||||
int vt, txt, aes;
|
int vt, txt, aes;
|
||||||
msr_t microcode_ver;
|
|
||||||
static const char *const mode[] = {"NOT ", ""};
|
static const char *const mode[] = {"NOT ", ""};
|
||||||
const char *cpu_type = "Unknown";
|
const char *cpu_type = "Unknown";
|
||||||
|
|
||||||
fill_processor_name(cpu_name);
|
fill_processor_name(cpu_name);
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(BIOS_SIGN_ID);
|
|
||||||
|
|
||||||
/* Look for string to match the name */
|
/* Look for string to match the name */
|
||||||
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
||||||
|
@ -192,7 +185,7 @@ static void report_cpu_info(void)
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
||||||
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
||||||
cpu_id, cpu_type, microcode_ver.hi);
|
cpu_id, cpu_type, get_current_microcode_rev());
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
|
@ -12,8 +13,6 @@
|
||||||
#include <soc/pci_devs.h>
|
#include <soc/pci_devs.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#define BIOS_SIGN_ID 0x8B
|
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
u32 cpuid;
|
u32 cpuid;
|
||||||
const char *name;
|
const char *name;
|
||||||
|
@ -83,7 +82,6 @@ static void report_cpu_info(void)
|
||||||
const char cpu_not_found[] = "Platform info not available";
|
const char cpu_not_found[] = "Platform info not available";
|
||||||
const char *cpu_name = cpu_not_found; /* 48 bytes are reported */
|
const char *cpu_name = cpu_not_found; /* 48 bytes are reported */
|
||||||
int vt, txt, aes;
|
int vt, txt, aes;
|
||||||
msr_t microcode_ver;
|
|
||||||
static const char *const mode[] = {"NOT ", ""};
|
static const char *const mode[] = {"NOT ", ""};
|
||||||
const char *cpu_type = "Unknown";
|
const char *cpu_type = "Unknown";
|
||||||
u32 p[13];
|
u32 p[13];
|
||||||
|
@ -108,11 +106,7 @@ static void report_cpu_info(void)
|
||||||
cpu_name++;
|
cpu_name++;
|
||||||
}
|
}
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(BIOS_SIGN_ID);
|
|
||||||
|
|
||||||
/* Look for string to match the name */
|
/* Look for string to match the name */
|
||||||
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
||||||
|
@ -124,7 +118,7 @@ static void report_cpu_info(void)
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
||||||
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
||||||
cpu_id, cpu_type, microcode_ver.hi);
|
cpu_id, cpu_type, get_current_microcode_rev());
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <cpu/x86/name.h>
|
#include <cpu/x86/name.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
|
@ -13,8 +14,6 @@
|
||||||
#include <soc/pci_devs.h>
|
#include <soc/pci_devs.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#define BIOS_SIGN_ID 0x8B
|
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
u32 cpuid;
|
u32 cpuid;
|
||||||
const char *name;
|
const char *name;
|
||||||
|
@ -62,17 +61,11 @@ static void report_cpu_info(void)
|
||||||
u32 i, cpu_id, cpu_feature_flag;
|
u32 i, cpu_id, cpu_feature_flag;
|
||||||
char cpu_name[49];
|
char cpu_name[49];
|
||||||
int vt, txt, aes;
|
int vt, txt, aes;
|
||||||
msr_t microcode_ver;
|
|
||||||
static const char *const mode[] = {"NOT ", ""};
|
static const char *const mode[] = {"NOT ", ""};
|
||||||
const char *cpu_type = "Unknown";
|
const char *cpu_type = "Unknown";
|
||||||
|
|
||||||
fill_processor_name(cpu_name);
|
fill_processor_name(cpu_name);
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(BIOS_SIGN_ID);
|
|
||||||
|
|
||||||
/* Look for string to match the name */
|
/* Look for string to match the name */
|
||||||
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
||||||
|
@ -84,7 +77,7 @@ static void report_cpu_info(void)
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
||||||
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
||||||
cpu_id, cpu_type, microcode_ver.hi);
|
cpu_id, cpu_type, get_current_microcode_rev());
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <cpu/x86/name.h>
|
#include <cpu/x86/name.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
|
@ -153,17 +154,11 @@ static void report_cpu_info(void)
|
||||||
u32 i, cpu_id, cpu_feature_flag;
|
u32 i, cpu_id, cpu_feature_flag;
|
||||||
char cpu_name[49];
|
char cpu_name[49];
|
||||||
int vt, txt, aes;
|
int vt, txt, aes;
|
||||||
msr_t microcode_ver;
|
|
||||||
static const char *const mode[] = {"NOT ", ""};
|
static const char *const mode[] = {"NOT ", ""};
|
||||||
const char *cpu_type = "Unknown";
|
const char *cpu_type = "Unknown";
|
||||||
|
|
||||||
fill_processor_name(cpu_name);
|
fill_processor_name(cpu_name);
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(IA32_BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(IA32_BIOS_SIGN_ID);
|
|
||||||
|
|
||||||
/* Look for string to match the name */
|
/* Look for string to match the name */
|
||||||
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
||||||
|
@ -175,7 +170,7 @@ static void report_cpu_info(void)
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
||||||
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
||||||
cpu_id, cpu_type, microcode_ver.hi);
|
cpu_id, cpu_type, get_current_microcode_rev());
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
|
#include <cpu/intel/microcode.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
|
@ -18,8 +19,6 @@
|
||||||
#include <soc/pci_devs.h>
|
#include <soc/pci_devs.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#define BIOS_SIGN_ID 0x8B
|
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
u32 cpuid;
|
u32 cpuid;
|
||||||
const char *name;
|
const char *name;
|
||||||
|
@ -104,7 +103,6 @@ static void report_cpu_info(void)
|
||||||
const char cpu_not_found[] = "Platform info not available";
|
const char cpu_not_found[] = "Platform info not available";
|
||||||
const char *cpu_name = cpu_not_found; /* 48 bytes are reported */
|
const char *cpu_name = cpu_not_found; /* 48 bytes are reported */
|
||||||
int vt, txt, aes;
|
int vt, txt, aes;
|
||||||
msr_t microcode_ver;
|
|
||||||
static const char *const mode[] = {"NOT ", ""};
|
static const char *const mode[] = {"NOT ", ""};
|
||||||
const char *cpu_type = "Unknown";
|
const char *cpu_type = "Unknown";
|
||||||
u32 p[13];
|
u32 p[13];
|
||||||
|
@ -129,11 +127,7 @@ static void report_cpu_info(void)
|
||||||
cpu_name++;
|
cpu_name++;
|
||||||
}
|
}
|
||||||
|
|
||||||
microcode_ver.lo = 0;
|
|
||||||
microcode_ver.hi = 0;
|
|
||||||
wrmsr(BIOS_SIGN_ID, microcode_ver);
|
|
||||||
cpu_id = cpu_get_cpuid();
|
cpu_id = cpu_get_cpuid();
|
||||||
microcode_ver = rdmsr(BIOS_SIGN_ID);
|
|
||||||
|
|
||||||
/* Look for string to match the name */
|
/* Look for string to match the name */
|
||||||
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
|
||||||
|
@ -145,7 +139,7 @@ static void report_cpu_info(void)
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
|
||||||
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
|
||||||
cpu_id, cpu_type, microcode_ver.hi);
|
cpu_id, cpu_type, get_current_microcode_rev());
|
||||||
|
|
||||||
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
cpu_feature_flag = cpu_get_feature_flags_ecx();
|
||||||
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
|
||||||
|
|
Loading…
Reference in a new issue