Received: by 10.192.165.156 with SMTP id m28csp2014025imm; Thu, 12 Apr 2018 07:16:50 -0700 (PDT) X-Google-Smtp-Source: AIpwx48aB62PK8pLTlh8TC+m448iE5Pc1mYaIGJmnMxl4oaDl19Rq4rH9LuJ3cT0D/pEKj0ogSX9 X-Received: by 2002:a17:902:b411:: with SMTP id x17-v6mr1252913plr.402.1523542610045; Thu, 12 Apr 2018 07:16:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523542609; cv=none; d=google.com; s=arc-20160816; b=xM0WHvxfc7bLY186t/uOpap0y3z1PzPqSLT95r3/FkX52m80B9fAojRSotUjz3RQ4c TFdhMcouv0Dii0nzxG0rBVwSXsZTv/qmf1YAOdmx/z48oVM7/fwYY+ZFJn2a9aXKs3Q5 pDYFcwd5/fBawhAUaIbUuFebkW5ZrTHByxxOeRueHGRHIUILpdPf6HWmWOmHFgBX2/j/ kE8tWMpSuuj7PlcVHuZpL3qpyBpS0cU4mxRazQkLNEGWwm34V+J44tngBGRdIeu9daVN jYupcG7gCex8jM9kAexJwhEA1bNOqXc14y9NEk+z0EwavCePQyVh+EOlwunoFNvIW62E ZkpQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:references:message-id :content-transfer-encoding:cc:date:in-reply-to:from:subject :mime-version:arc-authentication-results; bh=t4njFP5OmB0t2V9p5JLLD//kHYC5Dwj2Iwtvl6QVaNo=; b=x/5UrUgBTMIHz+PSUITIHKfzVM6hJazTsiNFw5w0HVLcaOpRHLGWRKkuNBneeuy2H4 6EXuNqTggUx7kpS9aMhfCCaTFa8OuFFgUOxjBc5V5VuS1wGBFwmitJYDkpjUsEbehfmT O6I73BJIPHErXyX1Cu3woqJ7mlcYPIkwEE6A/cYuBKWRFAN2/AHG9jvO/NyawDwsATeH mjDE147Kq+sfw0M8Rw7EsGOaEUPhioCM9LHwEZEaocw57t3no4mMwm81Q6PJ9WW4IZvB bKJnKQfMOTRZGQ+b5aEKK0TX5DHFJ1SUgE0wCaW9Hha+mnpclQVyXZbPPVMyzEoS+ovo 6DRg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p6si2276164pgq.292.2018.04.12.07.16.12; Thu, 12 Apr 2018 07:16:49 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752846AbeDLONB (ORCPT + 99 others); Thu, 12 Apr 2018 10:13:01 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:40333 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752303AbeDLOM5 (ORCPT ); Thu, 12 Apr 2018 10:12:57 -0400 Received: from mail-pl0-f69.google.com ([209.85.160.69]) by youngberry.canonical.com with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.76) (envelope-from ) id 1f6cy8-0006UP-9w for linux-kernel@vger.kernel.org; Thu, 12 Apr 2018 14:12:56 +0000 Received: by mail-pl0-f69.google.com with SMTP id w9-v6so3919506plp.0 for ; Thu, 12 Apr 2018 07:12:56 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=t4njFP5OmB0t2V9p5JLLD//kHYC5Dwj2Iwtvl6QVaNo=; b=rLLIxaPlcZBVT7XPhU7IGKn+HTFN1dRUMCh70T7pvmNYPkJoQ/Fjira8Hhm5SZgrNi gH0jhoOSCqtNkfkq8oHLnZPRXf6jQSqW7M85AY/uQez7VS0gLBOJdm0Tppo2xm2ScvvD 9af/UZxXTD+42B8YhApmlqxMObuAuXTCGFmyKezharuttLyQWEf9dz7W0i6c/8HZG0WF 8JTv/g/9uk7MJXeWBgn4xsFz+1IZiP0le4y4l3n/pHIPP0RodjNq/jIO6qmKMU4HQkhQ LUbHDvtKrngm/4bdYTeGu/71gbpmHe3HYRmhevZZuxCTjWfQrLxDMMrBoQHlgJcl3iox a6SA== X-Gm-Message-State: ALQs6tBNwoxsl1/dRszCYvzgaknx4M5w7sdF8YVWZngysXjwstx/Rn9A Tcmh89CiNQPwbUUtLq9RCDRG8tw9begpi9GnGme1+bFqjOt4LxaAEf6OwVAiPDg6f2Ig2UVLKiO 8F29hXiYFhGpgYdFojLHQ7QDM4/Opgl4Hl2t1Jgr/cA== X-Received: by 10.99.126.73 with SMTP id o9mr863111pgn.168.1523542374938; Thu, 12 Apr 2018 07:12:54 -0700 (PDT) X-Received: by 10.99.126.73 with SMTP id o9mr863075pgn.168.1523542374433; Thu, 12 Apr 2018 07:12:54 -0700 (PDT) Received: from [192.168.1.205] (114-32-108-117.HINET-IP.hinet.net. [114.32.108.117]) by smtp.gmail.com with ESMTPSA id t23sm8518412pgu.41.2018.04.12.07.12.52 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 12 Apr 2018 07:12:53 -0700 (PDT) Content-Type: text/plain; charset=us-ascii; delsp=yes; format=flowed Mime-Version: 1.0 (Mac OS X Mail 11.3 \(3445.6.18\)) Subject: Re: [PATCH v3 3/3] ALSA: hda: Disabled unused audio controller for Dell platforms with Switchable Graphics From: Kai-Heng Feng In-Reply-To: Date: Thu, 12 Apr 2018 22:12:49 +0800 Cc: Lukas Wunner , mario.limonciello@dell.com, pali.rohar@gmail.com, andy@infradead.org, dvhart@infradead.org, mjg59@srcf.ucam.org, alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org, platform-driver-x86@vger.kernel.org Content-Transfer-Encoding: 7bit Message-Id: <018FF40E-B380-4E22-9599-2F4A2A8B51B7@canonical.com> References: <20180412104239.25584-1-kai.heng.feng@canonical.com> <20180412104239.25584-3-kai.heng.feng@canonical.com> To: Takashi Iwai X-Mailer: Apple Mail (2.3445.6.18) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org at 6:50 PM, Takashi Iwai wrote: > On Thu, 12 Apr 2018 12:42:39 +0200, > Kai-Heng Feng wrote: >> Some Dell platforms (Preicsion 7510/7710/7520/7720) have a BIOS option >> "Switchable Graphics" (SG). >> >> When SG is enabled, we have: >> 00:02.0 VGA compatible controller: Intel Corporation Device 591b (rev 04) >> 00:1f.3 Audio device: Intel Corporation CM238 HD Audio Controller (rev 31) >> 01:00.0 VGA compatible controller: Advanced Micro Devices, Inc. >> [AMD/ATI] Ellesmere [Polaris10] >> 01:00.1 Audio device: Advanced Micro Devices, Inc. [AMD/ATI] Ellesmere >> [Radeon RX 580] >> >> The Intel Audio outputs all the sound, including HDMI audio. The audio >> controller comes with AMD graphics doesn't get used. >> >> When SG is disabled, we have: >> 00:1f.3 Audio device: Intel Corporation CM238 HD Audio Controller (rev 31) >> 01:00.0 VGA compatible controller: Advanced Micro Devices, Inc. >> [AMD/ATI] Ellesmere [Polaris10] >> 01:00.1 Audio device: Advanced Micro Devices, Inc. [AMD/ATI] Ellesmere >> [Radeon RX 580] >> >> Now it's a typical discrete-only system. HDMI audio comes from AMD audio >> controller, others from Intel audio controller. >> >> When SG is enabled, the unused AMD audio controller still exposes its >> sysfs, so userspace still opens the control file and stream. If >> userspace tries to output sound through the stream, it hangs when >> runtime suspend kicks in: >> [ 12.796265] snd_hda_intel 0000:01:00.1: Disabling via vga_switcheroo >> [ 12.796367] snd_hda_intel 0000:01:00.1: Cannot lock devices! >> >> Since the discrete audio controller isn't useful when SG enabled, we >> should just disable the device. >> >> Signed-off-by: Kai-Heng Feng > > Adding Lukas to Cc. > > I thought we manage this better now with runtime PM by Lukas's recent > patchset? > Yes, that's true. I'll update commit log for next iteration. Nevertheless, the unusable control file and stream still get exposed via sysfs. We should disable them when SG is enabled. Kai-Heng > > thanks, > > Takashi > >> --- >> v3: Simplify dell_switchable_gfx_is_enabled() by returning bool instead >> of error code. >> Use DMI_DEV_TYPE_OEM_STRING to match Dell System. >> >> v2: Mario suggested to squash the HDA part into the same series. >> >> sound/pci/hda/hda_intel.c | 39 +++++++++++++++++++++++++++++++++++++++ >> 1 file changed, 39 insertions(+) >> >> diff --git a/sound/pci/hda/hda_intel.c b/sound/pci/hda/hda_intel.c >> index 7720e3102bcc..d9310616d5ca 100644 >> --- a/sound/pci/hda/hda_intel.c >> +++ b/sound/pci/hda/hda_intel.c >> @@ -49,6 +49,8 @@ >> #include >> #include >> #include >> +#include >> +#include >> >> #ifdef CONFIG_X86 >> /* for snoop control */ >> @@ -1629,6 +1631,38 @@ static void check_msi(struct azx *chip) >> } >> } >> >> +#if IS_ENABLED(CONFIG_DELL_LAPTOP) >> +static bool check_dell_switchable_gfx(struct pci_dev *pdev) >> +{ >> + bool (*dell_switchable_gfx_is_enabled_func)(void); >> + bool enabled; >> + >> + /* Only need to check for Dell laptops and AIOs */ >> + if (!dmi_find_device(DMI_DEV_TYPE_OEM_STRING, "Dell System", NULL) || >> + !(dmi_match(DMI_CHASSIS_TYPE, "10") || >> + dmi_match(DMI_CHASSIS_TYPE, "13")) || >> + !(pdev->vendor == PCI_VENDOR_ID_ATI || >> + pdev->vendor == PCI_VENDOR_ID_NVIDIA)) >> + return false; >> + >> + dell_switchable_gfx_is_enabled_func = >> + symbol_request(dell_switchable_gfx_is_enabled); >> + if (!dell_switchable_gfx_is_enabled_func) >> + return false; >> + >> + enabled = dell_switchable_gfx_is_enabled_func(); >> + >> + symbol_put(dell_switchable_gfx_is_enabled); >> + >> + return enabled; >> +} >> +#else >> +static bool check_dell_switchable_gfx(struct pci_dev *pdev) >> +{ >> + return false; >> +} >> +#endif >> + >> /* check the snoop mode availability */ >> static void azx_check_snoop_available(struct azx *chip) >> { >> @@ -1711,6 +1745,11 @@ static int azx_create(struct snd_card *card, >> struct pci_dev *pci, >> if (err < 0) >> return err; >> >> + if (check_dell_switchable_gfx(pci)) { >> + pci_disable_device(pci); >> + return -ENODEV; >> + } >> + >> hda = kzalloc(sizeof(*hda), GFP_KERNEL); >> if (!hda) { >> pci_disable_device(pci); >> -- >> 2.17.0