Blame SOURCES/0006-Revert-netdrv-ice-add-a-devlink-region-for-dumping-N.patch

2eb987
From 1b267d3510d8ee9ab46ec4101ee481cda310cf8b Mon Sep 17 00:00:00 2001
2eb987
From: Eugene Syromiatnikov <esyr@redhat.com>
2eb987
Date: Thu, 27 Aug 2020 19:15:44 +0200
2eb987
Subject: [PATCH 6/6] Revert "[netdrv] ice: add a devlink region for dumping
2eb987
 NVM contents"
2eb987
2eb987
This reverts commit 14d67603e80fde05381c96562be7f191d568237f.
2eb987
---
2eb987
 drivers/net/ethernet/intel/ice/ice.h         |  2 -
2eb987
 drivers/net/ethernet/intel/ice/ice_devlink.c | 96 ----------------------------
2eb987
 drivers/net/ethernet/intel/ice/ice_devlink.h |  3 -
2eb987
 drivers/net/ethernet/intel/ice/ice_main.c    |  4 --
2eb987
 4 files changed, 105 deletions(-)
2eb987
2eb987
diff --git a/drivers/net/ethernet/intel/ice/ice.h b/drivers/net/ethernet/intel/ice/ice.h
2eb987
index 5792ee616b5c..54b9d567841e 100644
2eb987
--- a/drivers/net/ethernet/intel/ice/ice.h
2eb987
+++ b/drivers/net/ethernet/intel/ice/ice.h
2eb987
@@ -373,8 +373,6 @@ struct ice_pf {
2eb987
 	/* devlink port data */
2eb987
 	struct devlink_port devlink_port;
2eb987
 
2eb987
-	struct devlink_region *nvm_region;
2eb987
-
2eb987
 	/* OS reserved IRQ details */
2eb987
 	struct msix_entry *msix_entries;
2eb987
 	struct ice_res_tracker *irq_tracker;
2eb987
diff --git a/drivers/net/ethernet/intel/ice/ice_devlink.c b/drivers/net/ethernet/intel/ice/ice_devlink.c
2eb987
index a73d06e06b5d..fafec5c6b407 100644
2eb987
--- a/drivers/net/ethernet/intel/ice/ice_devlink.c
2eb987
+++ b/drivers/net/ethernet/intel/ice/ice_devlink.c
2eb987
@@ -341,99 +341,3 @@ void ice_devlink_destroy_port(struct ice_pf *pf)
2eb987
 	devlink_port_type_clear(&pf->devlink_port);
2eb987
 	devlink_port_unregister(&pf->devlink_port);
2eb987
 }
2eb987
-
2eb987
-/**
2eb987
- * ice_devlink_nvm_snapshot - Capture a snapshot of the Shadow RAM contents
2eb987
- * @devlink: the devlink instance
2eb987
- * @extack: extended ACK response structure
2eb987
- * @data: on exit points to snapshot data buffer
2eb987
- *
2eb987
- * This function is called in response to the DEVLINK_CMD_REGION_TRIGGER for
2eb987
- * the shadow-ram devlink region. It captures a snapshot of the shadow ram
2eb987
- * contents. This snapshot can later be viewed via the devlink-region
2eb987
- * interface.
2eb987
- *
2eb987
- * @returns zero on success, and updates the data pointer. Returns a non-zero
2eb987
- * error code on failure.
2eb987
- */
2eb987
-static int ice_devlink_nvm_snapshot(struct devlink *devlink,
2eb987
-				    struct netlink_ext_ack *extack, u8 **data)
2eb987
-{
2eb987
-	struct ice_pf *pf = devlink_priv(devlink);
2eb987
-	struct device *dev = ice_pf_to_dev(pf);
2eb987
-	struct ice_hw *hw = &pf->hw;
2eb987
-	enum ice_status status;
2eb987
-	void *nvm_data;
2eb987
-	u32 nvm_size;
2eb987
-
2eb987
-	nvm_size = hw->nvm.flash_size;
2eb987
-	nvm_data = vzalloc(nvm_size);
2eb987
-	if (!nvm_data)
2eb987
-		return -ENOMEM;
2eb987
-
2eb987
-	status = ice_acquire_nvm(hw, ICE_RES_READ);
2eb987
-	if (status) {
2eb987
-		dev_dbg(dev, "ice_acquire_nvm failed, err %d aq_err %d\n",
2eb987
-			status, hw->adminq.sq_last_status);
2eb987
-		NL_SET_ERR_MSG_MOD(extack, "Failed to acquire NVM semaphore");
2eb987
-		vfree(nvm_data);
2eb987
-		return -EIO;
2eb987
-	}
2eb987
-
2eb987
-	status = ice_read_flat_nvm(hw, 0, &nvm_size, nvm_data, false);
2eb987
-	if (status) {
2eb987
-		dev_dbg(dev, "ice_read_flat_nvm failed after reading %u bytes, err %d aq_err %d\n",
2eb987
-			nvm_size, status, hw->adminq.sq_last_status);
2eb987
-		NL_SET_ERR_MSG_MOD(extack, "Failed to read NVM contents");
2eb987
-		ice_release_nvm(hw);
2eb987
-		vfree(nvm_data);
2eb987
-		return -EIO;
2eb987
-	}
2eb987
-
2eb987
-	ice_release_nvm(hw);
2eb987
-
2eb987
-	*data = nvm_data;
2eb987
-
2eb987
-	return 0;
2eb987
-}
2eb987
-
2eb987
-static const struct devlink_region_ops ice_nvm_region_ops = {
2eb987
-	.name = "nvm-flash",
2eb987
-	.destructor = vfree,
2eb987
-	.snapshot = ice_devlink_nvm_snapshot,
2eb987
-};
2eb987
-
2eb987
-/**
2eb987
- * ice_devlink_init_regions - Initialize devlink regions
2eb987
- * @pf: the PF device structure
2eb987
- *
2eb987
- * Create devlink regions used to enable access to dump the contents of the
2eb987
- * flash memory on the device.
2eb987
- */
2eb987
-void ice_devlink_init_regions(struct ice_pf *pf)
2eb987
-{
2eb987
-	struct devlink *devlink = priv_to_devlink(pf);
2eb987
-	struct device *dev = ice_pf_to_dev(pf);
2eb987
-	u64 nvm_size;
2eb987
-
2eb987
-	nvm_size = pf->hw.nvm.flash_size;
2eb987
-	pf->nvm_region = devlink_region_create(devlink, &ice_nvm_region_ops, 1,
2eb987
-					       nvm_size);
2eb987
-	if (IS_ERR(pf->nvm_region)) {
2eb987
-		dev_err(dev, "failed to create NVM devlink region, err %ld\n",
2eb987
-			PTR_ERR(pf->nvm_region));
2eb987
-		pf->nvm_region = NULL;
2eb987
-	}
2eb987
-}
2eb987
-
2eb987
-/**
2eb987
- * ice_devlink_destroy_regions - Destroy devlink regions
2eb987
- * @pf: the PF device structure
2eb987
- *
2eb987
- * Remove previously created regions for this PF.
2eb987
- */
2eb987
-void ice_devlink_destroy_regions(struct ice_pf *pf)
2eb987
-{
2eb987
-	if (pf->nvm_region)
2eb987
-		devlink_region_destroy(pf->nvm_region);
2eb987
-}
2eb987
diff --git a/drivers/net/ethernet/intel/ice/ice_devlink.h b/drivers/net/ethernet/intel/ice/ice_devlink.h
2eb987
index 6e806a08dc23..f94dc93c24c5 100644
2eb987
--- a/drivers/net/ethernet/intel/ice/ice_devlink.h
2eb987
+++ b/drivers/net/ethernet/intel/ice/ice_devlink.h
2eb987
@@ -11,7 +11,4 @@ void ice_devlink_unregister(struct ice_pf *pf);
2eb987
 int ice_devlink_create_port(struct ice_pf *pf);
2eb987
 void ice_devlink_destroy_port(struct ice_pf *pf);
2eb987
 
2eb987
-void ice_devlink_init_regions(struct ice_pf *pf);
2eb987
-void ice_devlink_destroy_regions(struct ice_pf *pf);
2eb987
-
2eb987
 #endif /* _ICE_DEVLINK_H_ */
2eb987
diff --git a/drivers/net/ethernet/intel/ice/ice_main.c b/drivers/net/ethernet/intel/ice/ice_main.c
2eb987
index 2b02506d0840..1deffd909a13 100644
2eb987
--- a/drivers/net/ethernet/intel/ice/ice_main.c
2eb987
+++ b/drivers/net/ethernet/intel/ice/ice_main.c
2eb987
@@ -3391,8 +3391,6 @@ ice_probe(struct pci_dev *pdev, const struct pci_device_id __always_unused *ent)
2eb987
 		goto err_init_pf_unroll;
2eb987
 	}
2eb987
 
2eb987
-	ice_devlink_init_regions(pf);
2eb987
-
2eb987
 	pf->num_alloc_vsi = hw->func_caps.guar_num_vsi;
2eb987
 	if (!pf->num_alloc_vsi) {
2eb987
 		err = -EIO;
2eb987
@@ -3506,7 +3504,6 @@ ice_probe(struct pci_dev *pdev, const struct pci_device_id __always_unused *ent)
2eb987
 	devm_kfree(dev, pf->vsi);
2eb987
 err_init_pf_unroll:
2eb987
 	ice_deinit_pf(pf);
2eb987
-	ice_devlink_destroy_regions(pf);
2eb987
 	ice_deinit_hw(hw);
2eb987
 err_exit_unroll:
2eb987
 	ice_devlink_unregister(pf);
2eb987
@@ -3552,7 +3549,6 @@ static void ice_remove(struct pci_dev *pdev)
2eb987
 		ice_vsi_free_q_vectors(pf->vsi[i]);
2eb987
 	}
2eb987
 	ice_deinit_pf(pf);
2eb987
-	ice_devlink_destroy_regions(pf);
2eb987
 	ice_deinit_hw(&pf->hw);
2eb987
 	ice_devlink_unregister(pf);
2eb987
 
2eb987
-- 
2eb987
2.13.6
2eb987