]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
platform/x86/intel: vsec: Fix a memory leak in intel_vsec_add_aux
authorDongliang Mu <dzm91@hust.edu.cn>
Thu, 9 Mar 2023 04:01:07 +0000 (12:01 +0800)
committerStefan Bader <stefan.bader@canonical.com>
Fri, 16 Jun 2023 12:57:54 +0000 (14:57 +0200)
BugLink: https://bugs.launchpad.net/bugs/2023929
[ Upstream commit da0ba0ccce54059d6c6b788a75099bfce95126da ]

The first error handling code in intel_vsec_add_aux misses the
deallocation of intel_vsec_dev->resource.

Fix this by adding kfree(intel_vsec_dev->resource) in the error handling
code.

Reviewed-by: David E. Box <david.e.box@linux.intel.com>
Signed-off-by: Dongliang Mu <dzm91@hust.edu.cn>
Link: https://lore.kernel.org/r/20230309040107.534716-4-dzm91@hust.edu.cn
Reviewed-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
drivers/platform/x86/intel/vsec.c

index 89c5374e33b32a44ed52dc0e98cae6c7299797dd..bcbd522d062bff948074cf230e73c7d76e368122 100644 (file)
@@ -141,6 +141,7 @@ static int intel_vsec_add_aux(struct pci_dev *pdev, struct intel_vsec_device *in
 
        ret = ida_alloc(intel_vsec_dev->ida, GFP_KERNEL);
        if (ret < 0) {
+               kfree(intel_vsec_dev->resource);
                kfree(intel_vsec_dev);
                return ret;
        }