On Thu, Feb 21, 2013 at 9:36 PM, Sjur Brændeland <sjurbren@xxxxxxxxx> wrote: > OK, We did carefully consider using the normal vrings, but concluded it was > not doable. I'll try to give you some of the background that I can > recall from top of my head. > (I can dig out more if you're still not convinced :) > > The modem we're integrating with is a complex beast (multi mode modem > LTE, HSPA+, etc). > When a packet is received deep down in the radio stack, it allocates packet > buffers using the internal slab allocator.The packet may contain > anything from control, voice, > or IP packets. If the packet contains IP-payload it will travel to a > different asymmetric CPU that > handles the IPC towards the modem. If the packet is not a IP-packet it will be > processed internally and eventually freed. > > What we have done to integrate virtio is to inject the carveout into the > the modem internal slab-allocator. > > Using the reversed ring allows us to introduce zero-copy for virtio > with virtually no > impact on the radio-stack, only a small change on the modem slab allocator. > It supports dynamic size buffer allocation, and modem internal > messaging using data > allocated from the shared region. It also allows modem to manage it's > own memory, > without any dependency on host side allocators. Thanks for the description, Sjur. It sounds like this mostly simplifies your modem-side code, especially if it talks to other cores as well. My impression is that persistently sticking to guest vrings is also possible, but it makes things cumbersome. We will most probably adopt vringh in rpmsg too when a real multicore use case shows up. Ohad. _______________________________________________ Virtualization mailing list Virtualization@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/virtualization