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>