bpf.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Daniel Borkmann <daniel@iogearbox.net>
To: Andrey Ignatov <rdna@fb.com>, bpf@vger.kernel.org
Cc: ast@kernel.org, osandov@fb.com, corbet@lwn.net, toke@redhat.com,
	brouer@redhat.com, kernel-team@fb.com
Subject: Re: [PATCH v2 bpf-next] bpf: Document bpf_inspect drgn tool
Date: Tue, 17 Mar 2020 20:57:21 +0100	[thread overview]
Message-ID: <9b7e4709-80c2-7509-6cfd-1a46eef5c5d6@iogearbox.net> (raw)
In-Reply-To: <20200314003916.2753148-1-rdna@fb.com>

Hey Andrey,

On 3/14/20 1:39 AM, Andrey Ignatov wrote:
> It's a follow-up for discussion in [1].
> 
> drgn tool bpf_inspect.py was merged to drgn repo in [2]. Document it in
> kernel tree to make BPF developers aware that the tool exists and can
> help with getting BPF state unavailable via UAPI.
> 
> For now it's just one tool but the doc is written in a way that allows
> to cover more tools in the future if needed.
> 
> Please refer to the doc itself for more details.
> 
> The patch was tested by `make htmldocs` and sanity-checking that
> resulting html looks good.
> 
> [1]
> https://lore.kernel.org/bpf/20200228201514.GB51456@rdna-mbp/T/#mefed65e8a98116bd5d07d09a570a3eac46724951
> [2] https://github.com/osandov/drgn/pull/49
> 
> Signed-off-by: Andrey Ignatov <rdna@fb.com>
> ---
>   Documentation/bpf/drgn.rst  | 39 +++++++++++++++++++++++++++++++++++++
>   Documentation/bpf/index.rst |  5 +++--
>   2 files changed, 42 insertions(+), 2 deletions(-)
>   create mode 100644 Documentation/bpf/drgn.rst
> 
> diff --git a/Documentation/bpf/drgn.rst b/Documentation/bpf/drgn.rst
> new file mode 100644
> index 000000000000..2ff9ef3e0b58
> --- /dev/null
> +++ b/Documentation/bpf/drgn.rst
> @@ -0,0 +1,39 @@
> +.. SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause)
> +
> +==============
> +BPF drgn tools
> +==============
> +
> +drgn scripts is a convenient and easy to use mechanism to retrieve arbitrary
> +kernel data structures. drgn is not relying on kernel UAPI to read the data.
> +Instead it's reading directly from ``/proc/kcore`` or vmcore and pretty prints
> +the data based on DWARF debug information from vmlinux.
> +
> +This document describes BPF related drgn tools.
> +
> +See `drgn/tools`_ for all tools available at the moment and `drgn/doc`_ for
> +more details on drgn itself.
> +
> +bpf_inspect.py
> +**************
> +
> +`bpf_inspect.py`_ is a tool intended to inspect BPF programs and maps. It can
> +iterate over all programs and maps in the system and print basic information
> +about these objects, including id, type and name.
> +
> +The main use-case `bpf_inspect.py`_ covers is to show BPF programs of types
> +``BPF_PROG_TYPE_EXT`` and ``BPF_PROG_TYPE_TRACING`` attached to other BPF
> +programs via ``freplace``/``fentry``/``fexit`` mechanisms, since there is no
> +user-space API to get this information.
> +
> +Any developer can edit the tool and get any piece of ``struct bpf_prog`` or
> +``struct bpf_map`` they're interested in, e.g. the whole ``struct
> +bpf_prog_aux``.
> +
> +See ``--help`` for more details.

I do like bcc's explicit usage examples/recipes so one can immediately grok
whether it fits to a given use-case (e.g. [0]). Given this is targeted for
developers perhaps it makes sense to add an example usage as you have described
in [1] to the doc as well here?

Maybe last two paragraphs are not that useful. Could we structure each tool
we're going to add here with two sub-headers "Description", "Getting Started"
where the former has the first two paragraphs and then the latter has a usage
example that shows e.g. [1] or as you write in your last paragraph a modification
to dump the whole ``struct bpf_prog_aux``, for example?

Thanks,
Daniel

   [0] https://github.com/iovisor/bcc/blob/master/tools/bpflist_example.txt
   [1] https://github.com/osandov/drgn/pull/49

> +.. Links
> +.. _drgn/doc: https://drgn.readthedocs.io/en/latest/
> +.. _drgn/tools: https://github.com/osandov/drgn/tree/master/tools
> +.. _bpf_inspect.py:
> +   https://github.com/osandov/drgn/blob/master/tools/bpf_inspect.py
> diff --git a/Documentation/bpf/index.rst b/Documentation/bpf/index.rst
> index 4f5410b61441..7be43c5f2dcf 100644
> --- a/Documentation/bpf/index.rst
> +++ b/Documentation/bpf/index.rst
> @@ -47,12 +47,13 @@ Program types
>      prog_flow_dissector
>   
>   
> -Testing BPF
> -===========
> +Testing and debugging BPF
> +=========================
>   
>   .. toctree::
>      :maxdepth: 1
>   
> +   drgn
>      s390
>   
>   
> 


  reply	other threads:[~2020-03-17 19:57 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-03-14  0:39 [PATCH v2 bpf-next] bpf: Document bpf_inspect drgn tool Andrey Ignatov
2020-03-17 19:57 ` Daniel Borkmann [this message]
2020-03-24 18:50   ` Andrey Ignatov

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=9b7e4709-80c2-7509-6cfd-1a46eef5c5d6@iogearbox.net \
    --to=daniel@iogearbox.net \
    --cc=ast@kernel.org \
    --cc=bpf@vger.kernel.org \
    --cc=brouer@redhat.com \
    --cc=corbet@lwn.net \
    --cc=kernel-team@fb.com \
    --cc=osandov@fb.com \
    --cc=rdna@fb.com \
    --cc=toke@redhat.com \
    /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).