Received: by 2002:ac0:8c9a:0:0:0:0:0 with SMTP id r26csp3617216ima; Mon, 4 Feb 2019 02:11:00 -0800 (PST) X-Google-Smtp-Source: ALg8bN73t+JiLH6uy+1qZNMoHP2NfYms0sosjT2Jg1UET2eB6NxColTsiSNzuEMGpQHXmGkS0Ufw X-Received: by 2002:a17:902:887:: with SMTP id 7mr50547326pll.164.1549275060472; Mon, 04 Feb 2019 02:11:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549275060; cv=none; d=google.com; s=arc-20160816; b=IY0d7HrYpwFJIgBc2bdLy3rb10BDV98XXsIqXnBsZa9xIIuBBTrUbQMssZF5/BpUn5 HB1cWXwgLe6978SXUdSv35NHt67sCCpHU3BKqWTtkRvZkoPlFoku0AuA6L1jEhvEebPi FRxS4I4HkrqCpqMKd4G9VdxzVj+aiYXksCRxWQxUxJltl36CXhCxKv9kJCGyvBD5r6Tl jBUhgZcLX/FgLycPPHw5D0/DAwTl1ZcC8tAY6cCTpB2JEZTbkkUB/hc1Dg3hM5ZbSauk 6m6miHPlBLo6M5D/wHJ/hbsB6M4i6dZ1+uqDu9D1tnsvgIPG9utgdWXwJsQxlTyIvuO4 ZpRA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=tacV9aTXTZ6U1taWrh3IDBot/ks3MtFe50Js+BXkZhs=; b=Ig7oDLT00ur3eap+eNm/sdAgRRZg+mCBwf1ofHXfnamI1RaO8Wa+jLsJqB3IpspERa x/RKdA/lNsRxo0Qx72EISY4EcqgeIU45MzCz4W8VQSlX5cZy8H9Eof1wL6YT0f2AqfSQ RKvl5V1omjD+UfEd+VpIHyh4r5Qb0vpq3AYskwvA8ymISjOf5WJOaMEKsdbg4F15YQ8P PnD1we+/GnhnqdnTB+HQx+7H6WR/KsboLusRMmjmCC5AJ3LSGp/HV6YSSlsXNCjny9+y xba4sqZX8nPf/B8MPsWSAW25ti7GjHLIs1Gjc3iif9C/a5isCVntMHFZb/ZL/PQw/T+5 mzGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=mUTMRtgg; 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=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o29si815764pgb.126.2019.02.04.02.10.44; Mon, 04 Feb 2019 02:11:00 -0800 (PST) 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=@nvidia.com header.s=n1 header.b=mUTMRtgg; 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=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729239AbfBDKE7 (ORCPT + 99 others); Mon, 4 Feb 2019 05:04:59 -0500 Received: from hqemgate16.nvidia.com ([216.228.121.65]:3194 "EHLO hqemgate16.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728308AbfBDKE7 (ORCPT ); Mon, 4 Feb 2019 05:04:59 -0500 Received: from hqpgpgate102.nvidia.com (Not Verified[216.228.121.13]) by hqemgate16.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Mon, 04 Feb 2019 02:04:52 -0800 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate102.nvidia.com (PGP Universal service); Mon, 04 Feb 2019 02:04:58 -0800 X-PGP-Universal: processed; by hqpgpgate102.nvidia.com on Mon, 04 Feb 2019 02:04:58 -0800 Received: from [10.26.11.58] (10.124.1.5) by HQMAIL101.nvidia.com (172.20.187.10) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Mon, 4 Feb 2019 10:04:53 +0000 Subject: Re: [PATCH v2] ALSA: hda/tegra: enable clock during probe To: Sameer Pujar , "Rafael J. Wysocki" , Thierry Reding CC: "Rafael J. Wysocki" , Takashi Iwai , Pierre-Louis Bossart , Jaroslav Kysela , "moderated list:SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM..." , , , , Linux Kernel Mailing List , , Linux PM References: <1548414418-5785-1-git-send-email-spujar@nvidia.com> <20190131143024.GO23438@ulmo> <2034694.JE9CgBysmF@aspire.rjw.lan> From: Jon Hunter Message-ID: <80a45aa3-8a22-959c-0c73-03ad2d6b1f8c@nvidia.com> Date: Mon, 4 Feb 2019 10:04:50 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL104.nvidia.com (172.18.146.11) To HQMAIL101.nvidia.com (172.20.187.10) Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: quoted-printable DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1549274692; bh=tacV9aTXTZ6U1taWrh3IDBot/ks3MtFe50Js+BXkZhs=; h=X-PGP-Universal:Subject:To:CC:References:From:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Language: Content-Transfer-Encoding; b=mUTMRtggE50xAn35t83fnPvKoDHqfmY5F7EUHTNnjCGEmHgYwQQRsT9oB8al+6UDW Zs7rMWQp/ApcpuHUW+aN5Y8wpTbuhdSuvXGVzWGhuIjC8aybxsyC20AFTC5mSc0kj9 gjCtmnIr4kz1zhrxCphmq/U83PYPLlw1LRNPrYTLQmH7/dZ9Esek1rw7zIgZwm/zjL bARMWW3lVZXDuR+LjTO/G7HjejUBdLLncWRp/6plV6vuo7PA3K4iYXxZhDfNohx3iE sVIt2UBCo0pGPEhjgGlEPZTGeb5Kii9X3K27gf+hS5dk1x8YFNM/IjjViECRSvd9CL rwKYa/0ScJ3VA== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/02/2019 08:16, Sameer Pujar wrote: ... > Objective is to have things working with or without CONFIG_PM enabled. > From previous comments and discussions it appears that there is mixed > response > for calling hda_tegra_runtime_resume() or runtime PM APIs in probe() > call. Need > to have consensus regarding the best practice to be followed, which > would eventually > can be used in other drivers too. >=20 > Rafael is suggesting to use CONFIG_PM check to do manual setup or > runtime PM setup in probe, > which would bring back the earlier above mentioned concern. >=20 > if (IS_ENABLED(CONFIG_PM)) { > do setup based on pm-runtime > } else { > =C2=A0=C2=A0=C2=A0 do manual setup > } > Both if/else might end up doing the same here. > Do we really need CONFIG_PM check here? >=20 > Instead does below proposal appear fine? >=20 > probe() { > =C2=A0=C2=A0=C2=A0 hda_tegra_enable_clock(); > } >=20 > probe_work() { > =C2=A0=C2=A0=C2=A0 /* hda setup */ > =C2=A0=C2=A0=C2=A0 . . . > =C2=A0=C2=A0=C2=A0 pm_runtime_set_active(); /* initial state as active */ > =C2=A0=C2=A0=C2=A0 pm_runtime_enable(); > =C2=A0=C2=A0=C2=A0 return; > } I believe that this still does not work, because if there is a power-domain that needs to be turned on, this does not guarantee this. So I think that you need to call pm_runtime_get ... probe() { if (!IS_ENABLED(CONFIG_PM)) hda_tegra_enable_clock(); } probe_work() { /* hda setup */ . . . pm_runtime_enable(); pm_runtime_get_sync(); return; } The alternative here could just be ... probe() { pm_runtime_enable(); if (!pm_runtime_enabled()) ret =3D hda_tegra_enable_clock(); else ret =3D pm_runtime_get_sync(); if (ret < 0) { ... } } Very similar to what I was saying to begin with but not call the pm_runtime_resume handler directly. Which I believe was Iwai-san's dislike. Cheers Jon --=20 nvpublic