Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 11 Nov 2014 15:00:37 -0800
From:      Luigi Rizzo <rizzo@iet.unipi.it>
To:        Franco Fichtner <franco@lastsummer.de>
Cc:        Adrian Chadd <adrian@freebsd.org>, freebsd-current <freebsd-current@freebsd.org>
Subject:   Re: netmap: extension to store user data per packet/slot?
Message-ID:  <CA%2BhQ2%2BjQMg62_SqDKcWgQUugc%2BOPvWU8ZX0fHVcC3jJDP-%2B-dg@mail.gmail.com>
In-Reply-To: <C8510DF9-8F18-4E8F-AE6B-365EAE39CA33@lastsummer.de>
References:  <560E07EA-2506-487E-88DD-E2B9F7ED9792@lastsummer.de> <CAJ-Vmo=1XxdXNOBYR=_iXP-wEgNzYcBuy43TAE32O_5TnZ%2BT-w@mail.gmail.com> <E4CF1489-B259-4ECE-9FFA-FD3850AE1DEC@lastsummer.de> <CAJ-VmomLyE5to3hYDmhW%2B32j7UWo0fATPBxOTCiOfpCPytNcTQ@mail.gmail.com> <C8510DF9-8F18-4E8F-AE6B-365EAE39CA33@lastsummer.de>

next in thread | previous in thread | raw e-mail | index | archive | help
Franco,
apparently you want some user-defined metadata to move
along with the packet, but i do not think it is
reasonable to put it in the slots.
If we do that, what about timestamps, flow IDs,
interface and queue index and all the rest of the things that
we normally find in an mbuf/skbuf ? This is not
going to scale.

Also consider that at some point you may use a different
arrangement (with packets passed along VALE switches
or physical interfaces etc.) i believe the most
reasonable place to put the extra info is at the end
of the packet and possibly bump the length in the slot
so you are safe in case the packet is copied.

There is no timestamp appended to the packet at the moment,
it was a feature i thought somebody may want to have,
but between the relative scarcity of hardware that provides
per-packet timestamps, and the questionable usefulness
of the same, i doubt it will be available.

cheers
luigi


On Tue, Nov 11, 2014 at 2:01 PM, Franco Fichtner <franco@lastsummer.de>
wrote:

>
> On 11 Nov 2014, at 22:48, Adrian Chadd <adrian@freebsd.org> wrote:
>
> > Ah, I see. You're missing some unique identifier for each netmap
> > buffer. I thought there was one already. Silly me.
>
> Exactly, and, no, thank you for making clear what is needed.  :)
>
> A little more on this: I think struct netmap_slot is convenient
> due to the fact that in zero-copy one wouldn't want to mess with
> the actual buffer for speed and userland code already touches slot
> internals for each ring transition so there is no performance
> degradation.
>
> The key benefit is that if userland can use this storage freely
> netmap(4) doesn't get in the way of building complex setups that
> require decoupled logic and each ring "hop" may alter the state
> as required.
>
>
> Cheers,
> Franco
>



-- 
-----------------------------------------+-------------------------------
 Prof. Luigi RIZZO, rizzo@iet.unipi.it  . Dip. di Ing. dell'Informazione
 http://www.iet.unipi.it/~luigi/        . Universita` di Pisa
 TEL      +39-050-2211611               . via Diotisalvi 2
 Mobile   +39-338-6809875               . 56122 PISA (Italy)
-----------------------------------------+-------------------------------



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CA%2BhQ2%2BjQMg62_SqDKcWgQUugc%2BOPvWU8ZX0fHVcC3jJDP-%2B-dg>