Files
pcem/includes/private/cpu/x86_ops_msr.h
2022-06-23 11:26:13 -07:00

30 lines
779 B
C

#ifndef _X86_OPS_MSR_H_
#define _X86_OPS_MSR_H_
static int opRDTSC(uint32_t fetchdat) {
if (!cpu_has_feature(CPU_FEATURE_RDTSC)) {
cpu_state.pc = cpu_state.oldpc;
x86illegal();
return 1;
}
if ((cr4 & CR4_TSD) && CPL) {
x86gpf("RDTSC when TSD set and CPL != 0", 0);
return 1;
}
EAX = tsc & 0xffffffff;
EDX = tsc >> 32;
CLOCK_CYCLES(1);
return 0;
}
static int opRDPMC(uint32_t fetchdat) {
if (ECX > 1 || (!(cr4 & CR4_PCE) && (cr0 & 1) && CPL)) {
x86gpf("RDPMC not allowed", 0);
return 1;
}
EAX = EDX = 0;
CLOCK_CYCLES(1);
return 0;
}
#endif /* _X86_OPS_MSR_H_ */