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 C3EFCADCA
 for <dev@dpdk.org>; Sat, 14 May 2016 00:51:00 +0200 (CEST)
X-IronPort-AV: E=Sophos;i="5.24,615,1455004800"; d="scan'208";a="95337965"
Received: from mail-irv-18.broadcom.com ([10.15.198.37])
 by mail-gw2-out.broadcom.com with ESMTP; 13 May 2016 16:06:16 -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 02BDA82022
 for <dev@dpdk.org>; Fri, 13 May 2016 15:51:00 -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 DF51313DB43
 for <dev@dpdk.org>; Fri, 13 May 2016 15:47:08 -0700 (PDT)
From: Stephen Hurd <stephen.hurd@broadcom.com>
To: dev@dpdk.org
Date: Fri, 13 May 2016 15:46:23 -0700
Message-Id: <1463179589-82681-34-git-send-email-stephen.hurd@broadcom.com>
X-Mailer: git-send-email 1.9.1
In-Reply-To: <1463179589-82681-1-git-send-email-stephen.hurd@broadcom.com>
References: <CAJ9nmBYsstDhTCB4H1V5zGFD7ffTeXd=L+v+pdCjqB5KJ6AEvQ@mail.gmail.com>
 <1463179589-82681-1-git-send-email-stephen.hurd@broadcom.com>
Subject: [dpdk-dev] [PATCH v2 34/40] bnxt: add device close operation
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: Fri, 13 May 2016 22:51:01 -0000

Frees all resources except the hwrm ones, which are required to notify
the HWRM that the driver is unloaded (these are freed in uninit()).

Signed-off-by: Stephen Hurd <stephen.hurd@broadcom.com>
Reviewed-by: Ajit Kumar Khaparde <ajit.khaparde@broadcom.com>
---
 drivers/net/bnxt/bnxt_ethdev.c | 11 +++++++++++
 1 file changed, 11 insertions(+)

diff --git a/drivers/net/bnxt/bnxt_ethdev.c b/drivers/net/bnxt/bnxt_ethdev.c
index 97ef0b4..edb7427 100644
--- a/drivers/net/bnxt/bnxt_ethdev.c
+++ b/drivers/net/bnxt/bnxt_ethdev.c
@@ -390,6 +390,16 @@ static void bnxt_dev_stop_op(struct rte_eth_dev *eth_dev)
 	bnxt_shutdown_nic(bp);
 }
 
+static void bnxt_dev_close_op(struct rte_eth_dev *eth_dev)
+{
+	struct bnxt *bp = (struct bnxt *)eth_dev->data->dev_private;
+
+	bnxt_free_tx_mbufs(bp);
+	bnxt_free_rx_mbufs(bp);
+	bnxt_free_mem(bp);
+	rte_free(eth_dev->data->mac_addrs);
+}
+
 static int bnxt_link_update_op(struct rte_eth_dev *eth_dev,
 			       int wait_to_complete)
 {
@@ -492,6 +502,7 @@ static struct eth_dev_ops bnxt_dev_ops = {
 	.dev_configure = bnxt_dev_configure_op,
 	.dev_start = bnxt_dev_start_op,
 	.dev_stop = bnxt_dev_stop_op,
+	.dev_close = bnxt_dev_close_op,
 	.stats_get = bnxt_stats_get_op,
 	.stats_reset = bnxt_stats_reset_op,
 	.rx_queue_setup = bnxt_rx_queue_setup_op,
-- 
1.9.1