From: Thomas Monjalon <thomas@monjalon.net>
To: Kevin Traynor <ktraynor@redhat.com>,
"Loftus, Ciara" <ciara.loftus@intel.com>
Cc: devendra rawat <devendra.rawat.singh@gmail.com>,
ovs-dev@openvswitch.org,
Adrien Mazarguil <adrien.mazarguil@6wind.com>,
nelio.laranjeiro@6wind.com, users@dpdk.org,
Yuanhan Liu <yliu@fridaylinux.org>,
olgas@mellanox.com
Subject: Re: [dpdk-users] [ovs-dev] adding dpdk ports sharing same pci address to ovs-dpdk bridge
Date: Thu, 21 Sep 2017 00:08:45 +0200 [thread overview]
Message-ID: <1990042.kGnXgAYS5O@xps> (raw)
In-Reply-To: <aa7c3082-8346-fbfb-22cc-e846defd88b6@redhat.com>
20/09/2017 19:33, Kevin Traynor:
> On 09/08/2017 10:56 AM, Loftus, Ciara wrote:
> >> Hi,
> >>
> >> I have compiled and built ovs-dpdk using DPDK v17.08 and OVS v2.8.0. The
> >> NIC that I am using is Mellanox ConnectX-3 Pro, which is a dual port 10G
> >> NIC. The problem with this NIC is that it provides only one PCI address for
> >> both the 10G ports.
> >>
> >> So when I am trying to add the two DPDK ports to my br0 bridge
> >>
> >> # ovs-vsctl --no-wait add-port br0 dpdk0 -- set Interface dpdk0 type=dpdk
> >> options:dpdk-devargs=0002:01:00.0
> >>
> >> # ovs-vsctl --no-wait add-port br0 dpdk1 -- set Interface dpdk1 type=dpdk
> >> options:dpdk-devargs=0002:01:00.0
> >>
> >> The port dpdk1 is added successfully and able to transfer data, but adding
> >> dpdk0 to br0 fails:
[...]
> >> With OVS v2.6.1 I never had this problem as dpdk-devargs was not
> >> mandatory
> >> and just specifying port name was enough to add that port to bridge.
> >>
> >> Is there a way to add port both ports to bridge ?
> >
> > It seems the DPDK function rte_eth_dev_get_port_by_name() will always return the port ID of the first port on your NIC, when you specify the single PCI address and that's where the problem is. There doesn't seem to be a way currently to indicate to the calling application that in fact two (or more) port IDs are associated with the one PCI address.
We have two ports (with the same PCI address) so we should have
two different names.
Where the names passed to rte_eth_dev_get_port_by_name() come from?
It is the user parameter from options:dpdk-devargs=0002:01:00.0, right?
> > I am cc-ing DPDK users mailing list for hopefully some input. Are there any plans for the rte_eth_dev_get_port_by_name function to be compatible with NICs with multiple ports under the same PCI address?
We cannot return two different ports for the same name.
There are two issues here:
- the input should not be the PCI address
- the ethdev function should look at ethdev name, not rte_device one
The idea is that we have only one rte_device object and we instantiate
two rte_eth_dev ports.
An ethdev port can be identified with its id (a number) or its unique name.
Unfortunately, the user cannot guess the port id or the name set by the PMD.
> Hi Adrien/Nelio,
>
> Is this something you can answer? We're wondering how to handle this in
> OVS and whether a temporary or long term solution is needed.
I suggest to rely on ethdev name.
You will need to show to the user the mapping between the bus information
(PCI id here) and the device names.
Another alternative is to add a new function returning all ethdev ports
associated to a given rte_device resource.
So you would get two ports and you could pick one on the first "add-port",
and the other one for the second "add-port" command.
It means the user would be forced to add them in the right order if he
wants a reproducible result.
next prev parent reply other threads:[~2017-09-20 22:08 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <CACsJYqps0gM6NTUspVBcvjw1-VM4wj_UV2SbAhWGd-Y6WDBOzg@mail.gmail.com>
2017-09-08 9:56 ` Loftus, Ciara
2017-09-20 17:33 ` Kevin Traynor
2017-09-20 22:08 ` Thomas Monjalon [this message]
2017-09-21 8:04 ` Loftus, Ciara
2017-09-21 8:19 ` Thomas Monjalon
2017-09-21 8:28 ` Loftus, Ciara
2017-10-05 16:19 ` devendra rawat
2017-10-06 14:00 ` Loftus, Ciara
2017-10-10 12:56 ` devendra rawat
2017-11-07 9:08 ` Yuanhan Liu
2017-09-21 9:17 ` Adrien Mazarguil
2017-09-21 9:45 ` Adrien Mazarguil
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1990042.kGnXgAYS5O@xps \
--to=thomas@monjalon.net \
--cc=adrien.mazarguil@6wind.com \
--cc=ciara.loftus@intel.com \
--cc=devendra.rawat.singh@gmail.com \
--cc=ktraynor@redhat.com \
--cc=nelio.laranjeiro@6wind.com \
--cc=olgas@mellanox.com \
--cc=ovs-dev@openvswitch.org \
--cc=users@dpdk.org \
--cc=yliu@fridaylinux.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).