mirror of https://github.com/xemu-project/xemu.git
Clean up cpu_inject_x86_mce()
Clean up cpu_inject_x86_mce() for later patch. Signed-off-by: Jin Dongming <jin.dongming@np.css.fujitsu.com> Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
This commit is contained in:
parent
14a095184c
commit
b3cd24e04a
|
@ -1021,21 +1021,12 @@ static void breakpoint_handler(CPUState *env)
|
||||||
/* This should come from sysemu.h - if we could include it here... */
|
/* This should come from sysemu.h - if we could include it here... */
|
||||||
void qemu_system_reset_request(void);
|
void qemu_system_reset_request(void);
|
||||||
|
|
||||||
void cpu_inject_x86_mce(CPUState *cenv, int bank, uint64_t status,
|
static void qemu_inject_x86_mce(CPUState *cenv, int bank, uint64_t status,
|
||||||
uint64_t mcg_status, uint64_t addr, uint64_t misc)
|
uint64_t mcg_status, uint64_t addr, uint64_t misc)
|
||||||
{
|
{
|
||||||
uint64_t mcg_cap = cenv->mcg_cap;
|
uint64_t mcg_cap = cenv->mcg_cap;
|
||||||
unsigned bank_num = mcg_cap & 0xff;
|
|
||||||
uint64_t *banks = cenv->mce_banks;
|
uint64_t *banks = cenv->mce_banks;
|
||||||
|
|
||||||
if (bank >= bank_num || !(status & MCI_STATUS_VAL))
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (kvm_enabled()) {
|
|
||||||
kvm_inject_x86_mce(cenv, bank, status, mcg_status, addr, misc, 0);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* if MSR_MCG_CTL is not all 1s, the uncorrected error
|
* if MSR_MCG_CTL is not all 1s, the uncorrected error
|
||||||
* reporting is disabled
|
* reporting is disabled
|
||||||
|
@ -1076,6 +1067,22 @@ void cpu_inject_x86_mce(CPUState *cenv, int bank, uint64_t status,
|
||||||
} else
|
} else
|
||||||
banks[1] |= MCI_STATUS_OVER;
|
banks[1] |= MCI_STATUS_OVER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cpu_inject_x86_mce(CPUState *cenv, int bank, uint64_t status,
|
||||||
|
uint64_t mcg_status, uint64_t addr, uint64_t misc)
|
||||||
|
{
|
||||||
|
unsigned bank_num = cenv->mcg_cap & 0xff;
|
||||||
|
|
||||||
|
if (bank >= bank_num || !(status & MCI_STATUS_VAL)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (kvm_enabled()) {
|
||||||
|
kvm_inject_x86_mce(cenv, bank, status, mcg_status, addr, misc, 0);
|
||||||
|
} else {
|
||||||
|
qemu_inject_x86_mce(cenv, bank, status, mcg_status, addr, misc);
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif /* !CONFIG_USER_ONLY */
|
#endif /* !CONFIG_USER_ONLY */
|
||||||
|
|
||||||
static void mce_init(CPUX86State *cenv)
|
static void mce_init(CPUX86State *cenv)
|
||||||
|
|
Loading…
Reference in New Issue