src: use mca_clear_status function instead of open coding
Change-Id: I53413b4051b79d7c2f24b1191ce877155e654400 Signed-off-by: Felix Held <felix-coreboot@felixheld.de> Reviewed-on: https://review.coreboot.org/c/coreboot/+/56259 Reviewed-by: Raul Rangel <rrangel@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
@@ -527,12 +527,10 @@ static void configure_mca(void)
|
||||
for (i = 0; i < num_banks; i++)
|
||||
wrmsr(IA32_MC_CTL(i), msr);
|
||||
|
||||
msr.lo = msr.hi = 0;
|
||||
/* TODO(adurbin): This should only be done on a cold boot. Also, some
|
||||
* of these banks are core vs package scope. For now every CPU clears
|
||||
* every bank. */
|
||||
for (i = 0; i < num_banks; i++)
|
||||
wrmsr(IA32_MC_STATUS(i), msr);
|
||||
mca_clear_status();
|
||||
}
|
||||
|
||||
/* All CPUs including BSP will run the following function. */
|
||||
|
@@ -73,24 +73,13 @@ static void set_max_ratio(void)
|
||||
((perf_ctl.lo >> 8) & 0xff) * IRONLAKE_BCLK);
|
||||
}
|
||||
|
||||
static void configure_mca(void)
|
||||
{
|
||||
msr_t msr;
|
||||
int i;
|
||||
const unsigned int num_banks = mca_get_bank_count();
|
||||
|
||||
msr.lo = msr.hi = 0;
|
||||
/* This should only be done on a cold boot */
|
||||
for (i = 0; i < num_banks; i++)
|
||||
wrmsr(IA32_MC_STATUS(i), msr);
|
||||
}
|
||||
|
||||
static void model_2065x_init(struct device *cpu)
|
||||
{
|
||||
char processor_name[49];
|
||||
|
||||
/* Clear out pending MCEs */
|
||||
configure_mca();
|
||||
/* This should only be done on a cold boot */
|
||||
mca_clear_status();
|
||||
|
||||
/* Print processor name */
|
||||
fill_processor_name(processor_name);
|
||||
|
@@ -297,18 +297,6 @@ unsigned int smbios_processor_external_clock(void)
|
||||
return SANDYBRIDGE_BCLK;
|
||||
}
|
||||
|
||||
static void configure_mca(void)
|
||||
{
|
||||
msr_t msr;
|
||||
int i;
|
||||
const unsigned int num_banks = mca_get_bank_count();
|
||||
|
||||
msr.lo = msr.hi = 0;
|
||||
/* This should only be done on a cold boot */
|
||||
for (i = 0; i < num_banks; i++)
|
||||
wrmsr(IA32_MC_STATUS(i), msr);
|
||||
}
|
||||
|
||||
static void model_206ax_report(void)
|
||||
{
|
||||
static const char *const mode[] = {"NOT ", ""};
|
||||
@@ -340,7 +328,8 @@ static void model_206ax_init(struct device *cpu)
|
||||
{
|
||||
|
||||
/* Clear out pending MCEs */
|
||||
configure_mca();
|
||||
/* This should only be done on a cold boot */
|
||||
mca_clear_status();
|
||||
|
||||
/* Print infos */
|
||||
model_206ax_report();
|
||||
|
Reference in New Issue
Block a user