From: Alexei Starovoitov <alexei.starovoitov@gmail.com>
To: Sebastiano Miano <sebastiano.miano@polito.it>
Cc: netdev@vger.kernel.org, ast@kernel.org, daniel@iogearbox.net,
mingo@redhat.com, rostedt@goodmis.org, brouer@redhat.com,
fulvio.risso@polito.it, "David S. Miller" <davem@davemloft.net>
Subject: Re: [bpf-next PATCH 3/3] bpf: add sample program to trace map events
Date: Thu, 19 Apr 2018 17:27:37 -0700 [thread overview]
Message-ID: <20180420002735.ytmnhzs73rwkwewm@ast-mbp> (raw)
In-Reply-To: <152406545918.3465.14253635905960610284.stgit@localhost.localdomain>
On Wed, Apr 18, 2018 at 05:30:59PM +0200, Sebastiano Miano wrote:
> This patch adds a sample program, called trace_map_events,
> that shows how to capture map events and filter them based on
> the map id.
...
> +struct bpf_map_keyval_ctx {
> + u64 pad; // First 8 bytes are not accessible by bpf code
> + u32 type; // offset:8; size:4; signed:0;
> + u32 key_len; // offset:12; size:4; signed:0;
> + u32 key; // offset:16; size:4; signed:0;
> + bool key_trunc; // offset:20; size:1; signed:0;
> + u32 val_len; // offset:24; size:4; signed:0;
> + u32 val; // offset:28; size:4; signed:0;
> + bool val_trunc; // offset:32; size:1; signed:0;
> + int ufd; // offset:36; size:4; signed:1;
> + u32 id; // offset:40; size:4; signed:0;
> +};
> +
> +SEC("tracepoint/bpf/bpf_map_lookup_elem")
> +int trace_bpf_map_lookup_elem(struct bpf_map_keyval_ctx *ctx)
> +{
> + struct map_event_data data;
> + int cpu = bpf_get_smp_processor_id();
> + bool *filter;
> + u32 key = 0, map_id = ctx->id;
> +
> + filter = bpf_map_lookup_elem(&filter_events, &key);
> + if (!filter)
> + return 1;
> +
> + if (!*filter)
> + goto send_event;
> +
> + /*
> + * If the map_id is not in the list of filtered
> + * ids we immediately return
> + */
> + if (!bpf_map_lookup_elem(&filtered_ids, &map_id))
> + return 0;
> +
> +send_event:
> + data.map_id = map_id;
> + data.evnt_type = MAP_LOOKUP;
> + data.map_type = ctx->type;
> +
> + bpf_perf_event_output(ctx, &map_event_trace, cpu, &data, sizeof(data));
> + return 0;
> +}
looks like the purpose of the series is to create map notify mechanism
so some external user space daemon can snoop all bpf map operations
that all other processes and bpf programs are doing.
I think it would be way better to create a proper mechanism for that
with permissions.
tracepoints in the bpf core were introduced as introspection mechanism
for debugging. Right now we have better ways to do introspection
with ids, queries, etc that bpftool is using, so original purpose of
those tracepoints is gone and they actually rot.
Let's not repurpose them into this map notify logic.
I don't want tracepoints in the bpf core to become a stable interface
it will stiffen the development.
next prev parent reply other threads:[~2018-04-20 0:27 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-18 15:30 [bpf-next PATCH 0/3] Add ID to bpf_map/prog tracepoints Sebastiano Miano
2018-04-18 15:30 ` [bpf-next PATCH 1/3] bpf: add id to map tracepoint Sebastiano Miano
2018-04-19 9:08 ` Jesper Dangaard Brouer
2018-04-18 15:30 ` [bpf-next PATCH 2/3] bpf: add id to prog tracepoint Sebastiano Miano
2018-04-19 9:10 ` Jesper Dangaard Brouer
2018-04-18 15:30 ` [bpf-next PATCH 3/3] bpf: add sample program to trace map events Sebastiano Miano
2018-04-19 9:20 ` Jesper Dangaard Brouer
2018-04-20 0:27 ` Alexei Starovoitov [this message]
2018-04-20 9:47 ` Jesper Dangaard Brouer
2018-04-23 14:08 ` Sebastiano Miano
2018-04-23 20:08 ` Alexei Starovoitov
2018-04-23 20:22 ` Jesper Dangaard Brouer
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=20180420002735.ytmnhzs73rwkwewm@ast-mbp \
--to=alexei.starovoitov@gmail.com \
--cc=ast@kernel.org \
--cc=brouer@redhat.com \
--cc=daniel@iogearbox.net \
--cc=davem@davemloft.net \
--cc=fulvio.risso@polito.it \
--cc=mingo@redhat.com \
--cc=netdev@vger.kernel.org \
--cc=rostedt@goodmis.org \
--cc=sebastiano.miano@polito.it \
/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