mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-22 23:13:01 +02:00 
			
		
		
		
	Merge branch 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/tnguy/linux
Tony Nguyen says: ==================== Prepare for Intel IPU E2000 (GEN3) This is the first part in introducing RDMA support for idpf. ---------------------------------------------------------------- Tatyana Nikolova says: To align with review comments, the patch series introducing RDMA RoCEv2 support for the Intel Infrastructure Processing Unit (IPU) E2000 line of products is going to be submitted in three parts: 1. Modify ice to use specific and common IIDC definitions and pass a core device info to irdma. 2. Add RDMA support to idpf and modify idpf to use specific and common IIDC definitions and pass a core device info to irdma. 3. Add RDMA RoCEv2 support for the E2000 products, referred to as GEN3 to irdma. This first part is a 5 patch series based on the original "iidc/ice/irdma: Update IDC to support multiple consumers" patch to allow for multiple CORE PCI drivers, using the auxbus. Patches: 1) Move header file to new name for clarity and replace ice specific DSCP define with a kernel equivalent one in irdma 2) Unify naming convention 3) Separate header file into common and driver specific info 4) Replace ice specific DSCP define with a kernel equivalent one in ice 5) Implement core device info struct and update drivers to use it ---------------------------------------------------------------- v1: https://lore.kernel.org/20250505212037.2092288-1-anthony.l.nguyen@intel.com IWL reviews: [v5] https://lore.kernel.org/20250416021549.606-1-tatyana.e.nikolova@intel.com [v4] https://lore.kernel.org/20250225050428.2166-1-tatyana.e.nikolova@intel.com [v3] https://lore.kernel.org/20250207194931.1569-1-tatyana.e.nikolova@intel.com [v2] https://lore.kernel.org/20240824031924.421-1-tatyana.e.nikolova@intel.com [v1] https://lore.kernel.org/20240724233917.704-1-tatyana.e.nikolova@intel.com * 'for-next' of git://git.kernel.org/pub/scm/linux/kernel/git/tnguy/linux: iidc/ice/irdma: Update IDC to support multiple consumers ice: Replace ice specific DSCP mapping num with a kernel define iidc/ice/irdma: Break iidc.h into two headers iidc/ice/irdma: Rename to iidc_* convention iidc/ice/irdma: Rename IDC header file ==================== Link: https://patch.msgid.link/20250509200712.2911060-1-anthony.l.nguyen@intel.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
		
						commit
						cc42263172
					
				|  | @ -11902,7 +11902,7 @@ F:	Documentation/networking/device_drivers/ethernet/intel/ | |||
| F:	drivers/net/ethernet/intel/ | ||||
| F:	drivers/net/ethernet/intel/*/ | ||||
| F:	include/linux/avf/virtchnl.h | ||||
| F:	include/linux/net/intel/iidc.h | ||||
| F:	include/linux/net/intel/*/ | ||||
| 
 | ||||
| INTEL ETHERNET PROTOCOL DRIVER FOR RDMA | ||||
| M:	Mustafa Ismail <mustafa.ismail@intel.com> | ||||
|  |  | |||
|  | @ -1,10 +1,8 @@ | |||
| // SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB
 | ||||
| /* Copyright (c) 2015 - 2021 Intel Corporation */ | ||||
| #include "main.h" | ||||
| #include "../../../net/ethernet/intel/ice/ice.h" | ||||
| 
 | ||||
| MODULE_ALIAS("i40iw"); | ||||
| MODULE_AUTHOR("Intel Corporation, <e1000-rdma@lists.sourceforge.net>"); | ||||
| MODULE_DESCRIPTION("Intel(R) Ethernet Protocol Driver for RDMA"); | ||||
| MODULE_LICENSE("Dual BSD/GPL"); | ||||
| 
 | ||||
|  | @ -61,7 +59,7 @@ static void irdma_log_invalid_mtu(u16 mtu, struct irdma_sc_dev *dev) | |||
| } | ||||
| 
 | ||||
| static void irdma_fill_qos_info(struct irdma_l2params *l2params, | ||||
| 				struct iidc_qos_params *qos_info) | ||||
| 				struct iidc_rdma_qos_params *qos_info) | ||||
| { | ||||
| 	int i; | ||||
| 
 | ||||
|  | @ -85,12 +83,13 @@ static void irdma_fill_qos_info(struct irdma_l2params *l2params, | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void irdma_iidc_event_handler(struct ice_pf *pf, struct iidc_event *event) | ||||
| static void irdma_iidc_event_handler(struct iidc_rdma_core_dev_info *cdev_info, | ||||
| 				     struct iidc_rdma_event *event) | ||||
| { | ||||
| 	struct irdma_device *iwdev = dev_get_drvdata(&pf->adev->dev); | ||||
| 	struct irdma_device *iwdev = dev_get_drvdata(&cdev_info->adev->dev); | ||||
| 	struct irdma_l2params l2params = {}; | ||||
| 
 | ||||
| 	if (*event->type & BIT(IIDC_EVENT_AFTER_MTU_CHANGE)) { | ||||
| 	if (*event->type & BIT(IIDC_RDMA_EVENT_AFTER_MTU_CHANGE)) { | ||||
| 		ibdev_dbg(&iwdev->ibdev, "CLNT: new MTU = %d\n", iwdev->netdev->mtu); | ||||
| 		if (iwdev->vsi.mtu != iwdev->netdev->mtu) { | ||||
| 			l2params.mtu = iwdev->netdev->mtu; | ||||
|  | @ -98,25 +97,26 @@ static void irdma_iidc_event_handler(struct ice_pf *pf, struct iidc_event *event | |||
| 			irdma_log_invalid_mtu(l2params.mtu, &iwdev->rf->sc_dev); | ||||
| 			irdma_change_l2params(&iwdev->vsi, &l2params); | ||||
| 		} | ||||
| 	} else if (*event->type & BIT(IIDC_EVENT_BEFORE_TC_CHANGE)) { | ||||
| 	} else if (*event->type & BIT(IIDC_RDMA_EVENT_BEFORE_TC_CHANGE)) { | ||||
| 		if (iwdev->vsi.tc_change_pending) | ||||
| 			return; | ||||
| 
 | ||||
| 		irdma_prep_tc_change(iwdev); | ||||
| 	} else if (*event->type & BIT(IIDC_EVENT_AFTER_TC_CHANGE)) { | ||||
| 		struct iidc_qos_params qos_info = {}; | ||||
| 	} else if (*event->type & BIT(IIDC_RDMA_EVENT_AFTER_TC_CHANGE)) { | ||||
| 		struct iidc_rdma_priv_dev_info *iidc_priv = cdev_info->iidc_priv; | ||||
| 
 | ||||
| 		if (!iwdev->vsi.tc_change_pending) | ||||
| 			return; | ||||
| 
 | ||||
| 		l2params.tc_changed = true; | ||||
| 		ibdev_dbg(&iwdev->ibdev, "CLNT: TC Change\n"); | ||||
| 		ice_get_qos_params(pf, &qos_info); | ||||
| 		irdma_fill_qos_info(&l2params, &qos_info); | ||||
| 
 | ||||
| 		irdma_fill_qos_info(&l2params, &iidc_priv->qos_info); | ||||
| 		if (iwdev->rf->protocol_used != IRDMA_IWARP_PROTOCOL_ONLY) | ||||
| 			iwdev->dcb_vlan_mode = qos_info.num_tc > 1 && !l2params.dscp_mode; | ||||
| 			iwdev->dcb_vlan_mode = | ||||
| 				l2params.num_tc > 1 && !l2params.dscp_mode; | ||||
| 		irdma_change_l2params(&iwdev->vsi, &l2params); | ||||
| 	} else if (*event->type & BIT(IIDC_EVENT_CRIT_ERR)) { | ||||
| 	} else if (*event->type & BIT(IIDC_RDMA_EVENT_CRIT_ERR)) { | ||||
| 		ibdev_warn(&iwdev->ibdev, "ICE OICR event notification: oicr = 0x%08x\n", | ||||
| 			   event->reg); | ||||
| 		if (event->reg & IRDMAPFINT_OICR_PE_CRITERR_M) { | ||||
|  | @ -151,10 +151,8 @@ static void irdma_iidc_event_handler(struct ice_pf *pf, struct iidc_event *event | |||
|  */ | ||||
| static void irdma_request_reset(struct irdma_pci_f *rf) | ||||
| { | ||||
| 	struct ice_pf *pf = rf->cdev; | ||||
| 
 | ||||
| 	ibdev_warn(&rf->iwdev->ibdev, "Requesting a reset\n"); | ||||
| 	ice_rdma_request_reset(pf, IIDC_PFR); | ||||
| 	ice_rdma_request_reset(rf->cdev, IIDC_FUNC_RESET); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  | @ -166,14 +164,15 @@ static int irdma_lan_register_qset(struct irdma_sc_vsi *vsi, | |||
| 				   struct irdma_ws_node *tc_node) | ||||
| { | ||||
| 	struct irdma_device *iwdev = vsi->back_vsi; | ||||
| 	struct ice_pf *pf = iwdev->rf->cdev; | ||||
| 	struct iidc_rdma_core_dev_info *cdev_info; | ||||
| 	struct iidc_rdma_qset_params qset = {}; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	cdev_info = iwdev->rf->cdev; | ||||
| 	qset.qs_handle = tc_node->qs_handle; | ||||
| 	qset.tc = tc_node->traffic_class; | ||||
| 	qset.vport_id = vsi->vsi_idx; | ||||
| 	ret = ice_add_rdma_qset(pf, &qset); | ||||
| 	ret = ice_add_rdma_qset(cdev_info, &qset); | ||||
| 	if (ret) { | ||||
| 		ibdev_dbg(&iwdev->ibdev, "WS: LAN alloc_res for rdma qset failed.\n"); | ||||
| 		return ret; | ||||
|  | @ -194,19 +193,20 @@ static void irdma_lan_unregister_qset(struct irdma_sc_vsi *vsi, | |||
| 				      struct irdma_ws_node *tc_node) | ||||
| { | ||||
| 	struct irdma_device *iwdev = vsi->back_vsi; | ||||
| 	struct ice_pf *pf = iwdev->rf->cdev; | ||||
| 	struct iidc_rdma_core_dev_info *cdev_info; | ||||
| 	struct iidc_rdma_qset_params qset = {}; | ||||
| 
 | ||||
| 	cdev_info = iwdev->rf->cdev; | ||||
| 	qset.qs_handle = tc_node->qs_handle; | ||||
| 	qset.tc = tc_node->traffic_class; | ||||
| 	qset.vport_id = vsi->vsi_idx; | ||||
| 	qset.teid = tc_node->l2_sched_node_id; | ||||
| 
 | ||||
| 	if (ice_del_rdma_qset(pf, &qset)) | ||||
| 	if (ice_del_rdma_qset(cdev_info, &qset)) | ||||
| 		ibdev_dbg(&iwdev->ibdev, "WS: LAN free_res for rdma qset failed.\n"); | ||||
| } | ||||
| 
 | ||||
| static int irdma_init_interrupts(struct irdma_pci_f *rf, struct ice_pf *pf) | ||||
| static int irdma_init_interrupts(struct irdma_pci_f *rf, struct iidc_rdma_core_dev_info *cdev) | ||||
| { | ||||
| 	int i; | ||||
| 
 | ||||
|  | @ -217,12 +217,12 @@ static int irdma_init_interrupts(struct irdma_pci_f *rf, struct ice_pf *pf) | |||
| 		return -ENOMEM; | ||||
| 
 | ||||
| 	for (i = 0; i < rf->msix_count; i++) | ||||
| 		if (ice_alloc_rdma_qvector(pf, &rf->msix_entries[i])) | ||||
| 		if (ice_alloc_rdma_qvector(cdev, &rf->msix_entries[i])) | ||||
| 			break; | ||||
| 
 | ||||
| 	if (i < IRDMA_MIN_MSIX) { | ||||
| 		for (; i > 0; i--) | ||||
| 			ice_free_rdma_qvector(pf, &rf->msix_entries[i]); | ||||
| 			ice_free_rdma_qvector(cdev, &rf->msix_entries[i]); | ||||
| 
 | ||||
| 		kfree(rf->msix_entries); | ||||
| 		return -ENOMEM; | ||||
|  | @ -233,54 +233,63 @@ static int irdma_init_interrupts(struct irdma_pci_f *rf, struct ice_pf *pf) | |||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static void irdma_deinit_interrupts(struct irdma_pci_f *rf, struct ice_pf *pf) | ||||
| static void irdma_deinit_interrupts(struct irdma_pci_f *rf, struct iidc_rdma_core_dev_info *cdev) | ||||
| { | ||||
| 	int i; | ||||
| 
 | ||||
| 	for (i = 0; i < rf->msix_count; i++) | ||||
| 		ice_free_rdma_qvector(pf, &rf->msix_entries[i]); | ||||
| 		ice_free_rdma_qvector(cdev, &rf->msix_entries[i]); | ||||
| 
 | ||||
| 	kfree(rf->msix_entries); | ||||
| } | ||||
| 
 | ||||
| static void irdma_remove(struct auxiliary_device *aux_dev) | ||||
| { | ||||
| 	struct iidc_auxiliary_dev *iidc_adev = container_of(aux_dev, | ||||
| 							    struct iidc_auxiliary_dev, | ||||
| 							    adev); | ||||
| 	struct ice_pf *pf = iidc_adev->pf; | ||||
| 	struct irdma_device *iwdev = auxiliary_get_drvdata(aux_dev); | ||||
| 	struct iidc_rdma_core_auxiliary_dev *iidc_adev; | ||||
| 	struct iidc_rdma_core_dev_info *cdev_info; | ||||
| 
 | ||||
| 	iidc_adev = container_of(aux_dev, struct iidc_rdma_core_auxiliary_dev, adev); | ||||
| 	cdev_info = iidc_adev->cdev_info; | ||||
| 
 | ||||
| 	ice_rdma_update_vsi_filter(cdev_info, iwdev->vsi_num, false); | ||||
| 	irdma_ib_unregister_device(iwdev); | ||||
| 	ice_rdma_update_vsi_filter(pf, iwdev->vsi_num, false); | ||||
| 	irdma_deinit_interrupts(iwdev->rf, pf); | ||||
| 	irdma_deinit_interrupts(iwdev->rf, cdev_info); | ||||
| 
 | ||||
| 	pr_debug("INIT: Gen2 PF[%d] device remove success\n", PCI_FUNC(pf->pdev->devfn)); | ||||
| 	pr_debug("INIT: Gen2 PF[%d] device remove success\n", PCI_FUNC(cdev_info->pdev->devfn)); | ||||
| } | ||||
| 
 | ||||
| static void irdma_fill_device_info(struct irdma_device *iwdev, struct ice_pf *pf, | ||||
| 				   struct ice_vsi *vsi) | ||||
| static void irdma_fill_device_info(struct irdma_device *iwdev, | ||||
| 				   struct iidc_rdma_core_dev_info *cdev_info) | ||||
| { | ||||
| 	struct iidc_rdma_priv_dev_info *iidc_priv = cdev_info->iidc_priv; | ||||
| 	struct irdma_pci_f *rf = iwdev->rf; | ||||
| 
 | ||||
| 	rf->cdev = pf; | ||||
| 	rf->sc_dev.hw = &rf->hw; | ||||
| 	rf->iwdev = iwdev; | ||||
| 	rf->cdev = cdev_info; | ||||
| 	rf->hw.hw_addr = iidc_priv->hw_addr; | ||||
| 	rf->pcidev = cdev_info->pdev; | ||||
| 	rf->hw.device = &rf->pcidev->dev; | ||||
| 	rf->pf_id = iidc_priv->pf_id; | ||||
| 	rf->gen_ops.register_qset = irdma_lan_register_qset; | ||||
| 	rf->gen_ops.unregister_qset = irdma_lan_unregister_qset; | ||||
| 	rf->hw.hw_addr = pf->hw.hw_addr; | ||||
| 	rf->pcidev = pf->pdev; | ||||
| 	rf->pf_id = pf->hw.pf_id; | ||||
| 	rf->default_vsi.vsi_idx = vsi->vsi_num; | ||||
| 	rf->protocol_used = pf->rdma_mode & IIDC_RDMA_PROTOCOL_ROCEV2 ? | ||||
| 			    IRDMA_ROCE_PROTOCOL_ONLY : IRDMA_IWARP_PROTOCOL_ONLY; | ||||
| 
 | ||||
| 	rf->default_vsi.vsi_idx = iidc_priv->vport_id; | ||||
| 	rf->protocol_used = | ||||
| 		cdev_info->rdma_protocol == IIDC_RDMA_PROTOCOL_ROCEV2 ? | ||||
| 		IRDMA_ROCE_PROTOCOL_ONLY : IRDMA_IWARP_PROTOCOL_ONLY; | ||||
| 	rf->rdma_ver = IRDMA_GEN_2; | ||||
| 	rf->rsrc_profile = IRDMA_HMC_PROFILE_DEFAULT; | ||||
| 	rf->rst_to = IRDMA_RST_TIMEOUT_HZ; | ||||
| 	rf->gen_ops.request_reset = irdma_request_reset; | ||||
| 	rf->limits_sel = 7; | ||||
| 	rf->iwdev = iwdev; | ||||
| 
 | ||||
| 	mutex_init(&iwdev->ah_tbl_lock); | ||||
| 	iwdev->netdev = vsi->netdev; | ||||
| 	iwdev->vsi_num = vsi->vsi_num; | ||||
| 
 | ||||
| 	iwdev->netdev = iidc_priv->netdev; | ||||
| 	iwdev->vsi_num = iidc_priv->vport_id; | ||||
| 	iwdev->init_state = INITIAL_STATE; | ||||
| 	iwdev->roce_cwnd = IRDMA_ROCE_CWND_DEFAULT; | ||||
| 	iwdev->roce_ackcreds = IRDMA_ROCE_ACKCREDS_DEFAULT; | ||||
|  | @ -292,19 +301,18 @@ static void irdma_fill_device_info(struct irdma_device *iwdev, struct ice_pf *pf | |||
| 
 | ||||
| static int irdma_probe(struct auxiliary_device *aux_dev, const struct auxiliary_device_id *id) | ||||
| { | ||||
| 	struct iidc_auxiliary_dev *iidc_adev = container_of(aux_dev, | ||||
| 							    struct iidc_auxiliary_dev, | ||||
| 							    adev); | ||||
| 	struct ice_pf *pf = iidc_adev->pf; | ||||
| 	struct ice_vsi *vsi = ice_get_main_vsi(pf); | ||||
| 	struct iidc_qos_params qos_info = {}; | ||||
| 	struct iidc_rdma_core_auxiliary_dev *iidc_adev; | ||||
| 	struct iidc_rdma_core_dev_info *cdev_info; | ||||
| 	struct iidc_rdma_priv_dev_info *iidc_priv; | ||||
| 	struct irdma_l2params l2params = {}; | ||||
| 	struct irdma_device *iwdev; | ||||
| 	struct irdma_pci_f *rf; | ||||
| 	struct irdma_l2params l2params = {}; | ||||
| 	int err; | ||||
| 
 | ||||
| 	if (!vsi) | ||||
| 		return -EIO; | ||||
| 	iidc_adev = container_of(aux_dev, struct iidc_rdma_core_auxiliary_dev, adev); | ||||
| 	cdev_info = iidc_adev->cdev_info; | ||||
| 	iidc_priv = cdev_info->iidc_priv; | ||||
| 
 | ||||
| 	iwdev = ib_alloc_device(irdma_device, ibdev); | ||||
| 	if (!iwdev) | ||||
| 		return -ENOMEM; | ||||
|  | @ -314,10 +322,10 @@ static int irdma_probe(struct auxiliary_device *aux_dev, const struct auxiliary_ | |||
| 		return -ENOMEM; | ||||
| 	} | ||||
| 
 | ||||
| 	irdma_fill_device_info(iwdev, pf, vsi); | ||||
| 	irdma_fill_device_info(iwdev, cdev_info); | ||||
| 	rf = iwdev->rf; | ||||
| 
 | ||||
| 	err = irdma_init_interrupts(rf, pf); | ||||
| 	err = irdma_init_interrupts(rf, cdev_info); | ||||
| 	if (err) | ||||
| 		goto err_init_interrupts; | ||||
| 
 | ||||
|  | @ -326,8 +334,7 @@ static int irdma_probe(struct auxiliary_device *aux_dev, const struct auxiliary_ | |||
| 		goto err_ctrl_init; | ||||
| 
 | ||||
| 	l2params.mtu = iwdev->netdev->mtu; | ||||
| 	ice_get_qos_params(pf, &qos_info); | ||||
| 	irdma_fill_qos_info(&l2params, &qos_info); | ||||
| 	irdma_fill_qos_info(&l2params, &iidc_priv->qos_info); | ||||
| 	if (iwdev->rf->protocol_used != IRDMA_IWARP_PROTOCOL_ONLY) | ||||
| 		iwdev->dcb_vlan_mode = l2params.num_tc > 1 && !l2params.dscp_mode; | ||||
| 
 | ||||
|  | @ -339,7 +346,7 @@ static int irdma_probe(struct auxiliary_device *aux_dev, const struct auxiliary_ | |||
| 	if (err) | ||||
| 		goto err_ibreg; | ||||
| 
 | ||||
| 	ice_rdma_update_vsi_filter(pf, iwdev->vsi_num, true); | ||||
| 	ice_rdma_update_vsi_filter(cdev_info, iwdev->vsi_num, true); | ||||
| 
 | ||||
| 	ibdev_dbg(&iwdev->ibdev, "INIT: Gen2 PF[%d] device probe success\n", PCI_FUNC(rf->pcidev->devfn)); | ||||
| 	auxiliary_set_drvdata(aux_dev, iwdev); | ||||
|  | @ -351,7 +358,7 @@ err_ibreg: | |||
| err_rt_init: | ||||
| 	irdma_ctrl_deinit_hw(rf); | ||||
| err_ctrl_init: | ||||
| 	irdma_deinit_interrupts(rf, pf); | ||||
| 	irdma_deinit_interrupts(rf, cdev_info); | ||||
| err_init_interrupts: | ||||
| 	kfree(iwdev->rf); | ||||
| 	ib_dealloc_device(&iwdev->ibdev); | ||||
|  | @ -367,7 +374,7 @@ static const struct auxiliary_device_id irdma_auxiliary_id_table[] = { | |||
| 
 | ||||
| MODULE_DEVICE_TABLE(auxiliary, irdma_auxiliary_id_table); | ||||
| 
 | ||||
| static struct iidc_auxiliary_drv irdma_auxiliary_drv = { | ||||
| static struct iidc_rdma_core_auxiliary_drv irdma_auxiliary_drv = { | ||||
| 	.adrv = { | ||||
| 	    .id_table = irdma_auxiliary_id_table, | ||||
| 	    .probe = irdma_probe, | ||||
|  |  | |||
|  | @ -29,7 +29,8 @@ | |||
| #include <linux/io-64-nonatomic-lo-hi.h> | ||||
| #endif | ||||
| #include <linux/auxiliary_bus.h> | ||||
| #include <linux/net/intel/iidc.h> | ||||
| #include <linux/net/intel/iidc_rdma.h> | ||||
| #include <linux/net/intel/iidc_rdma_ice.h> | ||||
| #include <rdma/ib_smi.h> | ||||
| #include <rdma/ib_verbs.h> | ||||
| #include <rdma/ib_pack.h> | ||||
|  |  | |||
|  | @ -5,8 +5,8 @@ | |||
| 
 | ||||
| #include <linux/pci.h> | ||||
| #include <linux/bitfield.h> | ||||
| #include <linux/net/intel/iidc.h> | ||||
| #include <rdma/ib_verbs.h> | ||||
| #include <net/dscp.h> | ||||
| 
 | ||||
| #define STATS_TIMER_DELAY	60000 | ||||
| 
 | ||||
|  |  | |||
|  | @ -567,7 +567,7 @@ struct irdma_sc_vsi { | |||
| 	u8 qos_rel_bw; | ||||
| 	u8 qos_prio_type; | ||||
| 	u8 stats_idx; | ||||
| 	u8 dscp_map[IIDC_MAX_DSCP_MAPPING]; | ||||
| 	u8 dscp_map[DSCP_MAX]; | ||||
| 	struct irdma_qos qos[IRDMA_MAX_USER_PRIORITY]; | ||||
| 	u64 hw_stats_regs[IRDMA_HW_STAT_INDEX_MAX_GEN_1]; | ||||
| 	bool dscp_mode:1; | ||||
|  | @ -695,7 +695,7 @@ struct irdma_l2params { | |||
| 	u16 qs_handle_list[IRDMA_MAX_USER_PRIORITY]; | ||||
| 	u16 mtu; | ||||
| 	u8 up2tc[IRDMA_MAX_USER_PRIORITY]; | ||||
| 	u8 dscp_map[IIDC_MAX_DSCP_MAPPING]; | ||||
| 	u8 dscp_map[DSCP_MAX]; | ||||
| 	u8 num_tc; | ||||
| 	u8 vsi_rel_bw; | ||||
| 	u8 vsi_prio_type; | ||||
|  |  | |||
|  | @ -1339,8 +1339,13 @@ ice_devlink_enable_roce_get(struct devlink *devlink, u32 id, | |||
| 			    struct devlink_param_gset_ctx *ctx) | ||||
| { | ||||
| 	struct ice_pf *pf = devlink_priv(devlink); | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 
 | ||||
| 	ctx->val.vbool = pf->rdma_mode & IIDC_RDMA_PROTOCOL_ROCEV2 ? true : false; | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (!cdev) | ||||
| 		return -ENODEV; | ||||
| 
 | ||||
| 	ctx->val.vbool = !!(cdev->rdma_protocol & IIDC_RDMA_PROTOCOL_ROCEV2); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
|  | @ -1350,19 +1355,24 @@ static int ice_devlink_enable_roce_set(struct devlink *devlink, u32 id, | |||
| 				       struct netlink_ext_ack *extack) | ||||
| { | ||||
| 	struct ice_pf *pf = devlink_priv(devlink); | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 	bool roce_ena = ctx->val.vbool; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (!cdev) | ||||
| 		return -ENODEV; | ||||
| 
 | ||||
| 	if (!roce_ena) { | ||||
| 		ice_unplug_aux_dev(pf); | ||||
| 		pf->rdma_mode &= ~IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 		cdev->rdma_protocol &= ~IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 		return 0; | ||||
| 	} | ||||
| 
 | ||||
| 	pf->rdma_mode |= IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 	cdev->rdma_protocol |= IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 	ret = ice_plug_aux_dev(pf); | ||||
| 	if (ret) | ||||
| 		pf->rdma_mode &= ~IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 		cdev->rdma_protocol &= ~IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 
 | ||||
| 	return ret; | ||||
| } | ||||
|  | @ -1373,11 +1383,16 @@ ice_devlink_enable_roce_validate(struct devlink *devlink, u32 id, | |||
| 				 struct netlink_ext_ack *extack) | ||||
| { | ||||
| 	struct ice_pf *pf = devlink_priv(devlink); | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 
 | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (!cdev) | ||||
| 		return -ENODEV; | ||||
| 
 | ||||
| 	if (!test_bit(ICE_FLAG_RDMA_ENA, pf->flags)) | ||||
| 		return -EOPNOTSUPP; | ||||
| 
 | ||||
| 	if (pf->rdma_mode & IIDC_RDMA_PROTOCOL_IWARP) { | ||||
| 	if (cdev->rdma_protocol & IIDC_RDMA_PROTOCOL_IWARP) { | ||||
| 		NL_SET_ERR_MSG_MOD(extack, "iWARP is currently enabled. This device cannot enable iWARP and RoCEv2 simultaneously"); | ||||
| 		return -EOPNOTSUPP; | ||||
| 	} | ||||
|  | @ -1390,8 +1405,13 @@ ice_devlink_enable_iw_get(struct devlink *devlink, u32 id, | |||
| 			  struct devlink_param_gset_ctx *ctx) | ||||
| { | ||||
| 	struct ice_pf *pf = devlink_priv(devlink); | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 
 | ||||
| 	ctx->val.vbool = pf->rdma_mode & IIDC_RDMA_PROTOCOL_IWARP; | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (!cdev) | ||||
| 		return -ENODEV; | ||||
| 
 | ||||
| 	ctx->val.vbool = !!(cdev->rdma_protocol & IIDC_RDMA_PROTOCOL_IWARP); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
|  | @ -1401,19 +1421,24 @@ static int ice_devlink_enable_iw_set(struct devlink *devlink, u32 id, | |||
| 				     struct netlink_ext_ack *extack) | ||||
| { | ||||
| 	struct ice_pf *pf = devlink_priv(devlink); | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 	bool iw_ena = ctx->val.vbool; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (!cdev) | ||||
| 		return -ENODEV; | ||||
| 
 | ||||
| 	if (!iw_ena) { | ||||
| 		ice_unplug_aux_dev(pf); | ||||
| 		pf->rdma_mode &= ~IIDC_RDMA_PROTOCOL_IWARP; | ||||
| 		cdev->rdma_protocol &= ~IIDC_RDMA_PROTOCOL_IWARP; | ||||
| 		return 0; | ||||
| 	} | ||||
| 
 | ||||
| 	pf->rdma_mode |= IIDC_RDMA_PROTOCOL_IWARP; | ||||
| 	cdev->rdma_protocol |= IIDC_RDMA_PROTOCOL_IWARP; | ||||
| 	ret = ice_plug_aux_dev(pf); | ||||
| 	if (ret) | ||||
| 		pf->rdma_mode &= ~IIDC_RDMA_PROTOCOL_IWARP; | ||||
| 		cdev->rdma_protocol &= ~IIDC_RDMA_PROTOCOL_IWARP; | ||||
| 
 | ||||
| 	return ret; | ||||
| } | ||||
|  | @ -1428,7 +1453,7 @@ ice_devlink_enable_iw_validate(struct devlink *devlink, u32 id, | |||
| 	if (!test_bit(ICE_FLAG_RDMA_ENA, pf->flags)) | ||||
| 		return -EOPNOTSUPP; | ||||
| 
 | ||||
| 	if (pf->rdma_mode & IIDC_RDMA_PROTOCOL_ROCEV2) { | ||||
| 	if (pf->cdev_info->rdma_protocol & IIDC_RDMA_PROTOCOL_ROCEV2) { | ||||
| 		NL_SET_ERR_MSG_MOD(extack, "RoCEv2 is currently enabled. This device cannot enable iWARP and RoCEv2 simultaneously"); | ||||
| 		return -EOPNOTSUPP; | ||||
| 	} | ||||
|  |  | |||
|  | @ -399,7 +399,6 @@ struct ice_vsi { | |||
| 	u16 req_rxq;			 /* User requested Rx queues */ | ||||
| 	u16 num_rx_desc; | ||||
| 	u16 num_tx_desc; | ||||
| 	u16 qset_handle[ICE_MAX_TRAFFIC_CLASS]; | ||||
| 	struct ice_tc_cfg tc_cfg; | ||||
| 	struct bpf_prog *xdp_prog; | ||||
| 	struct ice_tx_ring **xdp_rings;	 /* XDP ring array */ | ||||
|  | @ -556,7 +555,6 @@ struct ice_pf { | |||
| 	struct devlink_port devlink_port; | ||||
| 
 | ||||
| 	/* OS reserved IRQ details */ | ||||
| 	struct msix_entry *msix_entries; | ||||
| 	struct ice_irq_tracker irq_tracker; | ||||
| 	struct ice_virt_irq_tracker virt_irq_tracker; | ||||
| 
 | ||||
|  | @ -591,7 +589,6 @@ struct ice_pf { | |||
| 	struct gnss_serial *gnss_serial; | ||||
| 	struct gnss_device *gnss_dev; | ||||
| 	u16 num_rdma_msix;		/* Total MSIX vectors for RDMA driver */ | ||||
| 	u16 rdma_base_vector; | ||||
| 
 | ||||
| 	/* spinlock to protect the AdminQ wait list */ | ||||
| 	spinlock_t aq_wait_lock; | ||||
|  | @ -624,14 +621,12 @@ struct ice_pf { | |||
| 	struct ice_hw_port_stats stats_prev; | ||||
| 	struct ice_hw hw; | ||||
| 	u8 stat_prev_loaded:1; /* has previous stats been loaded */ | ||||
| 	u8 rdma_mode; | ||||
| 	u16 dcbx_cap; | ||||
| 	u32 tx_timeout_count; | ||||
| 	unsigned long tx_timeout_last_recovery; | ||||
| 	u32 tx_timeout_recovery_level; | ||||
| 	char int_name[ICE_INT_NAME_STR_LEN]; | ||||
| 	char int_name_ll_ts[ICE_INT_NAME_STR_LEN]; | ||||
| 	struct auxiliary_device *adev; | ||||
| 	int aux_idx; | ||||
| 	u32 sw_int_count; | ||||
| 	/* count of tc_flower filters specific to channel (aka where filter
 | ||||
|  | @ -663,6 +658,7 @@ struct ice_pf { | |||
| 	struct ice_dplls dplls; | ||||
| 	struct device *hwmon_dev; | ||||
| 	struct ice_health health_reporters; | ||||
| 	struct iidc_rdma_core_dev_info *cdev_info; | ||||
| 
 | ||||
| 	u8 num_quanta_prof_used; | ||||
| }; | ||||
|  |  | |||
|  | @ -1288,7 +1288,7 @@ ice_add_dscp_up_tlv(struct ice_lldp_org_tlv *tlv, struct ice_dcbx_cfg *dcbcfg) | |||
| 	tlv->ouisubtype = htonl(ouisubtype); | ||||
| 
 | ||||
| 	/* bytes 0 - 63 - IPv4 DSCP2UP LUT */ | ||||
| 	for (i = 0; i < ICE_DSCP_NUM_VAL; i++) { | ||||
| 	for (i = 0; i < DSCP_MAX; i++) { | ||||
| 		/* IPv4 mapping */ | ||||
| 		buf[i] = dcbcfg->dscp_map[i]; | ||||
| 		/* IPv6 mapping */ | ||||
|  |  | |||
|  | @ -352,8 +352,8 @@ int ice_pf_dcb_cfg(struct ice_pf *pf, struct ice_dcbx_cfg *new_cfg, bool locked) | |||
| 	struct ice_aqc_port_ets_elem buf = { 0 }; | ||||
| 	struct ice_dcbx_cfg *old_cfg, *curr_cfg; | ||||
| 	struct device *dev = ice_pf_to_dev(pf); | ||||
| 	struct iidc_rdma_event *event; | ||||
| 	int ret = ICE_DCB_NO_HW_CHG; | ||||
| 	struct iidc_event *event; | ||||
| 	struct ice_vsi *pf_vsi; | ||||
| 
 | ||||
| 	curr_cfg = &pf->hw.port_info->qos_cfg.local_dcbx_cfg; | ||||
|  | @ -405,7 +405,7 @@ int ice_pf_dcb_cfg(struct ice_pf *pf, struct ice_dcbx_cfg *new_cfg, bool locked) | |||
| 		goto free_cfg; | ||||
| 	} | ||||
| 
 | ||||
| 	set_bit(IIDC_EVENT_BEFORE_TC_CHANGE, event->type); | ||||
| 	set_bit(IIDC_RDMA_EVENT_BEFORE_TC_CHANGE, event->type); | ||||
| 	ice_send_event_to_aux(pf, event); | ||||
| 	kfree(event); | ||||
| 
 | ||||
|  | @ -740,7 +740,9 @@ static int ice_dcb_noncontig_cfg(struct ice_pf *pf) | |||
| void ice_pf_dcb_recfg(struct ice_pf *pf, bool locked) | ||||
| { | ||||
| 	struct ice_dcbx_cfg *dcbcfg = &pf->hw.port_info->qos_cfg.local_dcbx_cfg; | ||||
| 	struct iidc_event *event; | ||||
| 	struct iidc_rdma_priv_dev_info *privd; | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 	struct iidc_rdma_event *event; | ||||
| 	u8 tc_map = 0; | ||||
| 	int v, ret; | ||||
| 
 | ||||
|  | @ -783,13 +785,17 @@ void ice_pf_dcb_recfg(struct ice_pf *pf, bool locked) | |||
| 		if (vsi->type == ICE_VSI_PF) | ||||
| 			ice_dcbnl_set_all(vsi); | ||||
| 	} | ||||
| 	if (!locked) { | ||||
| 
 | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (cdev && !locked) { | ||||
| 		privd = cdev->iidc_priv; | ||||
| 		ice_setup_dcb_qos_info(pf, &privd->qos_info); | ||||
| 		/* Notify the AUX drivers that TC change is finished */ | ||||
| 		event = kzalloc(sizeof(*event), GFP_KERNEL); | ||||
| 		if (!event) | ||||
| 			return; | ||||
| 
 | ||||
| 		set_bit(IIDC_EVENT_AFTER_TC_CHANGE, event->type); | ||||
| 		set_bit(IIDC_RDMA_EVENT_AFTER_TC_CHANGE, event->type); | ||||
| 		ice_send_event_to_aux(pf, event); | ||||
| 		kfree(event); | ||||
| 	} | ||||
|  | @ -944,6 +950,37 @@ ice_tx_prepare_vlan_flags_dcb(struct ice_tx_ring *tx_ring, | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  * ice_setup_dcb_qos_info - Setup DCB QoS information | ||||
|  * @pf: ptr to ice_pf | ||||
|  * @qos_info: QoS param instance | ||||
|  */ | ||||
| void ice_setup_dcb_qos_info(struct ice_pf *pf, struct iidc_rdma_qos_params *qos_info) | ||||
| { | ||||
| 	struct ice_dcbx_cfg *dcbx_cfg; | ||||
| 	unsigned int i; | ||||
| 	u32 up2tc; | ||||
| 
 | ||||
| 	if (!pf || !qos_info) | ||||
| 		return; | ||||
| 
 | ||||
| 	dcbx_cfg = &pf->hw.port_info->qos_cfg.local_dcbx_cfg; | ||||
| 	up2tc = rd32(&pf->hw, PRTDCB_TUP2TC); | ||||
| 
 | ||||
| 	qos_info->num_tc = ice_dcb_get_num_tc(dcbx_cfg); | ||||
| 
 | ||||
| 	for (i = 0; i < IIDC_MAX_USER_PRIORITY; i++) | ||||
| 		qos_info->up2tc[i] = (up2tc >> (i * 3)) & 0x7; | ||||
| 
 | ||||
| 	for (i = 0; i < IEEE_8021QAZ_MAX_TCS; i++) | ||||
| 		qos_info->tc_info[i].rel_bw = dcbx_cfg->etscfg.tcbwtable[i]; | ||||
| 
 | ||||
| 	qos_info->pfc_mode = dcbx_cfg->pfc_mode; | ||||
| 	if (qos_info->pfc_mode == IIDC_DSCP_PFC_MODE) | ||||
| 		for (i = 0; i < DSCP_MAX; i++) | ||||
| 			qos_info->dscp_map[i] = dcbx_cfg->dscp_map[i]; | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  * ice_dcb_is_mib_change_pending - Check if MIB change is pending | ||||
|  * @state: MIB change state | ||||
|  |  | |||
|  | @ -31,6 +31,9 @@ void | |||
| ice_tx_prepare_vlan_flags_dcb(struct ice_tx_ring *tx_ring, | ||||
| 			      struct ice_tx_buf *first); | ||||
| void | ||||
| ice_setup_dcb_qos_info(struct ice_pf *pf, | ||||
| 		       struct iidc_rdma_qos_params *qos_info); | ||||
| void | ||||
| ice_dcb_process_lldp_set_mib_change(struct ice_pf *pf, | ||||
| 				    struct ice_rq_event_info *event); | ||||
| /**
 | ||||
|  | @ -134,5 +137,11 @@ static inline void ice_update_dcb_stats(struct ice_pf *pf) { } | |||
| static inline void | ||||
| ice_dcb_process_lldp_set_mib_change(struct ice_pf *pf, struct ice_rq_event_info *event) { } | ||||
| static inline void ice_set_cgd_num(struct ice_tlan_ctx *tlan_ctx, u8 dcb_tc) { } | ||||
| static inline void | ||||
| ice_setup_dcb_qos_info(struct ice_pf *pf, struct iidc_rdma_qos_params *qos_info) | ||||
| { | ||||
| 	qos_info->num_tc = 1; | ||||
| 	qos_info->tc_info[0].rel_bw = 100; | ||||
| } | ||||
| #endif /* CONFIG_DCB */ | ||||
| #endif /* _ICE_DCB_LIB_H_ */ | ||||
|  |  | |||
|  | @ -754,7 +754,7 @@ static int ice_dcbnl_setapp(struct net_device *netdev, struct dcb_app *app) | |||
| 	if (!ice_is_feature_supported(pf, ICE_F_DSCP)) | ||||
| 		return -EOPNOTSUPP; | ||||
| 
 | ||||
| 	if (app->protocol >= ICE_DSCP_NUM_VAL) { | ||||
| 	if (app->protocol >= DSCP_MAX) { | ||||
| 		netdev_err(netdev, "DSCP value 0x%04X out of range\n", | ||||
| 			   app->protocol); | ||||
| 		return -EINVAL; | ||||
|  | @ -931,7 +931,7 @@ static int ice_dcbnl_delapp(struct net_device *netdev, struct dcb_app *app) | |||
| 	/* if the last DSCP mapping just got deleted, need to switch
 | ||||
| 	 * to L2 VLAN QoS mode | ||||
| 	 */ | ||||
| 	if (bitmap_empty(new_cfg->dscp_mapped, ICE_DSCP_NUM_VAL) && | ||||
| 	if (bitmap_empty(new_cfg->dscp_mapped, DSCP_MAX) && | ||||
| 	    new_cfg->pfc_mode == ICE_QOS_MODE_DSCP) { | ||||
| 		ret = ice_aq_set_pfc_mode(&pf->hw, | ||||
| 					  ICE_AQC_PFC_VLAN_BASED_PFC, | ||||
|  |  | |||
|  | @ -3964,11 +3964,11 @@ static int ice_set_channels(struct net_device *dev, struct ethtool_channels *ch) | |||
| 		return -EINVAL; | ||||
| 	} | ||||
| 
 | ||||
| 	if (pf->adev) { | ||||
| 	if (pf->cdev_info && pf->cdev_info->adev) { | ||||
| 		mutex_lock(&pf->adev_mutex); | ||||
| 		device_lock(&pf->adev->dev); | ||||
| 		device_lock(&pf->cdev_info->adev->dev); | ||||
| 		locked = true; | ||||
| 		if (pf->adev->dev.driver) { | ||||
| 		if (pf->cdev_info->adev->dev.driver) { | ||||
| 			netdev_err(dev, "Cannot change channels when RDMA is active\n"); | ||||
| 			ret = -EBUSY; | ||||
| 			goto adev_unlock; | ||||
|  | @ -3987,7 +3987,7 @@ static int ice_set_channels(struct net_device *dev, struct ethtool_channels *ch) | |||
| 
 | ||||
| adev_unlock: | ||||
| 	if (locked) { | ||||
| 		device_unlock(&pf->adev->dev); | ||||
| 		device_unlock(&pf->cdev_info->adev->dev); | ||||
| 		mutex_unlock(&pf->adev_mutex); | ||||
| 	} | ||||
| 	return ret; | ||||
|  |  | |||
|  | @ -9,22 +9,25 @@ | |||
| static DEFINE_XARRAY_ALLOC1(ice_aux_id); | ||||
| 
 | ||||
| /**
 | ||||
|  * ice_get_auxiliary_drv - retrieve iidc_auxiliary_drv struct | ||||
|  * @pf: pointer to PF struct | ||||
|  * ice_get_auxiliary_drv - retrieve iidc_rdma_core_auxiliary_drv struct | ||||
|  * @cdev: pointer to iidc_rdma_core_dev_info struct | ||||
|  * | ||||
|  * This function has to be called with a device_lock on the | ||||
|  * pf->adev.dev to avoid race conditions. | ||||
|  * cdev->adev.dev to avoid race conditions. | ||||
|  * | ||||
|  * Return: pointer to the matched auxiliary driver struct | ||||
|  */ | ||||
| static struct iidc_auxiliary_drv *ice_get_auxiliary_drv(struct ice_pf *pf) | ||||
| static struct iidc_rdma_core_auxiliary_drv * | ||||
| ice_get_auxiliary_drv(struct iidc_rdma_core_dev_info *cdev) | ||||
| { | ||||
| 	struct auxiliary_device *adev; | ||||
| 
 | ||||
| 	adev = pf->adev; | ||||
| 	adev = cdev->adev; | ||||
| 	if (!adev || !adev->dev.driver) | ||||
| 		return NULL; | ||||
| 
 | ||||
| 	return container_of(adev->dev.driver, struct iidc_auxiliary_drv, | ||||
| 			    adrv.driver); | ||||
| 	return container_of(adev->dev.driver, | ||||
| 			    struct iidc_rdma_core_auxiliary_drv, adrv.driver); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  | @ -32,44 +35,54 @@ static struct iidc_auxiliary_drv *ice_get_auxiliary_drv(struct ice_pf *pf) | |||
|  * @pf: pointer to PF struct | ||||
|  * @event: event struct | ||||
|  */ | ||||
| void ice_send_event_to_aux(struct ice_pf *pf, struct iidc_event *event) | ||||
| void ice_send_event_to_aux(struct ice_pf *pf, struct iidc_rdma_event *event) | ||||
| { | ||||
| 	struct iidc_auxiliary_drv *iadrv; | ||||
| 	struct iidc_rdma_core_auxiliary_drv *iadrv; | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 
 | ||||
| 	if (WARN_ON_ONCE(!in_task())) | ||||
| 		return; | ||||
| 
 | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (!cdev) | ||||
| 		return; | ||||
| 
 | ||||
| 	mutex_lock(&pf->adev_mutex); | ||||
| 	if (!pf->adev) | ||||
| 	if (!cdev->adev) | ||||
| 		goto finish; | ||||
| 
 | ||||
| 	device_lock(&pf->adev->dev); | ||||
| 	iadrv = ice_get_auxiliary_drv(pf); | ||||
| 	device_lock(&cdev->adev->dev); | ||||
| 	iadrv = ice_get_auxiliary_drv(cdev); | ||||
| 	if (iadrv && iadrv->event_handler) | ||||
| 		iadrv->event_handler(pf, event); | ||||
| 	device_unlock(&pf->adev->dev); | ||||
| 		iadrv->event_handler(cdev, event); | ||||
| 	device_unlock(&cdev->adev->dev); | ||||
| finish: | ||||
| 	mutex_unlock(&pf->adev_mutex); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  * ice_add_rdma_qset - Add Leaf Node for RDMA Qset | ||||
|  * @pf: PF struct | ||||
|  * @cdev: pointer to iidc_rdma_core_dev_info struct | ||||
|  * @qset: Resource to be allocated | ||||
|  * | ||||
|  * Return: Zero on success or error code encountered | ||||
|  */ | ||||
| int ice_add_rdma_qset(struct ice_pf *pf, struct iidc_rdma_qset_params *qset) | ||||
| int ice_add_rdma_qset(struct iidc_rdma_core_dev_info *cdev, | ||||
| 		      struct iidc_rdma_qset_params *qset) | ||||
| { | ||||
| 	u16 max_rdmaqs[ICE_MAX_TRAFFIC_CLASS]; | ||||
| 	struct ice_vsi *vsi; | ||||
| 	struct device *dev; | ||||
| 	struct ice_pf *pf; | ||||
| 	u32 qset_teid; | ||||
| 	u16 qs_handle; | ||||
| 	int status; | ||||
| 	int i; | ||||
| 
 | ||||
| 	if (WARN_ON(!pf || !qset)) | ||||
| 	if (WARN_ON(!cdev || !qset)) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	pf = pci_get_drvdata(cdev->pdev); | ||||
| 	dev = ice_pf_to_dev(pf); | ||||
| 
 | ||||
| 	if (!ice_is_rdma_ena(pf)) | ||||
|  | @ -100,7 +113,6 @@ int ice_add_rdma_qset(struct ice_pf *pf, struct iidc_rdma_qset_params *qset) | |||
| 		dev_err(dev, "Failed VSI RDMA Qset enable\n"); | ||||
| 		return status; | ||||
| 	} | ||||
| 	vsi->qset_handle[qset->tc] = qset->qs_handle; | ||||
| 	qset->teid = qset_teid; | ||||
| 
 | ||||
| 	return 0; | ||||
|  | @ -109,18 +121,23 @@ EXPORT_SYMBOL_GPL(ice_add_rdma_qset); | |||
| 
 | ||||
| /**
 | ||||
|  * ice_del_rdma_qset - Delete leaf node for RDMA Qset | ||||
|  * @pf: PF struct | ||||
|  * @cdev: pointer to iidc_rdma_core_dev_info struct | ||||
|  * @qset: Resource to be freed | ||||
|  * | ||||
|  * Return: Zero on success, error code on failure | ||||
|  */ | ||||
| int ice_del_rdma_qset(struct ice_pf *pf, struct iidc_rdma_qset_params *qset) | ||||
| int ice_del_rdma_qset(struct iidc_rdma_core_dev_info *cdev, | ||||
| 		      struct iidc_rdma_qset_params *qset) | ||||
| { | ||||
| 	struct ice_vsi *vsi; | ||||
| 	struct ice_pf *pf; | ||||
| 	u32 teid; | ||||
| 	u16 q_id; | ||||
| 
 | ||||
| 	if (WARN_ON(!pf || !qset)) | ||||
| 	if (WARN_ON(!cdev || !qset)) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	pf = pci_get_drvdata(cdev->pdev); | ||||
| 	vsi = ice_find_vsi(pf, qset->vport_id); | ||||
| 	if (!vsi) { | ||||
| 		dev_err(ice_pf_to_dev(pf), "RDMA Invalid VSI\n"); | ||||
|  | @ -130,36 +147,36 @@ int ice_del_rdma_qset(struct ice_pf *pf, struct iidc_rdma_qset_params *qset) | |||
| 	q_id = qset->qs_handle; | ||||
| 	teid = qset->teid; | ||||
| 
 | ||||
| 	vsi->qset_handle[qset->tc] = 0; | ||||
| 
 | ||||
| 	return ice_dis_vsi_rdma_qset(vsi->port_info, 1, &teid, &q_id); | ||||
| } | ||||
| EXPORT_SYMBOL_GPL(ice_del_rdma_qset); | ||||
| 
 | ||||
| /**
 | ||||
|  * ice_rdma_request_reset - accept request from RDMA to perform a reset | ||||
|  * @pf: struct for PF | ||||
|  * @cdev: pointer to iidc_rdma_core_dev_info struct | ||||
|  * @reset_type: type of reset | ||||
|  * | ||||
|  * Return: Zero on success, error code on failure | ||||
|  */ | ||||
| int ice_rdma_request_reset(struct ice_pf *pf, enum iidc_reset_type reset_type) | ||||
| int ice_rdma_request_reset(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			   enum iidc_rdma_reset_type reset_type) | ||||
| { | ||||
| 	enum ice_reset_req reset; | ||||
| 	struct ice_pf *pf; | ||||
| 
 | ||||
| 	if (WARN_ON(!pf)) | ||||
| 	if (WARN_ON(!cdev)) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	pf = pci_get_drvdata(cdev->pdev); | ||||
| 
 | ||||
| 	switch (reset_type) { | ||||
| 	case IIDC_PFR: | ||||
| 	case IIDC_FUNC_RESET: | ||||
| 		reset = ICE_RESET_PFR; | ||||
| 		break; | ||||
| 	case IIDC_CORER: | ||||
| 	case IIDC_DEV_RESET: | ||||
| 		reset = ICE_RESET_CORER; | ||||
| 		break; | ||||
| 	case IIDC_GLOBR: | ||||
| 		reset = ICE_RESET_GLOBR; | ||||
| 		break; | ||||
| 	default: | ||||
| 		dev_err(ice_pf_to_dev(pf), "incorrect reset request\n"); | ||||
| 		return -EINVAL; | ||||
| 	} | ||||
| 
 | ||||
|  | @ -169,18 +186,23 @@ EXPORT_SYMBOL_GPL(ice_rdma_request_reset); | |||
| 
 | ||||
| /**
 | ||||
|  * ice_rdma_update_vsi_filter - update main VSI filters for RDMA | ||||
|  * @pf: pointer to struct for PF | ||||
|  * @cdev: pointer to iidc_rdma_core_dev_info struct | ||||
|  * @vsi_id: VSI HW idx to update filter on | ||||
|  * @enable: bool whether to enable or disable filters | ||||
|  * | ||||
|  * Return: Zero on success, error code on failure | ||||
|  */ | ||||
| int ice_rdma_update_vsi_filter(struct ice_pf *pf, u16 vsi_id, bool enable) | ||||
| int ice_rdma_update_vsi_filter(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			       u16 vsi_id, bool enable) | ||||
| { | ||||
| 	struct ice_vsi *vsi; | ||||
| 	struct ice_pf *pf; | ||||
| 	int status; | ||||
| 
 | ||||
| 	if (WARN_ON(!pf)) | ||||
| 	if (WARN_ON(!cdev)) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	pf = pci_get_drvdata(cdev->pdev); | ||||
| 	vsi = ice_find_vsi(pf, vsi_id); | ||||
| 	if (!vsi) | ||||
| 		return -EINVAL; | ||||
|  | @ -201,37 +223,23 @@ int ice_rdma_update_vsi_filter(struct ice_pf *pf, u16 vsi_id, bool enable) | |||
| EXPORT_SYMBOL_GPL(ice_rdma_update_vsi_filter); | ||||
| 
 | ||||
| /**
 | ||||
|  * ice_get_qos_params - parse QoS params for RDMA consumption | ||||
|  * @pf: pointer to PF struct | ||||
|  * @qos: set of QoS values | ||||
|  * ice_alloc_rdma_qvector - alloc vector resources reserved for RDMA driver | ||||
|  * @cdev: pointer to iidc_rdma_core_dev_info struct | ||||
|  * @entry: MSI-X entry to be removed | ||||
|  * | ||||
|  * Return: Zero on success, error code on failure | ||||
|  */ | ||||
| void ice_get_qos_params(struct ice_pf *pf, struct iidc_qos_params *qos) | ||||
| int ice_alloc_rdma_qvector(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			   struct msix_entry *entry) | ||||
| { | ||||
| 	struct ice_dcbx_cfg *dcbx_cfg; | ||||
| 	unsigned int i; | ||||
| 	u32 up2tc; | ||||
| 	struct msi_map map; | ||||
| 	struct ice_pf *pf; | ||||
| 
 | ||||
| 	dcbx_cfg = &pf->hw.port_info->qos_cfg.local_dcbx_cfg; | ||||
| 	up2tc = rd32(&pf->hw, PRTDCB_TUP2TC); | ||||
| 
 | ||||
| 	qos->num_tc = ice_dcb_get_num_tc(dcbx_cfg); | ||||
| 	for (i = 0; i < IIDC_MAX_USER_PRIORITY; i++) | ||||
| 		qos->up2tc[i] = (up2tc >> (i * 3)) & 0x7; | ||||
| 
 | ||||
| 	for (i = 0; i < IEEE_8021QAZ_MAX_TCS; i++) | ||||
| 		qos->tc_info[i].rel_bw = dcbx_cfg->etscfg.tcbwtable[i]; | ||||
| 
 | ||||
| 	qos->pfc_mode = dcbx_cfg->pfc_mode; | ||||
| 	if (qos->pfc_mode == IIDC_DSCP_PFC_MODE) | ||||
| 		for (i = 0; i < IIDC_MAX_DSCP_MAPPING; i++) | ||||
| 			qos->dscp_map[i] = dcbx_cfg->dscp_map[i]; | ||||
| } | ||||
| EXPORT_SYMBOL_GPL(ice_get_qos_params); | ||||
| 
 | ||||
| int ice_alloc_rdma_qvector(struct ice_pf *pf, struct msix_entry *entry) | ||||
| { | ||||
| 	struct msi_map map = ice_alloc_irq(pf, true); | ||||
| 	if (WARN_ON(!cdev)) | ||||
| 		return -EINVAL; | ||||
| 
 | ||||
| 	pf = pci_get_drvdata(cdev->pdev); | ||||
| 	map = ice_alloc_irq(pf, true); | ||||
| 	if (map.index < 0) | ||||
| 		return -ENOMEM; | ||||
| 
 | ||||
|  | @ -244,12 +252,19 @@ EXPORT_SYMBOL_GPL(ice_alloc_rdma_qvector); | |||
| 
 | ||||
| /**
 | ||||
|  * ice_free_rdma_qvector - free vector resources reserved for RDMA driver | ||||
|  * @pf: board private structure to initialize | ||||
|  * @cdev: pointer to iidc_rdma_core_dev_info struct | ||||
|  * @entry: MSI-X entry to be removed | ||||
|  */ | ||||
| void ice_free_rdma_qvector(struct ice_pf *pf, struct msix_entry *entry) | ||||
| void ice_free_rdma_qvector(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			   struct msix_entry *entry) | ||||
| { | ||||
| 	struct msi_map map; | ||||
| 	struct ice_pf *pf; | ||||
| 
 | ||||
| 	if (WARN_ON(!cdev || !entry)) | ||||
| 		return; | ||||
| 
 | ||||
| 	pf = pci_get_drvdata(cdev->pdev); | ||||
| 
 | ||||
| 	map.index = entry->entry; | ||||
| 	map.virq = entry->vector; | ||||
|  | @ -263,19 +278,23 @@ EXPORT_SYMBOL_GPL(ice_free_rdma_qvector); | |||
|  */ | ||||
| static void ice_adev_release(struct device *dev) | ||||
| { | ||||
| 	struct iidc_auxiliary_dev *iadev; | ||||
| 	struct iidc_rdma_core_auxiliary_dev *iadev; | ||||
| 
 | ||||
| 	iadev = container_of(dev, struct iidc_auxiliary_dev, adev.dev); | ||||
| 	iadev = container_of(dev, struct iidc_rdma_core_auxiliary_dev, | ||||
| 			     adev.dev); | ||||
| 	kfree(iadev); | ||||
| } | ||||
| 
 | ||||
| /**
 | ||||
|  * ice_plug_aux_dev - allocate and register AUX device | ||||
|  * @pf: pointer to pf struct | ||||
|  * | ||||
|  * Return: Zero on success, error code on failure | ||||
|  */ | ||||
| int ice_plug_aux_dev(struct ice_pf *pf) | ||||
| { | ||||
| 	struct iidc_auxiliary_dev *iadev; | ||||
| 	struct iidc_rdma_core_auxiliary_dev *iadev; | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 	struct auxiliary_device *adev; | ||||
| 	int ret; | ||||
| 
 | ||||
|  | @ -285,17 +304,22 @@ int ice_plug_aux_dev(struct ice_pf *pf) | |||
| 	if (!ice_is_rdma_ena(pf)) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	cdev = pf->cdev_info; | ||||
| 	if (!cdev) | ||||
| 		return -ENODEV; | ||||
| 
 | ||||
| 	iadev = kzalloc(sizeof(*iadev), GFP_KERNEL); | ||||
| 	if (!iadev) | ||||
| 		return -ENOMEM; | ||||
| 
 | ||||
| 	adev = &iadev->adev; | ||||
| 	iadev->pf = pf; | ||||
| 	iadev->cdev_info = cdev; | ||||
| 
 | ||||
| 	adev->id = pf->aux_idx; | ||||
| 	adev->dev.release = ice_adev_release; | ||||
| 	adev->dev.parent = &pf->pdev->dev; | ||||
| 	adev->name = pf->rdma_mode & IIDC_RDMA_PROTOCOL_ROCEV2 ? "roce" : "iwarp"; | ||||
| 	adev->name = cdev->rdma_protocol & IIDC_RDMA_PROTOCOL_ROCEV2 ? | ||||
| 		"roce" : "iwarp"; | ||||
| 
 | ||||
| 	ret = auxiliary_device_init(adev); | ||||
| 	if (ret) { | ||||
|  | @ -310,7 +334,7 @@ int ice_plug_aux_dev(struct ice_pf *pf) | |||
| 	} | ||||
| 
 | ||||
| 	mutex_lock(&pf->adev_mutex); | ||||
| 	pf->adev = adev; | ||||
| 	cdev->adev = adev; | ||||
| 	mutex_unlock(&pf->adev_mutex); | ||||
| 
 | ||||
| 	return 0; | ||||
|  | @ -324,8 +348,8 @@ void ice_unplug_aux_dev(struct ice_pf *pf) | |||
| 	struct auxiliary_device *adev; | ||||
| 
 | ||||
| 	mutex_lock(&pf->adev_mutex); | ||||
| 	adev = pf->adev; | ||||
| 	pf->adev = NULL; | ||||
| 	adev = pf->cdev_info->adev; | ||||
| 	pf->cdev_info->adev = NULL; | ||||
| 	mutex_unlock(&pf->adev_mutex); | ||||
| 
 | ||||
| 	if (adev) { | ||||
|  | @ -340,7 +364,9 @@ void ice_unplug_aux_dev(struct ice_pf *pf) | |||
|  */ | ||||
| int ice_init_rdma(struct ice_pf *pf) | ||||
| { | ||||
| 	struct iidc_rdma_priv_dev_info *privd; | ||||
| 	struct device *dev = &pf->pdev->dev; | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 	int ret; | ||||
| 
 | ||||
| 	if (!ice_is_rdma_ena(pf)) { | ||||
|  | @ -348,22 +374,50 @@ int ice_init_rdma(struct ice_pf *pf) | |||
| 		return 0; | ||||
| 	} | ||||
| 
 | ||||
| 	cdev = kzalloc(sizeof(*cdev), GFP_KERNEL); | ||||
| 	if (!cdev) | ||||
| 		return -ENOMEM; | ||||
| 
 | ||||
| 	pf->cdev_info = cdev; | ||||
| 
 | ||||
| 	privd = kzalloc(sizeof(*privd), GFP_KERNEL); | ||||
| 	if (!privd) { | ||||
| 		ret = -ENOMEM; | ||||
| 		goto err_privd_alloc; | ||||
| 	} | ||||
| 
 | ||||
| 	privd->pf_id = pf->hw.pf_id; | ||||
| 	ret = xa_alloc(&ice_aux_id, &pf->aux_idx, NULL, XA_LIMIT(1, INT_MAX), | ||||
| 		       GFP_KERNEL); | ||||
| 	if (ret) { | ||||
| 		dev_err(dev, "Failed to allocate device ID for AUX driver\n"); | ||||
| 		return -ENOMEM; | ||||
| 		ret = -ENOMEM; | ||||
| 		goto err_alloc_xa; | ||||
| 	} | ||||
| 
 | ||||
| 	pf->rdma_mode |= IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 	cdev->iidc_priv = privd; | ||||
| 	privd->netdev = pf->vsi[0]->netdev; | ||||
| 
 | ||||
| 	privd->hw_addr = (u8 __iomem *)pf->hw.hw_addr; | ||||
| 	cdev->pdev = pf->pdev; | ||||
| 	privd->vport_id = pf->vsi[0]->vsi_num; | ||||
| 
 | ||||
| 	pf->cdev_info->rdma_protocol |= IIDC_RDMA_PROTOCOL_ROCEV2; | ||||
| 	ice_setup_dcb_qos_info(pf, &privd->qos_info); | ||||
| 	ret = ice_plug_aux_dev(pf); | ||||
| 	if (ret) | ||||
| 		goto err_plug_aux_dev; | ||||
| 	return 0; | ||||
| 
 | ||||
| err_plug_aux_dev: | ||||
| 	pf->adev = NULL; | ||||
| 	pf->cdev_info->adev = NULL; | ||||
| 	xa_erase(&ice_aux_id, pf->aux_idx); | ||||
| err_alloc_xa: | ||||
| 	kfree(privd); | ||||
| err_privd_alloc: | ||||
| 	kfree(cdev); | ||||
| 	pf->cdev_info = NULL; | ||||
| 
 | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
|  | @ -378,4 +432,7 @@ void ice_deinit_rdma(struct ice_pf *pf) | |||
| 
 | ||||
| 	ice_unplug_aux_dev(pf); | ||||
| 	xa_erase(&ice_aux_id, pf->aux_idx); | ||||
| 	kfree(pf->cdev_info->iidc_priv); | ||||
| 	kfree(pf->cdev_info); | ||||
| 	pf->cdev_info = NULL; | ||||
| } | ||||
|  |  | |||
|  | @ -4,10 +4,11 @@ | |||
| #ifndef _ICE_IDC_INT_H_ | ||||
| #define _ICE_IDC_INT_H_ | ||||
| 
 | ||||
| #include <linux/net/intel/iidc.h> | ||||
| #include <linux/net/intel/iidc_rdma.h> | ||||
| #include <linux/net/intel/iidc_rdma_ice.h> | ||||
| 
 | ||||
| struct ice_pf; | ||||
| 
 | ||||
| void ice_send_event_to_aux(struct ice_pf *pf, struct iidc_event *event); | ||||
| void ice_send_event_to_aux(struct ice_pf *pf, struct iidc_rdma_event *event); | ||||
| 
 | ||||
| #endif /* !_ICE_IDC_INT_H_ */ | ||||
|  |  | |||
|  | @ -2401,11 +2401,11 @@ static void ice_service_task(struct work_struct *work) | |||
| 	} | ||||
| 
 | ||||
| 	if (test_and_clear_bit(ICE_AUX_ERR_PENDING, pf->state)) { | ||||
| 		struct iidc_event *event; | ||||
| 		struct iidc_rdma_event *event; | ||||
| 
 | ||||
| 		event = kzalloc(sizeof(*event), GFP_KERNEL); | ||||
| 		if (event) { | ||||
| 			set_bit(IIDC_EVENT_CRIT_ERR, event->type); | ||||
| 			set_bit(IIDC_RDMA_EVENT_CRIT_ERR, event->type); | ||||
| 			/* report the entire OICR value to AUX driver */ | ||||
| 			swap(event->reg, pf->oicr_err_reg); | ||||
| 			ice_send_event_to_aux(pf, event); | ||||
|  | @ -2424,11 +2424,11 @@ static void ice_service_task(struct work_struct *work) | |||
| 		ice_plug_aux_dev(pf); | ||||
| 
 | ||||
| 	if (test_and_clear_bit(ICE_FLAG_MTU_CHANGED, pf->flags)) { | ||||
| 		struct iidc_event *event; | ||||
| 		struct iidc_rdma_event *event; | ||||
| 
 | ||||
| 		event = kzalloc(sizeof(*event), GFP_KERNEL); | ||||
| 		if (event) { | ||||
| 			set_bit(IIDC_EVENT_AFTER_MTU_CHANGE, event->type); | ||||
| 			set_bit(IIDC_RDMA_EVENT_AFTER_MTU_CHANGE, event->type); | ||||
| 			ice_send_event_to_aux(pf, event); | ||||
| 			kfree(event); | ||||
| 		} | ||||
|  | @ -9342,6 +9342,7 @@ ice_setup_tc(struct net_device *netdev, enum tc_setup_type type, | |||
| { | ||||
| 	struct ice_netdev_priv *np = netdev_priv(netdev); | ||||
| 	enum flow_block_binder_type binder_type; | ||||
| 	struct iidc_rdma_core_dev_info *cdev; | ||||
| 	struct ice_pf *pf = np->vsi->back; | ||||
| 	flow_setup_cb_t *flower_handler; | ||||
| 	bool locked = false; | ||||
|  | @ -9373,11 +9374,12 @@ ice_setup_tc(struct net_device *netdev, enum tc_setup_type type, | |||
| 			return -EOPNOTSUPP; | ||||
| 		} | ||||
| 
 | ||||
| 		if (pf->adev) { | ||||
| 		cdev = pf->cdev_info; | ||||
| 		if (cdev && cdev->adev) { | ||||
| 			mutex_lock(&pf->adev_mutex); | ||||
| 			device_lock(&pf->adev->dev); | ||||
| 			device_lock(&cdev->adev->dev); | ||||
| 			locked = true; | ||||
| 			if (pf->adev->dev.driver) { | ||||
| 			if (cdev->adev->dev.driver) { | ||||
| 				netdev_err(netdev, "Cannot change qdisc when RDMA is active\n"); | ||||
| 				err = -EBUSY; | ||||
| 				goto adev_unlock; | ||||
|  | @ -9391,7 +9393,7 @@ ice_setup_tc(struct net_device *netdev, enum tc_setup_type type, | |||
| 
 | ||||
| adev_unlock: | ||||
| 		if (locked) { | ||||
| 			device_unlock(&pf->adev->dev); | ||||
| 			device_unlock(&cdev->adev->dev); | ||||
| 			mutex_unlock(&pf->adev_mutex); | ||||
| 		} | ||||
| 		return err; | ||||
|  |  | |||
|  | @ -19,6 +19,7 @@ | |||
| #include "ice_vlan_mode.h" | ||||
| #include "ice_fwlog.h" | ||||
| #include <linux/wait.h> | ||||
| #include <net/dscp.h> | ||||
| 
 | ||||
| static inline bool ice_is_tc_ena(unsigned long bitmap, u8 tc) | ||||
| { | ||||
|  | @ -695,7 +696,6 @@ struct ice_dcb_app_priority_table { | |||
| 
 | ||||
| #define ICE_MAX_USER_PRIORITY	8 | ||||
| #define ICE_DCBX_MAX_APPS	64 | ||||
| #define ICE_DSCP_NUM_VAL	64 | ||||
| #define ICE_LLDPDU_SIZE		1500 | ||||
| #define ICE_TLV_STATUS_OPER	0x1 | ||||
| #define ICE_TLV_STATUS_SYNC	0x2 | ||||
|  | @ -718,9 +718,9 @@ struct ice_dcbx_cfg { | |||
| 	u8 pfc_mode; | ||||
| 	struct ice_dcb_app_priority_table app[ICE_DCBX_MAX_APPS]; | ||||
| 	/* when DSCP mapping defined by user set its bit to 1 */ | ||||
| 	DECLARE_BITMAP(dscp_mapped, ICE_DSCP_NUM_VAL); | ||||
| 	DECLARE_BITMAP(dscp_mapped, DSCP_MAX); | ||||
| 	/* array holding DSCP -> UP/TC values for DSCP L3 QoS mode */ | ||||
| 	u8 dscp_map[ICE_DSCP_NUM_VAL]; | ||||
| 	u8 dscp_map[DSCP_MAX]; | ||||
| 	u8 dcbx_mode; | ||||
| #define ICE_DCBX_MODE_CEE	0x1 | ||||
| #define ICE_DCBX_MODE_IEEE	0x2 | ||||
|  |  | |||
|  | @ -1,109 +0,0 @@ | |||
| /* SPDX-License-Identifier: GPL-2.0 */ | ||||
| /* Copyright (C) 2021, Intel Corporation. */ | ||||
| 
 | ||||
| #ifndef _IIDC_H_ | ||||
| #define _IIDC_H_ | ||||
| 
 | ||||
| #include <linux/auxiliary_bus.h> | ||||
| #include <linux/dcbnl.h> | ||||
| #include <linux/device.h> | ||||
| #include <linux/if_ether.h> | ||||
| #include <linux/kernel.h> | ||||
| #include <linux/netdevice.h> | ||||
| 
 | ||||
| enum iidc_event_type { | ||||
| 	IIDC_EVENT_BEFORE_MTU_CHANGE, | ||||
| 	IIDC_EVENT_AFTER_MTU_CHANGE, | ||||
| 	IIDC_EVENT_BEFORE_TC_CHANGE, | ||||
| 	IIDC_EVENT_AFTER_TC_CHANGE, | ||||
| 	IIDC_EVENT_CRIT_ERR, | ||||
| 	IIDC_EVENT_NBITS		/* must be last */ | ||||
| }; | ||||
| 
 | ||||
| enum iidc_reset_type { | ||||
| 	IIDC_PFR, | ||||
| 	IIDC_CORER, | ||||
| 	IIDC_GLOBR, | ||||
| }; | ||||
| 
 | ||||
| enum iidc_rdma_protocol { | ||||
| 	IIDC_RDMA_PROTOCOL_IWARP = BIT(0), | ||||
| 	IIDC_RDMA_PROTOCOL_ROCEV2 = BIT(1), | ||||
| }; | ||||
| 
 | ||||
| #define IIDC_MAX_USER_PRIORITY		8 | ||||
| #define IIDC_MAX_DSCP_MAPPING		64 | ||||
| #define IIDC_DSCP_PFC_MODE		0x1 | ||||
| 
 | ||||
| /* Struct to hold per RDMA Qset info */ | ||||
| struct iidc_rdma_qset_params { | ||||
| 	/* Qset TEID returned to the RDMA driver in
 | ||||
| 	 * ice_add_rdma_qset and used by RDMA driver | ||||
| 	 * for calls to ice_del_rdma_qset | ||||
| 	 */ | ||||
| 	u32 teid;	/* Qset TEID */ | ||||
| 	u16 qs_handle; /* RDMA driver provides this */ | ||||
| 	u16 vport_id; /* VSI index */ | ||||
| 	u8 tc; /* TC branch the Qset should belong to */ | ||||
| }; | ||||
| 
 | ||||
| struct iidc_qos_info { | ||||
| 	u64 tc_ctx; | ||||
| 	u8 rel_bw; | ||||
| 	u8 prio_type; | ||||
| 	u8 egress_virt_up; | ||||
| 	u8 ingress_virt_up; | ||||
| }; | ||||
| 
 | ||||
| /* Struct to pass QoS info */ | ||||
| struct iidc_qos_params { | ||||
| 	struct iidc_qos_info tc_info[IEEE_8021QAZ_MAX_TCS]; | ||||
| 	u8 up2tc[IIDC_MAX_USER_PRIORITY]; | ||||
| 	u8 vport_relative_bw; | ||||
| 	u8 vport_priority_type; | ||||
| 	u8 num_tc; | ||||
| 	u8 pfc_mode; | ||||
| 	u8 dscp_map[IIDC_MAX_DSCP_MAPPING]; | ||||
| }; | ||||
| 
 | ||||
| struct iidc_event { | ||||
| 	DECLARE_BITMAP(type, IIDC_EVENT_NBITS); | ||||
| 	u32 reg; | ||||
| }; | ||||
| 
 | ||||
| struct ice_pf; | ||||
| 
 | ||||
| int ice_add_rdma_qset(struct ice_pf *pf, struct iidc_rdma_qset_params *qset); | ||||
| int ice_del_rdma_qset(struct ice_pf *pf, struct iidc_rdma_qset_params *qset); | ||||
| int ice_rdma_request_reset(struct ice_pf *pf, enum iidc_reset_type reset_type); | ||||
| int ice_rdma_update_vsi_filter(struct ice_pf *pf, u16 vsi_id, bool enable); | ||||
| void ice_get_qos_params(struct ice_pf *pf, struct iidc_qos_params *qos); | ||||
| int ice_alloc_rdma_qvector(struct ice_pf *pf, struct msix_entry *entry); | ||||
| void ice_free_rdma_qvector(struct ice_pf *pf, struct msix_entry *entry); | ||||
| 
 | ||||
| /* Structure representing auxiliary driver tailored information about the core
 | ||||
|  * PCI dev, each auxiliary driver using the IIDC interface will have an | ||||
|  * instance of this struct dedicated to it. | ||||
|  */ | ||||
| 
 | ||||
| struct iidc_auxiliary_dev { | ||||
| 	struct auxiliary_device adev; | ||||
| 	struct ice_pf *pf; | ||||
| }; | ||||
| 
 | ||||
| /* structure representing the auxiliary driver. This struct is to be
 | ||||
|  * allocated and populated by the auxiliary driver's owner. The core PCI | ||||
|  * driver will access these ops by performing a container_of on the | ||||
|  * auxiliary_device->dev.driver. | ||||
|  */ | ||||
| struct iidc_auxiliary_drv { | ||||
| 	struct auxiliary_driver adrv; | ||||
| 	/* This event_handler is meant to be a blocking call.  For instance,
 | ||||
| 	 * when a BEFORE_MTU_CHANGE event comes in, the event_handler will not | ||||
| 	 * return until the auxiliary driver is ready for the MTU change to | ||||
| 	 * happen. | ||||
| 	 */ | ||||
| 	void (*event_handler)(struct ice_pf *pf, struct iidc_event *event); | ||||
| }; | ||||
| 
 | ||||
| #endif /* _IIDC_H_*/ | ||||
							
								
								
									
										68
									
								
								include/linux/net/intel/iidc_rdma.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								include/linux/net/intel/iidc_rdma.h
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,68 @@ | |||
| /* SPDX-License-Identifier: GPL-2.0 */ | ||||
| /* Copyright (C) 2021-2025, Intel Corporation. */ | ||||
| 
 | ||||
| #ifndef _IIDC_RDMA_H_ | ||||
| #define _IIDC_RDMA_H_ | ||||
| 
 | ||||
| #include <linux/auxiliary_bus.h> | ||||
| #include <linux/device.h> | ||||
| #include <linux/if_ether.h> | ||||
| #include <linux/kernel.h> | ||||
| #include <linux/netdevice.h> | ||||
| #include <net/dscp.h> | ||||
| 
 | ||||
| enum iidc_rdma_event_type { | ||||
| 	IIDC_RDMA_EVENT_BEFORE_MTU_CHANGE, | ||||
| 	IIDC_RDMA_EVENT_AFTER_MTU_CHANGE, | ||||
| 	IIDC_RDMA_EVENT_BEFORE_TC_CHANGE, | ||||
| 	IIDC_RDMA_EVENT_AFTER_TC_CHANGE, | ||||
| 	IIDC_RDMA_EVENT_WARN_RESET, | ||||
| 	IIDC_RDMA_EVENT_CRIT_ERR, | ||||
| 	IIDC_RDMA_EVENT_NBITS		/* must be last */ | ||||
| }; | ||||
| 
 | ||||
| struct iidc_rdma_event { | ||||
| 	DECLARE_BITMAP(type, IIDC_RDMA_EVENT_NBITS); | ||||
| 	u32 reg; | ||||
| }; | ||||
| 
 | ||||
| enum iidc_rdma_reset_type { | ||||
| 	IIDC_FUNC_RESET, | ||||
| 	IIDC_DEV_RESET, | ||||
| }; | ||||
| 
 | ||||
| enum iidc_rdma_protocol { | ||||
| 	IIDC_RDMA_PROTOCOL_IWARP = BIT(0), | ||||
| 	IIDC_RDMA_PROTOCOL_ROCEV2 = BIT(1), | ||||
| }; | ||||
| 
 | ||||
| /* Structure to be populated by core LAN PCI driver */ | ||||
| struct iidc_rdma_core_dev_info { | ||||
| 	struct pci_dev *pdev; /* PCI device of corresponding to main function */ | ||||
| 	struct auxiliary_device *adev; | ||||
| 	/* Current active RDMA protocol */ | ||||
| 	enum iidc_rdma_protocol rdma_protocol; | ||||
| 	void *iidc_priv; /* elements unique to each driver */ | ||||
| }; | ||||
| 
 | ||||
| /* Structure representing auxiliary driver tailored information about the core
 | ||||
|  * PCI dev, each auxiliary driver using the IIDC interface will have an | ||||
|  * instance of this struct dedicated to it. | ||||
|  */ | ||||
| struct iidc_rdma_core_auxiliary_dev { | ||||
| 	struct auxiliary_device adev; | ||||
| 	struct iidc_rdma_core_dev_info *cdev_info; | ||||
| }; | ||||
| 
 | ||||
| /* structure representing the auxiliary driver. This struct is to be
 | ||||
|  * allocated and populated by the auxiliary driver's owner. The core PCI | ||||
|  * driver will access these ops by performing a container_of on the | ||||
|  * auxiliary_device->dev.driver. | ||||
|  */ | ||||
| struct iidc_rdma_core_auxiliary_drv { | ||||
| 	struct auxiliary_driver adrv; | ||||
| 	void (*event_handler)(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			      struct iidc_rdma_event *event); | ||||
| }; | ||||
| 
 | ||||
| #endif /* _IIDC_RDMA_H_*/ | ||||
							
								
								
									
										70
									
								
								include/linux/net/intel/iidc_rdma_ice.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								include/linux/net/intel/iidc_rdma_ice.h
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,70 @@ | |||
| /* SPDX-License-Identifier: GPL-2.0 */ | ||||
| /* Copyright (C) 2021-2025, Intel Corporation. */ | ||||
| 
 | ||||
| #ifndef _IIDC_RDMA_ICE_H_ | ||||
| #define _IIDC_RDMA_ICE_H_ | ||||
| 
 | ||||
| #include <linux/dcbnl.h> | ||||
| 
 | ||||
| #define IIDC_MAX_USER_PRIORITY         8 | ||||
| #define IIDC_DSCP_PFC_MODE             0x1 | ||||
| 
 | ||||
| /**
 | ||||
|  * struct iidc_rdma_qset_params - Struct to hold per RDMA Qset info | ||||
|  * @teid: TEID of the Qset node | ||||
|  * @qs_handle: SW index of the Qset, RDMA provides this | ||||
|  * @vport_id: VSI index | ||||
|  * @tc: Traffic Class branch the QSet should belong to | ||||
|  */ | ||||
| struct iidc_rdma_qset_params { | ||||
| 	/* Qset TEID returned to the RDMA driver in
 | ||||
| 	 * ice_add_rdma_qset and used by RDMA driver | ||||
| 	 * for calls to ice_del_rdma_qset | ||||
| 	 */ | ||||
| 	u32 teid; | ||||
| 	u16 qs_handle; | ||||
| 	u16 vport_id; | ||||
| 	u8 tc; | ||||
| }; | ||||
| 
 | ||||
| struct iidc_rdma_qos_info { | ||||
| 	u64 tc_ctx; | ||||
| 	u8 rel_bw; | ||||
| 	u8 prio_type; | ||||
| 	u8 egress_virt_up; | ||||
| 	u8 ingress_virt_up; | ||||
| }; | ||||
| 
 | ||||
| /* Struct to pass QoS info */ | ||||
| struct iidc_rdma_qos_params { | ||||
| 	struct iidc_rdma_qos_info tc_info[IEEE_8021QAZ_MAX_TCS]; | ||||
| 	u8 up2tc[IIDC_MAX_USER_PRIORITY]; | ||||
| 	u8 vport_relative_bw; | ||||
| 	u8 vport_priority_type; | ||||
| 	u8 num_tc; | ||||
| 	u8 pfc_mode; | ||||
| 	u8 dscp_map[DSCP_MAX]; | ||||
| }; | ||||
| 
 | ||||
| struct iidc_rdma_priv_dev_info { | ||||
| 	u8 pf_id; | ||||
| 	u16 vport_id; | ||||
| 	struct net_device *netdev; | ||||
| 	struct iidc_rdma_qos_params qos_info; | ||||
| 	u8 __iomem *hw_addr; | ||||
| }; | ||||
| 
 | ||||
| int ice_add_rdma_qset(struct iidc_rdma_core_dev_info *cdev, | ||||
| 		      struct iidc_rdma_qset_params *qset); | ||||
| int ice_del_rdma_qset(struct iidc_rdma_core_dev_info *cdev, | ||||
| 		      struct iidc_rdma_qset_params *qset); | ||||
| int ice_rdma_request_reset(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			   enum iidc_rdma_reset_type reset_type); | ||||
| int ice_rdma_update_vsi_filter(struct iidc_rdma_core_dev_info *cdev, u16 vsi_id, | ||||
| 			       bool enable); | ||||
| int ice_alloc_rdma_qvector(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			   struct msix_entry *entry); | ||||
| void ice_free_rdma_qvector(struct iidc_rdma_core_dev_info *cdev, | ||||
| 			   struct msix_entry *entry); | ||||
| 
 | ||||
| #endif /* _IIDC_RDMA_ICE_H_*/ | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Jakub Kicinski
						Jakub Kicinski