qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Anthony Liguori <anthony@codemonkey.ws>
To: Avi Kivity <avi@redhat.com>
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: Sun, 22 Aug 2010 16:02:56 -0500	[thread overview]
Message-ID: <4C719080.4030202@codemonkey.ws> (raw)
In-Reply-To: <4C718865.7010807@redhat.com>

On 08/22/2010 03:28 PM, Avi Kivity wrote:
>  On 08/20/2010 09:38 PM, Anthony Liguori wrote:
>>> While that might be useful, I don't quite see what makes CPUs so 
>>> special
>>> that they need to be kept out of qdev.  Could be just my ignorance, of
>>> course.
>>
>> CPUs have special relationships with things like memory in QEMU.  You 
>> can argue that a device is anything with pins and that CPUs are just 
>> like any other chip. 
>
> We're not modelling chips!  If we declare something a device, we do it 
> because it's functionally a device.  It could be part of a chip, or 
> spread along multiple chips.

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.

But we really need to spend some more energy on how we model the device 
tree because it's important to work out the interface that we want to 
represent without going too low.

>> But do we really want to model memory chipsets, a north and south 
>> bridge, and long with cache hierarchies?
>
> We do model devices within the north and south bridges.  The 
> aggregation into two chips is largely meaningless from a functional 
> point of view, as are cache hierarchies.

Right, but it's an issue of how we want devices to interact.

This is the important thing to figure out.  Implementations languages 
don't matter compared to getting the object model right.  If we tried to 
model the device tree based on pin-outs being the interface between 
devices at the lowest level, we're going to fail in any language.

>> If we wanted to add per-device locking based on putting a lock in 
>> DeviceState that was acquired and released whenever you executed a 
>> PIO, how would you do that today?
>>
>> You would convert cpu_register_ioport_* to take a DeviceState in 
>> serial_init_core.  Sure, you could add a layer of indirection in 
>> ISASerialDevice, but what about timers?  We would want to implement 
>> device based timers to do the same thing but again, when we register 
>> the timers we don't have a DeviceState.
>>
>> All device callbacks should be based on DeviceState * pointers which 
>> means if we want to share device code between multiple interfaces (be 
>> it ISA, PCI, or a SysBus device), we need to have a bus in between.
>
> How can you do that?  Do you mean that a timer calls 
> DeviceState::ops->timer(DeviceState *)?  How do you handle multiple 
> timers then?

No.  We have two types of timers today.  vm_clock based timers and 
rt_clock based timers.  It's always a bug for a device model to use an 
rt_clock based timer.  We ought to have a separate API for vm_clock 
based timers and it makes sense to tie that API to DeviceState.  For 
instance:

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.

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.

Regards,

Anthony Liguori

> Much better to call a traditional callback which then uses 
> container_of() to locate its state.
>

  reply	other threads:[~2010-08-22 21:03 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 [this message]
2010-08-23  5:46                   ` Avi Kivity
2010-08-23 13:23                     ` Anthony Liguori
2010-08-23 13:42                       ` Avi Kivity
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=4C719080.4030202@codemonkey.ws \
    --to=anthony@codemonkey.ws \
    --cc=armbru@redhat.com \
    --cc=avi@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 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).