[dpdk-dev] [PATCH 3/5] net/virtio-user: support to report net status
Tan, Jianfeng
jianfeng.tan at intel.com
Mon Mar 27 09:46:32 CEST 2017
> -----Original Message-----
> From: Yuanhan Liu [mailto:yuanhan.liu at linux.intel.com]
> Sent: Friday, March 17, 2017 2:55 PM
> To: Tan, Jianfeng
> Cc: dev at dpdk.org; david.marchand at 6wind.com
> Subject: Re: [PATCH 3/5] net/virtio-user: support to report net status
>
> On Fri, Mar 03, 2017 at 05:56:41PM +0000, Jianfeng Tan wrote:
> > Signed-off-by: Jianfeng Tan <jianfeng.tan at intel.com>
>
> Yet again, not a single work on explanation.
Sorry, will add in next version.
>
> > ---
> > drivers/net/virtio/virtio_user/virtio_user_dev.c | 1 +
> > drivers/net/virtio/virtio_user_ethdev.c | 13 +++++++------
> > 2 files changed, 8 insertions(+), 6 deletions(-)
> >
> > diff --git a/drivers/net/virtio/virtio_user/virtio_user_dev.c
> b/drivers/net/virtio/virtio_user/virtio_user_dev.c
> > index 9777d6b..cc6f557 100644
> > --- a/drivers/net/virtio/virtio_user/virtio_user_dev.c
> > +++ b/drivers/net/virtio/virtio_user/virtio_user_dev.c
> > @@ -176,6 +176,7 @@ virtio_user_start_device(struct virtio_user_dev
> *dev, uint8_t portid)
> > features &= ~(1ull << VIRTIO_NET_F_MAC);
> > /* Strip VIRTIO_NET_F_CTRL_VQ, as devices do not really need to
> know */
> > features &= ~(1ull << VIRTIO_NET_F_CTRL_VQ);
> > + features &= ~(1ull << VIRTIO_NET_F_STATUS);
> > ret = dev->ops->send_request(dev, VHOST_USER_SET_FEATURES,
> &features);
> > if (ret < 0)
> > goto error;
> > diff --git a/drivers/net/virtio/virtio_user_ethdev.c
> b/drivers/net/virtio/virtio_user_ethdev.c
> > index fa79419..fbdd0a8 100644
> > --- a/drivers/net/virtio/virtio_user_ethdev.c
> > +++ b/drivers/net/virtio/virtio_user_ethdev.c
> > @@ -121,7 +121,8 @@ virtio_user_get_features(struct virtio_hw *hw)
> > struct virtio_user_dev *dev = virtio_user_get_dev(hw);
> >
> > /* unmask feature bits defined in vhost user protocol */
> > - return dev->device_features &
> VIRTIO_PMD_SUPPORTED_GUEST_FEATURES;
> > + return (dev->device_features | (1 << VIRTIO_NET_F_STATUS))
> > + & VIRTIO_PMD_SUPPORTED_GUEST_FEATURES;
>
> Why not handle the features at virtio_user_dev_init()?
You mean add VIRTIO_NET_F_STATUS when get_features from device? Yes, we could do that there. But we originally add device_features to only record features supported by device.
>
> > }
> >
> > static void
> > @@ -129,23 +130,23 @@ virtio_user_set_features(struct virtio_hw *hw,
> uint64_t features)
> > {
> > struct virtio_user_dev *dev = virtio_user_get_dev(hw);
> >
> > - dev->features = features & dev->device_features;
> > + dev->features = features;
> > }
> >
> > static uint8_t
> > virtio_user_get_isr(struct virtio_hw *hw __rte_unused)
> > {
> > - /* When config interrupt happens, driver calls this function to query
> > - * what kinds of change happen. Interrupt mode not supported for
> now.
> > + /* rxq interrupts and config interrupt are separated in virtio-user,
> > + * here we only report config change.
> > */
> > - return 0;
> > + return VIRTIO_PCI_ISR_CONFIG;
> > }
> >
> > static uint16_t
> > virtio_user_set_config_irq(struct virtio_hw *hw __rte_unused,
> > uint16_t vec __rte_unused)
> > {
> > - return VIRTIO_MSI_NO_VECTOR;
> > + return 0;
>
> And the above two changes have something to do with this patch (support
> to report net statu)?
Yes, just pretend that irq/vec binding is configured successfully. When setting up config irq, the result is checked.
Thanks,
Jianfeng
More information about the dev
mailing list