[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4A0339D2.3050600@redhat.com>
Date: Thu, 07 May 2009 22:43:14 +0300
From: Avi Kivity <avi@...hat.com>
To: Gregory Haskins <gregory.haskins@...il.com>
CC: Gregory Haskins <ghaskins@...ell.com>,
Chris Wright <chrisw@...s-sol.org>,
linux-kernel@...r.kernel.org, kvm@...r.kernel.org,
Anthony Liguori <anthony@...emonkey.ws>
Subject: Re: [RFC PATCH 0/3] generic hypercall support
Gregory Haskins wrote:
>> Don't - it's broken. It will also catch device assignment mmio and
>> hypercall them.
>>
>>
> Ah. Crap.
>
> Would you be conducive if I continue along with the dynhc() approach then?
>
Oh yes. But don't call it dynhc - like Chris says it's the wrong semantic.
Since we want to connect it to an eventfd, call it HC_NOTIFY or HC_EVENT
or something along these lines. You won't be able to pass any data, but
that's fine. Registers are saved to memory anyway.
And btw, given that eventfd and the underlying infrastructure are so
flexible, it's probably better to go back to your original "irqfd gets
fd from userspace" just to be consistent everywhere.
(no, I'm not deliberately making you rewrite that patch again and
again... it's going to be a key piece of infrastructure so I want to get
it right)
Just to make sure we have everything plumbed down, here's how I see
things working out (using qemu and virtio, use sed to taste):
1. qemu starts up, sets up the VM
2. qemu creates virtio-net-server
3. qemu allocates six eventfds: irq, stopirq, notify (one set for tx
ring, one set for rx ring)
4. qemu connects the six eventfd to the data-available,
data-not-available, and kick ports of virtio-net-server
5. the guest starts up and configures virtio-net in pci pin mode
6. qemu notices and decides it will manage interrupts in user space
since this is complicated (shared level triggered interrupts)
7. the guest OS boots, loads device driver
8. device driver switches virtio-net to msix mode
9. qemu notices, plumbs the irq fds as msix interrupts, plumbs the
notify fds as notifyfd
10. look ma, no hands.
Under the hood, the following takes place.
kvm wires the irqfds to schedule a work item which fires the interrupt.
One day the kvm developers get their act together and change it to
inject the interrupt directly when the irqfd is signalled (which could
be from the net softirq or somewhere similarly nasty).
virtio-net-server wires notifyfd according to its liking. It may
schedule a thread, or it may execute directly.
And they all lived happily ever after.
--
Do not meddle in the internals of kernels, for they are subtle and quick to panic.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists