diff options
author | Stuart Maybee <Stuart.Maybee@Sun.COM> | 2009-03-09 15:20:14 -0700 |
---|---|---|
committer | Stuart Maybee <Stuart.Maybee@Sun.COM> | 2009-03-09 15:20:14 -0700 |
commit | b9bfdccda8a7c490cc133ece2ab92d914e10b8d7 (patch) | |
tree | 16b0ad37419e3e91d743ed2a902cc6b39db27ee4 /usr/src/uts/i86pc/os/microcode.c | |
parent | fcff38ebb7bf8c483f8a0427b4885ef7bbdc0c58 (diff) | |
download | illumos-joyent-b9bfdccda8a7c490cc133ece2ab92d914e10b8d7.tar.gz |
6775011 bad trap page fault while starting dom0
Diffstat (limited to 'usr/src/uts/i86pc/os/microcode.c')
-rw-r--r-- | usr/src/uts/i86pc/os/microcode.c | 22 |
1 files changed, 6 insertions, 16 deletions
diff --git a/usr/src/uts/i86pc/os/microcode.c b/usr/src/uts/i86pc/os/microcode.c index 8cf5d99d24..c69c8c0500 100644 --- a/usr/src/uts/i86pc/os/microcode.c +++ b/usr/src/uts/i86pc/os/microcode.c @@ -203,32 +203,22 @@ ucode_free(processorid_t id, void* buf, size_t size) static int ucode_capable_amd(cpu_t *cp) { -#ifndef __xpv - extern int xpv_is_hvm; - if (xpv_is_hvm) { - return (0); - } -#else - if (!DOMAIN_IS_INITDOMAIN(xen_info)) { + int hwenv = get_hwenv(); + + if (hwenv == HW_XEN_HVM || (hwenv == HW_XEN_PV && !is_controldom())) { return (0); } -#endif return (cpuid_getfamily(cp) >= 0x10); } static int ucode_capable_intel(cpu_t *cp) { -#ifndef __xpv - extern int xpv_is_hvm; - if (xpv_is_hvm) { - return (0); - } -#else - if (!DOMAIN_IS_INITDOMAIN(xen_info)) { + int hwenv = get_hwenv(); + + if (hwenv == HW_XEN_HVM || (hwenv == HW_XEN_PV && !is_controldom())) { return (0); } -#endif return (cpuid_getfamily(cp) >= 6); } |