On 07/26/2010 02:01 PM, Cam Macdonell wrote:
On Mon, Jul 26, 2010 at 7:48 AM, Anthony Liguori<anth...@codemonkey.ws>  wrote:
On 06/15/2010 03:23 PM, Cam Macdonell wrote:
Latest patch for PCI shared memory device that maps a host shared memory
object
to be shared between guests

Is this against qemu.git or qemu-kvm.git?  It depends on functions like
qemu_ram_map() which are not present in qemu.git (and are present in
qemu-kvm.git).
It is against qemu-kvm.git.  Is qemu_ram_map() going into qemu.git?
Another function I use (and virtio in qemu-kvm uses as well) is
kvm_set_irqfd() that is not qemu.git either.  Do I need ifdef these
functions with CONFIG_KVM?

kvm_set_irqfd() is fine, it just needs to be ported. It should be there due to vhost though?

qemu_ram_map() is more difficult. I would think the better approach would be to invert things. Instead of a "give me a stable mapping that is shared atomically with a guest to this ram region", I would go with "go create a ram region with this preallocated memory" and then just assume that afterwards, you can make use of it and it's exposed as atomic memory.

They're both layering violations, but at least the later is encapsulated to just the shared memory driver.

Regards,

Anthony Liguori

Please advise as to how to handle these two functions and then I can
rebase against qemu.git.

Thanks,
Cam

Regards,

Anthony Liguori

new in this series

     - replace marking memory from v6 with marking device as unmigratable
indicating
       that it should be unplugged before migration and re-added after.
     - 'peer' case changed to require removal before migration, only
'master'
       devices can be migrated while attached.

     v6
     - migration support with 'master' and 'peer' roles for guest to
determine
       who "owns" memory
     - modified phys_ram_dirty array for marking memory as not to be
migrated

     v5:
     - fixed segfault for non-server case
     - code style fixes
     - removed limit on the number of guests
     - shared memory server is now in qemu.git/contrib
     - made ioeventfd setup function generic
     - removed interrupts when guest joined (let application handle it)

     v4:
     - moved to single Doorbell register and use datamatch to trigger
different
       VMs rather than one register per eventfd
     - remove writing arbitrary values to eventfds.  Only values of 1 are
now
       written to ensure correct usage

Cam Macdonell (4):
   Device specification for shared memory PCI device
   Add function to assign ioeventfd to MMIO.
   Support marking a device as non-migratable
   Inter-VM shared memory PCI device

  Makefile.target                    |    3 +
  docs/specs/ivshmem_device_spec.txt |   96 +++++
  hw/hw.h                            |    1 +
  hw/ivshmem.c                       |  823
++++++++++++++++++++++++++++++++++++
  kvm-all.c                          |   32 ++
  kvm.h                              |    1 +
  qemu-char.c                        |    6 +
  qemu-char.h                        |    3 +
  qemu-doc.texi                      |   43 ++
  savevm.c                           |   32 ++-
  10 files changed, 1037 insertions(+), 3 deletions(-)
  create mode 100644 docs/specs/ivshmem_device_spec.txt
  create mode 100644 hw/ivshmem.c







Reply via email to