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

[Xen-changelog] [xen-unstable] [qemu patches] Update patches for changeset 11161:5c1021595e3c.



# HG changeset patch
# User chris@xxxxxxxxxxxxxxxxxxxxxxxx
# Node ID 130eee9e972876bba82c73a19e56d314859d8b77
# Parent  5c1021595e3ce923ff11e338172d4639da2aecb5
[qemu patches] Update patches for changeset 11161:5c1021595e3c.

Signed-off-by: Christian Limpach <Christian.Limpach@xxxxxxxxxxxxx>
---
 tools/ioemu/patches/series              |    1 
 tools/ioemu/patches/xen-platform-device |   37 ++++++++++++++++++++++++++++++++
 2 files changed, 38 insertions(+)

diff -r 5c1021595e3c -r 130eee9e9728 tools/ioemu/patches/series
--- a/tools/ioemu/patches/series        Thu Aug 17 12:01:23 2006 +0100
+++ b/tools/ioemu/patches/series        Thu Aug 17 12:01:44 2006 +0100
@@ -42,3 +42,4 @@ qemu-fix-write-to-disk-synchronous
 qemu-fix-write-to-disk-synchronous
 xen-support-buffered-ioreqs
 qemu-daemonize
+xen-platform-device
diff -r 5c1021595e3c -r 130eee9e9728 tools/ioemu/patches/xen-platform-device
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/tools/ioemu/patches/xen-platform-device   Thu Aug 17 12:01:44 2006 +0100
@@ -0,0 +1,186 @@
+Add the xen platform device to the qemu PCI bus.  Useful functionality
+will come later.
+
+Index: ioemu/Makefile.target
+===================================================================
+--- ioemu.orig/Makefile.target 2006-08-17 11:37:49.910902700 +0100
++++ ioemu/Makefile.target      2006-08-17 11:42:15.196191649 +0100
+@@ -359,6 +359,7 @@
+ VL_OBJS+= usb-uhci.o
+ VL_OBJS+= piix4acpi.o
+ VL_OBJS+= xenstore.o
++VL_OBJS+= xen_platform.o
+ DEFINES += -DHAS_AUDIO
+ endif
+ ifeq ($(TARGET_BASE_ARCH), ppc)
+Index: ioemu/hw/pc.c
+===================================================================
+--- ioemu.orig/hw/pc.c 2006-08-17 11:37:49.794915697 +0100
++++ ioemu/hw/pc.c      2006-08-17 11:43:11.818853900 +0100
+@@ -823,6 +823,9 @@
+     }
+ #endif /* !CONFIG_DM */
+ 
++    if (pci_enabled)
++        pci_xen_platform_init(pci_bus);
++
+     for(i = 0; i < MAX_SERIAL_PORTS; i++) {
+         if (serial_hds[i]) {
+             serial_init(&pic_set_irq_new, isa_pic,
+Index: ioemu/hw/xen_platform.c
+===================================================================
+--- /dev/null  1970-01-01 00:00:00.000000000 +0000
++++ ioemu/hw/xen_platform.c    2006-08-17 11:56:16.043076969 +0100
+@@ -0,0 +1,138 @@
++/*
++ * XEN platform fake pci device, formerly known as the event channel device
++ * 
++ * Copyright (c) 2003-2004 Intel Corp.
++ * Copyright (c) 2006 XenSource
++ * 
++ * 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 "vl.h"
++
++#include <xenguest.h>
++#include <xc_private.h>
++
++extern FILE *logfile;
++
++static void platform_ioport_write(void *opaque, uint32_t addr, uint32_t val)
++{
++    return;
++}
++
++static uint32_t platform_ioport_read(void *opaque, uint32_t addr)
++{
++    return 0;
++}
++
++static void platform_ioport_map(PCIDevice *pci_dev, int region_num,
++                                uint32_t addr, uint32_t size, int type)
++{
++    register_ioport_write(addr, 16, 4, platform_ioport_write, NULL);
++    register_ioport_read(addr, 16, 1, platform_ioport_read, NULL);
++}
++
++static uint32_t platform_mmio_read(void *opaque, target_phys_addr_t addr)
++{
++    fprintf(logfile, "Warning: try read from xen platform mmio space\n");
++    return 0;
++}
++
++static void platform_mmio_write(void *opaque, target_phys_addr_t addr,
++                             uint32_t val)
++{
++    fprintf(logfile, "Warning: try write to xen platform mmio space\n");
++    return;
++}
++
++static CPUReadMemoryFunc *platform_mmio_read_funcs[3] = {
++    platform_mmio_read,
++    platform_mmio_read,
++    platform_mmio_read,
++};
++
++static CPUWriteMemoryFunc *platform_mmio_write_funcs[3] = {
++    platform_mmio_write,
++    platform_mmio_write,
++    platform_mmio_write,
++};
++
++static void platform_mmio_map(PCIDevice *d, int region_num,
++                              uint32_t addr, uint32_t size, int type)
++{
++    int mmio_io_addr;
++
++    mmio_io_addr = cpu_register_io_memory(0, platform_mmio_read_funcs,
++                                          platform_mmio_write_funcs, NULL);
++
++    cpu_register_physical_memory(addr, 0x1000000, mmio_io_addr);
++}
++
++struct pci_config_header {
++    uint16_t vendor_id;
++    uint16_t device_id;
++    uint16_t command;
++    uint16_t status;
++    uint8_t  revision;
++    uint8_t  api;
++    uint8_t  subclass;
++    uint8_t  class;
++    uint8_t  cache_line_size; /* Units of 32 bit words */
++    uint8_t  latency_timer; /* In units of bus cycles */
++    uint8_t  header_type; /* Should be 0 */
++    uint8_t  bist; /* Built in self test */
++    uint32_t base_address_regs[6];
++    uint32_t reserved1;
++    uint32_t reserved2;
++    uint32_t rom_addr;
++    uint32_t reserved3;
++    uint32_t reserved4;
++    uint8_t  interrupt_line;
++    uint8_t  interrupt_pin;
++    uint8_t  min_gnt;
++    uint8_t  max_lat;
++};
++
++void pci_xen_platform_init(PCIBus *bus)
++{
++    PCIDevice *d;
++    struct pci_config_header *pch;
++
++    printf("Register xen platform.\n");
++    d = pci_register_device(bus, "xen-platform", sizeof(PCIDevice), -1, NULL,
++                          NULL);
++    pch = (struct pci_config_header *)d->config;
++    pch->vendor_id = 0xfffd;
++    pch->device_id = 0x0101;
++    pch->command = 3; /* IO and memory access */
++    pch->revision = 0;
++    pch->api = 0;
++    pch->subclass = 0x80; /* Other */
++    pch->class = 0xff; /* Unclassified device class */
++    pch->header_type = 0;
++    pch->interrupt_pin = 1;
++
++    pci_register_io_region(d, 0, 0x100, PCI_ADDRESS_SPACE_IO,
++                           platform_ioport_map);
++
++    /* reserve 16MB mmio address for share memory*/
++    pci_register_io_region(d, 1, 0x1000000, PCI_ADDRESS_SPACE_MEM_PREFETCH,
++                         platform_mmio_map);
++
++    register_savevm("platform", 0, 1, generic_pci_save, generic_pci_load, d);
++    printf("Done register platform.\n");
++}
+Index: ioemu/vl.h
+===================================================================
+--- ioemu.orig/vl.h    2006-08-17 11:37:49.932900235 +0100
++++ ioemu/vl.h 2006-08-17 11:44:59.487739984 +0100
+@@ -1208,6 +1208,9 @@
+ void xenstore_check_new_media_present(int timeout);
+ void xenstore_write_vncport(int vnc_display);
+ 
++/* xen_platform.c */
++void pci_xen_platform_init(PCIBus *bus);
++
+ 
+ void kqemu_record_dump(void);
+ 

_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.