From mboxrd@z Thu Jan 1 00:00:00 1970 From: Florian Fainelli Subject: Re: [PATCH net-next 07/11] net: dsa: debugfs: add port fdb Date: Tue, 15 Aug 2017 10:35:51 -0700 Message-ID: <1a72a0f3-c461-1099-1309-9604a990057c@gmail.com> References: <20170814222242.10643-1-vivien.didelot@savoirfairelinux.com> <20170814222242.10643-8-vivien.didelot@savoirfairelinux.com> Mime-Version: 1.0 Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Cc: linux-kernel@vger.kernel.org, kernel@savoirfairelinux.com, "David S. Miller" , Andrew Lunn , Egil Hjelmeland , John Crispin , Woojung Huh , Sean Wang , Volodymyr Bendiuga , Nikita Yushchenko , Maxime Hadjinlian , Chris Healy , Maxim Uvarov , Stefan Eichenberger , Jason Cobham , Juergen Borleis , Tobias Waldekranz To: Vivien Didelot , netdev@vger.kernel.org Return-path: In-Reply-To: <20170814222242.10643-8-vivien.didelot@savoirfairelinux.com> Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org List-Id: netdev.vger.kernel.org On 08/14/2017 03:22 PM, Vivien Didelot wrote: > Add a debug filesystem "fdb" entry to query a port's hardware FDB > entries through the .port_fdb_dump switch operation. > > This is really convenient to query directly the hardware or inspect DSA > or CPU links, since these ports are not exposed to userspace. > > # cat port1/fdb > vid 0 12:34:56:78:90:ab static unicast > > Signed-off-by: Vivien Didelot > --- > net/dsa/debugfs.c | 36 ++++++++++++++++++++++++++++++++++++ > 1 file changed, 36 insertions(+) > > diff --git a/net/dsa/debugfs.c b/net/dsa/debugfs.c > index 012fcf466cc1..8204c62dc9c1 100644 > --- a/net/dsa/debugfs.c > +++ b/net/dsa/debugfs.c > @@ -10,6 +10,7 @@ > */ > > #include > +#include > #include > > #include "dsa_priv.h" > @@ -109,6 +110,36 @@ static int dsa_debugfs_create_file(struct dsa_switch *ds, struct dentry *dir, > return 0; > } > > +static int dsa_debugfs_fdb_dump_cb(const unsigned char *addr, u16 vid, > + bool is_static, void *data) > +{ > + struct seq_file *seq = data; > + int i; unsigned int i? > + > + seq_printf(seq, "vid %d", vid); > + for (i = 0; i < ETH_ALEN; i++) > + seq_printf(seq, "%s%02x", i ? ":" : " ", addr[i]); Too bad we can use %pM here, or can we? Other than that: Reviewed-by: Florian Fainelli -- Florian