Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp328579yba; Mon, 20 May 2019 09:23:29 -0700 (PDT) X-Google-Smtp-Source: APXvYqy26a51N3SpaLXPwq2W0+Tp5flxep1ETHtE7B4fUdRX/c0PiTlGBFzRZtxHzB9tgpnb/jFG X-Received: by 2002:a17:902:5ac9:: with SMTP id g9mr76827755plm.134.1558369409418; Mon, 20 May 2019 09:23:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558369409; cv=none; d=google.com; s=arc-20160816; b=n2gg821BDWWN2N9lMf+hk+CkV8hFIV5l6OwozUnnboZKOxKo1B70FF+TkzKx62ES74 P1vCn4aYbaWdAET3g9mCu36e5JmAVC7xlAztbuRXbFwmhqjXff+gfC2ex/45kwS3YLFe wNMxVjwRe01NP0AXuKlDXNn92S3qpFPgaeFajuWkEVx7mMID41EbS8hdo/q9TCjl9m8G Zep4dKqMZQaiEa/dEQQamCDirdzq6LItDjl76BxUDAqUBc5QaKJp0MLJCoi8VRIPM4oM Yv4S/OCyHhl/k9F3sIeT+fvvMCbbZRQKx1a8iJklqiMr2EeeXX8LL6+uXsTCzAO8A19Q rdHw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=pVjihzQo6bWyGYvpyZLQ7ByoV7OV2mbOoK/UxwbQDEo=; b=ouDYw9j2n4s8mX3j+shPPLzWAXPRxAjUgTbkz24CyReUjfj9338KMkQbZq2GT3oPQg 38FqBkSjA4mrhGNmJluZWB9ZNjH1UUGB3/SqwsnwyWWd4mtp747yLTNhwuu6Rr7MNuMs DnQywlbnkbXJuk7mUwdg6122TdUTOYm3zd+Khvknxoa6hqG1nE5Y1i5DvF5QEvKAOBJV GMDOnz9BN8QLSSzTwlARR1Tn4huPqOaKtREEWyR2IDVaLzLI/ZTOXl3X0y1j3s/qteOL laMfT40IwVFa0Cqv9LQi6p1PZEiUiWZsCWXHhDrYUkqC89drJa9xDAlqk58qSHYDwl96 gBqg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=GqcfzE+8; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x65si20398932pfd.44.2019.05.20.09.23.13; Mon, 20 May 2019 09:23:29 -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; dkim=pass header.i=@kernel.org header.s=default header.b=GqcfzE+8; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389598AbfETM2C (ORCPT + 99 others); Mon, 20 May 2019 08:28:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:43614 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389590AbfETM17 (ORCPT ); Mon, 20 May 2019 08:27:59 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id C863420645; Mon, 20 May 2019 12:27:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1558355279; bh=IEOEw2Bx7S9kdk27RzkRVdpq0TTQ1zPAP8oIcWoTU5o=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=GqcfzE+88+mV4Bm34rKQ1MY6gVQ2vypXij+Ky7KVqwTMJuA35AJw+At77+ol3WbS8 lAqkagARdV/qvvzVnnvDearrkGqefePZIOWb4T6wyoFiIk20SazY650bS/jZ1tBTNT Vbk8KPjWxEza/3EWOCQB6iXbCmOdglkG7QGQlvFs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Libin Yang , Takashi Iwai , Pierre-Louis Bossart , Mark Brown Subject: [PATCH 5.0 056/123] ASoC: codec: hdac_hdmi add device_link to card device Date: Mon, 20 May 2019 14:13:56 +0200 Message-Id: <20190520115248.483509056@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190520115245.439864225@linuxfoundation.org> References: <20190520115245.439864225@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Libin Yang commit 01c8327667c249818d3712c3e25c7ad2aca7f389 upstream. In resume from S3, HDAC HDMI codec driver dapm event callback may be operated before HDMI codec driver turns on the display audio power domain because of the contest between display driver and hdmi codec driver. This patch adds the device_link between soc card device (consumer) and hdmi codec device (supplier) to make sure the sequence is always correct. Signed-off-by: Libin Yang Reviewed-by: Takashi Iwai Acked-by: Pierre-Louis Bossart Signed-off-by: Mark Brown Cc: stable@vger.kernel.org Signed-off-by: Greg Kroah-Hartman --- sound/soc/codecs/hdac_hdmi.c | 11 +++++++++++ 1 file changed, 11 insertions(+) --- a/sound/soc/codecs/hdac_hdmi.c +++ b/sound/soc/codecs/hdac_hdmi.c @@ -1872,6 +1872,17 @@ static int hdmi_codec_probe(struct snd_s hdmi->card = dapm->card->snd_card; /* + * Setup a device_link between card device and HDMI codec device. + * The card device is the consumer and the HDMI codec device is + * the supplier. With this setting, we can make sure that the audio + * domain in display power will be always turned on before operating + * on the HDMI audio codec registers. + * Let's use the flag DL_FLAG_AUTOREMOVE_CONSUMER. This can make + * sure the device link is freed when the machine driver is removed. + */ + device_link_add(component->card->dev, &hdev->dev, DL_FLAG_RPM_ACTIVE | + DL_FLAG_AUTOREMOVE_CONSUMER); + /* * hdac_device core already sets the state to active and calls * get_noresume. So enable runtime and set the device to suspend. */