[dpdk-dev] [PATCH v3 0/7] virtio_user as an alternative exception path
Tan, Jianfeng
jianfeng.tan at intel.com
Tue Jan 10 09:46:02 CET 2017
On 1/9/2017 10:06 PM, Bruce Richardson wrote:
> On Wed, Jan 04, 2017 at 03:59:19AM +0000, Jianfeng Tan wrote:
>> v3:
>> - Drop the patch to postpone driver ok sending patch, superseded it
>> with a bug fix to disable all virtqueues and re-init the device.
>> (you might wonder why not just send reset owner msg. Under my test,
>> it causes spinlock deadlock problem when killing the program).
>> - Avoid compiling error on 32-bit system for pointer convert.
>> - Fix a bug in patch "abstract virtio user backend ops", vhostfd is
>> not properly assigned.
>> - Fix a "MQ cannot be used" bug in v2, which is related to strip
>> some feature bits that vhost kernel does not recognize.
>> - Update release note.
>>
>> v2: (Lots of them are from yuanhan's comment)
>> - Add offloding feature.
>> - Add multiqueue support.
>> - Add a new patch to postpone the sending of driver ok notification.
>> - Put fix patch ahead of the whole patch series.
>> - Split original 0001 patch into 0003 and 0004 patches.
>> - Remove the original vhost_internal design, just add those into
>> struct virtio_user_dev for simplicity.
>> - Reword "control" to "send_request".
>> - Reword "host_features" to "device_features".
>>
>> In v16.07, we upstreamed a virtual device, virtio_user (with vhost-user
>> as the backend). The path to go with a vhost-kernel backend has been
>> dropped for bad performance comparing to vhost-user and code simplicity.
>>
>> But after a second thought, virtio_user + vhost-kernel is a good
>> candidate as an exceptional path, such as KNI, which exchanges packets
>> with kernel networking stack.
>> - maintenance: vhost-net (kernel) is upstreamed and extensively used
>> kernel module. We don't need any out-of-tree module like KNI.
>> - performance: as with KNI, this solution would use one or more
>> kthreads to send/receive packets from user space DPDK applications,
>> which has little impact on user space polling thread (except that
>> it might enter into kernel space to wake up those kthreads if
>> necessary).
>> - features: vhost-net is born to be a networking solution, which has
>> lots of networking related featuers, like multi queue, tso, multi-seg
>> mbuf, etc.
>>
>> Signed-off-by: Jianfeng Tan <jianfeng.tan at intel.com>
>>
> Sounds great. However, I think we'll need a how-to doc for this to help
> people get it up and running as a KNI replacement for packets to/from
> the kernel. Any plans to draw up such a doc? It would be good to include
> it in this patchset.
I was planning to do that in separate patchset. But I agree with you
that it's better to do that in this patchset.
Thanks,
Jianfeng
>
> /Bruce
More information about the dev
mailing list