From: Thomas Monjalon <thomas.monjalon@6wind.com>
To: dev@dpdk.org, David Verbeiren <david.verbeiren@gmail.com>
Subject: Re: [dpdk-dev] [RFC PATCH] ivshmem ring aliases
Date: Fri, 29 Apr 2016 17:52:26 +0200 [thread overview]
Message-ID: <487342714.Ci5BV3hPHa@xps13> (raw)
In-Reply-To: <1456310006-30296-1-git-send-email-david.verbeiren@gmail.com>
2016-02-24 11:33, David Verbeiren:
> The goal of this parch is to allow VMs to use standard ring names regardless of the names
> given to the rings by host environment. It applies to configurations using ivshmem.
>
> With shared memory rings, all VMs share a single namespace for the rings. However, a VM
> will typically expect to find its rings with a pre-determined name (e.g. p1_rx, p1_tx)
> regardless of how it's deployed, inserted in a service chain, or of which other VMs are
> deployed alongside it. Hence, it is desirable to introduce a level of indirection where
> the host can set a mapping from the actual ring names (e.g. dpdkr0_rx|tx with OVS) and
> the names that will be visible in the VM. This patch provides a simple implementation
> of such a mapping scheme.
>
> Since the mapping must be VM specific, the aliases are inserted into the IVSHMEM metadata
> area by the host and the guest side uses thoses aliases when doing rte_ring_lookup().
>
> A new function, rte_ivshmem_add_ring_alias() is provided in librte_ivshmem to populate
> alias entries in the host environment when creating the per-VM metadata.
I'm still not sure this library is a good idea at all.
This patch continue the tradition of librte_ivshmem by adding more
#ifdef in the code (in rte_ring here).
We could also comment the compile time values or the checkpatch warnings.
But more importantly, what is the use case of this library and why is
it important to have such support in DPDK?
> --- a/lib/librte_ring/rte_ring.c
> +++ b/lib/librte_ring/rte_ring.c
> @@ -352,6 +352,12 @@ rte_ring_lookup(const char *name)
> struct rte_ring *r = NULL;
> struct rte_ring_list *ring_list;
>
> +#ifdef RTE_LIBRTE_IVSHMEM
> + const char * target_name = rte_eal_ivshmem_alias_get(name);
> + if (target_name)
> + name = target_name;
> +#endif
This #ifdef should not exist.
prev parent reply other threads:[~2016-04-29 15:52 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-02-24 10:33 David Verbeiren
2016-04-25 13:21 ` Burakov, Anatoly
2016-04-29 15:52 ` Thomas Monjalon [this message]
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=487342714.Ci5BV3hPHa@xps13 \
--to=thomas.monjalon@6wind.com \
--cc=david.verbeiren@gmail.com \
--cc=dev@dpdk.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).