[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <BANLkTi==EpA8s4+F5EtetWsqWVaJcKD8kA@mail.gmail.com>
Date: Tue, 28 Jun 2011 14:14:36 +0900
From: Magnus Damm <magnus.damm@...il.com>
To: Rusty Russell <rusty@...tcorp.com.au>
Cc: linux-kernel@...r.kernel.org, vapier@...too.org,
linux-sh@...r.kernel.org,
virtualization@...ts.linux-foundation.org, horms@...ge.net.au,
mst@...hat.com, iws@...o.caltech.edu,
Christian Borntraeger <borntraeger@...ibm.com>
Subject: Re: [PATCH 00/02][RESEND] virtio: Virtio platform driver
On Wed, Jun 22, 2011 at 11:09 AM, Rusty Russell <rusty@...tcorp.com.au> wrote:
> On Tue, 21 Jun 2011 19:26:05 +0900, Magnus Damm <magnus.damm@...il.com> wrote:
>> virtio: Virtio platform driver
>>
>> [PATCH 01/02] virtio: Break out lguest virtio code to virtio_lguest.c
>> [PATCH 02/02] virtio: Add virtio platform driver
>>
>> These patches add a virtio platform driver to the Linux kernel. This
>> platform driver has the same role as the virtio_pci driver, but instead
>> of building on top of emulated PCI this driver is making use of the
>> platform bus together with driver specific callbacks.
>>
>> The virtio platform driver can be seen as a reusable implementation of
>> the lguest virtio driver - in fact, most code is just taken directly
>> from lguest_device.c and reworked to fit the platform device driver
>> abstraction. The first patch breaks out code that can be shared between
>> lguest and the virtio platform driver.
>>
>> This code has been used to implement a mailbox interface between the
>> two processor cores included in the sh7372 SoC. The sh7372 contains
>> one ARM Cortex-A8 and one SH4AL-DSP core, and in the prototype two
>> Linux kernels are running in parallel on the same chip. Virtio serves
>> as a communication link between the two cores.
Hi Rusty,
Thanks for your comments!
> OK, this seems pretty neat, but I have three questions before we nail this
> down (note that lguest doesn't have an ABI, so we can change it as much
> as we want).
>
> 1) The lguest bus is dumb, and I never thought about device hotplug, for
> example. It would be nice to handle that somehow. Is it possible?
> Is this something you care about?
I would most likely use device hotplug if it already existed, but my
goal with this patch and the rest of the sh7372 AMP code is to show
that virtio exists and that there is no need for people to invent
their own IPC software mechanism. So I don't care that much about
device hotplug.
I do however care about ABI and a non-GPL licensed virtio library to
allow people to tie in commercial RTOS with virtio. To prevent them
from rolling their own. It's pretty low priority though, I am quite
happy as-is staying in proof-of-concept-land running two instances of
Linux.
> 2) Have you seen the '[RFC 0/8] Introducing a generic AMP/IPC framework'
> patches? Seems to overlap with what you're doing after these patches.
Yes, there is clearly overlap, but surprisingly little. I believe
we're trying to solve different sides of the same problem.
Lguest system (Linux + Linux):
Host: lguest.c (user space) talks to /dev/lguest
Guest: lguest_device.c ties in virtio devices
SH Core Linux system (Linux + Linux):
Host: SoC-specific rtcpu-loader.c (user space) talks to /dev/uioX
Slave: SoC-specific code chats to virtio_platform.c that ties in virtio devices
"generic AMP/IPC framework" (Linux + DSP/RTOS):
Host: "remoteproc" and "rpmsg" run in the kernel
Slave: ?? (not covered by the patches I believe)
So while the "generic AMP/IPC framework" looks great for the host,
this patch tries to make something reusable on the slave/guest side.
> 3) The S/390 layout is identical, except their struct kvm_vqconfig is a
> bit different. Perhaps we should just use theirs (they use a 64-bit
> token instead of an interrupt number).
I don't mind so much, but alignment wise I find it odd that the s390
version chose to use u64 + u64 + u16.
Thanks,
/ magnus
--
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