mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-01 00:58:39 +02:00 
			
		
		
		
	net: hns3: fix kernel crash when devlink reload during initialization
The devlink reload process will access the hardware resources, but the register operation is done before the hardware is initialized. So, processing the devlink reload during initialization may lead to kernel crash. This patch fixes this by registering the devlink after hardware initialization. Fixes:cd6242991d("net: hns3: add support for registering devlink for VF") Fixes:93305b77ff("net: hns3: fix kernel crash when devlink reload during pf initialization") Signed-off-by: Yonglong Liu <liuyonglong@huawei.com> Signed-off-by: Jijie Shao <shaojijie@huawei.com> Signed-off-by: Paolo Abeni <pabeni@redhat.com>
This commit is contained in:
		
							parent
							
								
									f5db7a3b65
								
							
						
					
					
						commit
						35d92abfba
					
				
					 2 changed files with 9 additions and 18 deletions
				
			
		|  | @ -11631,16 +11631,10 @@ static int hclge_init_ae_dev(struct hnae3_ae_dev *ae_dev) | ||||||
| 	if (ret) | 	if (ret) | ||||||
| 		goto out; | 		goto out; | ||||||
| 
 | 
 | ||||||
| 	ret = hclge_devlink_init(hdev); |  | ||||||
| 	if (ret) |  | ||||||
| 		goto err_pci_uninit; |  | ||||||
| 
 |  | ||||||
| 	devl_lock(hdev->devlink); |  | ||||||
| 
 |  | ||||||
| 	/* Firmware command queue initialize */ | 	/* Firmware command queue initialize */ | ||||||
| 	ret = hclge_comm_cmd_queue_init(hdev->pdev, &hdev->hw.hw); | 	ret = hclge_comm_cmd_queue_init(hdev->pdev, &hdev->hw.hw); | ||||||
| 	if (ret) | 	if (ret) | ||||||
| 		goto err_devlink_uninit; | 		goto err_pci_uninit; | ||||||
| 
 | 
 | ||||||
| 	/* Firmware command initialize */ | 	/* Firmware command initialize */ | ||||||
| 	ret = hclge_comm_cmd_init(hdev->ae_dev, &hdev->hw.hw, &hdev->fw_version, | 	ret = hclge_comm_cmd_init(hdev->ae_dev, &hdev->hw.hw, &hdev->fw_version, | ||||||
|  | @ -11808,6 +11802,10 @@ static int hclge_init_ae_dev(struct hnae3_ae_dev *ae_dev) | ||||||
| 		dev_warn(&pdev->dev, | 		dev_warn(&pdev->dev, | ||||||
| 			 "failed to wake on lan init, ret = %d\n", ret); | 			 "failed to wake on lan init, ret = %d\n", ret); | ||||||
| 
 | 
 | ||||||
|  | 	ret = hclge_devlink_init(hdev); | ||||||
|  | 	if (ret) | ||||||
|  | 		goto err_ptp_uninit; | ||||||
|  | 
 | ||||||
| 	hclge_state_init(hdev); | 	hclge_state_init(hdev); | ||||||
| 	hdev->last_reset_time = jiffies; | 	hdev->last_reset_time = jiffies; | ||||||
| 
 | 
 | ||||||
|  | @ -11815,8 +11813,6 @@ static int hclge_init_ae_dev(struct hnae3_ae_dev *ae_dev) | ||||||
| 		 HCLGE_DRIVER_NAME); | 		 HCLGE_DRIVER_NAME); | ||||||
| 
 | 
 | ||||||
| 	hclge_task_schedule(hdev, round_jiffies_relative(HZ)); | 	hclge_task_schedule(hdev, round_jiffies_relative(HZ)); | ||||||
| 
 |  | ||||||
| 	devl_unlock(hdev->devlink); |  | ||||||
| 	return 0; | 	return 0; | ||||||
| 
 | 
 | ||||||
| err_ptp_uninit: | err_ptp_uninit: | ||||||
|  | @ -11830,9 +11826,6 @@ static int hclge_init_ae_dev(struct hnae3_ae_dev *ae_dev) | ||||||
| 	pci_free_irq_vectors(pdev); | 	pci_free_irq_vectors(pdev); | ||||||
| err_cmd_uninit: | err_cmd_uninit: | ||||||
| 	hclge_comm_cmd_uninit(hdev->ae_dev, &hdev->hw.hw); | 	hclge_comm_cmd_uninit(hdev->ae_dev, &hdev->hw.hw); | ||||||
| err_devlink_uninit: |  | ||||||
| 	devl_unlock(hdev->devlink); |  | ||||||
| 	hclge_devlink_uninit(hdev); |  | ||||||
| err_pci_uninit: | err_pci_uninit: | ||||||
| 	pcim_iounmap(pdev, hdev->hw.hw.io_base); | 	pcim_iounmap(pdev, hdev->hw.hw.io_base); | ||||||
| 	pci_release_regions(pdev); | 	pci_release_regions(pdev); | ||||||
|  |  | ||||||
|  | @ -2845,10 +2845,6 @@ static int hclgevf_init_hdev(struct hclgevf_dev *hdev) | ||||||
| 	if (ret) | 	if (ret) | ||||||
| 		return ret; | 		return ret; | ||||||
| 
 | 
 | ||||||
| 	ret = hclgevf_devlink_init(hdev); |  | ||||||
| 	if (ret) |  | ||||||
| 		goto err_devlink_init; |  | ||||||
| 
 |  | ||||||
| 	ret = hclge_comm_cmd_queue_init(hdev->pdev, &hdev->hw.hw); | 	ret = hclge_comm_cmd_queue_init(hdev->pdev, &hdev->hw.hw); | ||||||
| 	if (ret) | 	if (ret) | ||||||
| 		goto err_cmd_queue_init; | 		goto err_cmd_queue_init; | ||||||
|  | @ -2941,6 +2937,10 @@ static int hclgevf_init_hdev(struct hclgevf_dev *hdev) | ||||||
| 
 | 
 | ||||||
| 	hclgevf_init_rxd_adv_layout(hdev); | 	hclgevf_init_rxd_adv_layout(hdev); | ||||||
| 
 | 
 | ||||||
|  | 	ret = hclgevf_devlink_init(hdev); | ||||||
|  | 	if (ret) | ||||||
|  | 		goto err_config; | ||||||
|  | 
 | ||||||
| 	set_bit(HCLGEVF_STATE_SERVICE_INITED, &hdev->state); | 	set_bit(HCLGEVF_STATE_SERVICE_INITED, &hdev->state); | ||||||
| 
 | 
 | ||||||
| 	hdev->last_reset_time = jiffies; | 	hdev->last_reset_time = jiffies; | ||||||
|  | @ -2960,8 +2960,6 @@ static int hclgevf_init_hdev(struct hclgevf_dev *hdev) | ||||||
| err_cmd_init: | err_cmd_init: | ||||||
| 	hclge_comm_cmd_uninit(hdev->ae_dev, &hdev->hw.hw); | 	hclge_comm_cmd_uninit(hdev->ae_dev, &hdev->hw.hw); | ||||||
| err_cmd_queue_init: | err_cmd_queue_init: | ||||||
| 	hclgevf_devlink_uninit(hdev); |  | ||||||
| err_devlink_init: |  | ||||||
| 	hclgevf_pci_uninit(hdev); | 	hclgevf_pci_uninit(hdev); | ||||||
| 	clear_bit(HCLGEVF_STATE_IRQ_INITED, &hdev->state); | 	clear_bit(HCLGEVF_STATE_IRQ_INITED, &hdev->state); | ||||||
| 	return ret; | 	return ret; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Yonglong Liu
						Yonglong Liu