All of lore.kernel.org
 help / color / mirror / Atom feed
From: Avi Kivity <avi@redhat.com>
To: Anthony Liguori <anthony@codemonkey.ws>
Cc: Blue Swirl <blauwirbel@gmail.com>,
	"Liu >> \"Liu, Jinsong\"" <jinsong.liu@intel.com>,
	qemu-devel <qemu-devel@nongnu.org>,
	Markus Armbruster <armbru@redhat.com>,
	Paul Brook <paul@codesourcery.com>
Subject: Re: [Qemu-devel] [PATCH v2 0/7] APIC/IOAPIC cleanup
Date: Mon, 23 Aug 2010 16:42:36 +0300	[thread overview]
Message-ID: <4C727ACC.7080501@redhat.com> (raw)
In-Reply-To: <4C727646.3040903@codemonkey.ws>

  On 08/23/2010 04:23 PM, Anthony Liguori wrote:
>>> This is really a fundamental discussion.  If you look closely at 
>>> qdev in it's current form, what it actually models is a device with 
>>> GPIO input and output whereas the GPIO input and output correspond 
>>> to qemu_irqs which really model pins that can be raised and lowered.
>>>
>>> To me, this is insane and I'm looking to move the GPIO stuff out of 
>>> qdev.  There are some devices where it makes sense to model the 
>>> interactions between pins but not for the vast majority of devices.
>>
>> I agree, but I don't see the burning need or why it's "insane".  
>> Seems like a minor design issue, can't you just ignore GPIO when you 
>> don't need it?
>
>
> In a sane object model, the expectation is that you can meaningfully 
> interact with base classes using the interfaces provided by the base 
> class.
>
> If DeviceState has a GPIO interface, you should be able to use that 
> interface without knowledge of the subclasses.  This implies that all 
> subclasses implement a GPIO interface and that it can be the primary 
> interface to interact and connect with devices.  Modelling a PCI 
> device based on a GPIO interface is what I was referring to as insane.

The pci device has num_gpio_out == num_gpio_in == 0, so it all works 
(trivially).  Again I agree except for the sense of impending doom.  
It's silly but not insane - it assumes most devices have >0 gpio pins, 
which isn't the case for the devices we care about (so it's only 
subjectively silly).

>> GPIO is just one way for a device to talk, same as 
>> (*bus)_phys_memory_rw() or its netdev or its chardev or its timers.  
>> It doesn't need to have special status within DeviceState, but it 
>> doesn't hurt so much that I can tell.
>
> Everything extra hurts when you're trying to move code in to a library 
> with unit tests covering the functionality :-)

Sure, it's a worthy cleanup.  But it's not a reason to go to DEFCON 1.

>
>>> typedef struct Timer Timer;
>>>
>>> void timer_init(DeviceState *, void (*fn)(Timer *));
>>> void timer_update_rel_ns(Timer *);
>>> void timer_cancel(Timer *);
>>> void timer_release(Timer *);
>>>
>>> Timer objects get embedded into the device's state and container_of 
>>> can be used to get to the original device state.  We could also pass 
>>> DeviceState.  It's not clear to me which is better.
>>
>> Not embedding the DeviceState is more generic.  For example, a device 
>> with a variable number of timers wouldn't be able to embed them in 
>> DeviceState.
>
> Where would they put them?  Everything a device does has to be stored 
> in a DeviceState.  It may put them in a container of some form if the 
> timers are dynamic.

Right.  In any case, I don't see how passing a DeviceState helps.

>>> But being able to associate timers with devices seems like a very 
>>> good idea to me because it means that you can see which devices are 
>>> registering timers.
>>
>> You might also have the timers auto-cancelled and auto-destroyed on 
>> device removal.  But the whole thing seems like a minor coding issue 
>> rather than something fundamental.
>
> The fundamental issue is: every function (minus trivial ones) in the 
> device models code should have a state reference.  That state 
> reference should inherit from a DeviceState.  If this statement isn't 
> true, then the device has been modelled in qdev incorrectly.
>
> Using this test, quite a lot of the "converted" devices are being 
> modelled incorrectly.

Is a "state reference" allowed to have a pointer to the state, or reach 
it in some other way (for example, static storage for singleton devices)?

Isn't "save/restore works" an equivalent statement to "device state is 
reachable from the DeviceState"?

-- 
error compiling committee.c: too many arguments to function

  reply	other threads:[~2010-08-23 13:42 UTC|newest]

Thread overview: 54+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-06-12 21:14 [Qemu-devel] [PATCH v2 0/7] APIC/IOAPIC cleanup Blue Swirl
2010-06-13 16:56 ` [Qemu-devel] " Jan Kiszka
2010-06-13 17:03   ` Andreas Färber
2010-06-13 17:53     ` Blue Swirl
2010-06-13 18:17       ` Andreas Färber
2010-06-13 17:49   ` Blue Swirl
2010-08-19 19:33 ` [Qemu-devel] " Anthony Liguori
2010-08-19 20:09   ` Blue Swirl
2010-08-19 20:49     ` Anthony Liguori
2010-08-19 21:21       ` Blue Swirl
2010-08-19 21:51         ` Anthony Liguori
2010-08-19 22:52           ` malc
2010-08-20  1:01             ` Anthony Liguori
2010-08-20 10:00               ` malc
2010-08-20  8:42           ` [Qemu-devel] " Paolo Bonzini
2010-08-20 17:01           ` [Qemu-devel] " Markus Armbruster
2010-08-20 18:38             ` Anthony Liguori
2010-08-22 20:28               ` Avi Kivity
2010-08-22 21:02                 ` Anthony Liguori
2010-08-23  5:46                   ` Avi Kivity
2010-08-23 13:23                     ` Anthony Liguori
2010-08-23 13:42                       ` Avi Kivity [this message]
2010-08-23 13:48                         ` Anthony Liguori
2010-08-23 14:00                           ` Avi Kivity
2010-08-23 14:26                             ` Anthony Liguori
2010-08-23 14:32                               ` Avi Kivity
2010-08-23 14:47                                 ` Anthony Liguori
2010-08-23 15:10                                   ` Markus Armbruster
2010-08-23 16:05                                     ` Anthony Liguori
2010-08-23 17:36                                       ` Markus Armbruster
2010-08-23 17:47                                         ` Anthony Liguori
2010-08-23 18:24                                       ` [Qemu-devel] " Jan Kiszka
2010-08-23 18:29                                         ` Anthony Liguori
2010-08-23 15:14                                   ` [Qemu-devel] " Avi Kivity
2010-08-23 16:02                                     ` Anthony Liguori
2010-08-24  9:51                                       ` Avi Kivity
2010-08-20 19:26           ` Blue Swirl
2010-08-20 10:35       ` [Qemu-devel] " Jan Kiszka
2010-08-22  9:37       ` [Qemu-devel] " Avi Kivity
2010-08-22 18:52         ` Anthony Liguori
2010-08-22 19:44           ` Avi Kivity
2010-08-22 20:03             ` Anthony Liguori
2010-08-22 20:33               ` Avi Kivity
2010-08-22 21:06                 ` Anthony Liguori
2010-08-23  5:49                   ` Avi Kivity
2010-08-23  9:09                     ` [Qemu-devel] " Jan Kiszka
2010-08-23  9:25                       ` Avi Kivity
2010-08-23 10:11                         ` Alexander Graf
2010-08-23 10:15                           ` Avi Kivity
2010-08-23 10:18                             ` Alexander Graf
2010-08-23 10:25                               ` Avi Kivity
2010-08-22 21:07             ` [Qemu-devel] " Anthony Liguori
2010-08-23  5:48               ` Avi Kivity
2010-08-22  9:13   ` 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=4C727ACC.7080501@redhat.com \
    --to=avi@redhat.com \
    --cc=anthony@codemonkey.ws \
    --cc=armbru@redhat.com \
    --cc=blauwirbel@gmail.com \
    --cc=jinsong.liu@intel.com \
    --cc=paul@codesourcery.com \
    --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.