Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp2120200ybl; Thu, 29 Aug 2019 03:58:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqzVmUHkgdCBuTzCKalxilX9fmu2ZLewGgEmyZXQh76dvZNdlzw2Hgd6d05RwmZQykrJKKji X-Received: by 2002:a63:5941:: with SMTP id j1mr5741144pgm.319.1567076288370; Thu, 29 Aug 2019 03:58:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567076288; cv=none; d=google.com; s=arc-20160816; b=a8/v0mni7XSMOWolOS3QOYmyR5zzIIe849S661QTQT9xTy9CyuIMwWkuWupeb99cex Qi4irv+0jl5nw9jS3Rnl+YV8Ggy+DTlrE+BhOBQAyAlvbSrjNUc/Ut9Q6HVDnNWdMEkG 8vLZg+PhoD8ll7dgnUYLJVL1UURCFaW0z3LP2g81ISx0EkrLIlYGIHeqGe5BH2As3LN7 2yg7eAkQGOge2CJfTWk3pAeEVEk+MbNsyQRVOZMEgMvoHlHLTxUUjsa2x7hwpDFhnWEC vRVXp+/L33REyTladE2XG4Kl+w3ma+c5IJ60capvDsUQKz29Q7BeN4FALxAwMDr7HJiA YV3Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:ironport-sdr; bh=87vE2xStId7s7ZhVxHn7I/lGeca+Gr3oRrlEXnB2yyY=; b=cscpSBWYHPlgtXh7Z7+n9DUQZugsVudo3ihlSurBMj34G31DNHKiZYkmF/73m273CM awRUkguDlsKAFJ4iLh63cTSshcwzQvn9Qx91Z4D+UfMT7QmMW5GItCx8sgymzJc3XPYt lFF8KOPwUp+29aT5OeBLuN8L0eEo6MjQSGf6X0RYpG0QBdPJLNmdydMaNLJV13AHo54y fEa+nrmP1XVd1QpBMS95BLWkY69R03UblnjBroktdd/svlnocczk46abzG+Rrdc9uNVe reruV68pHLMXmnIlzsy84qbshLM6PP2hrx7byXsbo36pPA21AtUWWEQpsUUTgIrqaIwD 73Dw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=microchip.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i21si1694373pgj.37.2019.08.29.03.57.52; Thu, 29 Aug 2019 03:58:08 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=microchip.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727474AbfH2K46 (ORCPT + 99 others); Thu, 29 Aug 2019 06:56:58 -0400 Received: from esa2.microchip.iphmx.com ([68.232.149.84]:58891 "EHLO esa2.microchip.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727123AbfH2K45 (ORCPT ); Thu, 29 Aug 2019 06:56:57 -0400 Received-SPF: Pass (esa2.microchip.iphmx.com: domain of Horatiu.Vultur@microchip.com designates 198.175.253.82 as permitted sender) identity=mailfrom; client-ip=198.175.253.82; receiver=esa2.microchip.iphmx.com; envelope-from="Horatiu.Vultur@microchip.com"; x-sender="Horatiu.Vultur@microchip.com"; x-conformance=spf_only; x-record-type="v=spf1"; x-record-text="v=spf1 mx a:ushub1.microchip.com a:smtpout.microchip.com a:mx1.microchip.iphmx.com a:mx2.microchip.iphmx.com include:servers.mcsv.net include:mktomail.com include:spf.protection.outlook.com ~all" Received-SPF: None (esa2.microchip.iphmx.com: no sender authenticity information available from domain of postmaster@email.microchip.com) identity=helo; client-ip=198.175.253.82; receiver=esa2.microchip.iphmx.com; envelope-from="Horatiu.Vultur@microchip.com"; x-sender="postmaster@email.microchip.com"; x-conformance=spf_only Authentication-Results: esa2.microchip.iphmx.com; dkim=none (message not signed) header.i=none; spf=Pass smtp.mailfrom=Horatiu.Vultur@microchip.com; spf=None smtp.helo=postmaster@email.microchip.com; dmarc=pass (p=none dis=none) d=microchip.com IronPort-SDR: kF1RWub9CXK6jgsNDuMyJeTx+jQyYj0BBM+qp3iaZc6Z3VJvJA8g6AyYGnKLzKWwj8fxBoby7V l/x4S3KXk4xCn5JTHE6gStzK/nhksXncpn7mbQYJwfWgoqXREWpfi7YdWvTPVsuGARz0tCw9/z UIOqbcrb0Ew9fZL5Uy3H32/cdv7aaWE4ItiWEmQoWYwOLcrOD4xc5dYnNnjeXC0gD44Cc3Xpbt yOmbLiG3ZUlxgTmrN7I22ayxTRpcATfE1YL0duemHcwbB8DZUH7tHCaH8MRQcRijcYLOfvZEQZ md0= X-IronPort-AV: E=Sophos;i="5.64,442,1559545200"; d="scan'208";a="46989148" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa2.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 29 Aug 2019 03:56:56 -0700 Received: from chn-vm-ex03.mchp-main.com (10.10.85.151) by chn-vm-ex01.mchp-main.com (10.10.85.143) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Thu, 29 Aug 2019 03:56:53 -0700 Received: from localhost (10.10.85.251) by chn-vm-ex03.mchp-main.com (10.10.85.151) with Microsoft SMTP Server id 15.1.1713.5 via Frontend Transport; Thu, 29 Aug 2019 03:56:56 -0700 Date: Thu, 29 Aug 2019 12:56:54 +0200 From: Horatiu Vultur To: Jiri Pirko CC: , , , , , , , , Subject: Re: [PATCH v3 1/2] net: core: Notify on changes to dev->promiscuity. Message-ID: <20190829105650.btgvytgja63sx6wx@soft-dev3.microsemi.net> References: <1567070549-29255-1-git-send-email-horatiu.vultur@microchip.com> <1567070549-29255-2-git-send-email-horatiu.vultur@microchip.com> <20190829095100.GH2312@nanopsycho> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Disposition: inline In-Reply-To: <20190829095100.GH2312@nanopsycho> User-Agent: NeoMutt/20180716 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The 08/29/2019 11:51, Jiri Pirko wrote: > External E-Mail > > > Thu, Aug 29, 2019 at 11:22:28AM CEST, horatiu.vultur@microchip.com wrote: > >Add the SWITCHDEV_ATTR_ID_PORT_PROMISCUITY switchdev notification type, > >used to indicate whenever the dev promiscuity counter is changed. > > > >The notification doesn't use any switchdev_attr attribute because in the > >notifier callbacks is it possible to get the dev and read directly > >the promiscuity value. > > > >Signed-off-by: Horatiu Vultur > >--- > > include/net/switchdev.h | 1 + > > net/core/dev.c | 9 +++++++++ > > 2 files changed, 10 insertions(+) > > > >diff --git a/include/net/switchdev.h b/include/net/switchdev.h > >index aee86a1..14b1617 100644 > >--- a/include/net/switchdev.h > >+++ b/include/net/switchdev.h > >@@ -40,6 +40,7 @@ enum switchdev_attr_id { > > SWITCHDEV_ATTR_ID_BRIDGE_VLAN_FILTERING, > > SWITCHDEV_ATTR_ID_BRIDGE_MC_DISABLED, > > SWITCHDEV_ATTR_ID_BRIDGE_MROUTER, > >+ SWITCHDEV_ATTR_ID_PORT_PROMISCUITY, > > }; > > > > struct switchdev_attr { > >diff --git a/net/core/dev.c b/net/core/dev.c > >index 49589ed..40c74f2 100644 > >--- a/net/core/dev.c > >+++ b/net/core/dev.c > >@@ -142,6 +142,7 @@ > > #include > > #include > > #include > >+#include > > > > #include "net-sysfs.h" > > > >@@ -7377,6 +7378,11 @@ static void dev_change_rx_flags(struct net_device *dev, int flags) > > static int __dev_set_promiscuity(struct net_device *dev, int inc, bool notify) > > { > > unsigned int old_flags = dev->flags; > >+ struct switchdev_attr attr = { > >+ .orig_dev = dev, > >+ .id = SWITCHDEV_ATTR_ID_PORT_PROMISCUITY, > >+ .flags = SWITCHDEV_F_DEFER, > Hi Jiri, > NACK > > This is invalid usecase for switchdev infra. Switchdev is there for > bridge offload purposes only. > > For promiscuity changes, the infrastructure is already present in the > code. See __dev_notify_flags(). it calls: > call_netdevice_notifiers_info(NETDEV_CHANGE, &change_info.info) > and you can actually see the changed flag in ".flags_changed". Yes, you are right. But in case the port is part of a bridge and then enable promisc mode by a user space application(tpcdump) then the drivers will not be notified. The reason is that the dev->flags will still be the same(because IFF_PROMISC was already set) and only promiscuity will be changed. One fix could be to call __dev_notify_flags() no matter when the promisc is enable or disabled. > > You just have to register netdev notifier block in your driver. Grep > for: register_netdevice_notifier > > > >+ }; > > kuid_t uid; > > kgid_t gid; > > > >@@ -7419,6 +7425,9 @@ static int __dev_set_promiscuity(struct net_device *dev, int inc, bool notify) > > } > > if (notify) > > __dev_notify_flags(dev, old_flags, IFF_PROMISC); > >+ > >+ switchdev_port_attr_set(dev, &attr); > >+ > > return 0; > > } > > > >-- > >2.7.4 > > > -- /Horatiu