mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-10-31 08:44:41 +00:00 
			
		
		
		
	firmware: stratix10-svc: fix error handle while alloc/add device failed
If add device "stratix10-rsu" failed in stratix10_svc_drv_probe(),
the 'svc_fifo' and 'genpool' need be freed in the error path.
If allocate or add device "intel-fcs" failed in stratix10_svc_drv_probe(),
the device "stratix10-rsu" need be unregistered in the error path.
Fixes: e6281c2667 ("firmware: stratix10-svc: Add support for FCS")
Signed-off-by: Yang Yingliang <yangyingliang@huawei.com>
Signed-off-by: Dinh Nguyen <dinguyen@kernel.org>
Link: https://lore.kernel.org/r/20221129163602.462369-2-dinguyen@kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
			
			
This commit is contained in:
		
							parent
							
								
									9175ee1a99
								
							
						
					
					
						commit
						d66a4c20ae
					
				
					 1 changed files with 6 additions and 3 deletions
				
			
		|  | @ -1202,19 +1202,20 @@ static int stratix10_svc_drv_probe(struct platform_device *pdev) | |||
| 	ret = platform_device_add(svc->stratix10_svc_rsu); | ||||
| 	if (ret) { | ||||
| 		platform_device_put(svc->stratix10_svc_rsu); | ||||
| 		return ret; | ||||
| 		goto err_free_kfifo; | ||||
| 	} | ||||
| 
 | ||||
| 	svc->intel_svc_fcs = platform_device_alloc(INTEL_FCS, 1); | ||||
| 	if (!svc->intel_svc_fcs) { | ||||
| 		dev_err(dev, "failed to allocate %s device\n", INTEL_FCS); | ||||
| 		return -ENOMEM; | ||||
| 		ret = -ENOMEM; | ||||
| 		goto err_unregister_dev; | ||||
| 	} | ||||
| 
 | ||||
| 	ret = platform_device_add(svc->intel_svc_fcs); | ||||
| 	if (ret) { | ||||
| 		platform_device_put(svc->intel_svc_fcs); | ||||
| 		return ret; | ||||
| 		goto err_unregister_dev; | ||||
| 	} | ||||
| 
 | ||||
| 	dev_set_drvdata(dev, svc); | ||||
|  | @ -1223,6 +1224,8 @@ static int stratix10_svc_drv_probe(struct platform_device *pdev) | |||
| 
 | ||||
| 	return 0; | ||||
| 
 | ||||
| err_unregister_dev: | ||||
| 	platform_device_unregister(svc->stratix10_svc_rsu); | ||||
| err_free_kfifo: | ||||
| 	kfifo_free(&controller->svc_fifo); | ||||
| err_destroy_pool: | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Yang Yingliang
						Yang Yingliang