* [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 @ 2015-10-15 11:08 Marcel Apfelbaum 2015-10-15 13:18 ` Michael S. Tsirkin 2015-10-16 6:39 ` Yuanhan Liu 0 siblings, 2 replies; 23+ messages in thread From: Marcel Apfelbaum @ 2015-10-15 11:08 UTC (permalink / raw) To: dev; +Cc: marcel, mst Make vhost-user virtio 1.0 compatible by adding it to the supported features and keeping the header length the same as for mergeable RX buffers. Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> --- To be applied on top of: [dpdk-dev] [PATCH v6 00/13] vhost-user multiple queues enabling Thanks, Marcel lib/librte_vhost/virtio-net.c | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/lib/librte_vhost/virtio-net.c b/lib/librte_vhost/virtio-net.c index a51327d..ee4650e 100644 --- a/lib/librte_vhost/virtio-net.c +++ b/lib/librte_vhost/virtio-net.c @@ -75,6 +75,7 @@ static struct virtio_net_config_ll *ll_root; (1ULL << VIRTIO_NET_F_CTRL_VQ) | \ (1ULL << VIRTIO_NET_F_CTRL_RX) | \ (1ULL << VIRTIO_NET_F_MQ) | \ + (1ULL << VIRTIO_F_VERSION_1) | \ (1ULL << VHOST_F_LOG_ALL) | \ (1ULL << VHOST_USER_F_PROTOCOL_FEATURES)) static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; @@ -477,17 +478,17 @@ set_features(struct vhost_device_ctx ctx, uint64_t *pu) return -1; dev->features = *pu; - if (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) { - LOG_DEBUG(VHOST_CONFIG, - "(%"PRIu64") Mergeable RX buffers enabled\n", - dev->device_fh); + if (dev->features & + ((1 << VIRTIO_NET_F_MRG_RXBUF) | (1ULL << VIRTIO_F_VERSION_1))) { vhost_hlen = sizeof(struct virtio_net_hdr_mrg_rxbuf); } else { - LOG_DEBUG(VHOST_CONFIG, - "(%"PRIu64") Mergeable RX buffers disabled\n", - dev->device_fh); vhost_hlen = sizeof(struct virtio_net_hdr); } + LOG_DEBUG(VHOST_CONFIG, + "(%"PRIu64") Mergeable RX buffers %s, virtio 1 %s\n", + dev->device_fh, + (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) ? "on" : "off", + (dev->features & (1ULL << VIRTIO_F_VERSION_1)) ? "on" : "off"); for (i = 0; i < dev->virt_qp_nb; i++) { uint16_t base_idx = i * VIRTIO_QNUM; -- 2.1.0 ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-15 11:08 [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 Marcel Apfelbaum @ 2015-10-15 13:18 ` Michael S. Tsirkin 2015-10-16 2:24 ` Yuanhan Liu ` (2 more replies) 2015-10-16 6:39 ` Yuanhan Liu 1 sibling, 3 replies; 23+ messages in thread From: Michael S. Tsirkin @ 2015-10-15 13:18 UTC (permalink / raw) To: Marcel Apfelbaum; +Cc: dev On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > Make vhost-user virtio 1.0 compatible by adding it to the > supported features and keeping the header length > the same as for mergeable RX buffers. > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> Looks good to me Acked-by: Michael S. Tsirkin <mst@redhat.com> Just one question: dpdk is only supported on little-endian platforms at the moment, right? virtio 1 spec requires little endian. > --- > > To be applied on top of: > [dpdk-dev] [PATCH v6 00/13] vhost-user multiple queues enabling > > Thanks, > Marcel > > lib/librte_vhost/virtio-net.c | 15 ++++++++------- > 1 file changed, 8 insertions(+), 7 deletions(-) > > diff --git a/lib/librte_vhost/virtio-net.c b/lib/librte_vhost/virtio-net.c > index a51327d..ee4650e 100644 > --- a/lib/librte_vhost/virtio-net.c > +++ b/lib/librte_vhost/virtio-net.c > @@ -75,6 +75,7 @@ static struct virtio_net_config_ll *ll_root; > (1ULL << VIRTIO_NET_F_CTRL_VQ) | \ > (1ULL << VIRTIO_NET_F_CTRL_RX) | \ > (1ULL << VIRTIO_NET_F_MQ) | \ > + (1ULL << VIRTIO_F_VERSION_1) | \ > (1ULL << VHOST_F_LOG_ALL) | \ > (1ULL << VHOST_USER_F_PROTOCOL_FEATURES)) > static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; > @@ -477,17 +478,17 @@ set_features(struct vhost_device_ctx ctx, uint64_t *pu) > return -1; > > dev->features = *pu; > - if (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) { > - LOG_DEBUG(VHOST_CONFIG, > - "(%"PRIu64") Mergeable RX buffers enabled\n", > - dev->device_fh); > + if (dev->features & > + ((1 << VIRTIO_NET_F_MRG_RXBUF) | (1ULL << VIRTIO_F_VERSION_1))) { > vhost_hlen = sizeof(struct virtio_net_hdr_mrg_rxbuf); > } else { > - LOG_DEBUG(VHOST_CONFIG, > - "(%"PRIu64") Mergeable RX buffers disabled\n", > - dev->device_fh); > vhost_hlen = sizeof(struct virtio_net_hdr); > } > + LOG_DEBUG(VHOST_CONFIG, > + "(%"PRIu64") Mergeable RX buffers %s, virtio 1 %s\n", > + dev->device_fh, > + (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) ? "on" : "off", > + (dev->features & (1ULL << VIRTIO_F_VERSION_1)) ? "on" : "off"); > > for (i = 0; i < dev->virt_qp_nb; i++) { > uint16_t base_idx = i * VIRTIO_QNUM; > -- > 2.1.0 ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-15 13:18 ` Michael S. Tsirkin @ 2015-10-16 2:24 ` Yuanhan Liu 2015-10-16 6:20 ` Michael S. Tsirkin 2015-10-16 13:52 ` Bruce Richardson 2015-11-02 22:13 ` Thomas Monjalon 2 siblings, 1 reply; 23+ messages in thread From: Yuanhan Liu @ 2015-10-16 2:24 UTC (permalink / raw) To: Michael S. Tsirkin, Marcel Apfelbaum; +Cc: dev On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > > Make vhost-user virtio 1.0 compatible by adding it to the > > supported features and keeping the header length > > the same as for mergeable RX buffers. > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> Marcel, that's actually one of my TODOs in this quarter. So, thank you! :) > > Looks good to me > > Acked-by: Michael S. Tsirkin <mst@redhat.com> > > Just one question: dpdk is only supported on little-endian > platforms at the moment, right? AFAIK, yes. But you might also see that there are some patch to add ARM arch support showed up in the mailing list few weeks ago. > virtio 1 spec requires little endian. I made a quick list of the difference between virtio v0.95 and v1.0 months ago just by reading your kernel commits of adding v1.0 support: +-------------------+-----------------+------------------------------+ | | v0.95 | v1.0 | +-------------------+-----------------+------------------------------+ 1) | features bits | 32 | 64 | +-------------------+-----------------+------------------------------+ 2) | Endianness | nature | Little Endian | +-------------------+-----------------+------------------------------+ 3) | vring space | contiguous | avail and used buffer could | | | memory | be on a separate memory | +-------------------+-----------------+------------------------------+ 4) | FEATURE_OK status | No | Yes | +-------------------+-----------------+------------------------------+ For 1), I guess we have been using 64 bit for storing features bits for vhost since long time ago. So, there should be no extra effort. For 2), as stated, there might be no issue as far as DPDK is little endian only. But we'd better add a wrapper for that, as it seems adding big endian support would come in near future. For 3), are we actually doing that? I just saw that there is a kernel patch to introduce two functions for getting the avail and used buffer address, respectively. But I didn't see that the two buffer are allocated in non-contiguous memory. For 4), it's a work we should do at virtio PMD driver. And it seems that there are far more work need to be done at virtio PDM driver than at vhost lib, say, adding the virtio morden PCI support. Besides those 4 differs, did I miss anyting? BTW, since we already have same TODOs, I guess it'd be better to share what we have in our TODO list. Here are what I got till the time writing this email (in order of priority): - a vhost performance issue (it might last long; it might not). - vhost-user live migration support - virtio 1.0 support, including PMD and vhost lib (and you guys have already done that :) Thanks. --yliu > > --- > > > > To be applied on top of: > > [dpdk-dev] [PATCH v6 00/13] vhost-user multiple queues enabling > > > > Thanks, > > Marcel > > > > lib/librte_vhost/virtio-net.c | 15 ++++++++------- > > 1 file changed, 8 insertions(+), 7 deletions(-) > > > > diff --git a/lib/librte_vhost/virtio-net.c b/lib/librte_vhost/virtio-net.c > > index a51327d..ee4650e 100644 > > --- a/lib/librte_vhost/virtio-net.c > > +++ b/lib/librte_vhost/virtio-net.c > > @@ -75,6 +75,7 @@ static struct virtio_net_config_ll *ll_root; > > (1ULL << VIRTIO_NET_F_CTRL_VQ) | \ > > (1ULL << VIRTIO_NET_F_CTRL_RX) | \ > > (1ULL << VIRTIO_NET_F_MQ) | \ > > + (1ULL << VIRTIO_F_VERSION_1) | \ > > (1ULL << VHOST_F_LOG_ALL) | \ > > (1ULL << VHOST_USER_F_PROTOCOL_FEATURES)) > > static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; > > @@ -477,17 +478,17 @@ set_features(struct vhost_device_ctx ctx, uint64_t *pu) > > return -1; > > > > dev->features = *pu; > > - if (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) { > > - LOG_DEBUG(VHOST_CONFIG, > > - "(%"PRIu64") Mergeable RX buffers enabled\n", > > - dev->device_fh); > > + if (dev->features & > > + ((1 << VIRTIO_NET_F_MRG_RXBUF) | (1ULL << VIRTIO_F_VERSION_1))) { > > vhost_hlen = sizeof(struct virtio_net_hdr_mrg_rxbuf); > > } else { > > - LOG_DEBUG(VHOST_CONFIG, > > - "(%"PRIu64") Mergeable RX buffers disabled\n", > > - dev->device_fh); > > vhost_hlen = sizeof(struct virtio_net_hdr); > > } > > + LOG_DEBUG(VHOST_CONFIG, > > + "(%"PRIu64") Mergeable RX buffers %s, virtio 1 %s\n", > > + dev->device_fh, > > + (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) ? "on" : "off", > > + (dev->features & (1ULL << VIRTIO_F_VERSION_1)) ? "on" : "off"); > > > > for (i = 0; i < dev->virt_qp_nb; i++) { > > uint16_t base_idx = i * VIRTIO_QNUM; > > -- > > 2.1.0 ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-16 2:24 ` Yuanhan Liu @ 2015-10-16 6:20 ` Michael S. Tsirkin 2015-10-16 7:43 ` Andriy Berestovskyy 0 siblings, 1 reply; 23+ messages in thread From: Michael S. Tsirkin @ 2015-10-16 6:20 UTC (permalink / raw) To: Yuanhan Liu; +Cc: Marcel Apfelbaum, dev On Fri, Oct 16, 2015 at 10:24:38AM +0800, Yuanhan Liu wrote: > On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: > > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > > > Make vhost-user virtio 1.0 compatible by adding it to the > > > supported features and keeping the header length > > > the same as for mergeable RX buffers. > > > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > Marcel, that's actually one of my TODOs in this quarter. So, thank > you! :) > > > > > Looks good to me > > > > Acked-by: Michael S. Tsirkin <mst@redhat.com> > > > > Just one question: dpdk is only supported on little-endian > > platforms at the moment, right? > > AFAIK, yes. But you might also see that there are some patch to add > ARM arch support showed up in the mailing list few weeks ago. Luckily, that's also little-endian. > > virtio 1 spec requires little endian. > > I made a quick list of the difference between virtio v0.95 and v1.0 > months ago just by reading your kernel commits of adding v1.0 support: > > +-------------------+-----------------+------------------------------+ > | | v0.95 | v1.0 | > +-------------------+-----------------+------------------------------+ > 1) | features bits | 32 | 64 | > +-------------------+-----------------+------------------------------+ > 2) | Endianness | nature | Little Endian | > +-------------------+-----------------+------------------------------+ > 3) | vring space | contiguous | avail and used buffer could | > | | memory | be on a separate memory | And desc buffer, too. > +-------------------+-----------------+------------------------------+ > 4) | FEATURE_OK status | No | Yes | > +-------------------+-----------------+------------------------------+ > > > > For 1), I guess we have been using 64 bit for storing features bits > for vhost since long time ago. So, there should be no extra effort. > > For 2), as stated, there might be no issue as far as DPDK is little > endian only. But we'd better add a wrapper for that, as it seems > adding big endian support would come in near future. OK, but it probably doesn't > For 3), are we actually doing that? I just saw that there is a kernel > patch to introduce two functions for getting the avail and used buffer > address, respectively. But I didn't see that the two buffer are > allocated in non-contiguous memory. That will soon happen, anyone claiming support for virtio 1 But vhost user already sends each ring part separately. Does dpdk assume they are contigious? > For 4), it's a work we should do at virtio PMD driver. And it seems > that there are far more work need to be done at virtio PDM driver than > at vhost lib, say, adding the virtio morden PCI support. > > Besides those 4 differs, did I miss anyting? >From virtio PMD point of view? There are more differences. The trick is to find "legacy interface" sections and go over them, that compares 0.9 to 1.0. > > BTW, since we already have same TODOs, I guess it'd be better to > share what we have in our TODO list. Here are what I got till the > time writing this email (in order of priority): > > - a vhost performance issue (it might last long; it might not). > > - vhost-user live migration support > > - virtio 1.0 support, including PMD and vhost lib (and you guys have > already done that :) > > Thanks. This patch only touches the vhost lib, though. > --yliu > > > > > --- > > > > > > To be applied on top of: > > > [dpdk-dev] [PATCH v6 00/13] vhost-user multiple queues enabling > > > > > > Thanks, > > > Marcel > > > > > > lib/librte_vhost/virtio-net.c | 15 ++++++++------- > > > 1 file changed, 8 insertions(+), 7 deletions(-) > > > > > > diff --git a/lib/librte_vhost/virtio-net.c b/lib/librte_vhost/virtio-net.c > > > index a51327d..ee4650e 100644 > > > --- a/lib/librte_vhost/virtio-net.c > > > +++ b/lib/librte_vhost/virtio-net.c > > > @@ -75,6 +75,7 @@ static struct virtio_net_config_ll *ll_root; > > > (1ULL << VIRTIO_NET_F_CTRL_VQ) | \ > > > (1ULL << VIRTIO_NET_F_CTRL_RX) | \ > > > (1ULL << VIRTIO_NET_F_MQ) | \ > > > + (1ULL << VIRTIO_F_VERSION_1) | \ > > > (1ULL << VHOST_F_LOG_ALL) | \ > > > (1ULL << VHOST_USER_F_PROTOCOL_FEATURES)) > > > static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; > > > @@ -477,17 +478,17 @@ set_features(struct vhost_device_ctx ctx, uint64_t *pu) > > > return -1; > > > > > > dev->features = *pu; > > > - if (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) { > > > - LOG_DEBUG(VHOST_CONFIG, > > > - "(%"PRIu64") Mergeable RX buffers enabled\n", > > > - dev->device_fh); > > > + if (dev->features & > > > + ((1 << VIRTIO_NET_F_MRG_RXBUF) | (1ULL << VIRTIO_F_VERSION_1))) { > > > vhost_hlen = sizeof(struct virtio_net_hdr_mrg_rxbuf); > > > } else { > > > - LOG_DEBUG(VHOST_CONFIG, > > > - "(%"PRIu64") Mergeable RX buffers disabled\n", > > > - dev->device_fh); > > > vhost_hlen = sizeof(struct virtio_net_hdr); > > > } > > > + LOG_DEBUG(VHOST_CONFIG, > > > + "(%"PRIu64") Mergeable RX buffers %s, virtio 1 %s\n", > > > + dev->device_fh, > > > + (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) ? "on" : "off", > > > + (dev->features & (1ULL << VIRTIO_F_VERSION_1)) ? "on" : "off"); > > > > > > for (i = 0; i < dev->virt_qp_nb; i++) { > > > uint16_t base_idx = i * VIRTIO_QNUM; > > > -- > > > 2.1.0 ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-16 6:20 ` Michael S. Tsirkin @ 2015-10-16 7:43 ` Andriy Berestovskyy 2015-10-16 7:50 ` Yuanhan Liu 2015-10-16 7:56 ` Michael S. Tsirkin 0 siblings, 2 replies; 23+ messages in thread From: Andriy Berestovskyy @ 2015-10-16 7:43 UTC (permalink / raw) To: Michael S. Tsirkin; +Cc: Marcel Apfelbaum, dev Hi guys, Just a minor note: ARM is bi-endian in fact. For instance, there are both endians tool chains available on Linaro. Andriy On Fri, Oct 16, 2015 at 8:20 AM, Michael S. Tsirkin <mst@redhat.com> wrote: > On Fri, Oct 16, 2015 at 10:24:38AM +0800, Yuanhan Liu wrote: >> On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: >> > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: >> > > Make vhost-user virtio 1.0 compatible by adding it to the >> > > supported features and keeping the header length >> > > the same as for mergeable RX buffers. >> > > >> > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> >> >> Marcel, that's actually one of my TODOs in this quarter. So, thank >> you! :) >> >> > >> > Looks good to me >> > >> > Acked-by: Michael S. Tsirkin <mst@redhat.com> >> > >> > Just one question: dpdk is only supported on little-endian >> > platforms at the moment, right? >> >> AFAIK, yes. But you might also see that there are some patch to add >> ARM arch support showed up in the mailing list few weeks ago. > > Luckily, that's also little-endian. > >> > virtio 1 spec requires little endian. >> >> I made a quick list of the difference between virtio v0.95 and v1.0 >> months ago just by reading your kernel commits of adding v1.0 support: >> >> +-------------------+-----------------+------------------------------+ >> | | v0.95 | v1.0 | >> +-------------------+-----------------+------------------------------+ >> 1) | features bits | 32 | 64 | >> +-------------------+-----------------+------------------------------+ >> 2) | Endianness | nature | Little Endian | >> +-------------------+-----------------+------------------------------+ >> 3) | vring space | contiguous | avail and used buffer could | >> | | memory | be on a separate memory | > > And desc buffer, too. > >> +-------------------+-----------------+------------------------------+ >> 4) | FEATURE_OK status | No | Yes | >> +-------------------+-----------------+------------------------------+ >> >> >> >> For 1), I guess we have been using 64 bit for storing features bits >> for vhost since long time ago. So, there should be no extra effort. >> >> For 2), as stated, there might be no issue as far as DPDK is little >> endian only. But we'd better add a wrapper for that, as it seems >> adding big endian support would come in near future. > > OK, but it probably doesn't > >> For 3), are we actually doing that? I just saw that there is a kernel >> patch to introduce two functions for getting the avail and used buffer >> address, respectively. But I didn't see that the two buffer are >> allocated in non-contiguous memory. > > That will soon happen, anyone claiming support for virtio 1 > > But vhost user already sends each ring part separately. > Does dpdk assume they are contigious? > >> For 4), it's a work we should do at virtio PMD driver. And it seems >> that there are far more work need to be done at virtio PDM driver than >> at vhost lib, say, adding the virtio morden PCI support. >> >> Besides those 4 differs, did I miss anyting? > > > From virtio PMD point of view? There are more > differences. The trick is to find "legacy interface" > sections and go over them, that compares 0.9 to 1.0. > >> >> BTW, since we already have same TODOs, I guess it'd be better to >> share what we have in our TODO list. Here are what I got till the >> time writing this email (in order of priority): >> >> - a vhost performance issue (it might last long; it might not). >> >> - vhost-user live migration support >> >> - virtio 1.0 support, including PMD and vhost lib (and you guys have >> already done that :) >> >> Thanks. > > This patch only touches the vhost lib, though. > >> --yliu >> >> >> > > --- >> > > >> > > To be applied on top of: >> > > [dpdk-dev] [PATCH v6 00/13] vhost-user multiple queues enabling >> > > >> > > Thanks, >> > > Marcel >> > > >> > > lib/librte_vhost/virtio-net.c | 15 ++++++++------- >> > > 1 file changed, 8 insertions(+), 7 deletions(-) >> > > >> > > diff --git a/lib/librte_vhost/virtio-net.c b/lib/librte_vhost/virtio-net.c >> > > index a51327d..ee4650e 100644 >> > > --- a/lib/librte_vhost/virtio-net.c >> > > +++ b/lib/librte_vhost/virtio-net.c >> > > @@ -75,6 +75,7 @@ static struct virtio_net_config_ll *ll_root; >> > > (1ULL << VIRTIO_NET_F_CTRL_VQ) | \ >> > > (1ULL << VIRTIO_NET_F_CTRL_RX) | \ >> > > (1ULL << VIRTIO_NET_F_MQ) | \ >> > > + (1ULL << VIRTIO_F_VERSION_1) | \ >> > > (1ULL << VHOST_F_LOG_ALL) | \ >> > > (1ULL << VHOST_USER_F_PROTOCOL_FEATURES)) >> > > static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; >> > > @@ -477,17 +478,17 @@ set_features(struct vhost_device_ctx ctx, uint64_t *pu) >> > > return -1; >> > > >> > > dev->features = *pu; >> > > - if (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) { >> > > - LOG_DEBUG(VHOST_CONFIG, >> > > - "(%"PRIu64") Mergeable RX buffers enabled\n", >> > > - dev->device_fh); >> > > + if (dev->features & >> > > + ((1 << VIRTIO_NET_F_MRG_RXBUF) | (1ULL << VIRTIO_F_VERSION_1))) { >> > > vhost_hlen = sizeof(struct virtio_net_hdr_mrg_rxbuf); >> > > } else { >> > > - LOG_DEBUG(VHOST_CONFIG, >> > > - "(%"PRIu64") Mergeable RX buffers disabled\n", >> > > - dev->device_fh); >> > > vhost_hlen = sizeof(struct virtio_net_hdr); >> > > } >> > > + LOG_DEBUG(VHOST_CONFIG, >> > > + "(%"PRIu64") Mergeable RX buffers %s, virtio 1 %s\n", >> > > + dev->device_fh, >> > > + (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) ? "on" : "off", >> > > + (dev->features & (1ULL << VIRTIO_F_VERSION_1)) ? "on" : "off"); >> > > >> > > for (i = 0; i < dev->virt_qp_nb; i++) { >> > > uint16_t base_idx = i * VIRTIO_QNUM; >> > > -- >> > > 2.1.0 -- Andriy Berestovskyy ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-16 7:43 ` Andriy Berestovskyy @ 2015-10-16 7:50 ` Yuanhan Liu 2015-10-16 7:56 ` Michael S. Tsirkin 1 sibling, 0 replies; 23+ messages in thread From: Yuanhan Liu @ 2015-10-16 7:50 UTC (permalink / raw) To: Andriy Berestovskyy; +Cc: Marcel Apfelbaum, dev, Michael S. Tsirkin On Fri, Oct 16, 2015 at 09:43:09AM +0200, Andriy Berestovskyy wrote: > Hi guys, > Just a minor note: ARM is bi-endian in fact. Thank you for clarifying that my old memory is right :) --yliu > For instance, there are > both endians tool chains available on Linaro. > > Andriy > > > On Fri, Oct 16, 2015 at 8:20 AM, Michael S. Tsirkin <mst@redhat.com> wrote: > > On Fri, Oct 16, 2015 at 10:24:38AM +0800, Yuanhan Liu wrote: > >> On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: > >> > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > >> > > Make vhost-user virtio 1.0 compatible by adding it to the > >> > > supported features and keeping the header length > >> > > the same as for mergeable RX buffers. > >> > > > >> > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > >> > >> Marcel, that's actually one of my TODOs in this quarter. So, thank > >> you! :) > >> > >> > > >> > Looks good to me > >> > > >> > Acked-by: Michael S. Tsirkin <mst@redhat.com> > >> > > >> > Just one question: dpdk is only supported on little-endian > >> > platforms at the moment, right? > >> > >> AFAIK, yes. But you might also see that there are some patch to add > >> ARM arch support showed up in the mailing list few weeks ago. > > > > Luckily, that's also little-endian. > > > >> > virtio 1 spec requires little endian. > >> > >> I made a quick list of the difference between virtio v0.95 and v1.0 > >> months ago just by reading your kernel commits of adding v1.0 support: > >> > >> +-------------------+-----------------+------------------------------+ > >> | | v0.95 | v1.0 | > >> +-------------------+-----------------+------------------------------+ > >> 1) | features bits | 32 | 64 | > >> +-------------------+-----------------+------------------------------+ > >> 2) | Endianness | nature | Little Endian | > >> +-------------------+-----------------+------------------------------+ > >> 3) | vring space | contiguous | avail and used buffer could | > >> | | memory | be on a separate memory | > > > > And desc buffer, too. > > > >> +-------------------+-----------------+------------------------------+ > >> 4) | FEATURE_OK status | No | Yes | > >> +-------------------+-----------------+------------------------------+ > >> > >> > >> > >> For 1), I guess we have been using 64 bit for storing features bits > >> for vhost since long time ago. So, there should be no extra effort. > >> > >> For 2), as stated, there might be no issue as far as DPDK is little > >> endian only. But we'd better add a wrapper for that, as it seems > >> adding big endian support would come in near future. > > > > OK, but it probably doesn't > > > >> For 3), are we actually doing that? I just saw that there is a kernel > >> patch to introduce two functions for getting the avail and used buffer > >> address, respectively. But I didn't see that the two buffer are > >> allocated in non-contiguous memory. > > > > That will soon happen, anyone claiming support for virtio 1 > > > > But vhost user already sends each ring part separately. > > Does dpdk assume they are contigious? > > > >> For 4), it's a work we should do at virtio PMD driver. And it seems > >> that there are far more work need to be done at virtio PDM driver than > >> at vhost lib, say, adding the virtio morden PCI support. > >> > >> Besides those 4 differs, did I miss anyting? > > > > > > From virtio PMD point of view? There are more > > differences. The trick is to find "legacy interface" > > sections and go over them, that compares 0.9 to 1.0. > > > >> > >> BTW, since we already have same TODOs, I guess it'd be better to > >> share what we have in our TODO list. Here are what I got till the > >> time writing this email (in order of priority): > >> > >> - a vhost performance issue (it might last long; it might not). > >> > >> - vhost-user live migration support > >> > >> - virtio 1.0 support, including PMD and vhost lib (and you guys have > >> already done that :) > >> > >> Thanks. > > > > This patch only touches the vhost lib, though. > > > >> --yliu > >> > >> > >> > > --- > >> > > > >> > > To be applied on top of: > >> > > [dpdk-dev] [PATCH v6 00/13] vhost-user multiple queues enabling > >> > > > >> > > Thanks, > >> > > Marcel > >> > > > >> > > lib/librte_vhost/virtio-net.c | 15 ++++++++------- > >> > > 1 file changed, 8 insertions(+), 7 deletions(-) > >> > > > >> > > diff --git a/lib/librte_vhost/virtio-net.c b/lib/librte_vhost/virtio-net.c > >> > > index a51327d..ee4650e 100644 > >> > > --- a/lib/librte_vhost/virtio-net.c > >> > > +++ b/lib/librte_vhost/virtio-net.c > >> > > @@ -75,6 +75,7 @@ static struct virtio_net_config_ll *ll_root; > >> > > (1ULL << VIRTIO_NET_F_CTRL_VQ) | \ > >> > > (1ULL << VIRTIO_NET_F_CTRL_RX) | \ > >> > > (1ULL << VIRTIO_NET_F_MQ) | \ > >> > > + (1ULL << VIRTIO_F_VERSION_1) | \ > >> > > (1ULL << VHOST_F_LOG_ALL) | \ > >> > > (1ULL << VHOST_USER_F_PROTOCOL_FEATURES)) > >> > > static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; > >> > > @@ -477,17 +478,17 @@ set_features(struct vhost_device_ctx ctx, uint64_t *pu) > >> > > return -1; > >> > > > >> > > dev->features = *pu; > >> > > - if (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) { > >> > > - LOG_DEBUG(VHOST_CONFIG, > >> > > - "(%"PRIu64") Mergeable RX buffers enabled\n", > >> > > - dev->device_fh); > >> > > + if (dev->features & > >> > > + ((1 << VIRTIO_NET_F_MRG_RXBUF) | (1ULL << VIRTIO_F_VERSION_1))) { > >> > > vhost_hlen = sizeof(struct virtio_net_hdr_mrg_rxbuf); > >> > > } else { > >> > > - LOG_DEBUG(VHOST_CONFIG, > >> > > - "(%"PRIu64") Mergeable RX buffers disabled\n", > >> > > - dev->device_fh); > >> > > vhost_hlen = sizeof(struct virtio_net_hdr); > >> > > } > >> > > + LOG_DEBUG(VHOST_CONFIG, > >> > > + "(%"PRIu64") Mergeable RX buffers %s, virtio 1 %s\n", > >> > > + dev->device_fh, > >> > > + (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) ? "on" : "off", > >> > > + (dev->features & (1ULL << VIRTIO_F_VERSION_1)) ? "on" : "off"); > >> > > > >> > > for (i = 0; i < dev->virt_qp_nb; i++) { > >> > > uint16_t base_idx = i * VIRTIO_QNUM; > >> > > -- > >> > > 2.1.0 > > > > -- > Andriy Berestovskyy ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-16 7:43 ` Andriy Berestovskyy 2015-10-16 7:50 ` Yuanhan Liu @ 2015-10-16 7:56 ` Michael S. Tsirkin 1 sibling, 0 replies; 23+ messages in thread From: Michael S. Tsirkin @ 2015-10-16 7:56 UTC (permalink / raw) To: Andriy Berestovskyy; +Cc: Marcel Apfelbaum, dev On Fri, Oct 16, 2015 at 09:43:09AM +0200, Andriy Berestovskyy wrote: > Hi guys, > Just a minor note: ARM is bi-endian in fact. For instance, there are > both endians tool chains available on Linaro. > > Andriy Yea. BE support is around for legacy stuff. So I'm not sure it's all that important to support that mode in NFV/DPDK applications. If it becomes important, for virtio 0.9 you won't be able to support transparently in dpdk anyway - you'll need a new vhost-user message to get the endian-ness of the guest, and do byteswaps conditionally, adding overhead. Maybe going virtio 1 only is the sane thing to do for these applications. -- MST ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-15 13:18 ` Michael S. Tsirkin 2015-10-16 2:24 ` Yuanhan Liu @ 2015-10-16 13:52 ` Bruce Richardson 2015-10-18 7:04 ` Michael S. Tsirkin 2015-11-02 22:13 ` Thomas Monjalon 2 siblings, 1 reply; 23+ messages in thread From: Bruce Richardson @ 2015-10-16 13:52 UTC (permalink / raw) To: Michael S. Tsirkin; +Cc: Marcel Apfelbaum, dev On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > > Make vhost-user virtio 1.0 compatible by adding it to the > > supported features and keeping the header length > > the same as for mergeable RX buffers. > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > Looks good to me > > Acked-by: Michael S. Tsirkin <mst@redhat.com> > > Just one question: dpdk is only supported on little-endian > platforms at the moment, right? A recent release added in support for PPC (patches supplied by IBM). For example, see: http://dpdk.org/browse/dpdk/commit/?id=704ba3770032c5a901719d3837845581d5a56b58 /Bruce ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-16 13:52 ` Bruce Richardson @ 2015-10-18 7:04 ` Michael S. Tsirkin 2015-10-30 17:48 ` Thomas Monjalon 0 siblings, 1 reply; 23+ messages in thread From: Michael S. Tsirkin @ 2015-10-18 7:04 UTC (permalink / raw) To: Bruce Richardson; +Cc: Marcel Apfelbaum, dev On Fri, Oct 16, 2015 at 02:52:30PM +0100, Bruce Richardson wrote: > On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: > > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > > > Make vhost-user virtio 1.0 compatible by adding it to the > > > supported features and keeping the header length > > > the same as for mergeable RX buffers. > > > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > > > Looks good to me > > > > Acked-by: Michael S. Tsirkin <mst@redhat.com> > > > > Just one question: dpdk is only supported on little-endian > > platforms at the moment, right? > > A recent release added in support for PPC (patches supplied by IBM). For > example, see: > http://dpdk.org/browse/dpdk/commit/?id=704ba3770032c5a901719d3837845581d5a56b58 > > /Bruce This will require more work then as 1.0 is a different endian-ness from 0.9. It's up to you guys to decide whether correct BE support is now a requirement for all new dpdk code. Let us know. -- MST ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-18 7:04 ` Michael S. Tsirkin @ 2015-10-30 17:48 ` Thomas Monjalon 2015-11-01 9:00 ` Marcel Apfelbaum 2015-11-09 19:55 ` Michael S. Tsirkin 0 siblings, 2 replies; 23+ messages in thread From: Thomas Monjalon @ 2015-10-30 17:48 UTC (permalink / raw) To: Michael S. Tsirkin, Marcel Apfelbaum; +Cc: dev 2015-10-18 10:04, Michael S. Tsirkin: > On Fri, Oct 16, 2015 at 02:52:30PM +0100, Bruce Richardson wrote: > > On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: > > > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > > > > Make vhost-user virtio 1.0 compatible by adding it to the > > > > supported features and keeping the header length > > > > the same as for mergeable RX buffers. > > > > > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > > > > > Looks good to me > > > > > > Acked-by: Michael S. Tsirkin <mst@redhat.com> > > > > > > Just one question: dpdk is only supported on little-endian > > > platforms at the moment, right? > > > > A recent release added in support for PPC (patches supplied by IBM). For > > example, see: > > http://dpdk.org/browse/dpdk/commit/?id=704ba3770032c5a901719d3837845581d5a56b58 > > > > /Bruce > > This will require more work then as 1.0 is a different > endian-ness from 0.9. It's up to you guys to decide > whether correct BE support is now a requirement for all > new dpdk code. Let us know. I'm not sure to understand. Yes DPDK must work on big endian platforms. Does this patch prevent from using virtio 0.9 with big endian? Does it work with old QEMU not supporting virtio 1.0? ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-30 17:48 ` Thomas Monjalon @ 2015-11-01 9:00 ` Marcel Apfelbaum 2015-11-01 9:53 ` Thomas Monjalon 2015-11-09 19:55 ` Michael S. Tsirkin 1 sibling, 1 reply; 23+ messages in thread From: Marcel Apfelbaum @ 2015-11-01 9:00 UTC (permalink / raw) To: Thomas Monjalon, Michael S. Tsirkin; +Cc: dev On 10/30/2015 07:48 PM, Thomas Monjalon wrote: > 2015-10-18 10:04, Michael S. Tsirkin: >> On Fri, Oct 16, 2015 at 02:52:30PM +0100, Bruce Richardson wrote: >>> On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: >>>> On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: >>>>> Make vhost-user virtio 1.0 compatible by adding it to the >>>>> supported features and keeping the header length >>>>> the same as for mergeable RX buffers. >>>>> >>>>> Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> >>>> >>>> Looks good to me >>>> >>>> Acked-by: Michael S. Tsirkin <mst@redhat.com> >>>> >>>> Just one question: dpdk is only supported on little-endian >>>> platforms at the moment, right? >>> >>> A recent release added in support for PPC (patches supplied by IBM). For >>> example, see: >>> http://dpdk.org/browse/dpdk/commit/?id=704ba3770032c5a901719d3837845581d5a56b58 >>> >>> /Bruce >> >> This will require more work then as 1.0 is a different >> endian-ness from 0.9. It's up to you guys to decide >> whether correct BE support is now a requirement for all >> new dpdk code. Let us know. > Hi, > I'm not sure to understand. > Yes DPDK must work on big endian platforms. > Does this patch prevent from using virtio 0.9 with big endian? No, if it worked until now, will continue to work. (And the other way around) However, if virtio 1.0 is supported by both QEMU and vhost-user, virtio 1.0 has different endianess requirements than prev virtio, Michael can better elaborate more. > Does it work with old QEMU not supporting virtio 1.0? Yes, it does. virtio 1.0 will be enabled only if the feature is supported by both QEMU and vhost-user backend, otherwise it will work as before. Thanks, Marcel > ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-01 9:00 ` Marcel Apfelbaum @ 2015-11-01 9:53 ` Thomas Monjalon 2015-11-01 11:22 ` Marcel Apfelbaum 0 siblings, 1 reply; 23+ messages in thread From: Thomas Monjalon @ 2015-11-01 9:53 UTC (permalink / raw) To: Marcel Apfelbaum, Michael S. Tsirkin; +Cc: dev 2015-11-01 11:00, Marcel Apfelbaum: > On 10/30/2015 07:48 PM, Thomas Monjalon wrote: > > 2015-10-18 10:04, Michael S. Tsirkin: > >> This will require more work then as 1.0 is a different > >> endian-ness from 0.9. It's up to you guys to decide > >> whether correct BE support is now a requirement for all > >> new dpdk code. Let us know. > > > I'm not sure to understand. > > Yes DPDK must work on big endian platforms. > > Does this patch prevent from using virtio 0.9 with big endian? > > No, if it worked until now, will continue to work. (And the other way around) > > However, if virtio 1.0 is supported by both QEMU and vhost-user, > virtio 1.0 has different endianess requirements than prev virtio, OK so that's an acceptable workaround: big endian platforms must use virtio 0.9. In order to have a big endian support of virtio 1.0, is it sufficient to convert data? Is it something we want regarding performance? ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-01 9:53 ` Thomas Monjalon @ 2015-11-01 11:22 ` Marcel Apfelbaum 0 siblings, 0 replies; 23+ messages in thread From: Marcel Apfelbaum @ 2015-11-01 11:22 UTC (permalink / raw) To: Thomas Monjalon, Michael S. Tsirkin; +Cc: dev On 11/01/2015 11:53 AM, Thomas Monjalon wrote: > 2015-11-01 11:00, Marcel Apfelbaum: >> On 10/30/2015 07:48 PM, Thomas Monjalon wrote: >>> 2015-10-18 10:04, Michael S. Tsirkin: >>>> This will require more work then as 1.0 is a different >>>> endian-ness from 0.9. It's up to you guys to decide >>>> whether correct BE support is now a requirement for all >>>> new dpdk code. Let us know. >> >>> I'm not sure to understand. >>> Yes DPDK must work on big endian platforms. >>> Does this patch prevent from using virtio 0.9 with big endian? >> >> No, if it worked until now, will continue to work. (And the other way around) >> >> However, if virtio 1.0 is supported by both QEMU and vhost-user, >> virtio 1.0 has different endianess requirements than prev virtio, > > OK so that's an acceptable workaround: big endian platforms must use > virtio 0.9. > > In order to have a big endian support of virtio 1.0, is it sufficient to > convert data? Is it something we want regarding performance? I think that converting the data should be enough, however Michael can give a more knowledgeable answer, we'll have to wait a few days for him as he is not available this week. Thanks, Marcel > ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-30 17:48 ` Thomas Monjalon 2015-11-01 9:00 ` Marcel Apfelbaum @ 2015-11-09 19:55 ` Michael S. Tsirkin 1 sibling, 0 replies; 23+ messages in thread From: Michael S. Tsirkin @ 2015-11-09 19:55 UTC (permalink / raw) To: Thomas Monjalon; +Cc: Marcel Apfelbaum, dev On Fri, Oct 30, 2015 at 06:48:09PM +0100, Thomas Monjalon wrote: > 2015-10-18 10:04, Michael S. Tsirkin: > > On Fri, Oct 16, 2015 at 02:52:30PM +0100, Bruce Richardson wrote: > > > On Thu, Oct 15, 2015 at 04:18:59PM +0300, Michael S. Tsirkin wrote: > > > > On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > > > > > Make vhost-user virtio 1.0 compatible by adding it to the > > > > > supported features and keeping the header length > > > > > the same as for mergeable RX buffers. > > > > > > > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > > > > > > > Looks good to me > > > > > > > > Acked-by: Michael S. Tsirkin <mst@redhat.com> > > > > > > > > Just one question: dpdk is only supported on little-endian > > > > platforms at the moment, right? > > > > > > A recent release added in support for PPC (patches supplied by IBM). For > > > example, see: > > > http://dpdk.org/browse/dpdk/commit/?id=704ba3770032c5a901719d3837845581d5a56b58 > > > > > > /Bruce > > > > This will require more work then as 1.0 is a different > > endian-ness from 0.9. It's up to you guys to decide > > whether correct BE support is now a requirement for all > > new dpdk code. Let us know. > > I'm not sure to understand. > Yes DPDK must work on big endian platforms. > Does this patch prevent from using virtio 0.9 with big endian? No it doesn't. virtio 0.9 with big endian most likely does not work reliably with vhost-user at the moment since qemu does not tell vhost-user about guest endian-ness (though it's common to have it match host, then it will work by luck). > Does it work with old QEMU not supporting virtio 1.0? Yes it does. virtio 1 requires a bunch of fields to be little endian. If someone uses this patch with new QEMU on BE machine, things won't work: you need if (virtio_1) cpu_to_le On LE, cpu_to_le is a NOP so things work by luck. In other words this patch is fine, more is needed to make virtio 1 work on BE hosts. -- MST ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-15 13:18 ` Michael S. Tsirkin 2015-10-16 2:24 ` Yuanhan Liu 2015-10-16 13:52 ` Bruce Richardson @ 2015-11-02 22:13 ` Thomas Monjalon 2015-11-03 3:45 ` Xu, Qian Q 2 siblings, 1 reply; 23+ messages in thread From: Thomas Monjalon @ 2015-11-02 22:13 UTC (permalink / raw) To: Marcel Apfelbaum; +Cc: dev, Michael S. Tsirkin > > Make vhost-user virtio 1.0 compatible by adding it to the > > supported features and keeping the header length > > the same as for mergeable RX buffers. > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > Looks good to me > > Acked-by: Michael S. Tsirkin <mst@redhat.com> Applied, thanks ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-02 22:13 ` Thomas Monjalon @ 2015-11-03 3:45 ` Xu, Qian Q 2015-11-03 3:49 ` Xu, Qian Q 0 siblings, 1 reply; 23+ messages in thread From: Xu, Qian Q @ 2015-11-03 3:45 UTC (permalink / raw) To: Thomas Monjalon, Marcel Apfelbaum; +Cc: dev, Michael S. Tsirkin DPDK GCC 64bit build on kernel 3.18 will be failed, could you help check? == Build lib/librte_pipeline /home/qxu10/virtio-opt-test/dpdk/lib/librte_vhost/virtio-net.c:81:106: error: 'VIRTIO_F_VERSION_1' undeclared here (not in a function) static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; ^ /home/qxu10/virtio-opt-test/dpdk/mk/internal/rte.compile-pre.mk:126: recipe for target 'virtio-net.o' failed make[5]: *** [virtio-net.o] Error 1 /home/qxu10/virtio-opt-test/dpdk/mk/rte.subdir.mk:61: recipe for target 'librte_vhost' failed make[4]: *** [librte_vhost] Error 2 make[4]: *** Waiting for unfinished jobs.... SYMLINK-FILE include/rte_pipeline.h CC rte_pipeline.o AR librte_pipeline.a INSTALL-LIB librte_pipeline.a /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkbuild.mk:93: recipe for target 'lib' failed make[3]: *** [lib] Error 2 /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkroot.mk:124: recipe for target 'all' failed make[2]: *** [all] Error 2 /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkinstall.mk:58: recipe for target 'x86_64-native-linuxapp-gcc_install' failed make[1]: *** [x86_64-native-linuxapp-gcc_install] Error 2 /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkroot.mk:102: recipe for target 'install' failed make: *** [install] Error 2 Thanks Qian -----Original Message----- From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Thomas Monjalon Sent: Tuesday, November 03, 2015 6:14 AM To: Marcel Apfelbaum Cc: dev@dpdk.org; Michael S. Tsirkin Subject: Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 > > Make vhost-user virtio 1.0 compatible by adding it to the supported > > features and keeping the header length the same as for mergeable RX > > buffers. > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > Looks good to me > > Acked-by: Michael S. Tsirkin <mst@redhat.com> Applied, thanks ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-03 3:45 ` Xu, Qian Q @ 2015-11-03 3:49 ` Xu, Qian Q 2015-11-03 8:03 ` Marcel Apfelbaum 0 siblings, 1 reply; 23+ messages in thread From: Xu, Qian Q @ 2015-11-03 3:49 UTC (permalink / raw) To: Xu, Qian Q, Thomas Monjalon, Marcel Apfelbaum; +Cc: dev, Michael S. Tsirkin Sorry, correct the kernel info, my kernel version is 4.1.8-100.fc21.x86_64. Thanks Qian -----Original Message----- From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Xu, Qian Q Sent: Tuesday, November 03, 2015 11:45 AM To: Thomas Monjalon; Marcel Apfelbaum Cc: dev@dpdk.org; Michael S. Tsirkin Subject: Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 DPDK GCC 64bit build on kernel 3.18 will be failed, could you help check? == Build lib/librte_pipeline /home/qxu10/virtio-opt-test/dpdk/lib/librte_vhost/virtio-net.c:81:106: error: 'VIRTIO_F_VERSION_1' undeclared here (not in a function) static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; ^ /home/qxu10/virtio-opt-test/dpdk/mk/internal/rte.compile-pre.mk:126: recipe for target 'virtio-net.o' failed make[5]: *** [virtio-net.o] Error 1 /home/qxu10/virtio-opt-test/dpdk/mk/rte.subdir.mk:61: recipe for target 'librte_vhost' failed make[4]: *** [librte_vhost] Error 2 make[4]: *** Waiting for unfinished jobs.... SYMLINK-FILE include/rte_pipeline.h CC rte_pipeline.o AR librte_pipeline.a INSTALL-LIB librte_pipeline.a /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkbuild.mk:93: recipe for target 'lib' failed make[3]: *** [lib] Error 2 /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkroot.mk:124: recipe for target 'all' failed make[2]: *** [all] Error 2 /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkinstall.mk:58: recipe for target 'x86_64-native-linuxapp-gcc_install' failed make[1]: *** [x86_64-native-linuxapp-gcc_install] Error 2 /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkroot.mk:102: recipe for target 'install' failed make: *** [install] Error 2 Thanks Qian -----Original Message----- From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Thomas Monjalon Sent: Tuesday, November 03, 2015 6:14 AM To: Marcel Apfelbaum Cc: dev@dpdk.org; Michael S. Tsirkin Subject: Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 > > Make vhost-user virtio 1.0 compatible by adding it to the supported > > features and keeping the header length the same as for mergeable RX > > buffers. > > > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > > Looks good to me > > Acked-by: Michael S. Tsirkin <mst@redhat.com> Applied, thanks ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-03 3:49 ` Xu, Qian Q @ 2015-11-03 8:03 ` Marcel Apfelbaum 2015-11-03 8:16 ` Xie, Huawei 0 siblings, 1 reply; 23+ messages in thread From: Marcel Apfelbaum @ 2015-11-03 8:03 UTC (permalink / raw) To: Xu, Qian Q, Thomas Monjalon; +Cc: dev, Michael S. Tsirkin On 11/03/2015 05:49 AM, Xu, Qian Q wrote: > Sorry, correct the kernel info, my kernel version is 4.1.8-100.fc21.x86_64. Hi, This is weird, VIRTIO_F_VERSION_1 is defined in 4.0 (I think), and for sure in 4.1 . You can see commit 4ec22fae (virtio: add virtio 1.0 feature bit) from 2014-10-22 in kernel git. Can you please check a mismatch in header files of your development machine? Thanks, Marcel > > Thanks > Qian > > > -----Original Message----- > From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Xu, Qian Q > Sent: Tuesday, November 03, 2015 11:45 AM > To: Thomas Monjalon; Marcel Apfelbaum > Cc: dev@dpdk.org; Michael S. Tsirkin > Subject: Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 > > DPDK GCC 64bit build on kernel 3.18 will be failed, could you help check? > > == Build lib/librte_pipeline > /home/qxu10/virtio-opt-test/dpdk/lib/librte_vhost/virtio-net.c:81:106: error: 'VIRTIO_F_VERSION_1' undeclared here (not in a function) static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; > ^ > /home/qxu10/virtio-opt-test/dpdk/mk/internal/rte.compile-pre.mk:126: recipe for target 'virtio-net.o' failed > make[5]: *** [virtio-net.o] Error 1 > /home/qxu10/virtio-opt-test/dpdk/mk/rte.subdir.mk:61: recipe for target 'librte_vhost' failed > make[4]: *** [librte_vhost] Error 2 > make[4]: *** Waiting for unfinished jobs.... > SYMLINK-FILE include/rte_pipeline.h > CC rte_pipeline.o > AR librte_pipeline.a > INSTALL-LIB librte_pipeline.a > /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkbuild.mk:93: recipe for target 'lib' failed > make[3]: *** [lib] Error 2 > /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkroot.mk:124: recipe for target 'all' failed > make[2]: *** [all] Error 2 > /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkinstall.mk:58: recipe for target 'x86_64-native-linuxapp-gcc_install' failed > make[1]: *** [x86_64-native-linuxapp-gcc_install] Error 2 > /home/qxu10/virtio-opt-test/dpdk/mk/rte.sdkroot.mk:102: recipe for target 'install' failed > make: *** [install] Error 2 > > Thanks > Qian > > > -----Original Message----- > From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Thomas Monjalon > Sent: Tuesday, November 03, 2015 6:14 AM > To: Marcel Apfelbaum > Cc: dev@dpdk.org; Michael S. Tsirkin > Subject: Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 > >>> Make vhost-user virtio 1.0 compatible by adding it to the supported >>> features and keeping the header length the same as for mergeable RX >>> buffers. >>> >>> Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> >> >> Looks good to me >> >> Acked-by: Michael S. Tsirkin <mst@redhat.com> > > Applied, thanks > ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-03 8:03 ` Marcel Apfelbaum @ 2015-11-03 8:16 ` Xie, Huawei 2015-11-03 8:26 ` Thomas Monjalon 2015-11-03 8:31 ` Marcel Apfelbaum 0 siblings, 2 replies; 23+ messages in thread From: Xie, Huawei @ 2015-11-03 8:16 UTC (permalink / raw) To: Marcel Apfelbaum, Xu, Qian Q, Thomas Monjalon; +Cc: dev, Michael S. Tsirkin On 11/3/2015 4:03 PM, Marcel Apfelbaum wrote: > On 11/03/2015 05:49 AM, Xu, Qian Q wrote: >> Sorry, correct the kernel info, my kernel version is >> 4.1.8-100.fc21.x86_64. > > Hi, > > This is weird, VIRTIO_F_VERSION_1 is defined in 4.0 (I think), and for > sure in 4.1 . > You can see commit 4ec22fae (virtio: add virtio 1.0 feature bit) from > 2014-10-22 in kernel git. > > Can you please check a mismatch in header files of your development > machine? Marcel: Would you prepare the ifdef fix? We have done the same thing in vhost multiple queue patch. > > Thanks, > Marcel ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-03 8:16 ` Xie, Huawei @ 2015-11-03 8:26 ` Thomas Monjalon 2015-11-03 8:30 ` Marcel Apfelbaum 2015-11-03 8:31 ` Marcel Apfelbaum 1 sibling, 1 reply; 23+ messages in thread From: Thomas Monjalon @ 2015-11-03 8:26 UTC (permalink / raw) To: Xie, Huawei, Marcel Apfelbaum; +Cc: dev, Michael S. Tsirkin 2015-11-03 08:16, Xie, Huawei: > On 11/3/2015 4:03 PM, Marcel Apfelbaum wrote: > > On 11/03/2015 05:49 AM, Xu, Qian Q wrote: > >> Sorry, correct the kernel info, my kernel version is > >> 4.1.8-100.fc21.x86_64. > > > > Hi, > > > > This is weird, VIRTIO_F_VERSION_1 is defined in 4.0 (I think), and for > > sure in 4.1 . > > You can see commit 4ec22fae (virtio: add virtio 1.0 feature bit) from > > 2014-10-22 in kernel git. > > > > Can you please check a mismatch in header files of your development > > machine? > Marcel: > Would you prepare the ifdef fix? We have done the same thing in vhost > multiple queue patch. Everybody (including me) forgot the support of older kernel. Please provide a fix ASAP. ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-03 8:26 ` Thomas Monjalon @ 2015-11-03 8:30 ` Marcel Apfelbaum 0 siblings, 0 replies; 23+ messages in thread From: Marcel Apfelbaum @ 2015-11-03 8:30 UTC (permalink / raw) To: Thomas Monjalon, Xie, Huawei; +Cc: dev, Michael S. Tsirkin On 11/03/2015 10:26 AM, Thomas Monjalon wrote: > 2015-11-03 08:16, Xie, Huawei: >> On 11/3/2015 4:03 PM, Marcel Apfelbaum wrote: >>> On 11/03/2015 05:49 AM, Xu, Qian Q wrote: >>>> Sorry, correct the kernel info, my kernel version is >>>> 4.1.8-100.fc21.x86_64. >>> >>> Hi, >>> >>> This is weird, VIRTIO_F_VERSION_1 is defined in 4.0 (I think), and for >>> sure in 4.1 . >>> You can see commit 4ec22fae (virtio: add virtio 1.0 feature bit) from >>> 2014-10-22 in kernel git. >>> >>> Can you please check a mismatch in header files of your development >>> machine? >> Marcel: >> Would you prepare the ifdef fix? We have done the same thing in vhost >> multiple queue patch. > > Everybody (including me) forgot the support of older kernel. > Please provide a fix ASAP. > Sure, I'll send a fix today. (on top of my prev patch) Thanks, Marcel ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-11-03 8:16 ` Xie, Huawei 2015-11-03 8:26 ` Thomas Monjalon @ 2015-11-03 8:31 ` Marcel Apfelbaum 1 sibling, 0 replies; 23+ messages in thread From: Marcel Apfelbaum @ 2015-11-03 8:31 UTC (permalink / raw) To: Xie, Huawei, Xu, Qian Q, Thomas Monjalon; +Cc: dev, Michael S. Tsirkin On 11/03/2015 10:16 AM, Xie, Huawei wrote: > On 11/3/2015 4:03 PM, Marcel Apfelbaum wrote: >> On 11/03/2015 05:49 AM, Xu, Qian Q wrote: >>> Sorry, correct the kernel info, my kernel version is >>> 4.1.8-100.fc21.x86_64. >> >> Hi, >> >> This is weird, VIRTIO_F_VERSION_1 is defined in 4.0 (I think), and for >> sure in 4.1 . >> You can see commit 4ec22fae (virtio: add virtio 1.0 feature bit) from >> 2014-10-22 in kernel git. >> >> Can you please check a mismatch in header files of your development >> machine? > Marcel: > Would you prepare the ifdef fix? We have done the same thing in vhost > multiple queue patch. Yes, thanks for pointing me to the solution. Marcel >> >> Thanks, >> Marcel > ^ permalink raw reply [flat|nested] 23+ messages in thread
* Re: [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 2015-10-15 11:08 [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 Marcel Apfelbaum 2015-10-15 13:18 ` Michael S. Tsirkin @ 2015-10-16 6:39 ` Yuanhan Liu 1 sibling, 0 replies; 23+ messages in thread From: Yuanhan Liu @ 2015-10-16 6:39 UTC (permalink / raw) To: Marcel Apfelbaum; +Cc: dev, mst Reviewed-by: Yuanhan Liu <yuanhan.liu@linux.intel.com> And thanks for the work. --yliu On Thu, Oct 15, 2015 at 02:08:39PM +0300, Marcel Apfelbaum wrote: > Make vhost-user virtio 1.0 compatible by adding it to the > supported features and keeping the header length > the same as for mergeable RX buffers. > > Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> > --- > > To be applied on top of: > [dpdk-dev] [PATCH v6 00/13] vhost-user multiple queues enabling > > Thanks, > Marcel > > lib/librte_vhost/virtio-net.c | 15 ++++++++------- > 1 file changed, 8 insertions(+), 7 deletions(-) > > diff --git a/lib/librte_vhost/virtio-net.c b/lib/librte_vhost/virtio-net.c > index a51327d..ee4650e 100644 > --- a/lib/librte_vhost/virtio-net.c > +++ b/lib/librte_vhost/virtio-net.c > @@ -75,6 +75,7 @@ static struct virtio_net_config_ll *ll_root; > (1ULL << VIRTIO_NET_F_CTRL_VQ) | \ > (1ULL << VIRTIO_NET_F_CTRL_RX) | \ > (1ULL << VIRTIO_NET_F_MQ) | \ > + (1ULL << VIRTIO_F_VERSION_1) | \ > (1ULL << VHOST_F_LOG_ALL) | \ > (1ULL << VHOST_USER_F_PROTOCOL_FEATURES)) > static uint64_t VHOST_FEATURES = VHOST_SUPPORTED_FEATURES; > @@ -477,17 +478,17 @@ set_features(struct vhost_device_ctx ctx, uint64_t *pu) > return -1; > > dev->features = *pu; > - if (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) { > - LOG_DEBUG(VHOST_CONFIG, > - "(%"PRIu64") Mergeable RX buffers enabled\n", > - dev->device_fh); > + if (dev->features & > + ((1 << VIRTIO_NET_F_MRG_RXBUF) | (1ULL << VIRTIO_F_VERSION_1))) { > vhost_hlen = sizeof(struct virtio_net_hdr_mrg_rxbuf); > } else { > - LOG_DEBUG(VHOST_CONFIG, > - "(%"PRIu64") Mergeable RX buffers disabled\n", > - dev->device_fh); > vhost_hlen = sizeof(struct virtio_net_hdr); > } > + LOG_DEBUG(VHOST_CONFIG, > + "(%"PRIu64") Mergeable RX buffers %s, virtio 1 %s\n", > + dev->device_fh, > + (dev->features & (1 << VIRTIO_NET_F_MRG_RXBUF)) ? "on" : "off", > + (dev->features & (1ULL << VIRTIO_F_VERSION_1)) ? "on" : "off"); > > for (i = 0; i < dev->virt_qp_nb; i++) { > uint16_t base_idx = i * VIRTIO_QNUM; > -- > 2.1.0 ^ permalink raw reply [flat|nested] 23+ messages in thread
end of thread, other threads:[~2015-11-09 19:55 UTC | newest] Thread overview: 23+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2015-10-15 11:08 [dpdk-dev] [PATCH] vhost-user: enable virtio 1.0 Marcel Apfelbaum 2015-10-15 13:18 ` Michael S. Tsirkin 2015-10-16 2:24 ` Yuanhan Liu 2015-10-16 6:20 ` Michael S. Tsirkin 2015-10-16 7:43 ` Andriy Berestovskyy 2015-10-16 7:50 ` Yuanhan Liu 2015-10-16 7:56 ` Michael S. Tsirkin 2015-10-16 13:52 ` Bruce Richardson 2015-10-18 7:04 ` Michael S. Tsirkin 2015-10-30 17:48 ` Thomas Monjalon 2015-11-01 9:00 ` Marcel Apfelbaum 2015-11-01 9:53 ` Thomas Monjalon 2015-11-01 11:22 ` Marcel Apfelbaum 2015-11-09 19:55 ` Michael S. Tsirkin 2015-11-02 22:13 ` Thomas Monjalon 2015-11-03 3:45 ` Xu, Qian Q 2015-11-03 3:49 ` Xu, Qian Q 2015-11-03 8:03 ` Marcel Apfelbaum 2015-11-03 8:16 ` Xie, Huawei 2015-11-03 8:26 ` Thomas Monjalon 2015-11-03 8:30 ` Marcel Apfelbaum 2015-11-03 8:31 ` Marcel Apfelbaum 2015-10-16 6:39 ` Yuanhan Liu
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).