Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp690908ybz; Fri, 1 May 2020 06:54:13 -0700 (PDT) X-Google-Smtp-Source: APiQypL01mBmtWqXUUNWeloUpwOAFHekjXGS3YbJZI+8BlW/4navdu1LLB2HcFApDCMIkOdkP0Nk X-Received: by 2002:a17:906:7c4e:: with SMTP id g14mr3344258ejp.382.1588341253269; Fri, 01 May 2020 06:54:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588341253; cv=none; d=google.com; s=arc-20160816; b=wj16ElDjyQUuMksYlRZlBZO9SReic4pWmrrcGoISWAJWFVcE6VeuPnRuc2Ch4GtV8g DZuO+VQdXDDHr/HNjPbqCE//P6wix5Q/9k7fRZ7CYalUavYpZgAzoYjqHZANBz2/Q42T vRv1S2SL7dP2qvrGPgmdnTfMb7hyN+H85BsWmJXP9OZQzaTnzq7ZngkD4CF1SsCbhsWS zHAIGzwB8fCTFhxrzw9QBwP2DNoNQSEjoz64lsYSFjZxKzAxY9v+loruQSOGPK9FxnLx +fUTeimAlPYxBy7YQhAB6iV43UUPMnLpESV7AFR6qSEPCquqoI3ECfbArbuoqAmf8v0p 2ZRg== 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=r/qF1Xkg9HtA99Ul23wtQU1WA9eBCWaoH1stX3XRM1M=; b=RLBQTPU23ot2/wN48oUROOiaIDPZ8CW/3tylWD56dkM16kd5eKPL75PEOdqvoDCYx/ AYXYdvzt9Pjq9v/mQJWERIrdQfCxyRGNQm65RuCSsXWTYAr3hhmg/jaLrzxJpiU80hj5 j9AiJmY9I2olHBBivdmq7YcW9hsbif0WF3/na8jB+Msc4mH4AcMjBhj9tvkBt43jXwbD ZNO4gVoqxePdwhjfqxA3s0fgwdVTbKpPVxovT3Ezt2FgZCJpyZHttg7PPg/iFqbRjRkU grdoJcXogDbKNK5Vm1Deo00BawAbx/bOZvlVsJrjijYP4Q4s0v32utpwhyAHxvknUoa1 8enA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=K5C78gcA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v17si1630781edx.158.2020.05.01.06.53.50; Fri, 01 May 2020 06:54:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=K5C78gcA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731557AbgEANuF (ORCPT + 99 others); Fri, 1 May 2020 09:50:05 -0400 Received: from mail.kernel.org ([198.145.29.99]:40466 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731277AbgEANkZ (ORCPT ); Fri, 1 May 2020 09:40:25 -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 E8794205C9; Fri, 1 May 2020 13:40:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588340425; bh=Ze3UjFGAi6ozjZV+S3NBPO6NJ/zGOZh2wAwP6wjQayw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=K5C78gcA4iZ+4KJOXoX2PxLAJMv3/Zfw/JGAUPX5ozO06X/woKhcWt/kPEHAgESa8 PD7F5cnZwyHZwAb+4wcZI8tBN4mieBA5oIKoSsEQ3HyURZTEYw4WoF2uxW8SXeOHau ufPXoZqLR9FOeH2VYTWzkShABGA2dn7nnQpm803Y= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Roy Spliet , Takashi Iwai , Sasha Levin Subject: [PATCH 5.4 60/83] ALSA: hda: Keep the controller initialization even if no codecs found Date: Fri, 1 May 2020 15:23:39 +0200 Message-Id: <20200501131540.240757439@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200501131524.004332640@linuxfoundation.org> References: <20200501131524.004332640@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: Takashi Iwai [ Upstream commit 9479e75fca370a5220784f7596bf598c4dad0b9b ] Currently, when the HD-audio controller driver doesn't detect any codecs, it tries to abort the probe. But this abort happens at the delayed probe, i.e. the primary probe call already returned success, hence the driver is never unbound until user does so explicitly. As a result, it may leave the HD-audio device in the running state without the runtime PM. More badly, if the device is a HD-audio bus that is tied with a GPU, GPU cannot reach to the full power down and consumes unnecessarily much power. This patch changes the logic after no-codec situation; it continues probing without the further codec initialization but keep the controller driver running normally. BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=207043 Tested-by: Roy Spliet Link: https://lore.kernel.org/r/20200413082034.25166-5-tiwai@suse.de Signed-off-by: Takashi Iwai Signed-off-by: Sasha Levin --- sound/pci/hda/hda_intel.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/sound/pci/hda/hda_intel.c b/sound/pci/hda/hda_intel.c index f82f95df757cf..fbffec2ab2372 100644 --- a/sound/pci/hda/hda_intel.c +++ b/sound/pci/hda/hda_intel.c @@ -1958,7 +1958,7 @@ static int azx_first_init(struct azx *chip) /* codec detection */ if (!azx_bus(chip)->codec_mask) { dev_err(card->dev, "no codecs found!\n"); - return -ENODEV; + /* keep running the rest for the runtime PM */ } if (azx_acquire_irq(chip, 0) < 0) @@ -2268,9 +2268,11 @@ static int azx_probe_continue(struct azx *chip) #endif /* create codec instances */ - err = azx_probe_codecs(chip, azx_max_codecs[chip->driver_type]); - if (err < 0) - goto out_free; + if (bus->codec_mask) { + err = azx_probe_codecs(chip, azx_max_codecs[chip->driver_type]); + if (err < 0) + goto out_free; + } #ifdef CONFIG_SND_HDA_PATCH_LOADER if (chip->fw) { @@ -2284,7 +2286,7 @@ static int azx_probe_continue(struct azx *chip) #endif } #endif - if ((probe_only[dev] & 1) == 0) { + if (bus->codec_mask && !(probe_only[dev] & 1)) { err = azx_codec_configure(chip); if (err < 0) goto out_free; -- 2.20.1