qemu: Updated to 0.12.0
Updated the metadata in the recipe, changed the git revision in poky-default-revisions.inc, and pulled the qemu patches forward.
This commit is contained in:
parent
eb69ecdfcc
commit
a49e605a52
|
@ -105,7 +105,7 @@ SRCREV_pn-pkgconfig ??= "66d49f1375fec838bcd301bb4ca2ef76cee0e47c"
|
||||||
SRCREV_pn-psplash ??= "422"
|
SRCREV_pn-psplash ??= "422"
|
||||||
SRCREV_pn-pseudo ??= "086e65c90420b3d38f30c3cd81a0f8573f6f69cf"
|
SRCREV_pn-pseudo ??= "086e65c90420b3d38f30c3cd81a0f8573f6f69cf"
|
||||||
SRCREV_pn-pseudo-native ??= "086e65c90420b3d38f30c3cd81a0f8573f6f69cf"
|
SRCREV_pn-pseudo-native ??= "086e65c90420b3d38f30c3cd81a0f8573f6f69cf"
|
||||||
QEMUSRCREV ??= "9eab386edbf8cf002a731f8204a156f243a47a57"
|
QEMUSRCREV ??= "72bb3c7571226af13cfe9eec020a56add3d30a70"
|
||||||
SRCREV_pn-qemu-native ??= "${QEMUSRCREV}"
|
SRCREV_pn-qemu-native ??= "${QEMUSRCREV}"
|
||||||
SRCREV_pn-qemu-nativesdk ??= "${QEMUSRCREV}"
|
SRCREV_pn-qemu-nativesdk ??= "${QEMUSRCREV}"
|
||||||
SRCREV_pn-qemu ??= "${QEMUSRCREV}"
|
SRCREV_pn-qemu ??= "${QEMUSRCREV}"
|
||||||
|
|
|
@ -1,130 +0,0 @@
|
||||||
From 2ca2078e287174522e3a6229618947d3d285b8c0 Mon Sep 17 00:00:00 2001
|
|
||||||
From: François Revol <revol@free.fr>
|
|
||||||
Date: Tue, 25 Aug 2009 09:14:10 +0000
|
|
||||||
Subject: Fixed wacom emulation
|
|
||||||
|
|
||||||
- for absolute mode, scale coordinates to the real device maximum values,
|
|
||||||
since some drivers (on Haiku and Linux at least) need them as such,
|
|
||||||
and the HID descriptor is boggus on some models anyway,
|
|
||||||
- keep the coordinates even when no button is pressed, on real tablet
|
|
||||||
the pen is sensed on the surface even without direct contact,
|
|
||||||
and drivers expect this,
|
|
||||||
- map left button to pressure according to what the Haiku driver wants,
|
|
||||||
- map the right button to the pen button,
|
|
||||||
- map the middle button to the eraser,
|
|
||||||
- use asynchronous reporting as the hid code does, stops the Haiku driver
|
|
||||||
(and probably others) from spending 50% cpu polling for changes.
|
|
||||||
|
|
||||||
Signed-off-by: François Revol <revol@free.fr>
|
|
||||||
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
|
|
||||||
---
|
|
||||||
Index: git/hw/usb-wacom.c
|
|
||||||
===================================================================
|
|
||||||
--- git.orig/hw/usb-wacom.c 2009-11-24 14:10:15.000000000 +0000
|
|
||||||
+++ git/hw/usb-wacom.c 2009-11-24 16:39:26.000000000 +0000
|
|
||||||
@@ -50,6 +50,8 @@
|
|
||||||
WACOM_MODE_HID = 1,
|
|
||||||
WACOM_MODE_WACOM = 2,
|
|
||||||
} mode;
|
|
||||||
+ uint8_t idle;
|
|
||||||
+ int changed;
|
|
||||||
} USBWacomState;
|
|
||||||
|
|
||||||
static const uint8_t qemu_wacom_dev_descriptor[] = {
|
|
||||||
@@ -125,6 +127,7 @@
|
|
||||||
s->dy += dy1;
|
|
||||||
s->dz += dz1;
|
|
||||||
s->buttons_state = buttons_state;
|
|
||||||
+ s->changed = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void usb_wacom_event(void *opaque,
|
|
||||||
@@ -132,10 +135,12 @@
|
|
||||||
{
|
|
||||||
USBWacomState *s = opaque;
|
|
||||||
|
|
||||||
- s->x = x;
|
|
||||||
- s->y = y;
|
|
||||||
+ /* scale to Penpartner resolution */
|
|
||||||
+ s->x = (x * 5040 / 0x7FFF);
|
|
||||||
+ s->y = (y * 3780 / 0x7FFF);
|
|
||||||
s->dz += dz;
|
|
||||||
s->buttons_state = buttons_state;
|
|
||||||
+ s->changed = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int int_clamp(int val, int vmin, int vmax)
|
|
||||||
@@ -199,26 +204,22 @@
|
|
||||||
if (s->buttons_state & MOUSE_EVENT_LBUTTON)
|
|
||||||
b |= 0x01;
|
|
||||||
if (s->buttons_state & MOUSE_EVENT_RBUTTON)
|
|
||||||
- b |= 0x02;
|
|
||||||
+ b |= 0x40;
|
|
||||||
if (s->buttons_state & MOUSE_EVENT_MBUTTON)
|
|
||||||
- b |= 0x04;
|
|
||||||
+ b |= 0x20; /* eraser */
|
|
||||||
|
|
||||||
if (len < 7)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
buf[0] = s->mode;
|
|
||||||
- buf[5] = 0x00;
|
|
||||||
- if (b) {
|
|
||||||
- buf[1] = s->x & 0xff;
|
|
||||||
- buf[2] = s->x >> 8;
|
|
||||||
- buf[3] = s->y & 0xff;
|
|
||||||
- buf[4] = s->y >> 8;
|
|
||||||
+ buf[5] = 0x00 | (b & 0xf0);
|
|
||||||
+ buf[1] = s->x & 0xff;
|
|
||||||
+ buf[2] = s->x >> 8;
|
|
||||||
+ buf[3] = s->y & 0xff;
|
|
||||||
+ buf[4] = s->y >> 8;
|
|
||||||
+ if (b & 0x3f) {
|
|
||||||
buf[6] = 0;
|
|
||||||
} else {
|
|
||||||
- buf[1] = 0;
|
|
||||||
- buf[2] = 0;
|
|
||||||
- buf[3] = 0;
|
|
||||||
- buf[4] = 0;
|
|
||||||
buf[6] = (unsigned char) -127;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -350,7 +351,12 @@
|
|
||||||
else if (s->mode == WACOM_MODE_WACOM)
|
|
||||||
ret = usb_wacom_poll(s, data, length);
|
|
||||||
break;
|
|
||||||
+ case HID_GET_IDLE:
|
|
||||||
+ ret = 1;
|
|
||||||
+ data[0] = s->idle;
|
|
||||||
+ break;
|
|
||||||
case HID_SET_IDLE:
|
|
||||||
+ s->idle = (uint8_t) (value >> 8);
|
|
||||||
ret = 0;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
@@ -369,6 +375,9 @@
|
|
||||||
switch (p->pid) {
|
|
||||||
case USB_TOKEN_IN:
|
|
||||||
if (p->devep == 1) {
|
|
||||||
+ if (!(s->changed || s->idle))
|
|
||||||
+ return USB_RET_NAK;
|
|
||||||
+ s->changed = 0;
|
|
||||||
if (s->mode == WACOM_MODE_HID)
|
|
||||||
ret = usb_mouse_poll(s, p->data, p->len);
|
|
||||||
else if (s->mode == WACOM_MODE_WACOM)
|
|
||||||
@@ -399,7 +408,6 @@
|
|
||||||
s = qemu_mallocz(sizeof(USBWacomState));
|
|
||||||
s->dev.speed = USB_SPEED_FULL;
|
|
||||||
s->dev.handle_packet = usb_generic_handle_packet;
|
|
||||||
-
|
|
||||||
s->dev.handle_reset = usb_wacom_handle_reset;
|
|
||||||
s->dev.handle_control = usb_wacom_handle_control;
|
|
||||||
s->dev.handle_data = usb_wacom_handle_data;
|
|
||||||
@@ -407,6 +415,7 @@
|
|
||||||
|
|
||||||
pstrcpy(s->dev.devname, sizeof(s->dev.devname),
|
|
||||||
"QEMU PenPartner Tablet");
|
|
||||||
+ s->changed = 1;
|
|
||||||
|
|
||||||
return (USBDevice *) s;
|
|
||||||
}
|
|
|
@ -1,7 +1,7 @@
|
||||||
Index: trunk/linux-user/syscall.c
|
Index: qemu/linux-user/syscall.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- trunk.orig/linux-user/syscall.c 2009-01-05 12:51:52.000000000 +0000
|
--- qemu.orig/linux-user/syscall.c 2010-05-11 13:16:22.421783949 -0400
|
||||||
+++ trunk/linux-user/syscall.c 2009-01-05 12:51:52.000000000 +0000
|
+++ qemu/linux-user/syscall.c 2010-05-11 13:16:31.759805849 -0400
|
||||||
@@ -26,6 +26,7 @@
|
@@ -26,6 +26,7 @@
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
|
@ -1,20 +1,21 @@
|
||||||
Index: git/Makefile.target
|
Index: qemu/Makefile.target
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/Makefile.target 2009-06-09 22:05:27.000000000 +0100
|
--- qemu.orig/Makefile.target 2010-05-11 16:53:34.545811866 -0400
|
||||||
+++ git/Makefile.target 2009-06-09 22:05:28.000000000 +0100
|
+++ qemu/Makefile.target 2010-05-11 16:53:37.743809704 -0400
|
||||||
@@ -155,6 +155,8 @@
|
@@ -47,6 +47,9 @@ libobj-$(CONFIG_NOSOFTFLOAT) += fpu/soft
|
||||||
|
libobj-y += op_helper.o helper.o
|
||||||
|
libobj-$(CONFIG_NEED_MMU) += mmu.o
|
||||||
|
libobj-$(TARGET_I386) += helper_opengl.o opengl_exec.o
|
||||||
|
+libobj-$(TARGET_X86_64) += helper_opengl.o opengl_exec.o
|
||||||
|
+libobj-$(TARGET_ARM) += dummygl.o
|
||||||
|
+libobj-$(TARGET_MIPS) += dummygl.o
|
||||||
|
libobj-$(TARGET_ARM) += neon_helper.o iwmmxt_helper.o
|
||||||
|
libobj-$(TARGET_ALPHA) += alpha_palcode.o
|
||||||
|
|
||||||
ifeq ($(TARGET_BASE_ARCH), i386)
|
Index: qemu/target-arm/dummygl.c
|
||||||
LIBOBJS+=helper_opengl.o opengl_exec.o
|
|
||||||
+else
|
|
||||||
+LIBOBJS+=dummygl.o
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(TARGET_BASE_ARCH), arm)
|
|
||||||
Index: git/target-arm/dummygl.c
|
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-arm/dummygl.c 2009-06-09 22:15:55.000000000 +0100
|
+++ qemu/target-arm/dummygl.c 2010-05-11 16:53:37.743809704 -0400
|
||||||
@@ -0,0 +1,22 @@
|
@@ -0,0 +1,22 @@
|
||||||
+#include <string.h>
|
+#include <string.h>
|
||||||
+#include <stdlib.h>
|
+#include <stdlib.h>
|
||||||
|
@ -38,10 +39,10 @@ Index: git/target-arm/dummygl.c
|
||||||
+{
|
+{
|
||||||
+
|
+
|
||||||
+}
|
+}
|
||||||
Index: git/target-mips/dummygl.c
|
Index: qemu/target-mips/dummygl.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-mips/dummygl.c 2009-06-09 22:15:55.000000000 +0100
|
+++ qemu/target-mips/dummygl.c 2010-05-11 16:53:37.744811919 -0400
|
||||||
@@ -0,0 +1,22 @@
|
@@ -0,0 +1,22 @@
|
||||||
+#include <string.h>
|
+#include <string.h>
|
||||||
+#include <stdlib.h>
|
+#include <stdlib.h>
|
||||||
|
|
|
@ -1,22 +1,26 @@
|
||||||
--- qemu.orig/Makefile 2008-01-29 23:16:27.000000000 -0800
|
Index: qemu/Makefile
|
||||||
+++ qemu-0.9.1/Makefile 2008-01-29 23:16:38.000000000 -0800
|
===================================================================
|
||||||
@@ -174,7 +174,7 @@
|
--- qemu.orig/Makefile 2010-05-11 17:17:06.416912704 -0400
|
||||||
|
+++ qemu/Makefile 2010-05-11 17:17:17.051812402 -0400
|
||||||
|
@@ -300,7 +300,7 @@ endif
|
||||||
install: all $(if $(BUILD_DOCS),install-doc)
|
install: all $(if $(BUILD_DOCS),install-doc)
|
||||||
mkdir -p "$(DESTDIR)$(bindir)"
|
$(INSTALL_DIR) "$(DESTDIR)$(bindir)"
|
||||||
ifneq ($(TOOLS),)
|
ifneq ($(TOOLS),)
|
||||||
- $(INSTALL) -m 755 -s $(TOOLS) "$(DESTDIR)$(bindir)"
|
- $(INSTALL_PROG) $(STRIP_OPT) $(TOOLS) "$(DESTDIR)$(bindir)"
|
||||||
+ $(INSTALL) -m 755 $(TOOLS) "$(DESTDIR)$(bindir)"
|
+ $(INSTALL_PROG) $(TOOLS) "$(DESTDIR)$(bindir)"
|
||||||
endif
|
endif
|
||||||
mkdir -p "$(DESTDIR)$(datadir)"
|
ifneq ($(BLOBS),)
|
||||||
for x in bios.bin vgabios.bin vgabios-cirrus.bin ppc_rom.bin \
|
$(INSTALL_DIR) "$(DESTDIR)$(datadir)"
|
||||||
--- qemu.orig/Makefile.target 2008-01-29 23:16:27.000000000 -0800
|
Index: qemu/Makefile.target
|
||||||
+++ qemu-0.9.1/Makefile.target 2008-01-29 23:17:33.000000000 -0800
|
===================================================================
|
||||||
@@ -632,7 +632,7 @@
|
--- qemu.orig/Makefile.target 2010-05-11 17:17:12.188784092 -0400
|
||||||
|
+++ qemu/Makefile.target 2010-05-11 17:17:17.052808122 -0400
|
||||||
|
@@ -351,7 +351,7 @@ clean:
|
||||||
|
|
||||||
install: all
|
install: all
|
||||||
ifneq ($(PROGS),)
|
ifneq ($(PROGS),)
|
||||||
- $(INSTALL) -m 755 -s $(PROGS) "$(DESTDIR)$(bindir)"
|
- $(INSTALL) -m 755 $(STRIP_OPT) $(PROGS) "$(DESTDIR)$(bindir)"
|
||||||
+ $(INSTALL) -m 755 $(PROGS) "$(DESTDIR)$(bindir)"
|
+ $(INSTALL) -m 755 $(PROGS) "$(DESTDIR)$(bindir)"
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq ($(wildcard .depend),)
|
# Include automatically generated dependency files
|
||||||
|
|
|
@ -1,21 +1,18 @@
|
||||||
Index: git/Makefile.target
|
Index: qemu/Makefile.target
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/Makefile.target 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/Makefile.target 2010-05-11 18:05:22.955784896 -0400
|
||||||
+++ git/Makefile.target 2010-01-14 16:34:58.000000000 +0000
|
+++ qemu/Makefile.target 2010-05-14 13:34:07.721301429 -0400
|
||||||
@@ -153,6 +153,10 @@
|
@@ -46,6 +46,7 @@ libobj-$(CONFIG_SOFTFLOAT) += fpu/softfl
|
||||||
CPPFLAGS+=-I$(SRC_PATH)/fpu
|
libobj-$(CONFIG_NOSOFTFLOAT) += fpu/softfloat-native.o
|
||||||
LIBOBJS+= op_helper.o helper.o
|
libobj-y += op_helper.o helper.o
|
||||||
|
libobj-$(CONFIG_NEED_MMU) += mmu.o
|
||||||
|
+libobj-$(TARGET_I386) += helper_opengl.o opengl_exec.o
|
||||||
|
libobj-$(TARGET_ARM) += neon_helper.o iwmmxt_helper.o
|
||||||
|
libobj-$(TARGET_ALPHA) += alpha_palcode.o
|
||||||
|
|
||||||
+ifeq ($(TARGET_BASE_ARCH), i386)
|
@@ -82,6 +83,21 @@ op_helper.o cpu-exec.o: QEMU_CFLAGS += $
|
||||||
+LIBOBJS+=helper_opengl.o opengl_exec.o
|
# cpu_signal_handler() in cpu-exec.c.
|
||||||
+endif
|
signal.o: QEMU_CFLAGS += $(HELPER_CFLAGS)
|
||||||
+
|
|
||||||
ifeq ($(TARGET_BASE_ARCH), arm)
|
|
||||||
LIBOBJS+= neon_helper.o iwmmxt_helper.o
|
|
||||||
endif
|
|
||||||
@@ -224,6 +228,21 @@
|
|
||||||
|
|
||||||
cpu-exec.o: CFLAGS += $(HELPER_CFLAGS)
|
|
||||||
|
|
||||||
+parse_gl_h: parse_gl_h.c
|
+parse_gl_h: parse_gl_h.c
|
||||||
+ $(HOST_CC) -g -o $@ $<
|
+ $(HOST_CC) -g -o $@ $<
|
||||||
|
@ -35,29 +32,31 @@ Index: git/Makefile.target
|
||||||
#########################################################
|
#########################################################
|
||||||
# Linux user emulator target
|
# Linux user emulator target
|
||||||
|
|
||||||
@@ -584,7 +603,7 @@
|
@@ -196,6 +212,10 @@ obj-i386-y += usb-uhci.o vmmouse.o vmpor
|
||||||
OBJS+= cirrus_vga.o apic.o parallel.o acpi.o piix_pci.o
|
obj-i386-y += device-hotplug.o pci-hotplug.o smbios.o wdt_ib700.o
|
||||||
OBJS+= usb-uhci.o vmmouse.o vmport.o vmware_vga.o hpet.o
|
obj-i386-y += ne2000-isa.o
|
||||||
OBJS += device-hotplug.o pci-hotplug.o
|
|
||||||
-CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
|
|
||||||
+CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE -DTARGET_OPENGL_OK
|
|
||||||
endif
|
|
||||||
ifeq ($(TARGET_BASE_ARCH), ppc)
|
|
||||||
CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
|
|
||||||
@@ -727,7 +746,7 @@
|
|
||||||
$(QEMU_PROG): LIBS += $(SDL_LIBS) $(COCOA_LIBS) $(CURSES_LIBS) $(BRLAPI_LIBS) $(VDE_LIBS)
|
|
||||||
|
|
||||||
$(QEMU_PROG): $(OBJS) ../libqemu_common.a libqemu.a
|
+ifeq ($(TARGET_BASE_ARCH), i386)
|
||||||
- $(LINK)
|
+QEMU_CFLAGS += -DTARGET_OPENGL_OK
|
||||||
+ $(LINK) -lGL -lGLU
|
+endif
|
||||||
|
+
|
||||||
|
# shared objects
|
||||||
|
obj-ppc-y = ppc.o ide/core.o ide/qdev.o ide/isa.o ide/pci.o ide/macio.o
|
||||||
|
obj-ppc-y += ide/cmd646.o
|
||||||
|
@@ -303,6 +323,8 @@ vl.o: qemu-options.h
|
||||||
|
|
||||||
endif # !CONFIG_USER_ONLY
|
monitor.o: qemu-monitor.h
|
||||||
|
|
||||||
Index: git/hw/pixel_ops.h
|
+LIBS += -lGL -lGLU
|
||||||
|
+
|
||||||
|
ARLIBS=../libqemu_common.a libqemu.a $(HWLIB)
|
||||||
|
|
||||||
|
endif # CONFIG_SOFTMMU
|
||||||
|
Index: qemu/hw/pixel_ops.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/hw/pixel_ops.h 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/hw/pixel_ops.h 2010-05-11 18:05:22.959804376 -0400
|
||||||
+++ git/hw/pixel_ops.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/hw/pixel_ops.h 2010-05-12 12:10:40.092908994 -0400
|
||||||
@@ -4,6 +4,12 @@
|
@@ -4,6 +4,12 @@ static inline unsigned int rgb_to_pixel8
|
||||||
return ((r >> 5) << 5) | ((g >> 5) << 2) | (b >> 6);
|
return ((r >> 5) << 5) | ((g >> 5) << 2) | (b >> 6);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,11 +69,11 @@ Index: git/hw/pixel_ops.h
|
||||||
static inline unsigned int rgb_to_pixel15(unsigned int r, unsigned int g,
|
static inline unsigned int rgb_to_pixel15(unsigned int r, unsigned int g,
|
||||||
unsigned int b)
|
unsigned int b)
|
||||||
{
|
{
|
||||||
Index: git/hw/vmware_vga.c
|
Index: qemu/hw/vmware_vga.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/hw/vmware_vga.c 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/hw/vmware_vga.c 2010-05-11 18:05:22.959804376 -0400
|
||||||
+++ git/hw/vmware_vga.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/hw/vmware_vga.c 2010-05-12 12:10:40.124785891 -0400
|
||||||
@@ -484,6 +484,8 @@
|
@@ -489,6 +489,8 @@ static inline void vmsvga_cursor_define(
|
||||||
|
|
||||||
#define CMD(f) le32_to_cpu(s->cmd->f)
|
#define CMD(f) le32_to_cpu(s->cmd->f)
|
||||||
|
|
||||||
|
@ -83,7 +82,7 @@ Index: git/hw/vmware_vga.c
|
||||||
static inline int vmsvga_fifo_empty(struct vmsvga_state_s *s)
|
static inline int vmsvga_fifo_empty(struct vmsvga_state_s *s)
|
||||||
{
|
{
|
||||||
if (!s->config || !s->enable)
|
if (!s->config || !s->enable)
|
||||||
@@ -493,11 +495,18 @@
|
@@ -498,11 +500,18 @@ static inline int vmsvga_fifo_empty(stru
|
||||||
|
|
||||||
static inline uint32_t vmsvga_fifo_read_raw(struct vmsvga_state_s *s)
|
static inline uint32_t vmsvga_fifo_read_raw(struct vmsvga_state_s *s)
|
||||||
{
|
{
|
||||||
|
@ -106,7 +105,7 @@ Index: git/hw/vmware_vga.c
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline uint32_t vmsvga_fifo_read(struct vmsvga_state_s *s)
|
static inline uint32_t vmsvga_fifo_read(struct vmsvga_state_s *s)
|
||||||
@@ -507,12 +516,12 @@
|
@@ -512,12 +521,12 @@ static inline uint32_t vmsvga_fifo_read(
|
||||||
|
|
||||||
static void vmsvga_fifo_run(struct vmsvga_state_s *s)
|
static void vmsvga_fifo_run(struct vmsvga_state_s *s)
|
||||||
{
|
{
|
||||||
|
@ -121,7 +120,7 @@ Index: git/hw/vmware_vga.c
|
||||||
case SVGA_CMD_UPDATE:
|
case SVGA_CMD_UPDATE:
|
||||||
case SVGA_CMD_UPDATE_VERBOSE:
|
case SVGA_CMD_UPDATE_VERBOSE:
|
||||||
x = vmsvga_fifo_read(s);
|
x = vmsvga_fifo_read(s);
|
||||||
@@ -612,7 +621,7 @@
|
@@ -617,7 +626,7 @@ static void vmsvga_fifo_run(struct vmsvg
|
||||||
while (args --)
|
while (args --)
|
||||||
vmsvga_fifo_read(s);
|
vmsvga_fifo_read(s);
|
||||||
printf("%s: Unknown command 0x%02x in SVGA command FIFO\n",
|
printf("%s: Unknown command 0x%02x in SVGA command FIFO\n",
|
||||||
|
@ -130,71 +129,24 @@ Index: git/hw/vmware_vga.c
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -914,8 +923,9 @@
|
@@ -1136,6 +1145,12 @@ static void vmsvga_init(struct vmsvga_st
|
||||||
s->width = -1;
|
|
||||||
s->height = -1;
|
vga_init_vbe(&s->vga);
|
||||||
s->svgaid = SVGA_ID;
|
|
||||||
- s->depth = 24;
|
|
||||||
+ s->depth = 32;
|
|
||||||
s->bypp = (s->depth + 7) >> 3;
|
|
||||||
+ s->bypp = 4; /* XXX: until we can get host's actual depth */
|
|
||||||
s->cursor.on = 0;
|
|
||||||
s->redraw_fifo_first = 0;
|
|
||||||
s->redraw_fifo_last = 0;
|
|
||||||
@@ -1140,6 +1150,12 @@
|
|
||||||
/* XXX: use optimized standard vga accesses */
|
|
||||||
cpu_register_physical_memory(VBE_DISPI_LFB_PHYSICAL_ADDRESS,
|
|
||||||
vga_ram_size, vga_ram_offset);
|
|
||||||
+
|
|
||||||
+#ifdef EMBED_STDVGA
|
+#ifdef EMBED_STDVGA
|
||||||
+ s->map_addr = VBE_DISPI_LFB_PHYSICAL_ADDRESS;
|
+ s->vga.map_addr = VBE_DISPI_LFB_PHYSICAL_ADDRESS;
|
||||||
+ s->map_end = VBE_DISPI_LFB_PHYSICAL_ADDRESS + vga_ram_size;
|
+ s->vga.map_end = VBE_DISPI_LFB_PHYSICAL_ADDRESS + vga_ram_size;
|
||||||
+ vga_dirty_log_start((VGAState *) s);
|
+ vga_dirty_log_start(s);
|
||||||
+#endif
|
+#endif
|
||||||
#endif
|
+
|
||||||
}
|
rom_add_vga(VGABIOS_FILENAME);
|
||||||
|
|
||||||
Index: git/kqemu.c
|
vmsvga_reset(s);
|
||||||
|
Index: qemu/qemu-char.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/kqemu.c 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/qemu-char.c 2010-05-11 18:05:22.955784896 -0400
|
||||||
+++ git/kqemu.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/qemu-char.c 2010-05-12 17:20:54.280909040 -0400
|
||||||
@@ -93,6 +93,8 @@
|
@@ -2232,6 +2232,69 @@ static CharDriverState *qemu_chr_open_so
|
||||||
int qpi_io_memory;
|
|
||||||
uint32_t kqemu_comm_base; /* physical address of the QPI communication page */
|
|
||||||
|
|
||||||
+extern int enable_gl;
|
|
||||||
+
|
|
||||||
#define cpuid(index, eax, ebx, ecx, edx) \
|
|
||||||
asm volatile ("cpuid" \
|
|
||||||
: "=a" (eax), "=b" (ebx), "=c" (ecx), "=d" (edx) \
|
|
||||||
@@ -860,6 +862,22 @@
|
|
||||||
else
|
|
||||||
env->hflags &= ~HF_OSFXSR_MASK;
|
|
||||||
|
|
||||||
+ /* OPENGL Stuff */
|
|
||||||
+ if (enable_gl && ((env->hflags & HF_CPL_MASK) == 3)) {
|
|
||||||
+ int index = (env->eip >> TARGET_PAGE_BITS) & (CPU_TLB_SIZE - 1);
|
|
||||||
+ if (env->segs[R_CS].base != 0)
|
|
||||||
+ fprintf(stderr, "env->segs[R_CS].base != 0 !\n");
|
|
||||||
+ else if (__builtin_expect(env->tlb_table[1][index].addr_code !=
|
|
||||||
+ (env->eip & TARGET_PAGE_MASK), 0))
|
|
||||||
+ ldub_code(env->eip);
|
|
||||||
+
|
|
||||||
+ if (env->tlb_table[1][index].addend) {
|
|
||||||
+ unsigned char *ptr = env->eip + env->tlb_table[1][index].addend;
|
|
||||||
+ if (ptr[0] == 0xcd && ptr[1] == 0x99)
|
|
||||||
+ helper_opengl();
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
LOG_INT("kqemu: kqemu_cpu_exec: ret=0x%x\n", ret);
|
|
||||||
if (ret == KQEMU_RET_SYSCALL) {
|
|
||||||
/* syscall instruction */
|
|
||||||
Index: git/qemu-char.c
|
|
||||||
===================================================================
|
|
||||||
--- git.orig/qemu-char.c 2009-12-02 13:13:56.000000000 +0000
|
|
||||||
+++ git/qemu-char.c 2010-01-14 15:55:40.000000000 +0000
|
|
||||||
@@ -2112,6 +2112,69 @@
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -253,7 +205,7 @@ Index: git/qemu-char.c
|
||||||
+ chr->opaque = chr;
|
+ chr->opaque = chr;
|
||||||
+ chr->chr_write = opengl_chr_write;
|
+ chr->chr_write = opengl_chr_write;
|
||||||
+
|
+
|
||||||
+ qemu_chr_reset(chr);
|
+ qemu_chr_generic_open(chr);
|
||||||
+
|
+
|
||||||
+ return chr;
|
+ return chr;
|
||||||
+}
|
+}
|
||||||
|
@ -261,45 +213,54 @@ Index: git/qemu-char.c
|
||||||
+#define qemu_chr_open_opengl() 0
|
+#define qemu_chr_open_opengl() 0
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
CharDriverState *qemu_chr_open(const char *label, const char *filename, void (*init)(struct CharDriverState *s))
|
QemuOpts *qemu_chr_parse_compat(const char *label, const char *filename)
|
||||||
{
|
{
|
||||||
const char *p;
|
char host[65], port[33], width[8], height[8];
|
||||||
@@ -2192,6 +2255,9 @@
|
@@ -2352,6 +2415,10 @@ QemuOpts *qemu_chr_parse_compat(const ch
|
||||||
chr = chr_baum_init();
|
qemu_opt_set(opts, "path", filename);
|
||||||
} else
|
return opts;
|
||||||
#endif
|
|
||||||
+ if (!strcmp(filename, "opengl")) {
|
|
||||||
+ chr = qemu_chr_open_opengl();
|
|
||||||
+ } else
|
|
||||||
{
|
|
||||||
chr = NULL;
|
|
||||||
}
|
}
|
||||||
Index: git/sdl.c
|
+ if (!strcmp(filename, "opengl")){
|
||||||
|
+ qemu_opt_set(opts, "backend", "opengl");
|
||||||
|
+ return opts;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
fail:
|
||||||
|
fprintf(stderr, "%s: fail on \"%s\"\n", __FUNCTION__, filename);
|
||||||
|
@@ -2368,6 +2435,7 @@ static const struct {
|
||||||
|
{ .name = "udp", .open = qemu_chr_open_udp },
|
||||||
|
{ .name = "msmouse", .open = qemu_chr_open_msmouse },
|
||||||
|
{ .name = "vc", .open = text_console_init },
|
||||||
|
+ { .name = "opengl", .open = qemu_chr_open_opengl },
|
||||||
|
#ifdef _WIN32
|
||||||
|
{ .name = "file", .open = qemu_chr_open_win_file_out },
|
||||||
|
{ .name = "pipe", .open = qemu_chr_open_win_pipe },
|
||||||
|
Index: qemu/sdl.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/sdl.c 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/sdl.c 2010-05-11 18:05:22.959804376 -0400
|
||||||
+++ git/sdl.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/sdl.c 2010-05-12 12:10:40.128783931 -0400
|
||||||
@@ -54,6 +54,8 @@
|
@@ -58,6 +58,8 @@ static uint8_t allocator;
|
||||||
static int guest_x, guest_y;
|
static SDL_PixelFormat host_format;
|
||||||
static SDL_Cursor *guest_sprite = 0;
|
static int scaling_active = 0;
|
||||||
|
|
||||||
+extern void opengl_exec_set_parent_window(Display* _dpy, Window _parent_window);
|
+extern void opengl_exec_set_parent_window(Display* _dpy, Window _parent_window);
|
||||||
+
|
+
|
||||||
static void sdl_update(DisplayState *ds, int x, int y, int w, int h)
|
static void sdl_update(DisplayState *ds, int x, int y, int w, int h)
|
||||||
{
|
{
|
||||||
SDL_Rect rec;
|
// printf("updating x=%d y=%d w=%d h=%d\n", x, y, w, h);
|
||||||
@@ -85,7 +87,9 @@
|
@@ -119,12 +121,22 @@ static void do_sdl_resize(int new_width,
|
||||||
|
|
||||||
static void sdl_resize(DisplayState *ds)
|
static void sdl_resize(DisplayState *ds)
|
||||||
{
|
{
|
||||||
|
- if (!allocator) {
|
||||||
+ SDL_SysWMinfo info;
|
+ SDL_SysWMinfo info;
|
||||||
int flags;
|
|
||||||
+ static Display *dpy;
|
+ static Display *dpy;
|
||||||
|
+
|
||||||
// printf("resizing to %d %d\n", w, h);
|
+ if (!allocator) {
|
||||||
|
if (!scaling_active)
|
||||||
@@ -104,6 +108,13 @@
|
do_sdl_resize(ds_get_width(ds), ds_get_height(ds), 0);
|
||||||
}
|
else if (real_screen->format->BitsPerPixel != ds_get_bits_per_pixel(ds))
|
||||||
|
do_sdl_resize(real_screen->w, real_screen->h, ds_get_bits_per_pixel(ds));
|
||||||
sdl_setdata(ds);
|
sdl_setdata(ds);
|
||||||
+
|
+
|
||||||
+ SDL_GetWMInfo(&info);
|
+ SDL_GetWMInfo(&info);
|
||||||
|
@ -308,10 +269,10 @@ Index: git/sdl.c
|
||||||
+ dpy = info.info.x11.display;
|
+ dpy = info.info.x11.display;
|
||||||
+ opengl_exec_set_parent_window(dpy, info.info.x11.window);
|
+ opengl_exec_set_parent_window(dpy, info.info.x11.window);
|
||||||
+ }
|
+ }
|
||||||
}
|
} else {
|
||||||
|
if (guest_screen != NULL) {
|
||||||
/* generic keyboard conversion */
|
SDL_FreeSurface(guest_screen);
|
||||||
@@ -323,7 +334,7 @@
|
@@ -453,7 +465,7 @@ static void sdl_show_cursor(void)
|
||||||
|
|
||||||
if (!kbd_mouse_is_absolute()) {
|
if (!kbd_mouse_is_absolute()) {
|
||||||
SDL_ShowCursor(1);
|
SDL_ShowCursor(1);
|
||||||
|
@ -320,7 +281,7 @@ Index: git/sdl.c
|
||||||
(gui_grab || kbd_mouse_is_absolute() || absolute_enabled))
|
(gui_grab || kbd_mouse_is_absolute() || absolute_enabled))
|
||||||
SDL_SetCursor(guest_sprite);
|
SDL_SetCursor(guest_sprite);
|
||||||
else
|
else
|
||||||
@@ -334,7 +345,8 @@
|
@@ -464,7 +476,8 @@ static void sdl_show_cursor(void)
|
||||||
static void sdl_grab_start(void)
|
static void sdl_grab_start(void)
|
||||||
{
|
{
|
||||||
if (guest_cursor) {
|
if (guest_cursor) {
|
||||||
|
@ -330,7 +291,7 @@ Index: git/sdl.c
|
||||||
if (!kbd_mouse_is_absolute() && !absolute_enabled)
|
if (!kbd_mouse_is_absolute() && !absolute_enabled)
|
||||||
SDL_WarpMouse(guest_x, guest_y);
|
SDL_WarpMouse(guest_x, guest_y);
|
||||||
} else
|
} else
|
||||||
@@ -375,8 +387,8 @@
|
@@ -505,8 +518,8 @@ static void sdl_send_mouse_event(int dx,
|
||||||
absolute_enabled = 1;
|
absolute_enabled = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -341,7 +302,7 @@ Index: git/sdl.c
|
||||||
} else if (absolute_enabled) {
|
} else if (absolute_enabled) {
|
||||||
sdl_show_cursor();
|
sdl_show_cursor();
|
||||||
absolute_enabled = 0;
|
absolute_enabled = 0;
|
||||||
@@ -606,7 +618,8 @@
|
@@ -760,7 +773,8 @@ static void sdl_mouse_warp(int x, int y,
|
||||||
if (!guest_cursor)
|
if (!guest_cursor)
|
||||||
sdl_show_cursor();
|
sdl_show_cursor();
|
||||||
if (gui_grab || kbd_mouse_is_absolute() || absolute_enabled) {
|
if (gui_grab || kbd_mouse_is_absolute() || absolute_enabled) {
|
||||||
|
@ -351,18 +312,7 @@ Index: git/sdl.c
|
||||||
if (!kbd_mouse_is_absolute() && !absolute_enabled)
|
if (!kbd_mouse_is_absolute() && !absolute_enabled)
|
||||||
SDL_WarpMouse(x, y);
|
SDL_WarpMouse(x, y);
|
||||||
}
|
}
|
||||||
@@ -631,6 +644,10 @@
|
@@ -814,7 +828,7 @@ static void sdl_mouse_define(int width,
|
||||||
line = image;
|
|
||||||
for (x = 0; x < width; x ++, dst ++) {
|
|
||||||
switch (bpp) {
|
|
||||||
+ case 32:
|
|
||||||
+ src = *(line ++); src |= *(line ++);
|
|
||||||
+ src = *(line ++); src |= *(line ++);
|
|
||||||
+ break;
|
|
||||||
case 24:
|
|
||||||
src = *(line ++); src |= *(line ++); src |= *(line ++);
|
|
||||||
break;
|
|
||||||
@@ -657,7 +674,7 @@
|
|
||||||
}
|
}
|
||||||
guest_sprite = SDL_CreateCursor(sprite, mask, width, height, hot_x, hot_y);
|
guest_sprite = SDL_CreateCursor(sprite, mask, width, height, hot_x, hot_y);
|
||||||
|
|
||||||
|
@ -371,17 +321,17 @@ Index: git/sdl.c
|
||||||
(gui_grab || kbd_mouse_is_absolute() || absolute_enabled))
|
(gui_grab || kbd_mouse_is_absolute() || absolute_enabled))
|
||||||
SDL_SetCursor(guest_sprite);
|
SDL_SetCursor(guest_sprite);
|
||||||
}
|
}
|
||||||
@@ -673,6 +690,7 @@
|
@@ -831,6 +845,7 @@ void sdl_display_init(DisplayState *ds,
|
||||||
{
|
|
||||||
int flags;
|
int flags;
|
||||||
uint8_t data = 0;
|
uint8_t data = 0;
|
||||||
|
DisplayAllocator *da;
|
||||||
+ SDL_SysWMinfo info;
|
+ SDL_SysWMinfo info;
|
||||||
|
const SDL_VideoInfo *vi;
|
||||||
|
|
||||||
#if defined(__APPLE__)
|
#if defined(__APPLE__)
|
||||||
/* always use generic keymaps */
|
@@ -855,6 +870,12 @@ void sdl_display_init(DisplayState *ds,
|
||||||
@@ -694,6 +712,12 @@
|
vi = SDL_GetVideoInfo();
|
||||||
exit(1);
|
host_format = *(vi->vfmt);
|
||||||
}
|
|
||||||
|
|
||||||
+ SDL_GetWMInfo(&info);
|
+ SDL_GetWMInfo(&info);
|
||||||
+ if (info.subsystem == SDL_SYSWM_X11 && info.info.x11.display)
|
+ if (info.subsystem == SDL_SYSWM_X11 && info.info.x11.display)
|
||||||
|
@ -392,7 +342,7 @@ Index: git/sdl.c
|
||||||
dcl = qemu_mallocz(sizeof(DisplayChangeListener));
|
dcl = qemu_mallocz(sizeof(DisplayChangeListener));
|
||||||
dcl->dpy_update = sdl_update;
|
dcl->dpy_update = sdl_update;
|
||||||
dcl->dpy_resize = sdl_resize;
|
dcl->dpy_resize = sdl_resize;
|
||||||
@@ -717,4 +741,9 @@
|
@@ -890,4 +911,9 @@ void sdl_display_init(DisplayState *ds,
|
||||||
gui_fullscreen_initial_grab = 1;
|
gui_fullscreen_initial_grab = 1;
|
||||||
sdl_grab_start();
|
sdl_grab_start();
|
||||||
}
|
}
|
||||||
|
@ -402,31 +352,19 @@ Index: git/sdl.c
|
||||||
+ opengl_exec_set_parent_window(info.info.x11.display,
|
+ opengl_exec_set_parent_window(info.info.x11.display,
|
||||||
+ info.info.x11.window);
|
+ info.info.x11.window);
|
||||||
}
|
}
|
||||||
Index: git/slirp/ctl.h
|
Index: qemu/slirp/udp.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/slirp/ctl.h 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/slirp/udp.c 2010-05-11 18:05:22.955784896 -0400
|
||||||
+++ git/slirp/ctl.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/slirp/udp.c 2010-05-12 12:10:40.129784123 -0400
|
||||||
@@ -2,6 +2,7 @@
|
|
||||||
#define CTL_EXEC 1
|
|
||||||
#define CTL_ALIAS 2
|
|
||||||
#define CTL_DNS 3
|
|
||||||
+#define CTL_OPENGL 6
|
|
||||||
|
|
||||||
#define CTL_SPECIAL "10.0.2.0"
|
|
||||||
#define CTL_LOCAL "10.0.2.15"
|
|
||||||
Index: git/slirp/udp.c
|
|
||||||
===================================================================
|
|
||||||
--- git.orig/slirp/udp.c 2009-12-02 13:13:56.000000000 +0000
|
|
||||||
+++ git/slirp/udp.c 2010-01-14 15:55:40.000000000 +0000
|
|
||||||
@@ -40,6 +40,7 @@
|
@@ -40,6 +40,7 @@
|
||||||
|
|
||||||
#include <slirp.h>
|
#include <slirp.h>
|
||||||
#include "ip_icmp.h"
|
#include "ip_icmp.h"
|
||||||
+#include "bswap.h"
|
+#include "bswap.h"
|
||||||
|
|
||||||
#ifdef LOG_ENABLED
|
static u_int8_t udp_tos(struct socket *so);
|
||||||
struct udpstat udpstat;
|
|
||||||
@@ -153,6 +154,11 @@
|
@@ -125,6 +126,11 @@ udp_input(register struct mbuf *m, int i
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -435,25 +373,25 @@ Index: git/slirp/udp.c
|
||||||
+ goto bad;
|
+ goto bad;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
if (slirp_restrict)
|
if (slirp->restricted) {
|
||||||
goto bad;
|
goto bad;
|
||||||
|
}
|
||||||
Index: git/sysemu.h
|
Index: qemu/sysemu.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/sysemu.h 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/sysemu.h 2010-05-11 18:05:22.959804376 -0400
|
||||||
+++ git/sysemu.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/sysemu.h 2010-05-12 12:10:40.129784123 -0400
|
||||||
@@ -96,6 +96,7 @@
|
@@ -141,6 +141,7 @@ extern int semihosting_enabled;
|
||||||
extern int no_quit;
|
|
||||||
extern int semihosting_enabled;
|
|
||||||
extern int old_param;
|
extern int old_param;
|
||||||
|
extern int boot_menu;
|
||||||
|
extern QEMUClock *rtc_clock;
|
||||||
+extern int force_pointer;
|
+extern int force_pointer;
|
||||||
extern const char *bootp_filename;
|
|
||||||
|
|
||||||
#ifdef USE_KQEMU
|
#define MAX_NODES 64
|
||||||
Index: git/target-i386/beginend_funcs.sh
|
extern int nb_numa_nodes;
|
||||||
|
Index: qemu/target-i386/beginend_funcs.sh
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/beginend_funcs.sh 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/beginend_funcs.sh 2010-05-12 12:10:40.129784123 -0400
|
||||||
@@ -0,0 +1,23 @@
|
@@ -0,0 +1,23 @@
|
||||||
+#! /bin/sh
|
+#! /bin/sh
|
||||||
+# Copyright 2008 (C) Intel Corporation
|
+# Copyright 2008 (C) Intel Corporation
|
||||||
|
@ -478,10 +416,10 @@ Index: git/target-i386/beginend_funcs.sh
|
||||||
+echo -e MAGIC_MACRO\(glCallList\)\\n
|
+echo -e MAGIC_MACRO\(glCallList\)\\n
|
||||||
+echo -e MAGIC_MACRO\(glCallLists\)\\n
|
+echo -e MAGIC_MACRO\(glCallLists\)\\n
|
||||||
+echo -e MAGIC_MACRO\(glEdgeFlag{,v}\)\\n
|
+echo -e MAGIC_MACRO\(glEdgeFlag{,v}\)\\n
|
||||||
Index: git/target-i386/ghash.c
|
Index: qemu/target-i386/ghash.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/ghash.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/ghash.c 2010-05-12 12:10:40.130781590 -0400
|
||||||
@@ -0,0 +1,347 @@
|
@@ -0,0 +1,347 @@
|
||||||
+/* This is a modified and simplified version of original ghash.c */
|
+/* This is a modified and simplified version of original ghash.c */
|
||||||
+
|
+
|
||||||
|
@ -830,10 +768,10 @@ Index: git/target-i386/ghash.c
|
||||||
+ hash_node = next;
|
+ hash_node = next;
|
||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
Index: git/target-i386/ghash.h
|
Index: qemu/target-i386/ghash.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/ghash.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/ghash.h 2010-05-12 12:10:40.130781590 -0400
|
||||||
@@ -0,0 +1,59 @@
|
@@ -0,0 +1,59 @@
|
||||||
+/* This is a modified and simplified version of original ghash.h */
|
+/* This is a modified and simplified version of original ghash.h */
|
||||||
+
|
+
|
||||||
|
@ -894,10 +832,10 @@ Index: git/target-i386/ghash.h
|
||||||
+
|
+
|
||||||
+#endif /* __SIMPLE_HASH_H__ */
|
+#endif /* __SIMPLE_HASH_H__ */
|
||||||
+
|
+
|
||||||
Index: git/target-i386/gl_func_perso.h
|
Index: qemu/target-i386/gl_func_perso.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/gl_func_perso.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/gl_func_perso.h 2010-05-12 12:10:40.130781590 -0400
|
||||||
@@ -0,0 +1,135 @@
|
@@ -0,0 +1,135 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Hand-implemented GL/GLX API
|
+ * Hand-implemented GL/GLX API
|
||||||
|
@ -1034,11 +972,11 @@ Index: git/target-i386/gl_func_perso.h
|
||||||
+MAGIC_MACRO(_glGetSelectBuffer_fake),
|
+MAGIC_MACRO(_glGetSelectBuffer_fake),
|
||||||
+MAGIC_MACRO(_glFeedbackBuffer_fake),
|
+MAGIC_MACRO(_glFeedbackBuffer_fake),
|
||||||
+MAGIC_MACRO(_glGetFeedbackBuffer_fake),
|
+MAGIC_MACRO(_glGetFeedbackBuffer_fake),
|
||||||
Index: git/target-i386/helper.c
|
Index: qemu/target-i386/helper.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/target-i386/helper.c 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/target-i386/helper.c 2010-05-11 18:05:22.955784896 -0400
|
||||||
+++ git/target-i386/helper.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/helper.c 2010-05-12 12:10:40.131781711 -0400
|
||||||
@@ -1326,7 +1326,7 @@
|
@@ -1433,7 +1433,7 @@ target_phys_addr_t cpu_get_phys_page_deb
|
||||||
}
|
}
|
||||||
|
|
||||||
page_offset = (addr & TARGET_PAGE_MASK) & (page_size - 1);
|
page_offset = (addr & TARGET_PAGE_MASK) & (page_size - 1);
|
||||||
|
@ -1047,21 +985,21 @@ Index: git/target-i386/helper.c
|
||||||
return paddr;
|
return paddr;
|
||||||
}
|
}
|
||||||
|
|
||||||
Index: git/target-i386/helper.h
|
Index: qemu/target-i386/helper.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/target-i386/helper.h 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/target-i386/helper.h 2010-05-11 18:05:22.956804503 -0400
|
||||||
+++ git/target-i386/helper.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/helper.h 2010-05-12 12:10:40.131781711 -0400
|
||||||
@@ -214,4 +214,6 @@
|
@@ -217,4 +217,6 @@ DEF_HELPER_2(rclq, tl, tl, tl)
|
||||||
DEF_HELPER_2(rcrq, tl, tl, tl)
|
DEF_HELPER_2(rcrq, tl, tl, tl)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
+DEF_HELPER_0(opengl, void)
|
+DEF_HELPER_0(opengl, void)
|
||||||
+
|
+
|
||||||
#include "def-helper.h"
|
#include "def-helper.h"
|
||||||
Index: git/target-i386/helper_opengl.c
|
Index: qemu/target-i386/helper_opengl.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/helper_opengl.c 2010-01-14 16:36:59.000000000 +0000
|
+++ qemu/target-i386/helper_opengl.c 2010-05-12 12:10:40.132781622 -0400
|
||||||
@@ -0,0 +1,1207 @@
|
@@ -0,0 +1,1207 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Host-side implementation of GL/GLX API
|
+ * Host-side implementation of GL/GLX API
|
||||||
|
@ -1148,16 +1086,16 @@ Index: git/target-i386/helper_opengl.c
|
||||||
+ cpu_x86_handle_mmu_fault((CPUState *) env, addr, 0, 1, 1));
|
+ cpu_x86_handle_mmu_fault((CPUState *) env, addr, 0, 1, 1));
|
||||||
+ return NULL;
|
+ return NULL;
|
||||||
+ } else {
|
+ } else {
|
||||||
+ if (ret + TARGET_PAGE_SIZE <= phys_ram_size) {
|
+ if (ret + TARGET_PAGE_SIZE <= last_ram_offset) {
|
||||||
+ return phys_ram_base + ret +
|
+ return qemu_get_ram_ptr(ret +
|
||||||
+ (((target_ulong) addr) & (TARGET_PAGE_SIZE - 1));
|
+ (((target_ulong) addr) & (TARGET_PAGE_SIZE - 1)));
|
||||||
+ } else {
|
+ } else {
|
||||||
+ fprintf(stderr,
|
+ fprintf(stderr,
|
||||||
+ "cpu_get_phys_page_debug(env, " TARGET_FMT_lx ") == "
|
+ "cpu_get_phys_page_debug(env, " TARGET_FMT_lx ") == "
|
||||||
+ TARGET_FMT_lx "\n", addr, ret);
|
+ TARGET_FMT_lx "\n", addr, ret);
|
||||||
+ fprintf(stderr,
|
+ fprintf(stderr,
|
||||||
+ "ret=" TARGET_FMT_lx " phys_ram_size= " TARGET_FMT_lx
|
+ "ret=" TARGET_FMT_lx " last_ram_offset= " TARGET_FMT_lx
|
||||||
+ "\n", ret, (target_ulong) phys_ram_size);
|
+ "\n", ret, (target_ulong) last_ram_offset);
|
||||||
+ return NULL;
|
+ return NULL;
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
|
@ -2270,11 +2208,11 @@ Index: git/target-i386/helper_opengl.c
|
||||||
+ io_register();
|
+ io_register();
|
||||||
+}
|
+}
|
||||||
+#endif
|
+#endif
|
||||||
Index: git/target-i386/kvm.c
|
Index: qemu/target-i386/kvm.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/target-i386/kvm.c 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/target-i386/kvm.c 2010-05-11 18:05:22.956804503 -0400
|
||||||
+++ git/target-i386/kvm.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/kvm.c 2010-05-12 12:10:40.132781622 -0400
|
||||||
@@ -480,7 +480,7 @@
|
@@ -528,7 +528,7 @@ static int kvm_get_fpu(CPUState *env)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2283,10 +2221,10 @@ Index: git/target-i386/kvm.c
|
||||||
{
|
{
|
||||||
struct kvm_sregs sregs;
|
struct kvm_sregs sregs;
|
||||||
uint32_t hflags;
|
uint32_t hflags;
|
||||||
Index: git/target-i386/mesa_enums.c
|
Index: qemu/target-i386/mesa_enums.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_enums.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_enums.c 2010-05-12 12:10:40.163783695 -0400
|
||||||
@@ -0,0 +1,4890 @@
|
@@ -0,0 +1,4890 @@
|
||||||
+/* DO NOT EDIT - This file generated automatically by gl_enums.py (from Mesa) script */
|
+/* DO NOT EDIT - This file generated automatically by gl_enums.py (from Mesa) script */
|
||||||
+
|
+
|
||||||
|
@ -7178,10 +7116,10 @@ Index: git/target-i386/mesa_enums.c
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+
|
+
|
||||||
Index: git/target-i386/mesa_get.c
|
Index: qemu/target-i386/mesa_get.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_get.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_get.c 2010-05-12 12:10:40.171781452 -0400
|
||||||
@@ -0,0 +1,5563 @@
|
@@ -0,0 +1,5563 @@
|
||||||
+
|
+
|
||||||
+/***
|
+/***
|
||||||
|
@ -12746,10 +12684,10 @@ Index: git/target-i386/mesa_get.c
|
||||||
+ params[i] = (GLdouble) values[i];
|
+ params[i] = (GLdouble) values[i];
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
Index: git/target-i386/mesa_gl.h
|
Index: qemu/target-i386/mesa_gl.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_gl.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_gl.h 2010-05-12 12:10:40.173780926 -0400
|
||||||
@@ -0,0 +1,2251 @@
|
@@ -0,0 +1,2251 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Mesa 3-D graphics library
|
+ * Mesa 3-D graphics library
|
||||||
|
@ -15002,10 +14940,10 @@ Index: git/target-i386/mesa_gl.h
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
+#endif /* __gl_h_ */
|
+#endif /* __gl_h_ */
|
||||||
Index: git/target-i386/mesa_glext.h
|
Index: qemu/target-i386/mesa_glext.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_glext.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_glext.h 2010-05-12 12:10:40.180780867 -0400
|
||||||
@@ -0,0 +1,7279 @@
|
@@ -0,0 +1,7279 @@
|
||||||
+#ifndef __glext_h_
|
+#ifndef __glext_h_
|
||||||
+#define __glext_h_
|
+#define __glext_h_
|
||||||
|
@ -22286,10 +22224,10 @@ Index: git/target-i386/mesa_glext.h
|
||||||
+
|
+
|
||||||
+/* ERO */
|
+/* ERO */
|
||||||
+GLAPI void GLAPIENTRY fake_gluBuild2DMipmaps (GLenum target, GLint internalFormat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *data);
|
+GLAPI void GLAPIENTRY fake_gluBuild2DMipmaps (GLenum target, GLint internalFormat, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *data);
|
||||||
Index: git/target-i386/mesa_glu.h
|
Index: qemu/target-i386/mesa_glu.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_glu.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_glu.h 2010-05-12 12:10:40.181781686 -0400
|
||||||
@@ -0,0 +1,354 @@
|
@@ -0,0 +1,354 @@
|
||||||
+/*
|
+/*
|
||||||
+** License Applicability. Except to the extent portions of this file are
|
+** License Applicability. Except to the extent portions of this file are
|
||||||
|
@ -22645,10 +22583,10 @@ Index: git/target-i386/mesa_glu.h
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
+#endif /* __glu_h__ */
|
+#endif /* __glu_h__ */
|
||||||
Index: git/target-i386/mesa_glx.h
|
Index: qemu/target-i386/mesa_glx.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_glx.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_glx.h 2010-05-12 12:10:40.181781686 -0400
|
||||||
@@ -0,0 +1,510 @@
|
@@ -0,0 +1,510 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Mesa 3-D graphics library
|
+ * Mesa 3-D graphics library
|
||||||
|
@ -23160,10 +23098,10 @@ Index: git/target-i386/mesa_glx.h
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
+#endif
|
+#endif
|
||||||
Index: git/target-i386/mesa_glxext.h
|
Index: qemu/target-i386/mesa_glxext.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_glxext.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_glxext.h 2010-05-12 12:10:40.182781668 -0400
|
||||||
@@ -0,0 +1,785 @@
|
@@ -0,0 +1,785 @@
|
||||||
+#ifndef __glxext_h_
|
+#ifndef __glxext_h_
|
||||||
+#define __glxext_h_
|
+#define __glxext_h_
|
||||||
|
@ -23950,10 +23888,10 @@ Index: git/target-i386/mesa_glxext.h
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
+#endif
|
+#endif
|
||||||
Index: git/target-i386/mesa_mipmap.c
|
Index: qemu/target-i386/mesa_mipmap.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/mesa_mipmap.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/mesa_mipmap.c 2010-05-12 12:10:40.183781579 -0400
|
||||||
@@ -0,0 +1,824 @@
|
@@ -0,0 +1,824 @@
|
||||||
+
|
+
|
||||||
+/*
|
+/*
|
||||||
|
@ -24779,10 +24717,10 @@ Index: git/target-i386/mesa_mipmap.c
|
||||||
+
|
+
|
||||||
+ return retval;
|
+ return retval;
|
||||||
+}
|
+}
|
||||||
Index: git/target-i386/opengl_exec.c
|
Index: qemu/target-i386/opengl_exec.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/opengl_exec.c 2010-01-14 16:34:53.000000000 +0000
|
+++ qemu/target-i386/opengl_exec.c 2010-05-14 13:34:05.506295624 -0400
|
||||||
@@ -0,0 +1,3931 @@
|
@@ -0,0 +1,3931 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Host-side implementation of GL/GLX API
|
+ * Host-side implementation of GL/GLX API
|
||||||
|
@ -28715,10 +28653,10 @@ Index: git/target-i386/opengl_exec.c
|
||||||
+
|
+
|
||||||
+ return ret_int;
|
+ return ret_int;
|
||||||
+}
|
+}
|
||||||
Index: git/target-i386/opengl_func.h
|
Index: qemu/target-i386/opengl_func.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/opengl_func.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/opengl_func.h 2010-05-12 12:10:40.187781086 -0400
|
||||||
@@ -0,0 +1,1108 @@
|
@@ -0,0 +1,1108 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Main header for both host and guest sides
|
+ * Main header for both host and guest sides
|
||||||
|
@ -29828,10 +29766,10 @@ Index: git/target-i386/opengl_func.h
|
||||||
+#error Unsupported ABI
|
+#error Unsupported ABI
|
||||||
+#endif
|
+#endif
|
||||||
+#endif
|
+#endif
|
||||||
Index: git/target-i386/opengl_player.c
|
Index: qemu/target-i386/opengl_player.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/opengl_player.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/opengl_player.c 2010-05-12 12:10:40.188781627 -0400
|
||||||
@@ -0,0 +1,1461 @@
|
@@ -0,0 +1,1461 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Plays a sequence of OpenGL calls recorded either under qemu or with opengl_server
|
+ * Plays a sequence of OpenGL calls recorded either under qemu or with opengl_server
|
||||||
|
@ -31294,10 +31232,10 @@ Index: git/target-i386/opengl_player.c
|
||||||
+ }
|
+ }
|
||||||
+ return 0;
|
+ return 0;
|
||||||
+}
|
+}
|
||||||
Index: git/target-i386/opengl_server.c
|
Index: qemu/target-i386/opengl_server.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/opengl_server.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/opengl_server.c 2010-05-12 12:10:40.188781627 -0400
|
||||||
@@ -0,0 +1,826 @@
|
@@ -0,0 +1,826 @@
|
||||||
+/*
|
+/*
|
||||||
+ * TCP/IP OpenGL server
|
+ * TCP/IP OpenGL server
|
||||||
|
@ -32125,10 +32063,10 @@ Index: git/target-i386/opengl_server.c
|
||||||
+
|
+
|
||||||
+ return 0;
|
+ return 0;
|
||||||
+}
|
+}
|
||||||
Index: git/target-i386/opengl_utils.h
|
Index: qemu/target-i386/opengl_utils.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/opengl_utils.h 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/opengl_utils.h 2010-05-12 12:10:40.189781608 -0400
|
||||||
@@ -0,0 +1,453 @@
|
@@ -0,0 +1,453 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Functions used by host & client sides
|
+ * Functions used by host & client sides
|
||||||
|
@ -32583,10 +32521,10 @@ Index: git/target-i386/opengl_utils.h
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
+#endif
|
+#endif
|
||||||
Index: git/target-i386/parse_gl_h.c
|
Index: qemu/target-i386/parse_gl_h.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/parse_gl_h.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/parse_gl_h.c 2010-05-12 12:10:40.190781520 -0400
|
||||||
@@ -0,0 +1,1496 @@
|
@@ -0,0 +1,1496 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Parse gl.h et glx.h to auto-generate source code
|
+ * Parse gl.h et glx.h to auto-generate source code
|
||||||
|
@ -34084,10 +34022,10 @@ Index: git/target-i386/parse_gl_h.c
|
||||||
+
|
+
|
||||||
+ return 0;
|
+ return 0;
|
||||||
+}
|
+}
|
||||||
Index: git/target-i386/parse_mesa_get_c.c
|
Index: qemu/target-i386/parse_mesa_get_c.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
||||||
+++ git/target-i386/parse_mesa_get_c.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/parse_mesa_get_c.c 2010-05-12 12:10:40.190781520 -0400
|
||||||
@@ -0,0 +1,225 @@
|
@@ -0,0 +1,225 @@
|
||||||
+/*
|
+/*
|
||||||
+ * Parse the "get.c" from mesa source tree to generate "glgetv_cst.h"
|
+ * Parse the "get.c" from mesa source tree to generate "glgetv_cst.h"
|
||||||
|
@ -34314,11 +34252,11 @@ Index: git/target-i386/parse_mesa_get_c.c
|
||||||
+ fclose(outf);
|
+ fclose(outf);
|
||||||
+ return 0;
|
+ return 0;
|
||||||
+}
|
+}
|
||||||
Index: git/target-i386/translate.c
|
Index: qemu/target-i386/translate.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/target-i386/translate.c 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/target-i386/translate.c 2010-05-11 18:05:22.957804134 -0400
|
||||||
+++ git/target-i386/translate.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/target-i386/translate.c 2010-05-12 12:10:40.192781553 -0400
|
||||||
@@ -741,6 +741,8 @@
|
@@ -743,6 +743,8 @@ static void gen_check_io(DisasContext *s
|
||||||
int state_saved;
|
int state_saved;
|
||||||
target_ulong next_eip;
|
target_ulong next_eip;
|
||||||
|
|
||||||
|
@ -34327,7 +34265,7 @@ Index: git/target-i386/translate.c
|
||||||
state_saved = 0;
|
state_saved = 0;
|
||||||
if (s->pe && (s->cpl > s->iopl || s->vm86)) {
|
if (s->pe && (s->cpl > s->iopl || s->vm86)) {
|
||||||
if (s->cc_op != CC_OP_DYNAMIC)
|
if (s->cc_op != CC_OP_DYNAMIC)
|
||||||
@@ -2592,11 +2594,18 @@
|
@@ -2676,11 +2678,18 @@ static void gen_exception(DisasContext *
|
||||||
s->is_jmp = 3;
|
s->is_jmp = 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34346,78 +34284,36 @@ Index: git/target-i386/translate.c
|
||||||
if (s->cc_op != CC_OP_DYNAMIC)
|
if (s->cc_op != CC_OP_DYNAMIC)
|
||||||
gen_op_set_cc_op(s->cc_op);
|
gen_op_set_cc_op(s->cc_op);
|
||||||
gen_jmp_im(cur_eip);
|
gen_jmp_im(cur_eip);
|
||||||
Index: git/vl.c
|
Index: qemu/vl.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- git.orig/vl.c 2009-12-02 13:13:56.000000000 +0000
|
--- qemu.orig/vl.c 2010-05-11 18:05:22.959804376 -0400
|
||||||
+++ git/vl.c 2010-01-14 15:55:40.000000000 +0000
|
+++ qemu/vl.c 2010-05-12 17:10:46.174909450 -0400
|
||||||
@@ -245,6 +245,7 @@
|
@@ -238,6 +238,7 @@ int semihosting_enabled = 0;
|
||||||
#ifdef TARGET_ARM
|
#ifdef TARGET_ARM
|
||||||
int old_param = 0;
|
int old_param = 0;
|
||||||
#endif
|
#endif
|
||||||
+int force_pointer = 0;
|
+int force_pointer = 0;
|
||||||
const char *qemu_name;
|
const char *qemu_name;
|
||||||
int alt_grab = 0;
|
int alt_grab = 0;
|
||||||
#if defined(TARGET_SPARC) || defined(TARGET_PPC)
|
int ctrl_grab = 0;
|
||||||
@@ -253,6 +254,7 @@
|
@@ -246,6 +247,7 @@ unsigned int nb_prom_envs = 0;
|
||||||
|
const char *prom_envs[MAX_PROM_ENVS];
|
||||||
#endif
|
#endif
|
||||||
int nb_drives_opt;
|
int boot_menu;
|
||||||
struct drive_opt drives_opt[MAX_DRIVES];
|
|
||||||
+extern int enable_gl;
|
+extern int enable_gl;
|
||||||
|
|
||||||
static CPUState *cur_cpu;
|
int nb_numa_nodes;
|
||||||
static CPUState *next_cpu;
|
uint64_t node_mem[MAX_NODES];
|
||||||
@@ -4208,12 +4210,14 @@
|
@@ -4418,6 +4420,8 @@ static void select_vgahw (const char *p)
|
||||||
QEMU_OPTION_clock,
|
} else if (strstart(p, "xenfb", &opts)) {
|
||||||
QEMU_OPTION_localtime,
|
vga_interface_type = VGA_XENFB;
|
||||||
QEMU_OPTION_startdate,
|
} else if (!strstart(p, "none", &opts)) {
|
||||||
+ QEMU_OPTION_enable_gl,
|
+ }
|
||||||
QEMU_OPTION_icount,
|
+ else {
|
||||||
QEMU_OPTION_echr,
|
|
||||||
QEMU_OPTION_virtiocon,
|
|
||||||
QEMU_OPTION_show_cursor,
|
|
||||||
QEMU_OPTION_semihosting,
|
|
||||||
QEMU_OPTION_old_param,
|
|
||||||
+ QEMU_OPTION_force_pointer,
|
|
||||||
QEMU_OPTION_tb_size,
|
|
||||||
QEMU_OPTION_incoming,
|
|
||||||
QEMU_OPTION_chroot,
|
|
||||||
@@ -4344,6 +4348,8 @@
|
|
||||||
#if defined(TARGET_ARM)
|
|
||||||
{ "old-param", 0, QEMU_OPTION_old_param },
|
|
||||||
#endif
|
|
||||||
+ { "force-pointer", 0, QEMU_OPTION_force_pointer },
|
|
||||||
+ { "enable-gl", 0, QEMU_OPTION_enable_gl },
|
|
||||||
{ "tb-size", HAS_ARG, QEMU_OPTION_tb_size },
|
|
||||||
{ "incoming", HAS_ARG, QEMU_OPTION_incoming },
|
|
||||||
{ "chroot", HAS_ARG, QEMU_OPTION_chroot },
|
|
||||||
@@ -4496,22 +4502,17 @@
|
|
||||||
{
|
|
||||||
const char *opts;
|
|
||||||
|
|
||||||
+ std_vga_enabled = 0;
|
|
||||||
+ cirrus_vga_enabled = 0;
|
|
||||||
+ vmsvga_enabled = 0;
|
|
||||||
+
|
|
||||||
if (strstart(p, "std", &opts)) {
|
|
||||||
std_vga_enabled = 1;
|
|
||||||
- cirrus_vga_enabled = 0;
|
|
||||||
- vmsvga_enabled = 0;
|
|
||||||
} else if (strstart(p, "cirrus", &opts)) {
|
|
||||||
cirrus_vga_enabled = 1;
|
|
||||||
- std_vga_enabled = 0;
|
|
||||||
- vmsvga_enabled = 0;
|
|
||||||
} else if (strstart(p, "vmware", &opts)) {
|
|
||||||
- cirrus_vga_enabled = 0;
|
|
||||||
- std_vga_enabled = 0;
|
|
||||||
vmsvga_enabled = 1;
|
|
||||||
} else if (strstart(p, "none", &opts)) {
|
|
||||||
- cirrus_vga_enabled = 0;
|
|
||||||
- std_vga_enabled = 0;
|
|
||||||
- vmsvga_enabled = 0;
|
|
||||||
} else {
|
|
||||||
invalid_vga:
|
invalid_vga:
|
||||||
fprintf(stderr, "Unknown vga type: %s\n", p);
|
fprintf(stderr, "Unknown vga type: %s\n", p);
|
||||||
@@ -5220,6 +5221,9 @@
|
exit(1);
|
||||||
|
@@ -5540,6 +5544,9 @@ int main(int argc, char **argv, char **e
|
||||||
old_param = 1;
|
old_param = 1;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
@ -34427,20 +34323,21 @@ Index: git/vl.c
|
||||||
case QEMU_OPTION_clock:
|
case QEMU_OPTION_clock:
|
||||||
configure_alarms(optarg);
|
configure_alarms(optarg);
|
||||||
break;
|
break;
|
||||||
@@ -5261,6 +5265,11 @@
|
@@ -5554,6 +5561,12 @@ int main(int argc, char **argv, char **e
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
configure_rtc(opts);
|
||||||
break;
|
break;
|
||||||
+#ifdef TARGET_OPENGL_OK
|
+#ifdef TARGET_OPENGL_OK
|
||||||
+ case QEMU_OPTION_enable_gl:
|
+ case QEMU_OPTION_enable_gl:
|
||||||
|
+ fprintf(stderr, "Enabling opengl\n");
|
||||||
+ enable_gl = 1;
|
+ enable_gl = 1;
|
||||||
+ break;
|
+ break;
|
||||||
+#endif
|
+#endif
|
||||||
case QEMU_OPTION_tb_size:
|
case QEMU_OPTION_tb_size:
|
||||||
tb_size = strtol(optarg, NULL, 0);
|
tb_size = strtol(optarg, NULL, 0);
|
||||||
if (tb_size < 0)
|
if (tb_size < 0)
|
||||||
@@ -5545,6 +5554,17 @@
|
@@ -5907,6 +5920,14 @@ int main(int argc, char **argv, char **e
|
||||||
exit(1);
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
+#ifdef TARGET_OPENGL_OK
|
+#ifdef TARGET_OPENGL_OK
|
||||||
|
@ -34448,12 +34345,32 @@ Index: git/vl.c
|
||||||
+ /* Use second serial port */
|
+ /* Use second serial port */
|
||||||
+ int opengl_serial = 1;
|
+ int opengl_serial = 1;
|
||||||
+
|
+
|
||||||
+ if (serial_devices[opengl_serial])
|
+ add_device_config(DEV_SERIAL, "opengl");
|
||||||
+ fprintf(stderr, "overriding second serial "
|
|
||||||
+ "port for OpenGL use\n");
|
|
||||||
+ serial_devices[opengl_serial] = "opengl";
|
|
||||||
+ }
|
+ }
|
||||||
+#endif
|
+#endif
|
||||||
|
|
||||||
if (monitor_device) {
|
if (foreach_device_config(DEV_SERIAL, serial_parse) < 0)
|
||||||
monitor_hd = qemu_chr_open("monitor", monitor_device, NULL);
|
exit(1);
|
||||||
|
Index: qemu/qemu-options.hx
|
||||||
|
===================================================================
|
||||||
|
--- qemu.orig/qemu-options.hx 2010-05-11 18:05:22.959804376 -0400
|
||||||
|
+++ qemu/qemu-options.hx 2010-05-12 17:18:10.420907903 -0400
|
||||||
|
@@ -1783,6 +1783,18 @@ many timer interrupts were not processed
|
||||||
|
re-inject them.
|
||||||
|
ETEXI
|
||||||
|
|
||||||
|
+DEF("enable-gl", 0, QEMU_OPTION_enable_gl, \
|
||||||
|
+ "-enable-gl\n")
|
||||||
|
+STEXI
|
||||||
|
+@item -enable-gl
|
||||||
|
+ETEXI
|
||||||
|
+
|
||||||
|
+DEF("force-pointer", 0, QEMU_OPTION_force_pointer, \
|
||||||
|
+ "-force-pointer\n")
|
||||||
|
+STEXI
|
||||||
|
+@item -force-pointer
|
||||||
|
+ETEXI
|
||||||
|
+
|
||||||
|
DEF("icount", HAS_ARG, QEMU_OPTION_icount, \
|
||||||
|
"-icount [N|auto]\n" \
|
||||||
|
" enable virtual instruction counter with 2^N clock ticks per\n" \
|
||||||
|
|
|
@ -10,11 +10,11 @@ committer Andrzej Zaborowski <andrew.zaborowski@intel.com> Tue, 16 Jun 2009 22:2
|
||||||
target-i386/opengl_exec.c | 31 ++++++++++++++++---------------
|
target-i386/opengl_exec.c | 31 ++++++++++++++++---------------
|
||||||
1 files changed, 16 insertions(+), 15 deletions(-)
|
1 files changed, 16 insertions(+), 15 deletions(-)
|
||||||
|
|
||||||
diff --git a/target-i386/opengl_exec.c b/target-i386/opengl_exec.c
|
Index: qemu/target-i386/opengl_exec.c
|
||||||
index 4a69b9b..3d6fb21 100644
|
===================================================================
|
||||||
--- a/target-i386/opengl_exec.c
|
--- qemu.orig/target-i386/opengl_exec.c 2010-05-10 18:46:43.175394992 -0400
|
||||||
+++ b/target-i386/opengl_exec.c
|
+++ qemu/target-i386/opengl_exec.c 2010-05-10 18:46:43.218419933 -0400
|
||||||
@@ -1600,10 +1600,9 @@ int do_function_call(int func_number, arg_t *args, char *ret_string)
|
@@ -1600,10 +1600,9 @@ int do_function_call(int func_number, ar
|
||||||
fprintf(stderr, "client_drawable=%p fake_ctx=%d\n",
|
fprintf(stderr, "client_drawable=%p fake_ctx=%d\n",
|
||||||
(void *) client_drawable, fake_ctxt);
|
(void *) client_drawable, fake_ctxt);
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ index 4a69b9b..3d6fb21 100644
|
||||||
get_association_fakepbuffer_pbuffer(
|
get_association_fakepbuffer_pbuffer(
|
||||||
process, client_drawable))) {
|
process, client_drawable))) {
|
||||||
GLXContext ctxt = get_association_fakecontext_glxcontext(
|
GLXContext ctxt = get_association_fakecontext_glxcontext(
|
||||||
@@ -1651,19 +1650,21 @@ int do_function_call(int func_number, arg_t *args, char *ret_string)
|
@@ -1651,19 +1650,21 @@ int do_function_call(int func_number, ar
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret_int) {
|
if (ret_int) {
|
||||||
|
|
|
@ -2,11 +2,11 @@
|
||||||
linux-user/syscall.c | 10 +++++++++-
|
linux-user/syscall.c | 10 +++++++++-
|
||||||
1 file changed, 9 insertions(+), 1 deletion(-)
|
1 file changed, 9 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
Index: trunk/linux-user/syscall.c
|
Index: qemu/linux-user/syscall.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- trunk.orig/linux-user/syscall.c 2009-01-05 12:47:06.000000000 +0000
|
--- qemu.orig/linux-user/syscall.c 2010-05-11 16:52:16.929785275 -0400
|
||||||
+++ trunk/linux-user/syscall.c 2009-01-05 12:48:04.000000000 +0000
|
+++ qemu/linux-user/syscall.c 2010-05-11 16:52:25.174783517 -0400
|
||||||
@@ -87,6 +87,15 @@
|
@@ -94,6 +94,15 @@
|
||||||
#define CLONE_NPTL_FLAGS2 0
|
#define CLONE_NPTL_FLAGS2 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -21,4 +21,4 @@ Index: trunk/linux-user/syscall.c
|
||||||
+
|
+
|
||||||
//#define DEBUG
|
//#define DEBUG
|
||||||
|
|
||||||
#if defined(TARGET_I386) || defined(TARGET_ARM) || defined(TARGET_SPARC) \
|
//#include <linux/msdos_fs.h>
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
Index: git/configure
|
|
||||||
===================================================================
|
|
||||||
--- git.orig/configure 2009-05-24 11:12:34.000000000 +0100
|
|
||||||
+++ git/configure 2009-05-24 11:12:55.000000000 +0100
|
|
||||||
@@ -749,7 +749,7 @@
|
|
||||||
#include <zlib.h>
|
|
||||||
int main(void) { zlibVersion(); return 0; }
|
|
||||||
EOF
|
|
||||||
-if $cc $ARCH_CFLAGS -o $TMPE ${OS_CFLAGS} $TMPC -lz > /dev/null 2> /dev/null ; then
|
|
||||||
+if $cc $CFLAGS $LDFLAGS $ARCH_CFLAGS -o $TMPE ${OS_CFLAGS} $TMPC -lz > /dev/null 2> /dev/null ; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
echo
|
|
|
@ -1,7 +1,7 @@
|
||||||
LICENSE = "GPL"
|
LICENSE = "GPL"
|
||||||
DEPENDS = "zlib"
|
DEPENDS = "zlib"
|
||||||
PV = "0.10.6+git${SRCREV}"
|
PV = "0.12.0+git${SRCREV}"
|
||||||
PR = "r3"
|
PR = "r4"
|
||||||
|
|
||||||
FILESPATH = "${FILE_DIRNAME}/qemu-${PV}/:${FILE_DIRNAME}/qemu-git/"
|
FILESPATH = "${FILE_DIRNAME}/qemu-${PV}/:${FILE_DIRNAME}/qemu-git/"
|
||||||
|
|
||||||
|
@ -12,13 +12,11 @@ SRC_URI = "\
|
||||||
file://no-strip.patch;patch=1 \
|
file://no-strip.patch;patch=1 \
|
||||||
file://fix-dirent.patch;patch=1 \
|
file://fix-dirent.patch;patch=1 \
|
||||||
file://fix-nogl.patch;patch=1 \
|
file://fix-nogl.patch;patch=1 \
|
||||||
file://zlibsearch.patch;patch=1 \
|
file://qemugl-allow-glxcontext-release.patch;patch=1"
|
||||||
file://qemugl-allow-glxcontext-release.patch;patch=1 \
|
|
||||||
file://2ca2078e287174522e3a6229618947d3d285b8c0.patch;patch=1"
|
|
||||||
|
|
||||||
S = "${WORKDIR}/git"
|
S = "${WORKDIR}/git"
|
||||||
|
|
||||||
EXTRA_OECONF = "--target-list=arm-linux-user,arm-softmmu,i386-softmmu,x86_64-softmmu,mips-linux-user,mips-softmmu --disable-gfx-check"
|
EXTRA_OECONF = "--target-list=arm-linux-user,arm-softmmu,i386-softmmu,x86_64-softmmu,mips-linux-user,mips-softmmu --disable-werror --disable-vnc-tls"
|
||||||
#EXTRA_OECONF += "--disable-sdl"
|
#EXTRA_OECONF += "--disable-sdl"
|
||||||
|
|
||||||
inherit autotools
|
inherit autotools
|
||||||
|
|
Loading…
Reference in New Issue