From: Petr Machata <petrm@nvidia.com>
To: Steven Rostedt <rostedt@goodmis.org>
Cc: Petr Machata <petrm@nvidia.com>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>,
"Paolo Abeni" <pabeni@redhat.com>,
Roopa Prabhu <roopa@nvidia.com>,
"Nikolay Aleksandrov" <razor@blackwall.org>,
<netdev@vger.kernel.org>, <bridge@lists.linux-foundation.org>,
Ido Schimmel <idosch@nvidia.com>,
<linux-trace-kernel@vger.kernel.org>
Subject: Re: [PATCH net-next 06/16] net: bridge: Add a tracepoint for MDB overflows
Date: Fri, 27 Jan 2023 15:29:19 +0100 [thread overview]
Message-ID: <87h6wc3um7.fsf@nvidia.com> (raw)
In-Reply-To: <20230126125344.1b7b34e2@gandalf.local.home>
Steven Rostedt <rostedt@goodmis.org> writes:
>> diff --git a/include/trace/events/bridge.h b/include/trace/events/bridge.h
>> index 6b200059c2c5..00d5e2dcb3ad 100644
>> --- a/include/trace/events/bridge.h
>> +++ b/include/trace/events/bridge.h
>> @@ -122,6 +122,73 @@ TRACE_EVENT(br_fdb_update,
>> __entry->flags)
>> );
>>
>> +TRACE_EVENT(br_mdb_full,
>> +
>> + TP_PROTO(const struct net_device *dev,
>> + const struct br_ip *group),
>> +
>> + TP_ARGS(dev, group),
>> +
>> + TP_STRUCT__entry(
>> + __string(dev, dev->name)
>> + __field(int, af)
>> + __field(u16, vid)
>> + __array(__u8, src4, 4)
>> + __array(__u8, src6, 16)
>> + __array(__u8, grp4, 4)
>> + __array(__u8, grp6, 16)
>> + __array(__u8, grpmac, ETH_ALEN) /* For af == 0. */
>
> Instead of wasting ring buffer space, why not just have:
>
> __array(__u8, src, 16)
> __array(__u8, grp, 16)
>
>> + ),
>> +
>> + TP_fast_assign(
>> + __assign_str(dev, dev->name);
>> + __entry->vid = group->vid;
>> +
>> + if (!group->proto) {
>> + __entry->af = 0;
>> +
>> + memset(__entry->src4, 0, sizeof(__entry->src4));
>> + memset(__entry->src6, 0, sizeof(__entry->src6));
>> + memset(__entry->grp4, 0, sizeof(__entry->grp4));
>> + memset(__entry->grp6, 0, sizeof(__entry->grp6));
>> + memcpy(__entry->grpmac, group->dst.mac_addr, ETH_ALEN);
>> + } else if (group->proto == htons(ETH_P_IP)) {
>> + __be32 *p32;
>> +
>> + __entry->af = AF_INET;
>> +
>> + p32 = (__be32 *) __entry->src4;
>> + *p32 = group->src.ip4;
>> +
>> + p32 = (__be32 *) __entry->grp4;
>> + *p32 = group->dst.ip4;
>
> struct in6_addr *in6;
>
> in6 = (struct in6_addr *)__entry->src;
> ipv6_addr_set_v4mapped(group->src.ip4, in6);
>
> in6 = (struct in6_addr *)__entry->grp;
> ipv6_addr_set_v4mapped(group->grp.ip4, in6);
>
>> +
>> + memset(__entry->src6, 0, sizeof(__entry->src6));
>> + memset(__entry->grp6, 0, sizeof(__entry->grp6));
>> + memset(__entry->grpmac, 0, ETH_ALEN);
>> +#if IS_ENABLED(CONFIG_IPV6)
>> + } else {
>> + struct in6_addr *in6;
>> +
>> + __entry->af = AF_INET6;
>> +
>> + in6 = (struct in6_addr *)__entry->src6;
>> + *in6 = group->src.ip6;
>> +
>> + in6 = (struct in6_addr *)__entry->grp6;
>> + *in6 = group->dst.ip6;
>> +
>> + memset(__entry->src4, 0, sizeof(__entry->src4));
>> + memset(__entry->grp4, 0, sizeof(__entry->grp4));
>> + memset(__entry->grpmac, 0, ETH_ALEN);
>> +#endif
>> + }
>> + ),
>> +
>> + TP_printk("dev %s af %u src %pI4/%pI6c grp %pI4/%pI6c/%pM vid %u",
>> + __get_str(dev), __entry->af, __entry->src4, __entry->src6,
>> + __entry->grp4, __entry->grp6, __entry->grpmac, __entry->vid)
>
> And just have:
>
> TP_printk("dev %s af %u src %pI6c grp %pI6c/%pM vid %u",
> __get_str(dev), __entry->af, __entry->src, __entry->grp,
> __entry->grpmac, __entry->vid)
>
> As the %pI6c should detect that it's a ipv4 address and show that.
So the reason I split the fields was that %pI4, %pI6c, %pM do not seem
to work with buffers of wrong size.
But I can consolidate 4/6 by changing the address to IPv6 like you
propose. I'll do this for v2. Thanks!
next prev parent reply other threads:[~2023-01-27 14:44 UTC|newest]
Thread overview: 45+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-01-26 17:01 [PATCH net-next 00/16] bridge: Limit number of MDB entries per port, port-vlan Petr Machata
2023-01-26 17:01 ` [PATCH net-next 01/16] net: bridge: Set strict_start_type at two policies Petr Machata
2023-01-26 19:18 ` Stephen Hemminger
2023-01-26 20:27 ` Nikolay Aleksandrov
2023-01-29 9:09 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 02/16] net: bridge: Add extack to br_multicast_new_port_group() Petr Machata
2023-01-29 9:09 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 03/16] net: bridge: Move extack-setting " Petr Machata
2023-01-29 9:09 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 04/16] net: bridge: Add br_multicast_del_port_group() Petr Machata
2023-01-29 9:11 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 05/16] net: bridge: Change a cleanup in br_multicast_new_port_group() to goto Petr Machata
2023-01-29 9:11 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 06/16] net: bridge: Add a tracepoint for MDB overflows Petr Machata
2023-01-26 17:53 ` Steven Rostedt
2023-01-27 14:29 ` Petr Machata [this message]
2023-01-30 15:50 ` Petr Machata
2023-01-30 23:23 ` Steven Rostedt
2023-01-26 17:01 ` [PATCH net-next 07/16] net: bridge: Maintain number of MDB entries in net_bridge_mcast_port Petr Machata
2023-01-29 9:40 ` Nikolay Aleksandrov
2023-01-29 16:55 ` Nikolay Aleksandrov
2023-01-30 8:08 ` Ido Schimmel
2023-01-30 8:56 ` Nikolay Aleksandrov
2023-01-30 15:02 ` Petr Machata
2023-01-26 17:01 ` [PATCH net-next 08/16] net: bridge: Add netlink knobs for number / maximum MDB entries Petr Machata
2023-01-29 10:07 ` Nikolay Aleksandrov
2023-01-29 14:58 ` Ido Schimmel
2023-01-30 11:07 ` Petr Machata
2023-01-26 17:01 ` [PATCH net-next 09/16] selftests: forwarding: Move IGMP- and MLD-related functions to lib Petr Machata
2023-01-29 10:08 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 10/16] selftests: forwarding: bridge_mdb: Fix a typo Petr Machata
2023-01-29 10:09 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 11/16] selftests: forwarding: lib: Add helpers for IP address handling Petr Machata
2023-01-29 10:09 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 12/16] selftests: forwarding: lib: Add helpers for checksum handling Petr Machata
2023-01-29 10:10 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 13/16] selftests: forwarding: lib: Parameterize IGMPv3/MLDv2 generation Petr Machata
2023-01-29 10:10 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 14/16] selftests: forwarding: lib: Allow list of IPs for IGMPv3/MLDv2 Petr Machata
2023-01-29 10:11 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 15/16] selftests: forwarding: lib: Add helpers to build IGMP/MLD leave packets Petr Machata
2023-01-29 10:11 ` Nikolay Aleksandrov
2023-01-26 17:01 ` [PATCH net-next 16/16] selftests: forwarding: bridge_mdb_max: Add a new selftest Petr Machata
2023-01-29 10:12 ` Nikolay Aleksandrov
2023-01-26 20:28 ` [PATCH net-next 00/16] bridge: Limit number of MDB entries per port, port-vlan Nikolay Aleksandrov
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=87h6wc3um7.fsf@nvidia.com \
--to=petrm@nvidia.com \
--cc=bridge@lists.linux-foundation.org \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=idosch@nvidia.com \
--cc=kuba@kernel.org \
--cc=linux-trace-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=razor@blackwall.org \
--cc=roopa@nvidia.com \
--cc=rostedt@goodmis.org \
/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).