Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp1863249pxb; Wed, 30 Mar 2022 11:27:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzgx+G1Q139H14N7JV7Pchg0ivzeUl2vAW0ez4p6Kn5Jf9NsF1SlFhlbwHndKs05w5OYACs X-Received: by 2002:a17:906:7304:b0:6e0:6918:ef6f with SMTP id di4-20020a170906730400b006e06918ef6fmr953384ejc.370.1648664870177; Wed, 30 Mar 2022 11:27:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648664870; cv=none; d=google.com; s=arc-20160816; b=zo4ihdwcylFIWaUuReAzEAdcOb1R8tCujFvmQpL/iywRtzRncA2SOqOU44SJTbF7bk om0/OIIkEB53XReJxXFueVw8RP0YlRD9Y/fs/MSSTB+HBUMpC6JEbh6xtVA51SzFzNwX hpqSyGV8FlMtBJK2obnz5Vb/kmbiv2I941E0yh/vDxw+TIy4Ksh2UzGYVbYFDk+acSnE h71J/PvW5dvVmrlFxYkwmijejlffUcdMMx9bUFLL+9BuLIs8OgheBBOMMQ/x7pnekUXp DRbR/p/F7M60wS4RZsRhiY5J6V6KDVMDW42Q5MaLdklHejc9ZM9/4dUQsiYxNCkdzIii K90A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:references:in-reply-to :subject:cc:to:from:message-id:date:dkim-signature:dkim-signature; bh=JZqpMZhlCgF2AWsu+Wq2l6pQPVihV5vbzAZIPvQvkpk=; b=j5sajaUAE1i91SlnXHPLFx9NQvuVPhZCMvdKytqiaRKTIQeQZ9sl84zj2/miL1da2F b1sGyRcQJmz819bUT7Y/bPr8gK3gldzcvllwpnAQSP+fF5FE3wrSU/gE97YCXHSBmpKU v81krGPKrnnzLBQo92puC+qh2Xw6BkPjjU+6NWvFMOTDz7yIGql7laeyVeS4v7O1d67l mf1L+G3PKqhAqGykFDiZGFGBWO7/3Jjlj3ayQgX1KLlT8mtwFOb6deGmSZEGaJ30WSpa cPdVOGiGr2506w0iKkoGO49Z4q96/Jww8BeX8Itk5zWxfi1AYB4MzESjLHNPZj0tJpyT niNQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=P6DRSmJO; dkim=neutral (no key) header.i=@suse.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id e9-20020a056402190900b0041b539d34c5si7507814edz.160.2022.03.30.11.27.24; Wed, 30 Mar 2022 11:27:50 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=P6DRSmJO; dkim=neutral (no key) header.i=@suse.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244324AbiC3IXT (ORCPT + 99 others); Wed, 30 Mar 2022 04:23:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58108 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244325AbiC3IW4 (ORCPT ); Wed, 30 Mar 2022 04:22:56 -0400 Received: from smtp-out2.suse.de (smtp-out2.suse.de [195.135.220.29]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D9C9630F52 for ; Wed, 30 Mar 2022 01:21:10 -0700 (PDT) Received: from relay2.suse.de (relay2.suse.de [149.44.160.134]) by smtp-out2.suse.de (Postfix) with ESMTP id 8B5201F86B; Wed, 30 Mar 2022 08:21:09 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_rsa; t=1648628469; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=JZqpMZhlCgF2AWsu+Wq2l6pQPVihV5vbzAZIPvQvkpk=; b=P6DRSmJOVf7Vt858EakxkCUkSH3NaDE3Ipe4F9v3z8Q3n1BltUFCOoXst/Izqt6plHgqDD J1U0aSPIrAUlc6XeW5eDfRMYq/mJPbXAyJ417RuH0rgrLkRupcWccIAZLieKdpFg/79xf2 5esi4G+YmpqqT6ykGXsopfOPfU9+QMM= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_ed25519; t=1648628469; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=JZqpMZhlCgF2AWsu+Wq2l6pQPVihV5vbzAZIPvQvkpk=; b=1cthgBtX0KqqTG8I7YTX0nCdrUyLGezaYJ1+7ERJ1wJ8QVY0VjcFYdL2Q7ffpd+rHOMRLQ XXBkoT3LIMLEWkDQ== Received: from alsa1.suse.de (alsa1.suse.de [10.160.4.42]) by relay2.suse.de (Postfix) with ESMTP id 76E45A3BA9; Wed, 30 Mar 2022 08:21:09 +0000 (UTC) Date: Wed, 30 Mar 2022 10:21:09 +0200 Message-ID: From: Takashi Iwai To: Mohan Kumar Cc: , , , , , , , Subject: Re: [PATCH] ALSA: hda: Avoid unsol event during RPM suspending In-Reply-To: <20220329155940.26331-1-mkumard@nvidia.com> References: <20220329155940.26331-1-mkumard@nvidia.com> User-Agent: Wanderlust/2.15.9 (Almost Unreal) SEMI/1.14.6 (Maruoka) FLIM/1.14.9 (=?UTF-8?B?R29qxY0=?=) APEL/10.8 Emacs/25.3 (x86_64-suse-linux-gnu) MULE/6.0 (HANACHIRUSATO) MIME-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 29 Mar 2022 17:59:40 +0200, Mohan Kumar wrote: > > There is a corner case with unsol event handling during codec runtime > suspending state. When the codec runtime suspend call initiated, the > codec->in_pm atomic variable would be 0, currently the codec runtime > suspend function calls snd_hdac_enter_pm() which will just increments > the codec->in_pm atomic variable. Consider unsol event happened just > after this step and before snd_hdac_leave_pm() in the codec runtime > suspend function. The snd_hdac_power_up_pm() in the unsol event > flow in hdmi_present_sense_via_verbs() function would just increment > the codec->in_pm atomic variable without calling pm_runtime_get_sync > function. > > As codec runtime suspend flow is already in progress and in parallel > unsol event is also accessing the codec verbs, as soon as codec > suspend flow completes and clocks are switched off before completing > the unsol event handling as both functions doesn't wait for each other. > This will result in below errors > > [ 589.428020] tegra-hda 3510000.hda: azx_get_response timeout, switching > to polling mode: last cmd=0x505f2f57 > [ 589.428344] tegra-hda 3510000.hda: spurious response 0x80000074:0x5, > last cmd=0x505f2f57 > [ 589.428547] tegra-hda 3510000.hda: spurious response 0x80000065:0x5, > last cmd=0x505f2f57 > > To avoid this, the unsol event flow should not perform any codec verb > related operations during RPM_SUSPENDING state. > > Signed-off-by: Mohan Kumar Thanks, applied now. Takashi