Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp2419069ybi; Mon, 17 Jun 2019 04:36:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqyfD8MYggECnz9ysQnvbMv6Mbb+g66/uK7OezHB/j/USXjnyfgZJ+R6rmR8gfcq5CM/cgmq X-Received: by 2002:a17:902:b592:: with SMTP id a18mr82809414pls.278.1560771376692; Mon, 17 Jun 2019 04:36:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560771376; cv=none; d=google.com; s=arc-20160816; b=hgsu6y8CpEQD9nBTFffIuXbxy2e9Fetj35fevNWDB3EWyUDqHxno+adfnCab1SmGuW 1IAQ7Yfm26gNHAp5pFe2AA55CFO5L5iTVj+5MIWJmzJeHINR0GF4KWiOK3zVvM3xQ893 4plwrl+Gzn0M7FjtmFOgf4DE77AQZOI3WKSUhA6daA0jzZRnhymbe3w1G1Gjq0CHRQuu G4/uL68B06FDc6mvuPnnnSUSAQnosrX6lq5BJPbcqkHYFYhD4OcWd1527ZOTJTD7pm6e Tq+SfBBrTrkEbyHRvBybXRT5U2qqWTtMUluwW+rGZMYtcf3S2fm+yGE/v2LoSVMqTb2i i6XA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=ObGaPQtXPTcTAkR71ZwEJLOFDPDHSg23elbH1M/JObw=; b=kGUynCS91y+drGp+3lE46yEJxEOuadChfdsWuuZZWahm2lZb3CiXHVjnvSq7mqqKX/ aiakeePFHLJtetreXuMGiGW6mNcZ7+nS/3jERIMK+9ASZwByjt47goMODWykLWsIVOaF YHzFiQfEtP6mugBxINRMpyeREME7u2t6UwGg+CxwDMANYAc3+x9FpQdXHvkARZwn989Y He2G/Rudx4uP2s+MJ40LgHxx//nx2FGckYbV+jTjzAmdQ+dxiLC9zwFJtLrnncOqfV0R 2wKGXZa8+UIIwch1G8aw1BQnmTGE2McIAjXkwP064UwvISq8zB49jXcK4+2qpS8Lx9xk XD5g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c36si10946140pgl.389.2019.06.17.04.36.01; Mon, 17 Jun 2019 04:36:16 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728306AbfFQLfR (ORCPT + 99 others); Mon, 17 Jun 2019 07:35:17 -0400 Received: from mga12.intel.com ([192.55.52.136]:54390 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728244AbfFQLfP (ORCPT ); Mon, 17 Jun 2019 07:35:15 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 17 Jun 2019 04:35:15 -0700 X-ExtLoop1: 1 Received: from xxx.igk.intel.com ([10.237.93.170]) by fmsmga006.fm.intel.com with ESMTP; 17 Jun 2019 04:35:12 -0700 From: =?UTF-8?q?Amadeusz=20S=C5=82awi=C5=84ski?= To: alsa-devel@alsa-project.org Cc: Jaroslav Kysela , Takashi Iwai , Liam Girdwood , Mark Brown , Pierre-Louis Bossart , Jie Yang , Cezary Rojewski , linux-kernel@vger.kernel.org, =?UTF-8?q?Amadeusz=20S=C5=82awi=C5=84ski?= Subject: [PATCH v2 09/11] ASoC: Intel: hdac_hdmi: Set ops to NULL on remove Date: Mon, 17 Jun 2019 13:36:42 +0200 Message-Id: <20190617113644.25621-10-amadeuszx.slawinski@linux.intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190617113644.25621-1-amadeuszx.slawinski@linux.intel.com> References: <20190617113644.25621-1-amadeuszx.slawinski@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When we unload Skylake driver we may end up calling hdac_component_master_unbind(), it uses acomp->audio_ops, which we set in hdmi_codec_probe(), so we need to set it to NULL in hdmi_codec_remove(), otherwise we will dereference no longer existing pointer. Signed-off-by: Amadeusz Sławiński --- sound/soc/codecs/hdac_hdmi.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/sound/soc/codecs/hdac_hdmi.c b/sound/soc/codecs/hdac_hdmi.c index 911bb6e2a1ac..9ee1bff548d8 100644 --- a/sound/soc/codecs/hdac_hdmi.c +++ b/sound/soc/codecs/hdac_hdmi.c @@ -1890,6 +1890,12 @@ static void hdmi_codec_remove(struct snd_soc_component *component) { struct hdac_hdmi_priv *hdmi = snd_soc_component_get_drvdata(component); struct hdac_device *hdev = hdmi->hdev; + int ret; + + ret = snd_hdac_acomp_register_notifier(hdev->bus, NULL); + if (ret < 0) + dev_err(&hdev->dev, "notifier unregister failed: err: %d\n", + ret); pm_runtime_disable(&hdev->dev); } -- 2.17.1