Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp2607774pxb; Sun, 24 Apr 2022 20:46:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzJrYAsN9VzcrcVgAEBfEBMHqm/Z+ZGYNVuZtg8xRg5cemmZUSgiK86sw2eH+P1jbKctMeC X-Received: by 2002:a17:907:8a0b:b0:6f3:6b70:c644 with SMTP id sc11-20020a1709078a0b00b006f36b70c644mr9915941ejc.530.1650858399401; Sun, 24 Apr 2022 20:46:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650858399; cv=none; d=google.com; s=arc-20160816; b=rVF5si7vs+wmQPiGiv58SGLp/0IuTU6EvQOseBH4hEso/McREbNb3Jc4wEiDyyiQOA aKq6odObsAfc/sT8Idc07TbvK4VIdvpOjLoXiWpUb5qN26a6VFhuK7+m9Mp+nwM2qcbb h4xCaIpLiOGiG8RnoWZv0cIprV6sJyy4j+nuoFuNm9ClqnPWUzudFy9YNZy7PxbWGGtJ 7RGBfq6ET/T9cyJV4JP4ar2xiX3pLp0P8lLg2LoMsV9iwO3bCF5GqiQgemdKwgqEwRjx kslkxyWGe5xmqFwrvJCxAcmohJyM2N7PoTbIVJWP3yUwfHUGmynkx5OGl/MrM+LaTBgM 1fsw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=0EgzoIHWVkAfvNpSWOnmV5LtfT6ZJcYhH7++3XB+glE=; b=mFqTMBgTMdnthzExLyKHZybHSnOW8Tn0I2UR5dBWYm8e9DUNCO2H/9mq7VJjcqh9B1 1EM+zE9ckon33jtRtdcFhZ/N0hAuUVoizZFcQq5OveuViTV3pRoWn+4fCgoOQTur69gl YQHz94knaFscu2SFtB7U524t4DJRNyghwSsHrLE8rjGDrr4rltq11PuPbTM2te0u+GG4 D/AlGtNPOD3UxlEnZ4wvNWfeUGODI2l2ZTaQ9GKzdrKWo9V7g/EQcmltkdv3xX/EcJ3r HyqJEFeoLoDTJXlRnztrmUld9KtWMy5SJqB5s4qkR0hPI/ErMVcR5GvINAytEIPkOLGK OX1g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@blackwall-org.20210112.gappssmtp.com header.s=20210112 header.b=xQq3liiy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y20-20020a056402359400b00421d0859a3esi12702928edc.50.2022.04.24.20.46.15; Sun, 24 Apr 2022 20:46:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@blackwall-org.20210112.gappssmtp.com header.s=20210112 header.b=xQq3liiy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230098AbiDXT6W (ORCPT + 99 others); Sun, 24 Apr 2022 15:58:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38498 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238834AbiDXT6R (ORCPT ); Sun, 24 Apr 2022 15:58:17 -0400 Received: from mail-ed1-x52c.google.com (mail-ed1-x52c.google.com [IPv6:2a00:1450:4864:20::52c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 62E4D8149B for ; Sun, 24 Apr 2022 12:55:15 -0700 (PDT) Received: by mail-ed1-x52c.google.com with SMTP id a21so4008638edb.1 for ; Sun, 24 Apr 2022 12:55:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=blackwall-org.20210112.gappssmtp.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:content-language:to :cc:references:from:in-reply-to:content-transfer-encoding; bh=0EgzoIHWVkAfvNpSWOnmV5LtfT6ZJcYhH7++3XB+glE=; b=xQq3liiyVG1TK522MGl5jBLsfT/Uix5DJ3L1iQks/PUiduhaj0NF/URdGJsujPgbam hLbi8IT6w9lG9NEFjrvb1UR+ca1mCX4b1Qa0CVbMAeny61wANYKKF9H4J11T+QSnUlBA 2l8hLqraXLvGyde7o9+APzhMhr3bL33Y+fT0z2fCfZIWjS+jC+OmP1EfZpvczGWyq1Z7 Q0c4u1b3TdLlzdFuNAllSb77AKFMOjv3sPo5qKywJgVDxQaMebwYqhmm8497vdHoGQfR mzs5YY8oyumj/q4pmo14yIiCU20R9SOZBaFVepZFNOAUC0i6Vz0LA50TSIWTJyCFrgON 8+WQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:cc:references:from:in-reply-to :content-transfer-encoding; bh=0EgzoIHWVkAfvNpSWOnmV5LtfT6ZJcYhH7++3XB+glE=; b=e0LyH8Xtmj5TQgY9DWVGPVkRnwMkBOguZZwzTgBLsjKz9YQzWgAaZGEgO9V14bKtVX gQLGjgXBJCwMgHHmV3sRLXv1FyQZi4IyEFUh5z0+SoWzN3gYOSB19GVgIRDcLR5FgMDv PUJZzqE+CwQLBgfPxY6BHZbCOkWy2qIdjL77S1jt629cM+l2l9n/Fmc6tLQ5Yu2QOYmt 3p2ELt677xzQV9f8xbUvpBN+hKZBl1Qu/g4vCqaftoe34QoVyokDshnI3kOwJ6XkzsRt TAtACXA1qJX7goOsBWcwIsIb4woM29wO8FEXx2Tsk6Q4qX990Ytd7XBBlEx8MAXVgA26 87XA== X-Gm-Message-State: AOAM533pDEnoUhGAHKeUkq8v6Jsh/zdd3OzeBntw9Z3sYwk8KPc5CEnr Q25Wikek6PYKcWkR+rFBznefFA== X-Received: by 2002:a50:8d8a:0:b0:423:d77b:a683 with SMTP id r10-20020a508d8a000000b00423d77ba683mr15397163edh.138.1650830113696; Sun, 24 Apr 2022 12:55:13 -0700 (PDT) Received: from [192.168.0.111] (87-243-81-1.ip.btc-net.bg. [87.243.81.1]) by smtp.gmail.com with ESMTPSA id e26-20020a50a69a000000b00425c11446fasm3325897edc.3.2022.04.24.12.55.12 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sun, 24 Apr 2022 12:55:13 -0700 (PDT) Message-ID: <4bf69eef-7444-1238-0f4a-fb0fccda080c@blackwall.org> Date: Sun, 24 Apr 2022 22:55:11 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 Subject: Re: [PATCH net-next v3 1/2] rtnetlink: add extack support in fdb del handlers Content-Language: en-US To: Alaa Mohamed , netdev@vger.kernel.org Cc: outreachy@lists.linux.dev, roopa@nvidia.com, jdenham@redhat.com, sbrivio@redhat.com, jesse.brandeburg@intel.com, anthony.l.nguyen@intel.com, davem@davemloft.net, kuba@kernel.org, pabeni@redhat.com, vladimir.oltean@nxp.com, claudiu.manoil@nxp.com, alexandre.belloni@bootlin.com, shshaikh@marvell.com, manishc@marvell.com, intel-wired-lan@lists.osuosl.org, linux-kernel@vger.kernel.org, UNGLinuxDriver@microchip.com, GR-Linux-NIC-Dev@marvell.com, bridge@lists.linux-foundation.org References: <7c8367b6-95c7-ea39-fafe-72495f343625@blackwall.org> From: Nikolay Aleksandrov In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,NICE_REPLY_A,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_NONE, URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 24/04/2022 22:49, Alaa Mohamed wrote: > > On ٢٤‏/٤‏/٢٠٢٢ ٢١:٠٢, Nikolay Aleksandrov wrote: >> On 24/04/2022 15:09, Alaa Mohamed wrote: >>> Add extack support to .ndo_fdb_del in netdevice.h and >>> all related methods. >>> >>> Signed-off-by: Alaa Mohamed >>> --- >>> changes in V3: >>>          fix errors reported by checkpatch.pl >>> --- >>>   drivers/net/ethernet/intel/ice/ice_main.c        | 4 ++-- >>>   drivers/net/ethernet/mscc/ocelot_net.c           | 4 ++-- >>>   drivers/net/ethernet/qlogic/qlcnic/qlcnic_main.c | 2 +- >>>   drivers/net/macvlan.c                            | 2 +- >>>   drivers/net/vxlan/vxlan_core.c                   | 2 +- >>>   include/linux/netdevice.h                        | 2 +- >>>   net/bridge/br_fdb.c                              | 2 +- >>>   net/bridge/br_private.h                          | 2 +- >>>   net/core/rtnetlink.c                             | 4 ++-- >>>   9 files changed, 12 insertions(+), 12 deletions(-) >>> >>> diff --git a/drivers/net/ethernet/intel/ice/ice_main.c b/drivers/net/ethernet/intel/ice/ice_main.c >>> index d768925785ca..7b55d8d94803 100644 >>> --- a/drivers/net/ethernet/intel/ice/ice_main.c >>> +++ b/drivers/net/ethernet/intel/ice/ice_main.c >>> @@ -5678,10 +5678,10 @@ ice_fdb_add(struct ndmsg *ndm, struct nlattr __always_unused *tb[], >>>   static int >>>   ice_fdb_del(struct ndmsg *ndm, __always_unused struct nlattr *tb[], >>>           struct net_device *dev, const unsigned char *addr, >>> -        __always_unused u16 vid) >>> +        __always_unused u16 vid, struct netlink_ext_ack *extack) >>>   { >>>       int err; >>> - >>> + >> What's changed here? > > In the previous version, I removed the blank line after "int err;" and you said I shouldn't so I added blank line. > Yeah, my question is are you fixing a dos ending or something else? The blank line is already there, what's wrong with it? The point is it's not nice to mix style fixes and other changes, more so if nothing is mentioned in the commit message. >> >>>       if (ndm->ndm_state & NUD_PERMANENT) { >>>           netdev_err(dev, "FDB only supports static addresses\n"); >>>           return -EINVAL; >>> diff --git a/drivers/net/ethernet/mscc/ocelot_net.c b/drivers/net/ethernet/mscc/ocelot_net.c >>> index 247bc105bdd2..e07c64e3159c 100644 >>> --- a/drivers/net/ethernet/mscc/ocelot_net.c >>> +++ b/drivers/net/ethernet/mscc/ocelot_net.c >>> @@ -774,14 +774,14 @@ static int ocelot_port_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], >>> >>>   static int ocelot_port_fdb_del(struct ndmsg *ndm, struct nlattr *tb[], >>>                      struct net_device *dev, >>> -                   const unsigned char *addr, u16 vid) >>> +                   const unsigned char *addr, u16 vid, struct netlink_ext_ack *extack) >>>   { >>>       struct ocelot_port_private *priv = netdev_priv(dev); >>>       struct ocelot_port *ocelot_port = &priv->port; >>>       struct ocelot *ocelot = ocelot_port->ocelot; >>>       int port = priv->chip_port; >>> >>> -    return ocelot_fdb_del(ocelot, port, addr, vid, ocelot_port->bridge); >>> +    return ocelot_fdb_del(ocelot, port, addr, vid, ocelot_port->bridge, extack); >>>   } >>> >>>   static int ocelot_port_fdb_dump(struct sk_buff *skb, >>> diff --git a/drivers/net/ethernet/qlogic/qlcnic/qlcnic_main.c b/drivers/net/ethernet/qlogic/qlcnic/qlcnic_main.c >>> index d320567b2cca..51fa23418f6a 100644 >>> --- a/drivers/net/ethernet/qlogic/qlcnic/qlcnic_main.c >>> +++ b/drivers/net/ethernet/qlogic/qlcnic/qlcnic_main.c >>> @@ -368,7 +368,7 @@ static int qlcnic_set_mac(struct net_device *netdev, void *p) >>> >>>   static int qlcnic_fdb_del(struct ndmsg *ndm, struct nlattr *tb[], >>>               struct net_device *netdev, >>> -            const unsigned char *addr, u16 vid) >>> +            const unsigned char *addr, u16 vid, struct netlink_ext_ack *extack) >>>   { >>>       struct qlcnic_adapter *adapter = netdev_priv(netdev); >>>       int err = -EOPNOTSUPP; >>> diff --git a/drivers/net/macvlan.c b/drivers/net/macvlan.c >>> index 069e8824c264..ffd34d9f7049 100644 >>> --- a/drivers/net/macvlan.c >>> +++ b/drivers/net/macvlan.c >>> @@ -1017,7 +1017,7 @@ static int macvlan_fdb_add(struct ndmsg *ndm, struct nlattr *tb[], >>> >>>   static int macvlan_fdb_del(struct ndmsg *ndm, struct nlattr *tb[], >>>                  struct net_device *dev, >>> -               const unsigned char *addr, u16 vid) >>> +               const unsigned char *addr, u16 vid, struct netlink_ext_ack *extack) >>>   { >>>       struct macvlan_dev *vlan = netdev_priv(dev); >>>       int err = -EINVAL; >>> diff --git a/drivers/net/vxlan/vxlan_core.c b/drivers/net/vxlan/vxlan_core.c >>> index de97ff98d36e..cf2f60037340 100644 >>> --- a/drivers/net/vxlan/vxlan_core.c >>> +++ b/drivers/net/vxlan/vxlan_core.c >>> @@ -1280,7 +1280,7 @@ int __vxlan_fdb_delete(struct vxlan_dev *vxlan, >>>   /* Delete entry (via netlink) */ >>>   static int vxlan_fdb_delete(struct ndmsg *ndm, struct nlattr *tb[], >>>                   struct net_device *dev, >>> -                const unsigned char *addr, u16 vid) >>> +                const unsigned char *addr, u16 vid, struct netlink_ext_ack *extack) >>>   { >>>       struct vxlan_dev *vxlan = netdev_priv(dev); >>>       union vxlan_addr ip; >>> diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h >>> index 28ea4f8269d4..d0d2a8f33c73 100644 >>> --- a/include/linux/netdevice.h >>> +++ b/include/linux/netdevice.h >>> @@ -1509,7 +1509,7 @@ struct net_device_ops { >>>                              struct nlattr *tb[], >>>                              struct net_device *dev, >>>                              const unsigned char *addr, >>> -                           u16 vid); >>> +                           u16 vid, struct netlink_ext_ack *extack); >>>       int            (*ndo_fdb_dump)(struct sk_buff *skb, >>>                           struct netlink_callback *cb, >>>                           struct net_device *dev, >>> diff --git a/net/bridge/br_fdb.c b/net/bridge/br_fdb.c >>> index 6ccda68bd473..5bfce2e9a553 100644 >>> --- a/net/bridge/br_fdb.c >>> +++ b/net/bridge/br_fdb.c >>> @@ -1110,7 +1110,7 @@ static int __br_fdb_delete(struct net_bridge *br, >>>   /* Remove neighbor entry with RTM_DELNEIGH */ >>>   int br_fdb_delete(struct ndmsg *ndm, struct nlattr *tb[], >>>             struct net_device *dev, >>> -          const unsigned char *addr, u16 vid) >>> +          const unsigned char *addr, u16 vid, struct netlink_ext_ack *extack) >>>   { >>>       struct net_bridge_vlan_group *vg; >>>       struct net_bridge_port *p = NULL; >>> diff --git a/net/bridge/br_private.h b/net/bridge/br_private.h >>> index 18ccc3d5d296..95348c1c9ce5 100644 >>> --- a/net/bridge/br_private.h >>> +++ b/net/bridge/br_private.h >>> @@ -780,7 +780,7 @@ void br_fdb_update(struct net_bridge *br, struct net_bridge_port *source, >>>              const unsigned char *addr, u16 vid, unsigned long flags); >>> >>>   int br_fdb_delete(struct ndmsg *ndm, struct nlattr *tb[], >>> -          struct net_device *dev, const unsigned char *addr, u16 vid); >>> +          struct net_device *dev, const unsigned char *addr, u16 vid, struct netlink_ext_ack *extack); >> This is way too long (111 chars) and checkpatch should've complained about it. >> WARNING: line length of 111 exceeds 100 columns >> #234: FILE: net/bridge/br_private.h:782: >> +          struct net_device *dev, const unsigned char *addr, u16 vid, struct netlink_ext_ack *extack); > > I will fix it. > >> >>>   int br_fdb_add(struct ndmsg *nlh, struct nlattr *tb[], struct net_device *dev, >>>              const unsigned char *addr, u16 vid, u16 nlh_flags, >>>              struct netlink_ext_ack *extack); >>> diff --git a/net/core/rtnetlink.c b/net/core/rtnetlink.c >>> index 4041b3e2e8ec..99b30ae58a47 100644 >>> --- a/net/core/rtnetlink.c >>> +++ b/net/core/rtnetlink.c >>> @@ -4223,7 +4223,7 @@ static int rtnl_fdb_del(struct sk_buff *skb, struct nlmsghdr *nlh, >>>           const struct net_device_ops *ops = br_dev->netdev_ops; >>> >>>           if (ops->ndo_fdb_del) >>> -            err = ops->ndo_fdb_del(ndm, tb, dev, addr, vid); >>> +            err = ops->ndo_fdb_del(ndm, tb, dev, addr, vid, extack); >>> >>>           if (err) >>>               goto out; >>> @@ -4235,7 +4235,7 @@ static int rtnl_fdb_del(struct sk_buff *skb, struct nlmsghdr *nlh, >>>       if (ndm->ndm_flags & NTF_SELF) { >>>           if (dev->netdev_ops->ndo_fdb_del) >>>               err = dev->netdev_ops->ndo_fdb_del(ndm, tb, dev, addr, >>> -                               vid); >>> +                               vid, extack); >>>           else >>>               err = ndo_dflt_fdb_del(ndm, tb, dev, addr, vid); >>> >>> -- >>> 2.36.0 >>>