Patch "platform/x86: mlx-platform: call pci_dev_put() to balance the refcount" has been added to the 6.6-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    platform/x86: mlx-platform: call pci_dev_put() to balance the refcount

to the 6.6-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     platform-x86-mlx-platform-call-pci_dev_put-to-balanc.patch
and it can be found in the queue-6.6 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit d7d7a8f08e8fcffaa1277464649e556e30942d4a
Author: Joe Hattori <joe@xxxxxxxxxxxxxxxxxxxxx>
Date:   Mon Dec 16 11:25:38 2024 +0900

    platform/x86: mlx-platform: call pci_dev_put() to balance the refcount
    
    [ Upstream commit 185e1b1d91e419445d3fd99c1c0376a970438acf ]
    
    mlxplat_pci_fpga_device_init() calls pci_get_device() but does not
    release the refcount on error path. Call pci_dev_put() on the error path
    and in mlxplat_pci_fpga_device_exit() to fix this.
    
    This bug was found by an experimental static analysis tool that I am
    developing.
    
    Fixes: 02daa222fbdd ("platform: mellanox: Add initial support for PCIe based programming logic device")
    Signed-off-by: Joe Hattori <joe@xxxxxxxxxxxxxxxxxxxxx>
    Reviewed-by: Vadim Pasternak <vadimp@xxxxxxxxxx>
    Link: https://lore.kernel.org/r/20241216022538.381209-1-joe@xxxxxxxxxxxxxxxxxxxxx
    Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@xxxxxxxxxxxxxxx>
    Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@xxxxxxxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/drivers/platform/x86/mlx-platform.c b/drivers/platform/x86/mlx-platform.c
index a2ffe4157df1..b8d77adc9ea1 100644
--- a/drivers/platform/x86/mlx-platform.c
+++ b/drivers/platform/x86/mlx-platform.c
@@ -6237,6 +6237,7 @@ mlxplat_pci_fpga_device_init(unsigned int device, const char *res_name, struct p
 fail_pci_request_regions:
 	pci_disable_device(pci_dev);
 fail_pci_enable_device:
+	pci_dev_put(pci_dev);
 	return err;
 }
 
@@ -6247,6 +6248,7 @@ mlxplat_pci_fpga_device_exit(struct pci_dev *pci_bridge,
 	iounmap(pci_bridge_addr);
 	pci_release_regions(pci_bridge);
 	pci_disable_device(pci_bridge);
+	pci_dev_put(pci_bridge);
 }
 
 static int




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux