From: Simon Horman <horms@kernel.org>
To: Lorenzo Bianconi <lorenzo@kernel.org>
Cc: Andrew Lunn <andrew+netdev@lunn.ch>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
Felix Fietkau <nbd@nbd.name>, Sean Wang <sean.wang@mediatek.com>,
Matthias Brugger <matthias.bgg@gmail.com>,
AngeloGioacchino Del Regno
<angelogioacchino.delregno@collabora.com>,
Philipp Zabel <p.zabel@pengutronix.de>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
"Chester A. Unal" <chester.a.unal@arinc9.com>,
Daniel Golle <daniel@makrotopia.org>,
DENG Qingfang <dqfext@gmail.com>, Andrew Lunn <andrew@lunn.ch>,
Vladimir Oltean <olteanv@gmail.com>,
netdev@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
linux-mediatek@lists.infradead.org, devicetree@vger.kernel.org,
upstream@airoha.com
Subject: Re: [PATCH net-next v4 16/16] net: airoha: Introduce PPE debugfs support
Date: Mon, 17 Feb 2025 18:44:16 +0000 [thread overview]
Message-ID: <20250217184416.GQ1615191@kernel.org> (raw)
In-Reply-To: <20250213-airoha-en7581-flowtable-offload-v4-16-b69ca16d74db@kernel.org>
On Thu, Feb 13, 2025 at 04:34:35PM +0100, Lorenzo Bianconi wrote:
> Similar to PPE support for Mediatek devices, introduce PPE debugfs
> in order to dump binded and unbinded flows.
>
> Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
...
> diff --git a/drivers/net/ethernet/airoha/airoha_ppe_debugfs.c b/drivers/net/ethernet/airoha/airoha_ppe_debugfs.c
...
> +static int airoha_ppe_debugfs_foe_show(struct seq_file *m, void *private,
> + bool bind)
> +{
> + static const char *const ppe_type_str[] = {
> + [PPE_PKT_TYPE_IPV4_HNAPT] = "IPv4 5T",
> + [PPE_PKT_TYPE_IPV4_ROUTE] = "IPv4 3T",
> + [PPE_PKT_TYPE_BRIDGE] = "L2B",
> + [PPE_PKT_TYPE_IPV4_DSLITE] = "DS-LITE",
> + [PPE_PKT_TYPE_IPV6_ROUTE_3T] = "IPv6 3T",
> + [PPE_PKT_TYPE_IPV6_ROUTE_5T] = "IPv6 5T",
> + [PPE_PKT_TYPE_IPV6_6RD] = "6RD",
> + };
> + static const char *const ppe_state_str[] = {
> + [AIROHA_FOE_STATE_INVALID] = "INV",
> + [AIROHA_FOE_STATE_UNBIND] = "UNB",
> + [AIROHA_FOE_STATE_BIND] = "BND",
> + [AIROHA_FOE_STATE_FIN] = "FIN",
> + };
> + struct airoha_ppe *ppe = m->private;
> + int i;
> +
> + for (i = 0; i < PPE_NUM_ENTRIES; i++) {
> + const char *state_str, *type_str = "UNKNOWN";
> + u16 *src_port = NULL, *dest_port = NULL;
> + struct airoha_foe_mac_info_common *l2;
> + unsigned char h_source[ETH_ALEN] = {};
> + unsigned char h_dest[ETH_ALEN];
> + struct airoha_foe_entry *hwe;
> + u32 type, state, ib2, data;
> + void *src_addr, *dest_addr;
> + bool ipv6 = false;
> +
> + hwe = airoha_ppe_foe_get_entry(ppe, i);
> + if (!hwe)
> + continue;
> +
> + state = FIELD_GET(AIROHA_FOE_IB1_STATE, hwe->ib1);
> + if (!state)
> + continue;
> +
> + if (bind && state != AIROHA_FOE_STATE_BIND)
> + continue;
> +
> + state_str = ppe_state_str[state % ARRAY_SIZE(ppe_state_str)];
> + type = FIELD_GET(AIROHA_FOE_IB1_PACKET_TYPE, hwe->ib1);
> + if (type < ARRAY_SIZE(ppe_type_str) && ppe_type_str[type])
> + type_str = ppe_type_str[type];
> +
> + seq_printf(m, "%05x %s %7s", i, state_str, type_str);
> +
> + switch (type) {
> + case PPE_PKT_TYPE_IPV4_HNAPT:
> + case PPE_PKT_TYPE_IPV4_DSLITE:
> + src_port = &hwe->ipv4.orig_tuple.src_port;
> + dest_port = &hwe->ipv4.orig_tuple.dest_port;
> + fallthrough;
> + case PPE_PKT_TYPE_IPV4_ROUTE:
> + src_addr = &hwe->ipv4.orig_tuple.src_ip;
> + dest_addr = &hwe->ipv4.orig_tuple.dest_ip;
> + break;
> + case PPE_PKT_TYPE_IPV6_ROUTE_5T:
> + src_port = &hwe->ipv6.src_port;
> + dest_port = &hwe->ipv6.dest_port;
> + fallthrough;
> + case PPE_PKT_TYPE_IPV6_ROUTE_3T:
> + case PPE_PKT_TYPE_IPV6_6RD:
> + src_addr = &hwe->ipv6.src_ip;
> + dest_addr = &hwe->ipv6.dest_ip;
> + ipv6 = true;
> + break;
> + }
Hi Lorenzo,
Perhaps it can't happen, but if type is not one of the cases handled
by the switch statement above then src_addr and dest_addr will
be used while uninitialised by the call to airoha_debugfs_ppe_print_tuple()
below.
Flagged by Smatch.
> +
> + seq_puts(m, " orig=");
> + airoha_debugfs_ppe_print_tuple(m, src_addr, dest_addr,
> + src_port, dest_port, ipv6);
> +
> + switch (type) {
> + case PPE_PKT_TYPE_IPV4_HNAPT:
> + case PPE_PKT_TYPE_IPV4_DSLITE:
> + src_port = &hwe->ipv4.new_tuple.src_port;
> + dest_port = &hwe->ipv4.new_tuple.dest_port;
> + fallthrough;
> + case PPE_PKT_TYPE_IPV4_ROUTE:
> + src_addr = &hwe->ipv4.new_tuple.src_ip;
> + dest_addr = &hwe->ipv4.new_tuple.dest_ip;
> + seq_puts(m, " new=");
> + airoha_debugfs_ppe_print_tuple(m, src_addr, dest_addr,
> + src_port, dest_port,
> + ipv6);
> + break;
> + }
> +
> + if (type >= PPE_PKT_TYPE_IPV6_ROUTE_3T) {
> + data = hwe->ipv6.data;
> + ib2 = hwe->ipv6.ib2;
> + l2 = &hwe->ipv6.l2;
> + } else {
> + data = hwe->ipv4.data;
> + ib2 = hwe->ipv4.ib2;
> + l2 = &hwe->ipv4.l2.common;
> + *((__be16 *)&h_source[4]) =
> + cpu_to_be16(hwe->ipv4.l2.src_mac_lo);
> + }
> +
> + *((__be32 *)h_dest) = cpu_to_be32(l2->dest_mac_hi);
> + *((__be16 *)&h_dest[4]) = cpu_to_be16(l2->dest_mac_lo);
> + *((__be32 *)h_source) = cpu_to_be32(l2->src_mac_hi);
> +
> + seq_printf(m, " eth=%pM->%pM etype=%04x data=%08x"
> + " vlan=%d,%d ib1=%08x ib2=%08x\n",
> + h_source, h_dest, l2->etype, data,
> + l2->vlan1, l2->vlan2, hwe->ib1, ib2);
> + }
> +
> + return 0;
> +}
...
next prev parent reply other threads:[~2025-02-17 18:46 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-13 15:34 [PATCH net-next v4 00/16] Introduce flowtable hw offloading in airoha_eth driver Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 01/16] net: airoha: Fix TSO support for header cloned skbs Lorenzo Bianconi
2025-02-14 21:35 ` Jakub Kicinski
2025-02-13 15:34 ` [PATCH net-next v4 02/16] net: airoha: Move airoha_eth driver in a dedicated folder Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 03/16] net: airoha: Move definitions in airoha_eth.h Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 04/16] net: airoha: Move reg/write utility routines " Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 05/16] net: airoha: Move register definitions in airoha_regs.h Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 06/16] net: airoha: Move DSA tag in DMA descriptor Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 07/16] net: dsa: mt7530: Enable Rx sptag for EN7581 SoC Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 08/16] net: airoha: Enable support for multiple net_devices Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 09/16] net: airoha: Move REG_GDM_FWD_CFG() initialization in airoha_dev_init() Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 10/16] net: airoha: Rename airoha_set_gdm_port_fwd_cfg() in airoha_set_vip_for_gdm_port() Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 11/16] dt-bindings: net: airoha: Add the NPU node for EN7581 SoC Lorenzo Bianconi
2025-02-14 8:03 ` Krzysztof Kozlowski
2025-02-13 15:34 ` [PATCH net-next v4 12/16] dt-bindings: net: airoha: Add airoha,npu phandle property Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 13/16] net: airoha: Introduce Airoha NPU support Lorenzo Bianconi
2025-02-17 18:38 ` Simon Horman
2025-02-17 19:23 ` Lorenzo Bianconi
2025-02-18 13:27 ` Simon Horman
2025-02-18 13:45 ` Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 14/16] net: airoha: Introduce flowtable offload support Lorenzo Bianconi
2025-02-14 14:06 ` kernel test robot
2025-02-13 15:34 ` [PATCH net-next v4 15/16] net: airoha: Add loopback support for GDM2 Lorenzo Bianconi
2025-02-13 15:34 ` [PATCH net-next v4 16/16] net: airoha: Introduce PPE debugfs support Lorenzo Bianconi
2025-02-17 18:44 ` Simon Horman [this message]
2025-02-17 21:43 ` Lorenzo Bianconi
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=20250217184416.GQ1615191@kernel.org \
--to=horms@kernel.org \
--cc=andrew+netdev@lunn.ch \
--cc=andrew@lunn.ch \
--cc=angelogioacchino.delregno@collabora.com \
--cc=chester.a.unal@arinc9.com \
--cc=conor+dt@kernel.org \
--cc=daniel@makrotopia.org \
--cc=davem@davemloft.net \
--cc=devicetree@vger.kernel.org \
--cc=dqfext@gmail.com \
--cc=edumazet@google.com \
--cc=krzk+dt@kernel.org \
--cc=kuba@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-mediatek@lists.infradead.org \
--cc=lorenzo@kernel.org \
--cc=matthias.bgg@gmail.com \
--cc=nbd@nbd.name \
--cc=netdev@vger.kernel.org \
--cc=olteanv@gmail.com \
--cc=p.zabel@pengutronix.de \
--cc=pabeni@redhat.com \
--cc=robh@kernel.org \
--cc=sean.wang@mediatek.com \
--cc=upstream@airoha.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.