From: Anthony Liguori <anthony@codemonkey.ws>
To: Peter Maydell <peter.maydell@linaro.org>
Cc: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>,
Avi Kivity <avi@redhat.com>,
qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] Memory API: handling unassigned physical memory
Date: Tue, 01 May 2012 10:09:26 -0500 [thread overview]
Message-ID: <4F9FFCA6.5070706@codemonkey.ws> (raw)
In-Reply-To: <CAFEAcA8H7yNgnOyqmd2ZUL_QAJd6=V6-Vy13VSnaGXkqp7z1=Q@mail.gmail.com>
On 05/01/2012 09:20 AM, Peter Maydell wrote:
> On 1 May 2012 15:06, Anthony Liguori<anthony@codemonkey.ws> wrote:
>> Do you mean:
>>
>> - qdev_connect_gpio_out(&dev->qdev, 0, irq_set[2]);
>> + pin_connect_qemu_irq(&s->int_out[0], irq_set[2]);
>>
>> There are three ways to do this:
>>
>> 1) pin_connect_qemu_irq(i8259_get_int_out(s), irq_set[2]);
>
> No good unless you're autogenerating all those accessor functions.
>
>> 2) pin_connect_qemu_irq(&s->int_out[0], irq_set[2]);
>
> Exposes the whole of the struct (including all the private
> memmbers) to anything that wants to use it. As you say
> later on in the email, this requires splitting everything up
> into two structs, one for "publicly accessible" and one for
> "private implementation"...which your series doesn't seem
> to do at the moment.
>
>> 3) pin_connect_qemu_irq(PIN(object_get_child(s, "int_out[0]")), irq_set[2]);
>
> This is a bit verbose. Something more like
> pin_connect(s, "int_out[0]", self, "int_set[2]");
This is incorrect, it would have to be:
Error *err = NULL;
if (pin_connect(s, "in_out[0]", self, "int_set[2]", &err)) {
error_propagate(errp, err);
return;
}
> would be a bit less longwinded. Or even
> connect(TYPE_PIN, s, "int_out[0]", self, "int_set[2]");
Not checking for failure is not an option.
> (No, this doesn't do compile time type checking. I don't
> think that's a problem particularly, or at least not enough
> of one to justify not doing it this way. The object model we
> have is dynamic and does things at runtime...)
Correctness is more important to me than brevity.
And really, we should focus on killing things like i8259_init(). These types of
functions should go away in favor of proper modeling of SoCs/SuperIO chips.
Regards,
Anthony Liguori
>
> -- PMM
next prev parent reply other threads:[~2012-05-01 15:09 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <4F9D797E.500@ilande.co.uk>
[not found] ` <4F9D97F3.8080608@codemonkey.ws>
[not found] ` <4F9E5028.7010306@redhat.com>
[not found] ` <4F9E82C7.10706@ilande.co.uk>
[not found] ` <4F9E9268.70408@redhat.com>
[not found] ` <CAFEAcA_sKtzmHpFcdhkANLCY0=FuW0Hbof0ifp3uHM66NkWoOQ@mail.gmail.com>
[not found] ` <4F9E9906.8060401@ilande.co.uk>
2012-05-01 6:57 ` [Qemu-devel] Memory API: handling unassigned physical memory Blue Swirl
2012-05-01 13:53 ` Anthony Liguori
2012-05-01 18:48 ` Mark Cave-Ayland
2012-05-02 15:15 ` Bob Breuer
2012-05-06 8:45 ` Blue Swirl
2012-05-06 8:41 ` Blue Swirl
[not found] ` <CAFEAcA9VeJWPQ-LU=DvX6vp+=g44-uWda7zokK2NKfLiSkgGAg@mail.gmail.com>
[not found] ` <4F9EA2AD.9050208@ilande.co.uk>
2012-05-01 7:10 ` Blue Swirl
2012-05-01 18:50 ` Mark Cave-Ayland
2012-05-01 21:21 ` Andreas Färber
[not found] ` <4F9E9569.5000700@redhat.com>
[not found] ` <CAFEAcA_wFfsq=PwHAc_r-2bgdwUpSHaTOaL2VPVCJSs9x_JT6A@mail.gmail.com>
2012-05-01 12:39 ` Avi Kivity
2012-05-01 12:41 ` Peter Maydell
2012-05-01 12:42 ` Avi Kivity
2012-05-01 12:43 ` Peter Maydell
2012-05-01 12:48 ` Avi Kivity
2012-05-01 12:49 ` Peter Maydell
2012-05-01 13:01 ` Avi Kivity
2012-05-01 13:50 ` Anthony Liguori
2012-05-01 14:00 ` Peter Maydell
2012-05-01 14:06 ` Anthony Liguori
2012-05-01 14:20 ` Peter Maydell
2012-05-01 15:09 ` Anthony Liguori [this message]
2012-05-01 15:20 ` Peter Maydell
2012-05-01 15:26 ` Anthony Liguori
2012-05-01 15:37 ` Peter Maydell
2012-05-01 17:21 ` Anthony Liguori
2012-05-01 18:57 ` Mark Cave-Ayland
2012-05-01 19:03 ` Peter Maydell
2012-05-01 14:09 ` Avi Kivity
2012-05-01 14:15 ` Anthony Liguori
2012-05-01 14:26 ` Avi Kivity
2012-05-01 15:13 ` Anthony Liguori
[not found] ` <4F9E96EC.5080005@codemonkey.ws>
2012-05-01 12:41 ` Avi Kivity
[not found] ` <4F9E964A.1010408@ilande.co.uk>
2012-05-01 12:46 ` Avi Kivity
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=4F9FFCA6.5070706@codemonkey.ws \
--to=anthony@codemonkey.ws \
--cc=avi@redhat.com \
--cc=mark.cave-ayland@ilande.co.uk \
--cc=peter.maydell@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.