Received: by 2002:a05:6512:2355:0:0:0:0 with SMTP id p21csp212165lfu; Wed, 30 Mar 2022 21:12:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy18UlvWJZ2qx1FXprSndPgYegzPQe60ZLFLLQJPcpsz1S7MuD6DriZ03JIijOCkZuIZ2Bm X-Received: by 2002:a17:90b:38d2:b0:1c7:1326:ec98 with SMTP id nn18-20020a17090b38d200b001c71326ec98mr3739144pjb.18.1648699462548; Wed, 30 Mar 2022 21:04:22 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1648699462; cv=pass; d=google.com; s=arc-20160816; b=OrMTiuevrhWazE5osMojyDO/v0zAA/hSCledYmCD4wfH7n22iYD5JYohB8sVlgx5a7 7NOXT7oBhZ5jTvnOGs2JFHWWkjL6HinNw6ByNKmfeA2QRYonkN5Fe+onsuiVGhEKkQUV jzVzS9SaOqIzdUSOqlVSnd98aOptOOIWij3w3yBdRw9rJkrpXiQfIRq4OysjtROnco3S AahsR5Too0ipAJylqcOYLs8isVcjvAN3Xvi3B5JsGuR1jFncB5dHp8mWbESvAHdg9OqF NpXpH2+MMB4ppaN6a6jB7awqFDOTVYjgZIycD43WMFDYlWYEqOk8cfmDmTG/lEzJjdAB mkkw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=YfyNHvyiXYIlNo0Bul5yEXwtvqGR5eGBhUOWRTdDK6g=; b=igByDhlvbCPQry8EZdxUp4kFrnFW1Dc7kHbEALfj1A8OELRJBxFk3RBIWFp7/36+I+ QLlVjey5XNEUm1aw6YvAbmSpKiRBPiukOqsiGL2GeCJcHM62NGgB7TYG4/ybGBxDPZYy CJOtYtz3B/mhU7APaUu58Be9ZOwE3BZfLRIxErgS63rXl7HxMsicaxilohUNzdiRCSD2 +jj4kdm0Dbmt4kaO+1cP7EnI/KACaFwZvgzjupROo9nwvQhBRZL+iG6AblNrQBaP3C4i w/TvhWgdD+3Z5cKngVkCHDE1Jos+M9oKy1dsekPywZunxpBZXvh6Y5Cof8n53cZS0oDZ eVZg== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@Nvidia.com header.s=selector2 header.b=l+M09axe; arc=pass (i=1 spf=pass spfdomain=nvidia.com dmarc=pass fromdomain=nvidia.com); spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=nvidia.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id b15-20020a170902d88f00b00153bb806739si21023934plz.478.2022.03.30.21.04.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 30 Mar 2022 21:04:22 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@Nvidia.com header.s=selector2 header.b=l+M09axe; arc=pass (i=1 spf=pass spfdomain=nvidia.com dmarc=pass fromdomain=nvidia.com); spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=nvidia.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id B8D4E183824; Wed, 30 Mar 2022 20:11:47 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238283AbiC2QBe (ORCPT + 99 others); Tue, 29 Mar 2022 12:01:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39596 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237665AbiC2QBd (ORCPT ); Tue, 29 Mar 2022 12:01:33 -0400 Received: from NAM12-MW2-obe.outbound.protection.outlook.com (mail-mw2nam12on2067.outbound.protection.outlook.com [40.107.244.67]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 68D6221278 for ; Tue, 29 Mar 2022 08:59:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=DONb/hpCilBFXXMk/8HGN0bod6JkOj0rERDx1Ef8GH3EsiKRMJZoUA/Y0w+PdrC+cMBMaFd3imdGqsLRND1uypAPMLNa96tI4ikp3e6DZvz3pEKuFsSOmJQeoeuFCl+eqV85fTfHO+BpnPdd48NTGbnUIbyBmfn60ngBdivPTBys1s7YF9ZX2p5E/a6uMRVYidD7lPCrdWyeFnQPtQHejB1pugMBii1L6IqHI8ttkxhAPMTA+B7UGCMc7/XlTCa2DNgD1iQ6pGuD1/tc0aujZ0S18Z5A5NzKZmo9smZN+Cq5UUHoRmShIyWQPBXweAOPEPXuDJ9CAB4DwuN9r/D1wg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=YfyNHvyiXYIlNo0Bul5yEXwtvqGR5eGBhUOWRTdDK6g=; b=dbicLCRu1gvEQuYPsRJDwPbZxRp2m5t5Z8+MpkofCFcsSDXb+F+A8NmD+ml5vaHppNja3ZQk2W75hq0wTcxwwC6MdZH0qeGzjVyBp2OMDeXMeiT9vPNHh23gmnjOmcI2PnaHWj5h7NkgKoJ3ly4igD4fD+KHE12RpBsP06ciSwFsBnvmBsIJEBYf9Yi8bt8CLLLxmHgBaj0htAotXVfCauEiGGdGGXufq4mVXpT+N3oHKzscQiAWRGXBM7/Xj7r5tROQJMpWwam1V8vMzqYeynR0GW4KmvBGtak3pUNnE0bNAITXbQUZuljT5UuzanN74Ukk/EvKimmAIM4x3ydarA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 12.22.5.234) smtp.rcpttodomain=alsa-project.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=YfyNHvyiXYIlNo0Bul5yEXwtvqGR5eGBhUOWRTdDK6g=; b=l+M09axev/5xOanWQnALsFnsEdw4P5jQN7mLr5i1fbKCWjGjZDmp/Et8/nvNOX4MfdSx3VZ90FRjQYBjZ4eGzbvqBs5PCJ2CjThiUIEM/ryeYx6ppOUZLB+DUO73zJVmAsHJByRJlGADG2WSLI567xVPdbgPrL2aZF63fLaZPI6/8y8iCqyR8ZeQM27ufQqXrOZiPaGnBtSweRTm9gTHRfm2LI+2Xy+E0RCqNhVXe+7+4lnAgCENj20vWoBl2RJ32A3dgECQeeSEqPvhW+VFgN+dtZhjhm7G7bIr0shVfK+ImfP1TKOqfRh9zYC4b1J0r+BWBUzfrEAzxM8mO+vLwQ== Received: from BN9PR03CA0988.namprd03.prod.outlook.com (2603:10b6:408:109::33) by CH2PR12MB4101.namprd12.prod.outlook.com (2603:10b6:610:a8::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5102.16; Tue, 29 Mar 2022 15:59:48 +0000 Received: from BN8NAM11FT011.eop-nam11.prod.protection.outlook.com (2603:10b6:408:109:cafe::23) by BN9PR03CA0988.outlook.office365.com (2603:10b6:408:109::33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5102.18 via Frontend Transport; Tue, 29 Mar 2022 15:59:47 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 12.22.5.234) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 12.22.5.234 as permitted sender) receiver=protection.outlook.com; client-ip=12.22.5.234; helo=mail.nvidia.com; Received: from mail.nvidia.com (12.22.5.234) by BN8NAM11FT011.mail.protection.outlook.com (10.13.176.140) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.5102.17 via Frontend Transport; Tue, 29 Mar 2022 15:59:47 +0000 Received: from rnnvmail202.nvidia.com (10.129.68.7) by DRHQMAIL101.nvidia.com (10.27.9.10) with Microsoft SMTP Server (TLS) id 15.0.1497.32; Tue, 29 Mar 2022 15:59:46 +0000 Received: from rnnvmail203.nvidia.com (10.129.68.9) by rnnvmail202.nvidia.com (10.129.68.7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Tue, 29 Mar 2022 08:59:45 -0700 Received: from mkumard.nvidia.com (10.127.8.13) by mail.nvidia.com (10.129.68.9) with Microsoft SMTP Server id 15.2.986.22 via Frontend Transport; Tue, 29 Mar 2022 08:59:43 -0700 From: Mohan Kumar To: , , , CC: , , , , Mohan Kumar Subject: [PATCH] ALSA: hda: Avoid unsol event during RPM suspending Date: Tue, 29 Mar 2022 21:29:40 +0530 Message-ID: <20220329155940.26331-1-mkumard@nvidia.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 3e0558db-401e-4b8d-2a96-08da119d261c X-MS-TrafficTypeDiagnostic: CH2PR12MB4101:EE_ X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: M1j8TMz7QkEod5ULtcFyLLDfsVM0haeV0gdI7HPFJQDp5GNDV5mz71afCHRQGO7FhI2/Re7Yrc7VX2qoX0fYXECX2bvZE2YWu8adYxBoipnwaF32bSwHPJmzmdbcTKVqYhE2Lo36DuJsz2GhDYr0R6NfU3UmTP1M5q1+fY8cuAAEJ+QZo0RwQ87aoYspdpy0gGnWjnC61ZugBQrWirIwTSiduF32uE4mb59lZhKGDkmMjT132gisZCur9quO646Jbl49EqJ7zs04YceI6aXztG4947S33zpqhwgFFDoUm8NN+9GAEvryVN99ZYbXAh24QC5A9Un1MJ8WnBp7hAvj7hZ48st/lhSPdSMKkm+oCfT+c3QjDbATh3sNVACTwWt1vmDEdhDHWg3gYCFeRFLEzMWz9dUnP6qMjZjlULwoX5snr4yF9HiHTIIszn3z9iIphvkQtMqQ3HIjiUrwD6bdhbHohb3dkJUfEb9jEysFMEL6g4lPRRbjw+U2H1l+A/WCAb0Xe0dudkImL7SoFjqvK6x+54IgRcWawm4iNVLfGbFwV+FZvokQLpW271TC2EElQ6kQdM1ssL6rNRN5gWGuhd1uSMGXqzjN9mFJyvV8ZFr1EwG+rDJEJf8arM2k1uaduCpnoYixGctM7ovWD/wo56GcmYberQrfBpuhj41yvCQ3tSbZZvuCfGppbTQbIWEewz4P8pxXoACtAlO/J+dpsw== X-Forefront-Antispam-Report: CIP:12.22.5.234;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:mail.nvidia.com;PTR:InfoNoRecords;CAT:NONE;SFS:(13230001)(4636009)(46966006)(40470700004)(36840700001)(70586007)(86362001)(316002)(8676002)(47076005)(82310400004)(356005)(40460700003)(54906003)(70206006)(110136005)(81166007)(4326008)(5660300002)(36860700001)(15650500001)(2906002)(26005)(8936002)(186003)(83380400001)(508600001)(336012)(426003)(2616005)(1076003)(107886003)(7696005)(36756003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 29 Mar 2022 15:59:47.1389 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 3e0558db-401e-4b8d-2a96-08da119d261c X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[12.22.5.234];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: BN8NAM11FT011.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CH2PR12MB4101 X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 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 --- sound/pci/hda/patch_hdmi.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/sound/pci/hda/patch_hdmi.c b/sound/pci/hda/patch_hdmi.c index c85ed7bc121e..3e086eebf88d 100644 --- a/sound/pci/hda/patch_hdmi.c +++ b/sound/pci/hda/patch_hdmi.c @@ -1625,6 +1625,7 @@ static void hdmi_present_sense_via_verbs(struct hdmi_spec_per_pin *per_pin, struct hda_codec *codec = per_pin->codec; struct hdmi_spec *spec = codec->spec; struct hdmi_eld *eld = &spec->temp_eld; + struct device *dev = hda_codec_dev(codec); hda_nid_t pin_nid = per_pin->pin_nid; int dev_id = per_pin->dev_id; /* @@ -1638,8 +1639,13 @@ static void hdmi_present_sense_via_verbs(struct hdmi_spec_per_pin *per_pin, int present; int ret; +#ifdef CONFIG_PM + if (dev->power.runtime_status == RPM_SUSPENDING) + return; +#endif + ret = snd_hda_power_up_pm(codec); - if (ret < 0 && pm_runtime_suspended(hda_codec_dev(codec))) + if (ret < 0 && pm_runtime_suspended(dev)) goto out; present = snd_hda_jack_pin_sense(codec, pin_nid, dev_id); -- 2.17.1