Received: by 2002:a05:6a10:c7c6:0:0:0:0 with SMTP id h6csp1722162pxy; Mon, 2 Aug 2021 08:40:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxpV37DhN+l94rH6r77d2G2u6PX942oKI0gQpsHYLLPdViDhjsZClAD9IobxNXqxINRyZon X-Received: by 2002:a17:906:4310:: with SMTP id j16mr16451245ejm.182.1627918821086; Mon, 02 Aug 2021 08:40:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627918821; cv=none; d=google.com; s=arc-20160816; b=S/eK7BbSMRDqcrjtaGJUYE2hnTn4xzpW7Utsag3SJd3DIHCNEf37M7xX7dOucp8uZ8 Ong4I6zp3zzGqKrKphikTZNzsDmDBaOQtYpnhSxcKg0M0+4emsGlwH/DB+o2MCQg/GQI XJR2S7zX3Sr8bcwhY20+EN1QyZsBkmQfMdaevrzgZ61HMG3xljI0Si9MnhdsCg1aBytw knkO1Y/StaIl/zGP32IJGWhXyQKK+3n3YLzkbDNN01MprolGUeJS5LDRkwUHrsQqTWlr Y3+syHwZWA6PA+uti5KdLNE1V7EGaFm39gAyzlKf2bs3MQph9UR+l39aOcjKbkrTbC0N QUSA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=XB6BGIdQEwggVbLWSap7UjJdUQbesE+7hXxtVRkvtSk=; b=m3+0S1PxeQbcuGEqzQT17cyQIGHdsVCrmXbkRnGobXfrVsoGhQGW6Xby6OTozVpBDE yYZ/lYIp36Q/DnjhiX8l+ejmKZpXP0TVLLmLGaP9uSUza4QHT+ciOBDixNZ/J18Wa4op 61Xtt1rWzY5SGnU95EpxHZj+sqxV6R9Jc8p8PVJR1VMKAmOvD/9pWD/MBLaWVE4nAtPA Sf3/vIPTDt8V7shTJ+wtWEvlHupZpHmB6BQV7nvddGZyAa6gt+TZ5OHXS5opQvuOfZWX SV1TxsfwToUCczaz+quieD+s48At1iDDgTD0Xjy1Qhj2k4vRgUTx1xpt+ZROC8VjysG8 /nmg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="rDgtou/W"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j18si3855726edw.279.2021.08.02.08.39.57; Mon, 02 Aug 2021 08:40:21 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="rDgtou/W"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235221AbhHBPhi (ORCPT + 99 others); Mon, 2 Aug 2021 11:37:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37680 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233939AbhHBPhh (ORCPT ); Mon, 2 Aug 2021 11:37:37 -0400 Received: from mail-ej1-x630.google.com (mail-ej1-x630.google.com [IPv6:2a00:1450:4864:20::630]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E8E9EC06175F; Mon, 2 Aug 2021 08:37:26 -0700 (PDT) Received: by mail-ej1-x630.google.com with SMTP id qk33so31516394ejc.12; Mon, 02 Aug 2021 08:37:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=XB6BGIdQEwggVbLWSap7UjJdUQbesE+7hXxtVRkvtSk=; b=rDgtou/WbtTDhDKzfBGhBu4uvJfyhWBsWAxHFuW9Uzlp5nJ3BeYLS9hFJ6uYan+XlA v64gxnDd+uPjdy5P40q3FE3aFbjQaYfl6fVsYz9S/ZvgipjkqocwLLC/k65S+tT4GD/V 6qRfZ/LFxNexi7P7IaYSo1a1ORsD+p0GdQU3kJVmIcs83pNTtbyNvp29pTiq7tZdwaQy 1+xgrNvtS6cqNcaOeGDbMZAqyq6zwpgjD5vYW0/zb4OUymOVJpJcKO3EYTOArQWfWfs5 pxWTHz/GplFX1P0MaGR+nqqgz7Us6YE2zb6I/zjsBy03P49f9Dt1GOKxG1FEhRxt7LqB eKDg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=XB6BGIdQEwggVbLWSap7UjJdUQbesE+7hXxtVRkvtSk=; b=XofECvqOLeBp2+Miyd+zXOAaUsjrh5anWBd2T+y3oNzkkQFery7nwvo3aa1eoRuI5Z q3JWXS9oqgw89SEnBIf7rRXtmDosNB5HM5DK+oBDyMrT7UKZb9pa0eay6oPQddTNh01y Ounl1TYxcPPPDlRpZqikml5aumHcmqQJ5ofQObp4E6EeBmHyfYpTM7PWUDD7YIVSvV8v LDKUlG+mOxj3XDl4Akrw5iIHbOLgJBZ0y8VVQ32r8bWw2GsN0sMr/d3923sDO2UgE9Jp tVgCqhNxiL8m9KHsIaLDtPpzsz0a54mly3FNQ+BMyjtqW5cVwsbbTJfXdg7+VJKbgJaZ vVCA== X-Gm-Message-State: AOAM530pYPoCDTqzbVdJCJne1oBhwTLswPL+9OnPJe1czXJJDX7Pfj4t +4dY9bIqLtAlH/SMAHFQ+Fc= X-Received: by 2002:a17:906:49d5:: with SMTP id w21mr15755703ejv.30.1627918645497; Mon, 02 Aug 2021 08:37:25 -0700 (PDT) Received: from skbuf ([188.25.144.60]) by smtp.gmail.com with ESMTPSA id l9sm1105962edt.55.2021.08.02.08.37.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 02 Aug 2021 08:37:25 -0700 (PDT) Date: Mon, 2 Aug 2021 18:37:23 +0300 From: Vladimir Oltean To: Oleksij Rempel Cc: Andrew Lunn , Vivien Didelot , Florian Fainelli , "David S. Miller" , Jakub Kicinski , Russell King , Pengutronix Kernel Team , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mips@vger.kernel.org Subject: Re: [PATCH net-next v3 3/6] net: dsa: qca: ar9331: add forwarding database support Message-ID: <20210802153723.vp4phpinclsuhlzz@skbuf> References: <20210802131037.32326-1-o.rempel@pengutronix.de> <20210802131037.32326-4-o.rempel@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210802131037.32326-4-o.rempel@pengutronix.de> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Aug 02, 2021 at 03:10:34PM +0200, Oleksij Rempel wrote: > +static int ar9331_sw_port_fdb_add(struct dsa_switch *ds, int port, > + const unsigned char *mac, u16 vid) > +{ > + struct ar9331_sw_priv *priv = (struct ar9331_sw_priv *)ds->priv; > + u16 port_mask = BIT(port); > + > + if (vid) > + return -EINVAL; When did you test this patch last time on net-next? Asking because when a port joins a VLAN-aware bridge, it will replay the FDB entries towards the bridge, which include a VLAN-unaware FDB entry with VID 0, and a VLAN-aware one with the bridge's default_pvid. If you return -EINVAL, that br_fdb_replay call will fail and you will fail to join the bridge. > + > + return ar9331_sw_port_fdb_rmw(priv, mac, port_mask, 0); > +} > + > +static int ar9331_sw_port_fdb_del(struct dsa_switch *ds, int port, > + const unsigned char *mac, u16 vid) > +{ > + struct ar9331_sw_priv *priv = (struct ar9331_sw_priv *)ds->priv; > + u16 port_mask = BIT(port); > + > + if (vid) > + return -EINVAL; > + > + return ar9331_sw_port_fdb_rmw(priv, mac, 0, port_mask); > +}