From mboxrd@z Thu Jan  1 00:00:00 1970
Return-Path: <stephen.hurd@broadcom.com>
Received: from mail-gw2-out.broadcom.com (mail-gw2-out.broadcom.com
 [216.31.210.63]) by dpdk.org (Postfix) with ESMTP id 187E2C486
 for <dev@dpdk.org>; Wed, 15 Jun 2016 23:24:32 +0200 (CEST)
X-IronPort-AV: E=Sophos;i="5.26,477,1459839600"; d="scan'208";a="97718186"
Received: from mail-irv-18.broadcom.com ([10.15.198.37])
 by mail-gw2-out.broadcom.com with ESMTP; 15 Jun 2016 14:44:49 -0700
Received: from mail-irva-12.broadcom.com (mail-irva-12.broadcom.com
 [10.11.16.101])
 by mail-irv-18.broadcom.com (Postfix) with ESMTP id 7B49382033;
 Wed, 15 Jun 2016 14:24:31 -0700 (PDT)
Received: from DPDK-C1.broadcom.com (dhcp-10-13-115-104.irv.broadcom.com
 [10.13.115.104])
 by mail-irva-12.broadcom.com (Postfix) with ESMTP id 815CBA6287;
 Wed, 15 Jun 2016 14:24:30 -0700 (PDT)
From: Stephen Hurd <stephen.hurd@broadcom.com>
To: dev@dpdk.org,
	ajit.khaparde@broadcom.com,
	bruce.richardson@intel.com
Date: Wed, 15 Jun 2016 14:23:31 -0700
Message-Id: <1466025818-124223-32-git-send-email-stephen.hurd@broadcom.com>
X-Mailer: git-send-email 1.9.1
In-Reply-To: <1466025818-124223-1-git-send-email-stephen.hurd@broadcom.com>
References: <1465944971-113413-1-git-send-email-stephen.hurd@broadcom.com>
 <1466025818-124223-1-git-send-email-stephen.hurd@broadcom.com>
Subject: [dpdk-dev] [PATCH v6 31/38] bnxt: add promiscuous enable/disable
	operations
X-BeenThere: dev@dpdk.org
X-Mailman-Version: 2.1.15
Precedence: list
List-Id: patches and discussions about DPDK <dev.dpdk.org>
List-Unsubscribe: <http://dpdk.org/ml/options/dev>,
 <mailto:dev-request@dpdk.org?subject=unsubscribe>
List-Archive: <http://dpdk.org/ml/archives/dev/>
List-Post: <mailto:dev@dpdk.org>
List-Help: <mailto:dev-request@dpdk.org?subject=help>
List-Subscribe: <http://dpdk.org/ml/listinfo/dev>,
 <mailto:dev-request@dpdk.org?subject=subscribe>
X-List-Received-Date: Wed, 15 Jun 2016 21:24:33 -0000

From: Ajit Khaparde <ajit.khaparde@broadcom.com>

This patch adds the promiscuous mode enable and disable dev_ops.
Uses the bnxt_hwrm_cfa_l2_set_rx_mask() API added in the earlier patch.

Signed-off-by: Ajit Khaparde <ajit.khaparde@broadcom.com>
Signed-off-by: Stephen Hurd <stephen.hurd@broadcom.com>
Reviewed-by: David Christensen <david.christensen@broadcom.com>

--
v4:
Fix couple of typos in the commit message.

v5:
Reorder footer
Rewrite the patch description.
---
 drivers/net/bnxt/bnxt_ethdev.c | 30 ++++++++++++++++++++++++++++++
 1 file changed, 30 insertions(+)

diff --git a/drivers/net/bnxt/bnxt_ethdev.c b/drivers/net/bnxt/bnxt_ethdev.c
index ac82876..3fce540 100644
--- a/drivers/net/bnxt/bnxt_ethdev.c
+++ b/drivers/net/bnxt/bnxt_ethdev.c
@@ -437,6 +437,34 @@ out:
 	return rc;
 }
 
+static void bnxt_promiscuous_enable_op(struct rte_eth_dev *eth_dev)
+{
+	struct bnxt *bp = (struct bnxt *)eth_dev->data->dev_private;
+	struct bnxt_vnic_info *vnic;
+
+	if (bp->vnic_info == NULL)
+		return;
+
+	vnic = &bp->vnic_info[0];
+
+	vnic->flags |= BNXT_VNIC_INFO_PROMISC;
+	bnxt_hwrm_cfa_l2_set_rx_mask(bp, vnic);
+}
+
+static void bnxt_promiscuous_disable_op(struct rte_eth_dev *eth_dev)
+{
+	struct bnxt *bp = (struct bnxt *)eth_dev->data->dev_private;
+	struct bnxt_vnic_info *vnic;
+
+	if (bp->vnic_info == NULL)
+		return;
+
+	vnic = &bp->vnic_info[0];
+
+	vnic->flags &= ~BNXT_VNIC_INFO_PROMISC;
+	bnxt_hwrm_cfa_l2_set_rx_mask(bp, vnic);
+}
+
 /*
  * Initialization
  */
@@ -454,6 +482,8 @@ static struct eth_dev_ops bnxt_dev_ops = {
 	.tx_queue_setup = bnxt_tx_queue_setup_op,
 	.tx_queue_release = bnxt_tx_queue_release_op,
 	.link_update = bnxt_link_update_op,
+	.promiscuous_enable = bnxt_promiscuous_enable_op,
+	.promiscuous_disable = bnxt_promiscuous_disable_op,
 };
 
 static bool bnxt_vf_pciid(uint16_t id)
-- 
1.9.1