summaryrefslogtreecommitdiff
path: root/sound
diff options
context:
space:
mode:
authorLucas De Marchi <lucas.demarchi@intel.com>2022-04-15 23:44:18 -0700
committerTakashi Iwai <tiwai@suse.de>2022-04-19 08:59:14 +0200
commit00fd7cfad0548b6b7234c93370076f9b9c2e39f8 (patch)
treeffb128d6f02143147eaf94581556eaab562a8a6c /sound
parent6624fb41f5126c7205e866e58d4aaae0453f0914 (diff)
downloadlwn-00fd7cfad0548b6b7234c93370076f9b9c2e39f8.tar.gz
lwn-00fd7cfad0548b6b7234c93370076f9b9c2e39f8.zip
ALSA: hda/i915: Fix one too many pci_dev_put()
pci_get_class() will already unref the pci device passed as argument. So if it's unconditionally unref'ed, even if the loop is not stopped, there will be one too many unref for each device not matched. Closes: https://gitlab.freedesktop.org/drm/intel/-/issues/5701 Fixes: c9db8a30d9f0 ("ALSA: hda/i915 - skip acomp init if no matching display") Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com> Reviewed-by: Kai Vehmanen <kai.vehmanen@linux.intel.com> Link: https://lore.kernel.org/r/20220416064418.2364582-1-lucas.demarchi@intel.com Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound')
-rw-r--r--sound/hda/hdac_i915.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/sound/hda/hdac_i915.c b/sound/hda/hdac_i915.c
index 48b8ed752b69..3f35972e1cf7 100644
--- a/sound/hda/hdac_i915.c
+++ b/sound/hda/hdac_i915.c
@@ -127,11 +127,10 @@ static int i915_gfx_present(struct pci_dev *hdac_pci)
display_dev = pci_get_class(class, display_dev);
if (display_dev && display_dev->vendor == PCI_VENDOR_ID_INTEL &&
- connectivity_check(display_dev, hdac_pci))
+ connectivity_check(display_dev, hdac_pci)) {
+ pci_dev_put(display_dev);
match = true;
-
- pci_dev_put(display_dev);
-
+ }
} while (!match && display_dev);
return match;