qemu-devel
[Top][All Lists]
Advanced

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

Re: [PATCH RESEND v6 17/36] multi-process: introduce proxy object


From: Jag Raman
Subject: Re: [PATCH RESEND v6 17/36] multi-process: introduce proxy object
Date: Tue, 12 May 2020 08:35:15 -0400


> On May 12, 2020, at 8:23 AM, Stefan Hajnoczi <address@hidden> wrote:
> 
> On Wed, Apr 22, 2020 at 09:13:52PM -0700, address@hidden wrote:
>> From: Elena Ufimtseva <address@hidden>
>> 
>> Defines a PCI Device proxy object as a parent of TYPE_PCI_DEVICE.
> 
> s/parent/child/
> 
>> 
>> PCI Proxy Object registers as a PCI device with QEMU and forwards all
>> PCI accesses to the remote process using the communication channel.
> 
> Please include that functionality in this patch. The code below just
> sets up a skeleton PCI device. There is no code that forwards accesses
> to the remote process.
> 
>> Signed-off-by: Elena Ufimtseva <address@hidden>
>> Signed-off-by: Jagannathan Raman <address@hidden>
>> Signed-off-by: John G Johnson <address@hidden>
>> ---
>> MAINTAINERS                   |  3 ++
>> hw/Makefile.objs              |  2 ++
>> hw/proxy/Makefile.objs        |  1 +
>> hw/proxy/qemu-proxy.c         | 56 +++++++++++++++++++++++++++++++++++
>> include/hw/proxy/qemu-proxy.h | 46 ++++++++++++++++++++++++++++
>> include/io/mpqemu-link.h      |  1 +
>> 6 files changed, 109 insertions(+)
>> create mode 100644 hw/proxy/Makefile.objs
>> create mode 100644 hw/proxy/qemu-proxy.c
>> create mode 100644 include/hw/proxy/qemu-proxy.h
>> 
>> diff --git a/MAINTAINERS b/MAINTAINERS
>> index 96f8d7ff19..3da3dcd311 100644
>> --- a/MAINTAINERS
>> +++ b/MAINTAINERS
>> @@ -2866,6 +2866,9 @@ F: include/remote/machine.h
>> F: remote/machine.c
>> F: include/remote/memory.h
>> F: remote/memory.c
>> +F: hw/proxy/Makefile.objs
>> +F: hw/proxy/qemu-proxy.c
>> +F: include/hw/proxy/qemu-proxy.h
> 
> It's a generic PCI device. hw/pci/proxy.c would be a good location for
> it.
> 
> By the way an alternative to the "proxy"/"remote" terminology is
> RemotePCIClient/RemotePCIServer. That makes it more obvious that "proxy"
> is related the "remote" feature. Feel free to keep the existing
> terminology, I just wanted to suggest another possibility.

OK, got it.

> 
>> 
>> Build and test automation
>> -------------------------
>> diff --git a/hw/Makefile.objs b/hw/Makefile.objs
>> index af9235b6f2..7b489b12a5 100644
>> --- a/hw/Makefile.objs
>> +++ b/hw/Makefile.objs
>> @@ -45,6 +45,8 @@ endif
>> common-obj-y += $(devices-dirs-y)
>> obj-y += $(devices-dirs-y)
>> 
>> +common-obj-$(CONFIG_MPQEMU) += proxy/
>> +
>> remote-pci-obj-$(CONFIG_MPQEMU) += core/
>> remote-pci-obj-$(CONFIG_MPQEMU) += block/
>> remote-pci-obj-$(CONFIG_MPQEMU) += pci/
>> diff --git a/hw/proxy/Makefile.objs b/hw/proxy/Makefile.objs
>> new file mode 100644
>> index 0000000000..eb81624cf8
>> --- /dev/null
>> +++ b/hw/proxy/Makefile.objs
>> @@ -0,0 +1 @@
>> +common-obj-$(CONFIG_MPQEMU) += qemu-proxy.o
>> diff --git a/hw/proxy/qemu-proxy.c b/hw/proxy/qemu-proxy.c
>> new file mode 100644
>> index 0000000000..bf6c4117ef
>> --- /dev/null
>> +++ b/hw/proxy/qemu-proxy.c
>> @@ -0,0 +1,56 @@
>> +/*
>> + * Copyright © 2018, 2020 Oracle and/or its affiliates.
>> + *
>> + * This work is licensed under the terms of the GNU GPL, version 2 or later.
>> + * See the COPYING file in the top-level directory.
>> + *
>> + */
>> +
>> +#include "qemu/osdep.h"
>> +#include "qemu-common.h"
>> +
>> +#include "qapi/error.h"
>> +#include "io/mpqemu-link.h"
>> +#include "hw/proxy/qemu-proxy.h"
>> +#include "hw/pci/pci.h"
>> +
>> +static void pci_proxy_dev_realize(PCIDevice *device, Error **errp)
>> +{
>> +    PCIProxyDev *dev = PCI_PROXY_DEV(device);
>> +    PCIProxyDevClass *k = PCI_PROXY_DEV_GET_CLASS(dev);
>> +    Error *local_err = NULL;
>> +
>> +    if (k->realize) {
> 
> Will anything inherit from this class? I thought this is the remote PCI
> client that can acts as a stand-in for all remote PCI devices, so it's
> not clear why it's acting as a base class here.

No one is inheriting from this class anymore. This is code from before
when that was the case. We could remove this.

> 
>> diff --git a/include/io/mpqemu-link.h b/include/io/mpqemu-link.h
>> index d46cb81058..73cc59b874 100644
>> --- a/include/io/mpqemu-link.h
>> +++ b/include/io/mpqemu-link.h
>> @@ -14,6 +14,7 @@
>> #include "qemu/osdep.h"
>> #include "qemu-common.h"
>> 
>> +#include "sys/eventfd.h"
> 
> Why? Nothing in this patch uses this header.

OK, got it.

Thanks!
—
Jag




reply via email to

[Prev in Thread] Current Thread [Next in Thread]