From: lkundrak@v3.sk
To: qemu-devel@nongnu.org
Subject: [Qemu-devel] [PATCH] Support for serial mouse emulation
Date: Tue, 2 Dec 2008 17:50:58 -0500 (EST) [thread overview]
Message-ID: <44179.89.102.207.186.1228258258.squirrel@mail.netbsd.sk> (raw)
[-- Attachment #1: Type: text/plain, Size: 399 bytes --]
Attaching (sorry for not posting it inline, but my e-mail client mangles
whitespace) a patch for mouse emulation on a serial port. Emulates a
three-button mouse that uses Microsoft protocol.
Tested with 386BSD 0.1 and XFree86 2.1. It seems that my guest is not the
only one that lacks PS/2 mouse support though [1] :)
[1] http://www.archivum.info/qemu-devel@nongnu.org/2005-09/msg00055.html
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: qemu-20081202-msmouse.patch --]
[-- Type: text/x-patch; name="qemu-20081202-msmouse.patch", Size: 7658 bytes --]
QEMU Microsoft serial mouse emulation
Lubomir Rintel <lkundrak@v3.sk>
Index: Makefile.target
===================================================================
--- Makefile.target (revision 5799)
+++ Makefile.target (working copy)
@@ -659,7 +659,7 @@
ifeq ($(TARGET_BASE_ARCH), i386)
# Hardware support
-OBJS+= ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o
+OBJS+= ide.o pckbd.o ps2.o msmouse.o vga.o $(SOUND_HW) dma.o
OBJS+= fdc.o mc146818rtc.o serial.o i8259.o i8254.o pcspk.o pc.o
OBJS+= cirrus_vga.o apic.o parallel.o acpi.o piix_pci.o
OBJS+= usb-uhci.o vmmouse.o vmport.o vmware_vga.o
@@ -670,7 +670,7 @@
# shared objects
OBJS+= ppc.o ide.o vga.o $(SOUND_HW) dma.o openpic.o
# PREP target
-OBJS+= pckbd.o ps2.o serial.o i8259.o i8254.o fdc.o m48t59.o mc146818rtc.o
+OBJS+= pckbd.o ps2.o msmouse.o serial.o i8259.o i8254.o fdc.o m48t59.o mc146818rtc.o
OBJS+= prep_pci.o ppc_prep.o
# Mac shared devices
OBJS+= macio.o cuda.o adb.o mac_nvram.o mac_dbdma.o
@@ -685,7 +685,7 @@
OBJS+= mips_r4k.o mips_jazz.o mips_malta.o mips_mipssim.o
OBJS+= mips_timer.o mips_int.o dma.o vga.o serial.o i8254.o i8259.o rc4030.o
OBJS+= g364fb.o jazz_led.o
-OBJS+= ide.o gt64xxx.o pckbd.o ps2.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
+OBJS+= ide.o gt64xxx.o pckbd.o ps2.o msmouse.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
OBJS+= piix_pci.o parallel.o cirrus_vga.o pcspk.o $(SOUND_HW)
OBJS+= mipsnet.o
OBJS+= pflash_cfi01.o
@@ -704,7 +704,7 @@
endif
ifeq ($(TARGET_BASE_ARCH), sparc)
ifeq ($(TARGET_ARCH), sparc64)
-OBJS+= sun4u.o ide.o pckbd.o ps2.o vga.o apb_pci.o
+OBJS+= sun4u.o ide.o pckbd.o ps2.o msmouse.o vga.o apb_pci.o
OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
OBJS+= cirrus_vga.o parallel.o ptimer.o
else
@@ -714,7 +714,7 @@
endif
endif
ifeq ($(TARGET_BASE_ARCH), arm)
-OBJS+= integratorcp.o versatilepb.o ps2.o smc91c111.o arm_pic.o arm_timer.o
+OBJS+= integratorcp.o versatilepb.o ps2.o msmouse.o smc91c111.o arm_pic.o arm_timer.o
OBJS+= arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
OBJS+= versatile_pci.o ptimer.o
OBJS+= realview_gic.o realview.o arm_sysctl.o mpcore.o
Index: qemu-char.c
===================================================================
--- qemu-char.c (revision 5799)
+++ qemu-char.c (working copy)
@@ -30,6 +30,7 @@
#include "block.h"
#include "hw/usb.h"
#include "hw/baum.h"
+#include "hw/msmouse.h"
#include <unistd.h>
#include <fcntl.h>
@@ -2120,6 +2121,41 @@
return NULL;
}
+/***********************************************************/
+/* Microsoft serial mouse */
+
+/* This is written to by hw/msmouse.c if non-NULL */
+CharDriverState *msmouse_chr = NULL;
+
+int msmouse_chr_write (struct CharDriverState *s, const uint8_t *buf, int len)
+{
+ /* Ignore writes to mouse port */
+ return len;
+}
+
+void msmouse_chr_close (struct CharDriverState *s)
+{
+ qemu_free (s);
+ msmouse_chr = NULL;
+}
+
+static CharDriverState *qemu_chr_open_msmouse(void)
+{
+ CharDriverState *chr;
+
+ /* Only one serial mouse per instance is allowed */
+ if (msmouse_chr != NULL) {
+ return NULL;
+ }
+
+ chr = qemu_mallocz(sizeof(CharDriverState));
+ chr->chr_write = msmouse_chr_write;
+ chr->chr_close = msmouse_chr_close;
+ msmouse_chr = chr;
+
+ return chr;
+}
+
static TAILQ_HEAD(CharDriverStateHead, CharDriverState) chardevs
= TAILQ_HEAD_INITIALIZER(chardevs);
@@ -2154,6 +2190,8 @@
} else {
printf("Unable to open driver: %s\n", p);
}
+ } else if (!strcmp(filename, "msmouse")) {
+ chr = qemu_chr_open_msmouse();
} else
#ifndef _WIN32
if (strstart(filename, "unix:", &p)) {
Index: qemu-doc.texi
===================================================================
--- qemu-doc.texi (revision 5799)
+++ qemu-doc.texi (working copy)
@@ -904,6 +904,8 @@
When @var{remote_host} or @var{src_ip} are not specified
they default to @code{0.0.0.0}.
When not using a specified @var{src_port} a random port is automatically chosen.
+@item msmouse
+Three button serial mouse. Configure the guest to use Microsoft protocol.
If you just want a simple readonly console you can use @code{netcat} or
@code{nc}, by starting qemu with: @code{-serial udp::4555} and nc as:
Index: hw/msmouse.c
===================================================================
--- hw/msmouse.c (revision 0)
+++ hw/msmouse.c (revision 0)
@@ -0,0 +1,61 @@
+/*
+ * QEMU Microsoft serial mouse emulation
+ *
+ * Copyright (c) 2008 Lubomir Rintel
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ */
+#include <stdlib.h>
+#include "../qemu-common.h"
+#include "../qemu-char.h"
+#include "../console.h"
+#include "msmouse.h"
+
+#define MSMOUSE_LO6(n) ((n) & 0x3f)
+#define MSMOUSE_HI2(n) (((n) & 0xc0) >> 6)
+
+static void msmouse_event(void *opaque,
+ int dx, int dy, int dz, int buttons_state)
+{
+ if (!msmouse_chr)
+ return;
+
+ char bytes[4] = { 0x40, 0x00, 0x00, 0x00 };
+
+ /* Movement deltas */
+ bytes[0] |= (MSMOUSE_HI2(dy) << 2) | MSMOUSE_HI2(dx);
+ bytes[1] |= MSMOUSE_LO6(dx);
+ bytes[2] |= MSMOUSE_LO6(dy);
+
+ /* Buttons */
+ bytes[0] |= (buttons_state & 0x01 ? 0x20 : 0x00);
+ bytes[0] |= (buttons_state & 0x02 ? 0x10 : 0x00);
+ bytes[3] |= (buttons_state & 0x04 ? 0x20 : 0x00);
+
+ /* We always send the packet of, so that we do not have to keep track
+ of previous state of the middle button. This can potentially confuse
+ some very old drivers for two button mice though. */
+ qemu_chr_read(msmouse_chr, bytes, 4);
+}
+
+void *msmouse_init()
+{
+ qemu_add_mouse_event_handler(msmouse_event, NULL, 0, "QEMU Microsoft Mouse");
+ return NULL;
+}
Index: hw/msmouse.h
===================================================================
--- hw/msmouse.h (revision 0)
+++ hw/msmouse.h (revision 0)
@@ -0,0 +1,2 @@
+extern CharDriverState *msmouse_chr;
+void *msmouse_init(void);
Index: hw/pc.c
===================================================================
--- hw/pc.c (revision 5799)
+++ hw/pc.c (working copy)
@@ -33,6 +33,7 @@
#include "boards.h"
#include "console.h"
#include "fw_cfg.h"
+#include "msmouse.h"
/* output Bochs bios info messages */
//#define DEBUG_BIOS
@@ -1092,6 +1093,8 @@
}
}
}
+
+ msmouse_init ();
}
static void pc_init_pci(ram_addr_t ram_size, int vga_ram_size,
next reply other threads:[~2008-12-02 22:51 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-12-02 22:50 lkundrak [this message]
2008-12-10 18:00 ` [Qemu-devel] [PATCH] Support for serial mouse emulation Aurelien Jarno
2008-12-24 19:22 ` lkundrak
2009-01-28 8:10 ` [Qemu-devel] [RESEND] " Lubomir Rintel
2009-02-08 15:53 ` Aurelien Jarno
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=44179.89.102.207.186.1228258258.squirrel@mail.netbsd.sk \
--to=lkundrak@v3.sk \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).