Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 22 Aug 2004 14:03:18 +0000
From:      Bosko Milekic <bmilekic@FreeBSD.org>
To:        Paolo Pisati <flag@oltrelinux.com>, FreeBSD_Hackers <freebsd-hackers@freebsd.org>
Subject:   Re: Playing with mbuf in userland
Message-ID:  <20040822140318.GA45977@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

Paolo Pisati wrote:
>Hi,
>
>i'm developing a little app that manipulates mbuf.
>Right now i'm still working on it as userland app but i
>would like to test it with some real mbufs straight
>from the stack.
>Do you know how i can get some of these structs in
>an easy way?
>I mean, is it possible to copy some of these struct from
>stack to userland?
>Or should i fake it in userland?

  One way to do this would be to instrument a for-superuser-only
  socket option that would copy out all of the data, including the
  metadata and mbuf headers, out to userland, while taking care to
  modify references within the mbufs to userland locations {*}.  To do
  this, in turn, you would need to obtain the userland target addresses
  of all mbufs and clusters you're copying out beforehand, and overwrite
  all mbufs' m_next, m_nextpkt, m_data, and in some cases, m_ext.ext_buf
  references before doing the copyout in-kernel.  This can be a pretty
  involved copy and would require careful implementation.

{*} The data is the socket buffer is kept as an mbuf chain so this is
    possible.

  Another option to look into would be to implement a sysctl(8)-exported
  handler that iterates over the mbuf chain and prints out the mbuf chains
  in something like XML, which your userland application can then more or less
  easily parse, and reproduce the chain ("fake it up") in userland.  This
  solution is rather attractive because you can do all sorts of things
  with the intermediate-parsing-language right from the kernel, as well
  as from userland (at the parsing stages).  To see an example of a sysctl(8)
  handler, refer to src/sys/vm/uma_core.c (the bottom) in FreeBSD 5.x.

  In any case, I would be very interested in seeing what you come up with,
  as this could be a very useful diagnostic tool.

-Bosko
--
Bosko Milekic <bmilekic@technokratis.com> <bmilekic@FreeBSD.org>
"For the wicked / Carry us away / Captivity require from us a song /
How can we sing king alpha's song in a strange land?" --Bob Marley



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20040822140318.GA45977>