From: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
To: "Philippe Mathieu-Daudé" <philmd@linaro.org>,
pbonzini@redhat.com, qemu-devel@nongnu.org
Subject: Re: [PATCH 2/3] softmmu/ioport.c: QOMify MemoryRegionPortioList
Date: Thu, 20 Apr 2023 11:53:13 +0100 [thread overview]
Message-ID: <c93ea57c-0737-9b11-128c-c02a4bcf74cf@ilande.co.uk> (raw)
In-Reply-To: <6c9b3360-e632-b41a-b890-288863f2c910@linaro.org>
On 20/04/2023 09:41, Philippe Mathieu-Daudé wrote:
> On 19/4/23 17:16, Mark Cave-Ayland wrote:
>> The aim of QOMification is so that the lifetime of the MemoryRegionPortioList
>> structure can be managed using QOM's in-built refcounting instead of having to
>> handle this manually.
>>
>> Due to the use of an opaque pointer it isn't possible to model the new
>> TYPE_MEMORY_REGION_PORTIO_LIST directly using QOM properties, however since
>> use of the new object is restricted to the portio API we can simply set the
>> opaque pointer (and the heap-allocated port list) internally.
>
> In all uses this opaque pointer is a Object*. Almost all cases are
> a DeviceState* and one is a BusState* (IDEBus).
>
> Could this opaque become 'Object *owner' (simplifying the next patch)?
I'm not sure that it does, since the opaque is part of the portio API and not related
to this series which is focused on MemoryRegionPortioList i.e. the glue interface
between the portio and memory APIs. Otherwise you end up changing the portio API and
the associated callbacks which is orthogonal to the bug this series is trying to fix.
>> Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
>> ---
>> softmmu/ioport.c | 25 ++++++++++++++++++++++---
>> 1 file changed, 22 insertions(+), 3 deletions(-)
>>
>> diff --git a/softmmu/ioport.c b/softmmu/ioport.c
>> index d0d5b0bcaa..238625a36f 100644
>> --- a/softmmu/ioport.c
>> +++ b/softmmu/ioport.c
>> @@ -32,11 +32,16 @@
>> #include "exec/address-spaces.h"
>> #include "trace.h"
>> -typedef struct MemoryRegionPortioList {
>> +struct MemoryRegionPortioList {
>> + Object obj;
>> +
>> MemoryRegion mr;
>> void *portio_opaque;
>> MemoryRegionPortio *ports;
>> -} MemoryRegionPortioList;
>> +};
ATB,
Mark.
next prev parent reply other threads:[~2023-04-20 10:54 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-04-19 15:16 [PATCH 0/3] softmmu/ioport.c: fix use-after-free when calling portio_list_destroy() Mark Cave-Ayland
2023-04-19 15:16 ` [PATCH 1/3] softmmu/ioport.c: allocate MemoryRegionPortioList ports on the heap Mark Cave-Ayland
2023-04-20 8:37 ` Philippe Mathieu-Daudé
2023-04-19 15:16 ` [PATCH 2/3] softmmu/ioport.c: QOMify MemoryRegionPortioList Mark Cave-Ayland
2023-04-20 8:41 ` Philippe Mathieu-Daudé
2023-04-20 10:53 ` Mark Cave-Ayland [this message]
2023-05-11 13:46 ` Philippe Mathieu-Daudé
2023-05-11 14:43 ` Mark Cave-Ayland
2023-05-17 16:31 ` Paolo Bonzini
2023-05-11 13:50 ` Philippe Mathieu-Daudé
2023-05-11 14:52 ` Mark Cave-Ayland
2023-05-17 16:37 ` Paolo Bonzini
2023-04-19 15:16 ` [PATCH 3/3] softmmu/ioport.c: make MemoryRegionPortioList owner of portio_list MemoryRegions Mark Cave-Ayland
2023-05-11 19:22 ` Philippe Mathieu-Daudé
2023-05-12 6:56 ` Mark Cave-Ayland
2023-05-12 14:13 ` Philippe Mathieu-Daudé
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=c93ea57c-0737-9b11-128c-c02a4bcf74cf@ilande.co.uk \
--to=mark.cave-ayland@ilande.co.uk \
--cc=pbonzini@redhat.com \
--cc=philmd@linaro.org \
--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).