Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/x86/x86 Check that the host supports GET_SPEED as w...



details:   https://anonhg.NetBSD.org/src/rev/07a21584d7c1
branches:  trunk
changeset: 356848:07a21584d7c1
user:      maya <maya%NetBSD.org@localhost>
date:      Tue Oct 17 05:47:09 2017 +0000

description:
Check that the host supports GET_SPEED as well as GET_VERSION
before deciding vmt_probe has succeeded.

qemu supports GET_VERSION but not the RPC protocol so the probe succeeds
but the attach fails, resulting in "vmt0: failed to open backdoor RPC
channel (TCLO protocol)".  All known versions of vmware support GET_SPEED
and no known qemu versions do, so this prevents it from attempting to
attach (and failing) on qemu while still working on vmware.

stop checking vmt_type to avoid having to adapt this code.

- Taken from openbsd

diffstat:

 sys/arch/x86/x86/vmt.c |  55 ++++++++++++++++++++------------------------------
 1 files changed, 22 insertions(+), 33 deletions(-)

diffs (91 lines):

diff -r 417c0e682861 -r 07a21584d7c1 sys/arch/x86/x86/vmt.c
--- a/sys/arch/x86/x86/vmt.c    Tue Oct 17 00:26:35 2017 +0000
+++ b/sys/arch/x86/x86/vmt.c    Tue Oct 17 05:47:09 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vmt.c,v 1.17 2017/06/01 02:45:08 chs Exp $ */
+/* $NetBSD: vmt.c,v 1.18 2017/10/17 05:47:09 maya Exp $ */
 /* $OpenBSD: vmt.c,v 1.11 2011/01/27 21:29:25 dtucker Exp $ */
 
 /*
@@ -126,28 +126,34 @@
 
 extern char hostname[MAXHOSTNAMELEN];
 
+static void
+vmt_probe_cmd(struct vm_backdoor *frame, uint16_t cmd)
+{
+       memset(frame, 0, sizeof(*frame));
+
+       (frame->eax).word = VM_MAGIC;
+       (frame->ebx).word = ~VM_MAGIC;
+       (frame->ecx).part.low = cmd;
+       (frame->ecx).part.high = 0xffff;
+       (frame->edx).part.low  = VM_PORT_CMD;
+       (frame->edx).part.high = 0;
+
+       vm_cmd(frame);
+}
+
 static bool
-vmt_probe(uint32_t *type)
+vmt_probe(void)
 {
        struct vm_backdoor frame;
 
-       memset(&frame, 0, sizeof(frame));
-
-       frame.eax.word = VM_MAGIC;
-       frame.ebx.word = ~VM_MAGIC;
-       frame.ecx.part.low = VM_CMD_GET_VERSION;
-       frame.ecx.part.high = 0xffff;
-       frame.edx.part.low  = VM_PORT_CMD;
-       frame.edx.part.high = 0;
-
-       vm_cmd(&frame);
-
+       vmt_probe_cmd(&frame, VM_CMD_GET_VERSION);
        if (frame.eax.word == 0xffffffff ||
            frame.ebx.word != VM_MAGIC)
                return false;
 
-       if (type)
-               *type = frame.ecx.word;
+       vmt_probe_cmd(&frame, VM_CMD_GET_SPEED);
+       if (frame.eax.word == VM_MAGIC)
+               return false;
 
        return true;
 }
@@ -163,23 +169,7 @@
        if ((ci->ci_flags & (CPUF_BSP|CPUF_SP|CPUF_PRIMARY)) == 0)
                return 0;
 
-       return vmt_probe(NULL);
-}
-
-static const char *
-vmt_type(void)
-{
-       uint32_t vmwaretype = 0;
-
-       vmt_probe(&vmwaretype);
-
-       switch (vmwaretype) {
-       case 1: return "Express";
-       case 2: return "ESX Server";
-       case 3: return "VMware Server";
-       case 4: return "Workstation";
-       default: return "Unknown";
-       }
+       return vmt_probe();
 }
 
 static void
@@ -189,7 +179,6 @@
        struct vmt_softc *sc = device_private(self);
 
        aprint_naive("\n");
-       aprint_normal(": %s\n", vmt_type());
 
        sc->sc_dev = self;
        sc->sc_log = NULL;



Home | Main Index | Thread Index | Old Index