target/i386/hvf: move and rename simulate_{rdmsr, wrmsr}
This requires making raise_exception non-static. That function needs to be renamed to avoid clashing with a function in TCG. Mostly code movement. No functional change. Signed-off-by: Wei Liu <liuwe@linux.microsoft.com> Link: https://lore.kernel.org/r/1740126987-8483-12-git-send-email-liuwe@linux.microsoft.com Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
dbccd48df0
commit
99e5aaf9af
@ -19,6 +19,8 @@
|
|||||||
uint32_t hvf_get_supported_cpuid(uint32_t func, uint32_t idx, int reg);
|
uint32_t hvf_get_supported_cpuid(uint32_t func, uint32_t idx, int reg);
|
||||||
|
|
||||||
void hvf_handle_io(CPUState *, uint16_t, void *, int, int, int);
|
void hvf_handle_io(CPUState *, uint16_t, void *, int, int, int);
|
||||||
|
void hvf_simulate_rdmsr(CPUX86State *env);
|
||||||
|
void hvf_simulate_wrmsr(CPUX86State *env);
|
||||||
|
|
||||||
/* Host specific functions */
|
/* Host specific functions */
|
||||||
int hvf_inject_interrupt(CPUArchState *env, int vector);
|
int hvf_inject_interrupt(CPUArchState *env, int vector);
|
||||||
|
@ -481,6 +481,218 @@ void hvf_store_regs(CPUState *cs)
|
|||||||
macvm_set_rip(cs, env->eip);
|
macvm_set_rip(cs, env->eip);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void hvf_simulate_rdmsr(CPUX86State *env)
|
||||||
|
{
|
||||||
|
X86CPU *cpu = env_archcpu(env);
|
||||||
|
CPUState *cs = env_cpu(env);
|
||||||
|
uint32_t msr = ECX(env);
|
||||||
|
uint64_t val = 0;
|
||||||
|
|
||||||
|
switch (msr) {
|
||||||
|
case MSR_IA32_TSC:
|
||||||
|
val = rdtscp() + rvmcs(cs->accel->fd, VMCS_TSC_OFFSET);
|
||||||
|
break;
|
||||||
|
case MSR_IA32_APICBASE:
|
||||||
|
val = cpu_get_apic_base(cpu->apic_state);
|
||||||
|
break;
|
||||||
|
case MSR_APIC_START ... MSR_APIC_END: {
|
||||||
|
int ret;
|
||||||
|
int index = (uint32_t)env->regs[R_ECX] - MSR_APIC_START;
|
||||||
|
|
||||||
|
ret = apic_msr_read(index, &val);
|
||||||
|
if (ret < 0) {
|
||||||
|
x86_emul_raise_exception(env, EXCP0D_GPF, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case MSR_IA32_UCODE_REV:
|
||||||
|
val = cpu->ucode_rev;
|
||||||
|
break;
|
||||||
|
case MSR_EFER:
|
||||||
|
val = rvmcs(cs->accel->fd, VMCS_GUEST_IA32_EFER);
|
||||||
|
break;
|
||||||
|
case MSR_FSBASE:
|
||||||
|
val = rvmcs(cs->accel->fd, VMCS_GUEST_FS_BASE);
|
||||||
|
break;
|
||||||
|
case MSR_GSBASE:
|
||||||
|
val = rvmcs(cs->accel->fd, VMCS_GUEST_GS_BASE);
|
||||||
|
break;
|
||||||
|
case MSR_KERNELGSBASE:
|
||||||
|
val = rvmcs(cs->accel->fd, VMCS_HOST_FS_BASE);
|
||||||
|
break;
|
||||||
|
case MSR_STAR:
|
||||||
|
abort();
|
||||||
|
break;
|
||||||
|
case MSR_LSTAR:
|
||||||
|
abort();
|
||||||
|
break;
|
||||||
|
case MSR_CSTAR:
|
||||||
|
abort();
|
||||||
|
break;
|
||||||
|
case MSR_IA32_MISC_ENABLE:
|
||||||
|
val = env->msr_ia32_misc_enable;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRphysBase(0):
|
||||||
|
case MSR_MTRRphysBase(1):
|
||||||
|
case MSR_MTRRphysBase(2):
|
||||||
|
case MSR_MTRRphysBase(3):
|
||||||
|
case MSR_MTRRphysBase(4):
|
||||||
|
case MSR_MTRRphysBase(5):
|
||||||
|
case MSR_MTRRphysBase(6):
|
||||||
|
case MSR_MTRRphysBase(7):
|
||||||
|
val = env->mtrr_var[(ECX(env) - MSR_MTRRphysBase(0)) / 2].base;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRphysMask(0):
|
||||||
|
case MSR_MTRRphysMask(1):
|
||||||
|
case MSR_MTRRphysMask(2):
|
||||||
|
case MSR_MTRRphysMask(3):
|
||||||
|
case MSR_MTRRphysMask(4):
|
||||||
|
case MSR_MTRRphysMask(5):
|
||||||
|
case MSR_MTRRphysMask(6):
|
||||||
|
case MSR_MTRRphysMask(7):
|
||||||
|
val = env->mtrr_var[(ECX(env) - MSR_MTRRphysMask(0)) / 2].mask;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRfix64K_00000:
|
||||||
|
val = env->mtrr_fixed[0];
|
||||||
|
break;
|
||||||
|
case MSR_MTRRfix16K_80000:
|
||||||
|
case MSR_MTRRfix16K_A0000:
|
||||||
|
val = env->mtrr_fixed[ECX(env) - MSR_MTRRfix16K_80000 + 1];
|
||||||
|
break;
|
||||||
|
case MSR_MTRRfix4K_C0000:
|
||||||
|
case MSR_MTRRfix4K_C8000:
|
||||||
|
case MSR_MTRRfix4K_D0000:
|
||||||
|
case MSR_MTRRfix4K_D8000:
|
||||||
|
case MSR_MTRRfix4K_E0000:
|
||||||
|
case MSR_MTRRfix4K_E8000:
|
||||||
|
case MSR_MTRRfix4K_F0000:
|
||||||
|
case MSR_MTRRfix4K_F8000:
|
||||||
|
val = env->mtrr_fixed[ECX(env) - MSR_MTRRfix4K_C0000 + 3];
|
||||||
|
break;
|
||||||
|
case MSR_MTRRdefType:
|
||||||
|
val = env->mtrr_deftype;
|
||||||
|
break;
|
||||||
|
case MSR_CORE_THREAD_COUNT:
|
||||||
|
val = cpu_x86_get_msr_core_thread_count(cpu);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* fprintf(stderr, "%s: unknown msr 0x%x\n", __func__, msr); */
|
||||||
|
val = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
RAX(env) = (uint32_t)val;
|
||||||
|
RDX(env) = (uint32_t)(val >> 32);
|
||||||
|
}
|
||||||
|
|
||||||
|
void hvf_simulate_wrmsr(CPUX86State *env)
|
||||||
|
{
|
||||||
|
X86CPU *cpu = env_archcpu(env);
|
||||||
|
CPUState *cs = env_cpu(env);
|
||||||
|
uint32_t msr = ECX(env);
|
||||||
|
uint64_t data = ((uint64_t)EDX(env) << 32) | EAX(env);
|
||||||
|
|
||||||
|
switch (msr) {
|
||||||
|
case MSR_IA32_TSC:
|
||||||
|
break;
|
||||||
|
case MSR_IA32_APICBASE: {
|
||||||
|
int r;
|
||||||
|
|
||||||
|
r = cpu_set_apic_base(cpu->apic_state, data);
|
||||||
|
if (r < 0) {
|
||||||
|
x86_emul_raise_exception(env, EXCP0D_GPF, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case MSR_APIC_START ... MSR_APIC_END: {
|
||||||
|
int ret;
|
||||||
|
int index = (uint32_t)env->regs[R_ECX] - MSR_APIC_START;
|
||||||
|
|
||||||
|
ret = apic_msr_write(index, data);
|
||||||
|
if (ret < 0) {
|
||||||
|
x86_emul_raise_exception(env, EXCP0D_GPF, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case MSR_FSBASE:
|
||||||
|
wvmcs(cs->accel->fd, VMCS_GUEST_FS_BASE, data);
|
||||||
|
break;
|
||||||
|
case MSR_GSBASE:
|
||||||
|
wvmcs(cs->accel->fd, VMCS_GUEST_GS_BASE, data);
|
||||||
|
break;
|
||||||
|
case MSR_KERNELGSBASE:
|
||||||
|
wvmcs(cs->accel->fd, VMCS_HOST_FS_BASE, data);
|
||||||
|
break;
|
||||||
|
case MSR_STAR:
|
||||||
|
abort();
|
||||||
|
break;
|
||||||
|
case MSR_LSTAR:
|
||||||
|
abort();
|
||||||
|
break;
|
||||||
|
case MSR_CSTAR:
|
||||||
|
abort();
|
||||||
|
break;
|
||||||
|
case MSR_EFER:
|
||||||
|
/*printf("new efer %llx\n", EFER(cs));*/
|
||||||
|
wvmcs(cs->accel->fd, VMCS_GUEST_IA32_EFER, data);
|
||||||
|
if (data & MSR_EFER_NXE) {
|
||||||
|
hv_vcpu_invalidate_tlb(cs->accel->fd);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case MSR_MTRRphysBase(0):
|
||||||
|
case MSR_MTRRphysBase(1):
|
||||||
|
case MSR_MTRRphysBase(2):
|
||||||
|
case MSR_MTRRphysBase(3):
|
||||||
|
case MSR_MTRRphysBase(4):
|
||||||
|
case MSR_MTRRphysBase(5):
|
||||||
|
case MSR_MTRRphysBase(6):
|
||||||
|
case MSR_MTRRphysBase(7):
|
||||||
|
env->mtrr_var[(ECX(env) - MSR_MTRRphysBase(0)) / 2].base = data;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRphysMask(0):
|
||||||
|
case MSR_MTRRphysMask(1):
|
||||||
|
case MSR_MTRRphysMask(2):
|
||||||
|
case MSR_MTRRphysMask(3):
|
||||||
|
case MSR_MTRRphysMask(4):
|
||||||
|
case MSR_MTRRphysMask(5):
|
||||||
|
case MSR_MTRRphysMask(6):
|
||||||
|
case MSR_MTRRphysMask(7):
|
||||||
|
env->mtrr_var[(ECX(env) - MSR_MTRRphysMask(0)) / 2].mask = data;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRfix64K_00000:
|
||||||
|
env->mtrr_fixed[ECX(env) - MSR_MTRRfix64K_00000] = data;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRfix16K_80000:
|
||||||
|
case MSR_MTRRfix16K_A0000:
|
||||||
|
env->mtrr_fixed[ECX(env) - MSR_MTRRfix16K_80000 + 1] = data;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRfix4K_C0000:
|
||||||
|
case MSR_MTRRfix4K_C8000:
|
||||||
|
case MSR_MTRRfix4K_D0000:
|
||||||
|
case MSR_MTRRfix4K_D8000:
|
||||||
|
case MSR_MTRRfix4K_E0000:
|
||||||
|
case MSR_MTRRfix4K_E8000:
|
||||||
|
case MSR_MTRRfix4K_F0000:
|
||||||
|
case MSR_MTRRfix4K_F8000:
|
||||||
|
env->mtrr_fixed[ECX(env) - MSR_MTRRfix4K_C0000 + 3] = data;
|
||||||
|
break;
|
||||||
|
case MSR_MTRRdefType:
|
||||||
|
env->mtrr_deftype = data;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Related to support known hypervisor interface */
|
||||||
|
/* if (g_hypervisor_iface)
|
||||||
|
g_hypervisor_iface->wrmsr_handler(cs, msr, data);
|
||||||
|
|
||||||
|
printf("write msr %llx\n", RCX(cs));*/
|
||||||
|
}
|
||||||
|
|
||||||
int hvf_vcpu_exec(CPUState *cpu)
|
int hvf_vcpu_exec(CPUState *cpu)
|
||||||
{
|
{
|
||||||
X86CPU *x86_cpu = X86_CPU(cpu);
|
X86CPU *x86_cpu = X86_CPU(cpu);
|
||||||
@ -663,9 +875,9 @@ int hvf_vcpu_exec(CPUState *cpu)
|
|||||||
{
|
{
|
||||||
hvf_load_regs(cpu);
|
hvf_load_regs(cpu);
|
||||||
if (exit_reason == EXIT_REASON_RDMSR) {
|
if (exit_reason == EXIT_REASON_RDMSR) {
|
||||||
simulate_rdmsr(env);
|
hvf_simulate_rdmsr(env);
|
||||||
} else {
|
} else {
|
||||||
simulate_wrmsr(env);
|
hvf_simulate_wrmsr(env);
|
||||||
}
|
}
|
||||||
env->eip += ins_len;
|
env->eip += ins_len;
|
||||||
hvf_store_regs(cpu);
|
hvf_store_regs(cpu);
|
||||||
|
@ -661,8 +661,7 @@ static void exec_lods(CPUX86State *env, struct x86_decode *decode)
|
|||||||
env->eip += decode->len;
|
env->eip += decode->len;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void raise_exception(CPUX86State *env, int exception_index,
|
void x86_emul_raise_exception(CPUX86State *env, int exception_index, int error_code)
|
||||||
int error_code)
|
|
||||||
{
|
{
|
||||||
env->exception_nr = exception_index;
|
env->exception_nr = exception_index;
|
||||||
env->error_code = error_code;
|
env->error_code = error_code;
|
||||||
@ -670,227 +669,15 @@ static void raise_exception(CPUX86State *env, int exception_index,
|
|||||||
env->exception_injected = 1;
|
env->exception_injected = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void simulate_rdmsr(CPUX86State *env)
|
|
||||||
{
|
|
||||||
X86CPU *cpu = env_archcpu(env);
|
|
||||||
CPUState *cs = env_cpu(env);
|
|
||||||
uint32_t msr = ECX(env);
|
|
||||||
uint64_t val = 0;
|
|
||||||
|
|
||||||
switch (msr) {
|
|
||||||
case MSR_IA32_TSC:
|
|
||||||
val = rdtscp() + rvmcs(cs->accel->fd, VMCS_TSC_OFFSET);
|
|
||||||
break;
|
|
||||||
case MSR_IA32_APICBASE:
|
|
||||||
val = cpu_get_apic_base(cpu->apic_state);
|
|
||||||
break;
|
|
||||||
case MSR_APIC_START ... MSR_APIC_END: {
|
|
||||||
int ret;
|
|
||||||
int index = (uint32_t)env->regs[R_ECX] - MSR_APIC_START;
|
|
||||||
|
|
||||||
ret = apic_msr_read(index, &val);
|
|
||||||
if (ret < 0) {
|
|
||||||
raise_exception(env, EXCP0D_GPF, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case MSR_IA32_UCODE_REV:
|
|
||||||
val = cpu->ucode_rev;
|
|
||||||
break;
|
|
||||||
case MSR_EFER:
|
|
||||||
val = rvmcs(cs->accel->fd, VMCS_GUEST_IA32_EFER);
|
|
||||||
break;
|
|
||||||
case MSR_FSBASE:
|
|
||||||
val = rvmcs(cs->accel->fd, VMCS_GUEST_FS_BASE);
|
|
||||||
break;
|
|
||||||
case MSR_GSBASE:
|
|
||||||
val = rvmcs(cs->accel->fd, VMCS_GUEST_GS_BASE);
|
|
||||||
break;
|
|
||||||
case MSR_KERNELGSBASE:
|
|
||||||
val = rvmcs(cs->accel->fd, VMCS_HOST_FS_BASE);
|
|
||||||
break;
|
|
||||||
case MSR_STAR:
|
|
||||||
abort();
|
|
||||||
break;
|
|
||||||
case MSR_LSTAR:
|
|
||||||
abort();
|
|
||||||
break;
|
|
||||||
case MSR_CSTAR:
|
|
||||||
abort();
|
|
||||||
break;
|
|
||||||
case MSR_IA32_MISC_ENABLE:
|
|
||||||
val = env->msr_ia32_misc_enable;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRphysBase(0):
|
|
||||||
case MSR_MTRRphysBase(1):
|
|
||||||
case MSR_MTRRphysBase(2):
|
|
||||||
case MSR_MTRRphysBase(3):
|
|
||||||
case MSR_MTRRphysBase(4):
|
|
||||||
case MSR_MTRRphysBase(5):
|
|
||||||
case MSR_MTRRphysBase(6):
|
|
||||||
case MSR_MTRRphysBase(7):
|
|
||||||
val = env->mtrr_var[(ECX(env) - MSR_MTRRphysBase(0)) / 2].base;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRphysMask(0):
|
|
||||||
case MSR_MTRRphysMask(1):
|
|
||||||
case MSR_MTRRphysMask(2):
|
|
||||||
case MSR_MTRRphysMask(3):
|
|
||||||
case MSR_MTRRphysMask(4):
|
|
||||||
case MSR_MTRRphysMask(5):
|
|
||||||
case MSR_MTRRphysMask(6):
|
|
||||||
case MSR_MTRRphysMask(7):
|
|
||||||
val = env->mtrr_var[(ECX(env) - MSR_MTRRphysMask(0)) / 2].mask;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRfix64K_00000:
|
|
||||||
val = env->mtrr_fixed[0];
|
|
||||||
break;
|
|
||||||
case MSR_MTRRfix16K_80000:
|
|
||||||
case MSR_MTRRfix16K_A0000:
|
|
||||||
val = env->mtrr_fixed[ECX(env) - MSR_MTRRfix16K_80000 + 1];
|
|
||||||
break;
|
|
||||||
case MSR_MTRRfix4K_C0000:
|
|
||||||
case MSR_MTRRfix4K_C8000:
|
|
||||||
case MSR_MTRRfix4K_D0000:
|
|
||||||
case MSR_MTRRfix4K_D8000:
|
|
||||||
case MSR_MTRRfix4K_E0000:
|
|
||||||
case MSR_MTRRfix4K_E8000:
|
|
||||||
case MSR_MTRRfix4K_F0000:
|
|
||||||
case MSR_MTRRfix4K_F8000:
|
|
||||||
val = env->mtrr_fixed[ECX(env) - MSR_MTRRfix4K_C0000 + 3];
|
|
||||||
break;
|
|
||||||
case MSR_MTRRdefType:
|
|
||||||
val = env->mtrr_deftype;
|
|
||||||
break;
|
|
||||||
case MSR_CORE_THREAD_COUNT:
|
|
||||||
val = cpu_x86_get_msr_core_thread_count(cpu);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
/* fprintf(stderr, "%s: unknown msr 0x%x\n", __func__, msr); */
|
|
||||||
val = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
RAX(env) = (uint32_t)val;
|
|
||||||
RDX(env) = (uint32_t)(val >> 32);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void exec_rdmsr(CPUX86State *env, struct x86_decode *decode)
|
static void exec_rdmsr(CPUX86State *env, struct x86_decode *decode)
|
||||||
{
|
{
|
||||||
simulate_rdmsr(env);
|
hvf_simulate_rdmsr(env);
|
||||||
env->eip += decode->len;
|
env->eip += decode->len;
|
||||||
}
|
}
|
||||||
|
|
||||||
void simulate_wrmsr(CPUX86State *env)
|
|
||||||
{
|
|
||||||
X86CPU *cpu = env_archcpu(env);
|
|
||||||
CPUState *cs = env_cpu(env);
|
|
||||||
uint32_t msr = ECX(env);
|
|
||||||
uint64_t data = ((uint64_t)EDX(env) << 32) | EAX(env);
|
|
||||||
|
|
||||||
switch (msr) {
|
|
||||||
case MSR_IA32_TSC:
|
|
||||||
break;
|
|
||||||
case MSR_IA32_APICBASE: {
|
|
||||||
int r;
|
|
||||||
|
|
||||||
r = cpu_set_apic_base(cpu->apic_state, data);
|
|
||||||
if (r < 0) {
|
|
||||||
raise_exception(env, EXCP0D_GPF, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case MSR_APIC_START ... MSR_APIC_END: {
|
|
||||||
int ret;
|
|
||||||
int index = (uint32_t)env->regs[R_ECX] - MSR_APIC_START;
|
|
||||||
|
|
||||||
ret = apic_msr_write(index, data);
|
|
||||||
if (ret < 0) {
|
|
||||||
raise_exception(env, EXCP0D_GPF, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case MSR_FSBASE:
|
|
||||||
wvmcs(cs->accel->fd, VMCS_GUEST_FS_BASE, data);
|
|
||||||
break;
|
|
||||||
case MSR_GSBASE:
|
|
||||||
wvmcs(cs->accel->fd, VMCS_GUEST_GS_BASE, data);
|
|
||||||
break;
|
|
||||||
case MSR_KERNELGSBASE:
|
|
||||||
wvmcs(cs->accel->fd, VMCS_HOST_FS_BASE, data);
|
|
||||||
break;
|
|
||||||
case MSR_STAR:
|
|
||||||
abort();
|
|
||||||
break;
|
|
||||||
case MSR_LSTAR:
|
|
||||||
abort();
|
|
||||||
break;
|
|
||||||
case MSR_CSTAR:
|
|
||||||
abort();
|
|
||||||
break;
|
|
||||||
case MSR_EFER:
|
|
||||||
/*printf("new efer %llx\n", EFER(cs));*/
|
|
||||||
wvmcs(cs->accel->fd, VMCS_GUEST_IA32_EFER, data);
|
|
||||||
if (data & MSR_EFER_NXE) {
|
|
||||||
hv_vcpu_invalidate_tlb(cs->accel->fd);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case MSR_MTRRphysBase(0):
|
|
||||||
case MSR_MTRRphysBase(1):
|
|
||||||
case MSR_MTRRphysBase(2):
|
|
||||||
case MSR_MTRRphysBase(3):
|
|
||||||
case MSR_MTRRphysBase(4):
|
|
||||||
case MSR_MTRRphysBase(5):
|
|
||||||
case MSR_MTRRphysBase(6):
|
|
||||||
case MSR_MTRRphysBase(7):
|
|
||||||
env->mtrr_var[(ECX(env) - MSR_MTRRphysBase(0)) / 2].base = data;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRphysMask(0):
|
|
||||||
case MSR_MTRRphysMask(1):
|
|
||||||
case MSR_MTRRphysMask(2):
|
|
||||||
case MSR_MTRRphysMask(3):
|
|
||||||
case MSR_MTRRphysMask(4):
|
|
||||||
case MSR_MTRRphysMask(5):
|
|
||||||
case MSR_MTRRphysMask(6):
|
|
||||||
case MSR_MTRRphysMask(7):
|
|
||||||
env->mtrr_var[(ECX(env) - MSR_MTRRphysMask(0)) / 2].mask = data;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRfix64K_00000:
|
|
||||||
env->mtrr_fixed[ECX(env) - MSR_MTRRfix64K_00000] = data;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRfix16K_80000:
|
|
||||||
case MSR_MTRRfix16K_A0000:
|
|
||||||
env->mtrr_fixed[ECX(env) - MSR_MTRRfix16K_80000 + 1] = data;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRfix4K_C0000:
|
|
||||||
case MSR_MTRRfix4K_C8000:
|
|
||||||
case MSR_MTRRfix4K_D0000:
|
|
||||||
case MSR_MTRRfix4K_D8000:
|
|
||||||
case MSR_MTRRfix4K_E0000:
|
|
||||||
case MSR_MTRRfix4K_E8000:
|
|
||||||
case MSR_MTRRfix4K_F0000:
|
|
||||||
case MSR_MTRRfix4K_F8000:
|
|
||||||
env->mtrr_fixed[ECX(env) - MSR_MTRRfix4K_C0000 + 3] = data;
|
|
||||||
break;
|
|
||||||
case MSR_MTRRdefType:
|
|
||||||
env->mtrr_deftype = data;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Related to support known hypervisor interface */
|
|
||||||
/* if (g_hypervisor_iface)
|
|
||||||
g_hypervisor_iface->wrmsr_handler(cs, msr, data);
|
|
||||||
|
|
||||||
printf("write msr %llx\n", RCX(cs));*/
|
|
||||||
}
|
|
||||||
|
|
||||||
static void exec_wrmsr(CPUX86State *env, struct x86_decode *decode)
|
static void exec_wrmsr(CPUX86State *env, struct x86_decode *decode)
|
||||||
{
|
{
|
||||||
simulate_wrmsr(env);
|
hvf_simulate_wrmsr(env);
|
||||||
env->eip += decode->len;
|
env->eip += decode->len;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,9 +25,7 @@
|
|||||||
|
|
||||||
void init_emu(void);
|
void init_emu(void);
|
||||||
bool exec_instruction(CPUX86State *env, struct x86_decode *ins);
|
bool exec_instruction(CPUX86State *env, struct x86_decode *ins);
|
||||||
|
void x86_emul_raise_exception(CPUX86State *env, int exception_index, int error_code);
|
||||||
void simulate_rdmsr(CPUX86State *env);
|
|
||||||
void simulate_wrmsr(CPUX86State *env);
|
|
||||||
|
|
||||||
target_ulong read_reg(CPUX86State *env, int reg, int size);
|
target_ulong read_reg(CPUX86State *env, int reg, int size);
|
||||||
void write_reg(CPUX86State *env, int reg, target_ulong val, int size);
|
void write_reg(CPUX86State *env, int reg, target_ulong val, int size);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user