Re: [Qemu-devel] KVM call minutes 2013-01-29 - Port I/O

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

 



On Wed, Jan 30, 2013 at 07:24:57AM -0600, Anthony Liguori wrote:
> "Michael S. Tsirkin" <mst@xxxxxxxxxx> writes:
> 
> > On Wed, Jan 30, 2013 at 11:48:14AM +0000, Peter Maydell wrote:
> >> On 30 January 2013 11:39, Andreas Färber <afaerber@xxxxxxx> wrote:
> >> > Proposal by hpoussin was to move _list_add() code to ISADevice:
> >> > http://lists.gnu.org/archive/html/qemu-devel/2013-01/msg00508.html
> >> >
> >> > Concerns:
> >> > * PCI devices (VGA, QXL) register I/O ports as well
> >> >   => above patches add dependency on ISABus to machines
> >> >      -> "<benh> no mac ever had one"
> >> >   => PCIDevice shouldn't use ISA API with NULL ISADevice
> >> > * Lack of avi: Who decides about memory API these days?
> >> >
> >> > armbru and agraf concluded that moving this into ISA is wrong.
> >> >
> >> > => I will drop the remaining ioport patches from above series.
> >> >
> >> > Suggestions on how to proceed with tackling the issue are welcome.
> >> 
> >> How does this stuff work on real hardware? I would have
> >> expected that a PCI device registering the fact it has
> >> IO ports would have to do so via the PCI controller it
> >> is plugged into...
> >
> > All programming is done by the OS, devices do not register
> > with controller.
> >
> > Each bridge has two ways to claim an IO transaction:
> > - transaction is within the window programmed in the bridge
> > - subtractive decoding enabled and no one else claims the transaction
> 
> And there can only be one endpoint that accepts subtractive decoding and
> this is usually the ISA bridge.
> 
> Also note that there are some really special cases with PCI.  The legacy
> VGA ports are always routed to the first device with a DISPLAY class
> type.
> 
> Likewise, with legacy IDE ports are routed to the first device with an
> IDE class.  That's the only reason you can have these legacy devices not
> behind the ISA bridge.
> 
> Regards,
> 
> Anthony Liguori

Yes. And to futher clarify that, 'routed' in the sense that the spec
specifies the addresses for each class, it's a hard-coded set of
addresses.

The hardware never looks at the class, each device of
simply knows which addresses to claim and whether it's enabled.

What happens if you have more than one VGA adapter on a bus?
As long as only one is enabled, you are fine.
If more than one is enabled, bad things will happen including
possibly overheating.

Also, it's not just the class that specifies the addresses,
it's the programming interface too.
For example for display, hardcoded addresses are used for legacy sublass 0x0
and for programming ifc 0x0 - vga compatible adapter and
0x1 - 8514 compatible adapter.
But again - it specifies this to the OS.

> >
> > At the bus level, transaction happens on a bus and an appropriate device
> > will claim it.
> >
> >> My naive don't-know-much-about-portio suggestion is that this
> >> should work the same way as memory regions: each device
> >> provides portio regions, and the controller for the bus
> >> (ISA or PCI) exposes those to the next layer up, and
> >> something at board level maps it all into the right places.
> >> 
> >> -- PMM
--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux