[Intel-gfx] [PATCH] drm/i915/dp: fix a memory leak in struct intel_vbt_panel_data

Yongxin Liu yongxin.liu at windriver.com
Thu Jun 8 02:45:27 UTC 2023


In commit 3f9ffce5765d ("drm/i915: Do panel VBT init early if the VBT
declares an explicit panel type"), intel_bios_init_panel_early() was
added to intel_edp_init_connector(), and it may call parse_lfp_panel_dtd()
to alloc memory for panel->vbt.lfp_lvds_vbt_mode.

If intel_edp_init_connector() returns false from lable out_vdd_off, the
memory pointed by panel->vbt.lfp_lvds_vbt_mode will be eventually lost by
kfree(connector) in intel_ddi_init_dp_connector().

Fix the following memory leak.

  unreferenced object 0xffff9e076562f100 (size 128):
    comm "modprobe", pid 365, jiffies 4294749388 (age 73.473s)
    hex dump (first 32 bytes):
      14 44 02 00 80 07 d8 07 05 08 98 08 00 00 38 04  .D............8.
      3b 04 41 04 65 04 00 00 0a 00 00 00 00 00 00 00  ;.A.e...........
    backtrace:
      __kmem_cache_alloc_node+0x1e6/0x3d0
      kmalloc_trace+0x2a/0xf0
      parse_lfp_data+0x1a9/0x300 [i915]
      intel_bios_init_panel+0x131/0x3d0 [i915]
      intel_bios_init_panel_early+0x13/0x20 [i915]
      intel_edp_init_connector+0xb2/0x620 [i915]
      intel_dp_init_connector+0x277/0x490 [i915]
      intel_ddi_init+0x877/0xd70 [i915]
      intel_setup_outputs+0x79d/0xbc0 [i915]
      intel_modeset_init_nogem+0x1a1/0x300 [i915]
      i915_driver_probe+0x2cd/0x580 [i915]
      i915_pci_probe+0xcd/0x150 [i915]
      local_pci_probe+0x44/0xa0
      pci_call_probe+0x54/0x160
      pci_device_probe+0x7e/0x100
      really_probe+0x197/0x3c0

Signed-off-by: Yongxin Liu <yongxin.liu at windriver.com>
---
 drivers/gpu/drm/i915/display/intel_dp.c | 1 +
 1 file changed, 1 insertion(+)

diff --git a/drivers/gpu/drm/i915/display/intel_dp.c b/drivers/gpu/drm/i915/display/intel_dp.c
index f4192fda1a76..9ae003b41b4a 100644
--- a/drivers/gpu/drm/i915/display/intel_dp.c
+++ b/drivers/gpu/drm/i915/display/intel_dp.c
@@ -5575,6 +5575,7 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp,
 
 out_vdd_off:
 	intel_pps_vdd_off_sync(intel_dp);
+	intel_bios_fini_panel(&intel_connector->panel);
 
 	return false;
 }
-- 
2.39.2



More information about the Intel-gfx mailing list