]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
net: dsa: mv88e6xxx: replace ATU violation prints with trace points
authorVladimir Oltean <vladimir.oltean@nxp.com>
Fri, 9 Dec 2022 17:28:16 +0000 (19:28 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 4 Sep 2024 11:17:41 +0000 (13:17 +0200)
[ Upstream commit 8646384d80f3d3b4a66b3284dbbd8232d1b8799e ]

In applications where the switch ports must perform 802.1X based
authentication and are therefore locked, ATU violation interrupts are
quite to be expected as part of normal operation. The problem is that
they currently spam the kernel log, even if rate limited.

Create a series of trace points, all derived from the same event class,
which log these violations to the kernel's trace buffer, which is both
much faster and much easier to ignore than printing to a serial console.

New usage model:

$ trace-cmd list | grep mv88e6xxx
mv88e6xxx
mv88e6xxx:mv88e6xxx_atu_full_violation
mv88e6xxx:mv88e6xxx_atu_miss_violation
mv88e6xxx:mv88e6xxx_atu_member_violation
$ trace-cmd record -e mv88e6xxx sleep 10

Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Reviewed-by: Saeed Mahameed <saeed@kernel.org>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Stable-dep-of: 528876d867a2 ("net: dsa: mv88e6xxx: Fix out-of-bound access")
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/dsa/mv88e6xxx/Makefile
drivers/net/dsa/mv88e6xxx/global1_atu.c
drivers/net/dsa/mv88e6xxx/trace.c [new file with mode: 0644]
drivers/net/dsa/mv88e6xxx/trace.h [new file with mode: 0644]

index 4b080b448ce74022a2273a83804a9a3b45cb7424..1f7240e0d6bcecd2391ce7c23badcfe2224caa1a 100644 (file)
@@ -15,3 +15,7 @@ mv88e6xxx-objs += port_hidden.o
 mv88e6xxx-$(CONFIG_NET_DSA_MV88E6XXX_PTP) += ptp.o
 mv88e6xxx-objs += serdes.o
 mv88e6xxx-objs += smi.o
+mv88e6xxx-objs += trace.o
+
+# for tracing framework to find trace.h
+CFLAGS_trace.o := -I$(src)
index b5580042250ffe4d62031cc4361e8ef555293549..1a4781a44e0d7e70bcc87951d96e5898ae3a2a9b 100644 (file)
@@ -12,6 +12,7 @@
 
 #include "chip.h"
 #include "global1.h"
+#include "trace.h"
 
 /* Offset 0x01: ATU FID Register */
 
@@ -435,23 +436,23 @@ static irqreturn_t mv88e6xxx_g1_atu_prob_irq_thread_fn(int irq, void *dev_id)
        }
 
        if (val & MV88E6XXX_G1_ATU_OP_MEMBER_VIOLATION) {
-               dev_err_ratelimited(chip->dev,
-                                   "ATU member violation for %pM fid %u portvec %x spid %d\n",
-                                   entry.mac, fid, entry.portvec, spid);
+               trace_mv88e6xxx_atu_member_violation(chip->dev, spid,
+                                                    entry.portvec, entry.mac,
+                                                    fid);
                chip->ports[spid].atu_member_violation++;
        }
 
        if (val & MV88E6XXX_G1_ATU_OP_MISS_VIOLATION) {
-               dev_err_ratelimited(chip->dev,
-                                   "ATU miss violation for %pM fid %u portvec %x spid %d\n",
-                                   entry.mac, fid, entry.portvec, spid);
+               trace_mv88e6xxx_atu_miss_violation(chip->dev, spid,
+                                                  entry.portvec, entry.mac,
+                                                  fid);
                chip->ports[spid].atu_miss_violation++;
        }
 
        if (val & MV88E6XXX_G1_ATU_OP_FULL_VIOLATION) {
-               dev_err_ratelimited(chip->dev,
-                                   "ATU full violation for %pM fid %u portvec %x spid %d\n",
-                                   entry.mac, fid, entry.portvec, spid);
+               trace_mv88e6xxx_atu_full_violation(chip->dev, spid,
+                                                  entry.portvec, entry.mac,
+                                                  fid);
                chip->ports[spid].atu_full_violation++;
        }
        mv88e6xxx_reg_unlock(chip);
diff --git a/drivers/net/dsa/mv88e6xxx/trace.c b/drivers/net/dsa/mv88e6xxx/trace.c
new file mode 100644 (file)
index 0000000..7833cb5
--- /dev/null
@@ -0,0 +1,6 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+/* Copyright 2022 NXP
+ */
+
+#define CREATE_TRACE_POINTS
+#include "trace.h"
diff --git a/drivers/net/dsa/mv88e6xxx/trace.h b/drivers/net/dsa/mv88e6xxx/trace.h
new file mode 100644 (file)
index 0000000..d9ab5c8
--- /dev/null
@@ -0,0 +1,66 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+/* Copyright 2022 NXP
+ */
+
+#undef TRACE_SYSTEM
+#define TRACE_SYSTEM   mv88e6xxx
+
+#if !defined(_MV88E6XXX_TRACE_H) || defined(TRACE_HEADER_MULTI_READ)
+#define _MV88E6XXX_TRACE_H
+
+#include <linux/device.h>
+#include <linux/if_ether.h>
+#include <linux/tracepoint.h>
+
+DECLARE_EVENT_CLASS(mv88e6xxx_atu_violation,
+
+       TP_PROTO(const struct device *dev, int spid, u16 portvec,
+                const unsigned char *addr, u16 fid),
+
+       TP_ARGS(dev, spid, portvec, addr, fid),
+
+       TP_STRUCT__entry(
+               __string(name, dev_name(dev))
+               __field(int, spid)
+               __field(u16, portvec)
+               __array(unsigned char, addr, ETH_ALEN)
+               __field(u16, fid)
+       ),
+
+       TP_fast_assign(
+               __assign_str(name, dev_name(dev));
+               __entry->spid = spid;
+               __entry->portvec = portvec;
+               memcpy(__entry->addr, addr, ETH_ALEN);
+               __entry->fid = fid;
+       ),
+
+       TP_printk("dev %s spid %d portvec 0x%x addr %pM fid %u",
+                 __get_str(name), __entry->spid, __entry->portvec,
+                 __entry->addr, __entry->fid)
+);
+
+DEFINE_EVENT(mv88e6xxx_atu_violation, mv88e6xxx_atu_member_violation,
+            TP_PROTO(const struct device *dev, int spid, u16 portvec,
+                     const unsigned char *addr, u16 fid),
+            TP_ARGS(dev, spid, portvec, addr, fid));
+
+DEFINE_EVENT(mv88e6xxx_atu_violation, mv88e6xxx_atu_miss_violation,
+            TP_PROTO(const struct device *dev, int spid, u16 portvec,
+                     const unsigned char *addr, u16 fid),
+            TP_ARGS(dev, spid, portvec, addr, fid));
+
+DEFINE_EVENT(mv88e6xxx_atu_violation, mv88e6xxx_atu_full_violation,
+            TP_PROTO(const struct device *dev, int spid, u16 portvec,
+                     const unsigned char *addr, u16 fid),
+            TP_ARGS(dev, spid, portvec, addr, fid));
+
+#endif /* _MV88E6XXX_TRACE_H */
+
+/* We don't want to use include/trace/events */
+#undef TRACE_INCLUDE_PATH
+#define TRACE_INCLUDE_PATH .
+#undef TRACE_INCLUDE_FILE
+#define TRACE_INCLUDE_FILE     trace
+/* This part must be outside protection */
+#include <trace/define_trace.h>