Received: by 2002:a05:6358:53a8:b0:117:f937:c515 with SMTP id z40csp3747454rwe; Mon, 17 Apr 2023 03:01:33 -0700 (PDT) X-Google-Smtp-Source: AKy350ZJhz2DEgBO6rfI+wDfHQS23XpfP0BUGbsKLOouXeaZ1eVvJsjqHD12n7O53wTMw61nLqiM X-Received: by 2002:a05:6a20:440c:b0:ef:7b11:3ad with SMTP id ce12-20020a056a20440c00b000ef7b1103admr5042414pzb.33.1681725693444; Mon, 17 Apr 2023 03:01:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681725693; cv=none; d=google.com; s=arc-20160816; b=N2C6Jcab1tOrOEWV7v8e9vH5Hp1WAhqmJL4qNCVMGk6vOG/z9E0pBPhr2WhxXh5WIH cuY0fsAM0yP3h3G1XWEdgAaZk2KcqIz8klajY5Wad2KGVw+i+2aqxAmvI7V9xObDJugF HTujOsBovy6Ce747OYOsMlB4SN0mYTSBGukOIbw819DrsAppMnfVrjhDLF/GMx/hNvl0 n7taOKTvuHaBNkVKNl+Z/qeZsOj5uwRwGM7qxSBYgcBQ7vXz0JcfjCLhQL7dwzQ3+5Ys cPvuk7gYAYq3yrU+qA83Dg1WuF/B140StZ7Ld1yWYrDFUTzWE3zSNssFM7PYBcQr7y6a +z4g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=446AftO1YTpTO8Uak9Nkazo7M9V8oMKbp3yXw2eFLNc=; b=cT+sXGtuNevkzABpvpC7LLW88wS6p0KbIzOpC86kxYTXYbn5XacGDxu4nucIpUlFZn TGWwUt5fdq/WZFvqYmOQDLiMo2OkFKMgRJwYGkVOIvUi8RjZ6Zc1zdisNthnMDS7f4IC YfnROSBkOU2kk7VYjgmWmXN5x/F5Zf25ylZxQajVffwuR+aP31jACVChZW7v803h/9Ov nmUoVwHwc3Eq20zwPVorLeNmzi/vYo6Lzlun8iZJqaNdvkDqhTLoB2fbgtMGGxnuk2F3 JeS+qBbFXKVDfCxng3KrGRxDyxzqxLnyIePgS5I2lrLMaLCkTX6HOUpfxILafYPa9qwD xkNw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=PcNZLluV; 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=linaro.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x5-20020a654145000000b005138c1f1fccsi11049978pgp.31.2023.04.17.03.01.17; Mon, 17 Apr 2023 03:01:33 -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=@linaro.org header.s=google header.b=PcNZLluV; 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=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229583AbjDQKBA (ORCPT + 99 others); Mon, 17 Apr 2023 06:01:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34326 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229555AbjDQKA6 (ORCPT ); Mon, 17 Apr 2023 06:00:58 -0400 Received: from mail-ej1-x631.google.com (mail-ej1-x631.google.com [IPv6:2a00:1450:4864:20::631]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id ABE4D59E8 for ; Mon, 17 Apr 2023 03:00:14 -0700 (PDT) Received: by mail-ej1-x631.google.com with SMTP id u3so10576912ejj.12 for ; Mon, 17 Apr 2023 03:00:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1681725607; x=1684317607; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=446AftO1YTpTO8Uak9Nkazo7M9V8oMKbp3yXw2eFLNc=; b=PcNZLluVNkbT0NeE/kEPH+FWVuik2f57wqzwJPqbweqLU1E02iin4GGVo43iD+3xm6 uhZbURFjh7KKISrUqMZeobGpanaUW7VcFZ1xrSkhY5DQ3V1A5wzu/G3CZWIGZ9r5gTc/ FyGhWflV4k5pdTU5j3fqUQ4hzr7ZZ7OLCnA4dD9bJ4I1kMnQ+c0nJ8hY77eJdRXlfEqi SZQQNaQVlvIa+ZSieAFjwk73Zk2sx2uqxFtvd6kH7ERRKb5u/qxa6LR1/vvnanzRaLCo suOp2UN7mekZrgMmUa1efDJPGym3F2i1+nfgrAUuVFhCCnm/u5GJsSF9uU9CeWJI2isq izhg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1681725607; x=1684317607; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=446AftO1YTpTO8Uak9Nkazo7M9V8oMKbp3yXw2eFLNc=; b=VxJbQykLbycgDM0V1yQyPDelF/ZfIbIWHezIMbk7YDoAiZClxrCkXVgIv1f9pkTo31 pCyLVyRGcINjWmi35qQGc1N1Gn4+IB8v0rQ3wBx6WO9Gf31VrZ6oiDt7emA3QrAGTcLz O32dOSPWaZbZpe0BRbNm46OE7EWtnmn8J8rJqknuoUPk2f8emDlU00uf1LheIkCVKLFR 1TGWLfujjBMMKY+Im/oikiSiol2wFhlxrtfBzJvHUb1FTjpEG56fHayi5pTe+PIof/AM cxEzsPRrGOe7eE1zNJWWHTubnkUxDiXVW5ECNnvjYZmGh77gzQ0YYW9eG04bajmYuBiv gIZA== X-Gm-Message-State: AAQBX9d+gm8jLYC3SYpInguyPNPAZB8nhQRMnudWFD2UNzmFeimKTPwj JGq/2opLCPfBbOPPtEp5FICkkg== X-Received: by 2002:a17:906:4c4a:b0:94e:4735:92f8 with SMTP id d10-20020a1709064c4a00b0094e473592f8mr6273016ejw.27.1681725606644; Mon, 17 Apr 2023 03:00:06 -0700 (PDT) Received: from [192.168.2.1] (146725694.box.freepro.com. [130.180.211.218]) by smtp.googlemail.com with ESMTPSA id y15-20020a170906524f00b0094e1026bc66sm6490180ejm.140.2023.04.17.03.00.05 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 17 Apr 2023 03:00:06 -0700 (PDT) Message-ID: <5c21f6b7-8c7e-6e42-fe02-c8fd3ae64016@linaro.org> Date: Mon, 17 Apr 2023 11:59:59 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.4.2 Subject: Re: [PATCH v2] thermal/drivers/intel/int340x: Add DLVR support Content-Language: en-US To: Srinivas Pandruvada , rafael@kernel.org, rui.zhang@intel.com Cc: linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org References: <20230413213753.129962-1-srinivas.pandruvada@linux.intel.com> From: Daniel Lezcano In-Reply-To: <20230413213753.129962-1-srinivas.pandruvada@linux.intel.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, 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 Hi Rafael, do you want me to pick this patch ? On 13/04/2023 23:37, Srinivas Pandruvada wrote: > Add support for DLVR (Digital Linear Voltage Regulator) attributes, > which can be used to control RFIM. > Here instead of "fivr" another directory "dlvr" is created with DLVR > attributes: > > /sys/bus/pci/devices/0000:00:04.0/dlvr > ├── dlvr_freq_mhz > ├── dlvr_freq_select > ├── dlvr_hardware_rev > ├── dlvr_pll_busy > ├── dlvr_rfim_enable > └── dlvr_spread_spectrum_pct > └── dlvr_control_mode > └── dlvr_control_lock > > Attributes > dlvr_freq_mhz (RO): > Current DLVR PLL frequency in MHz. > > dlvr_freq_select (RW): > Sets DLVR PLL clock frequency. > > dlvr_hardware_rev (RO): > DLVR hardware revision. > > dlvr_pll_busy (RO): > PLL can't accept frequency change when set. > > dlvr_rfim_enable (RW): > 0: Disable RF frequency hopping, 1: Enable RF frequency hopping. > > dlvr_control_mode (RW): > Specifies how frequencies are spread. 0: Down spread, 1: Spread in Center. > > dlvr_control_lock (RW): > 1: future writes are ignored. > > dlvr_spread_spectrum_pct (RW) > A write to this register updates the DLVR spread spectrum percent value. > > Signed-off-by: Srinivas Pandruvada > --- > v2 > - Updated documentation > - Added dlvr_control_lock attribute > > .../driver-api/thermal/intel_dptf.rst | 46 +++++++++- > .../processor_thermal_device.c | 3 +- > .../processor_thermal_device.h | 1 + > .../processor_thermal_device_pci.c | 2 +- > .../int340x_thermal/processor_thermal_rfim.c | 92 ++++++++++++++++++- > 5 files changed, 135 insertions(+), 9 deletions(-) > > diff --git a/Documentation/driver-api/thermal/intel_dptf.rst b/Documentation/driver-api/thermal/intel_dptf.rst > index f5c193cccbda..9ab4316322a1 100644 > --- a/Documentation/driver-api/thermal/intel_dptf.rst > +++ b/Documentation/driver-api/thermal/intel_dptf.rst > @@ -184,8 +184,9 @@ ABI. > DPTF Processor thermal RFIM interface > -------------------------------------------- > > -RFIM interface allows adjustment of FIVR (Fully Integrated Voltage Regulator) > -and DDR (Double Data Rate)frequencies to avoid RF interference with WiFi and 5G. > +RFIM interface allows adjustment of FIVR (Fully Integrated Voltage Regulator), > +DDR (Double Data Rate) and DLVR (Digital Linear Voltage Regulator) > +frequencies to avoid RF interference with WiFi and 5G. > > Switching voltage regulators (VR) generate radiated EMI or RFI at the > fundamental frequency and its harmonics. Some harmonics may interfere > @@ -196,6 +197,15 @@ small % and shift away the switching noise harmonic interference from > radio channels. OEM or ODMs can use the driver to control SOC IVR > operation within the range where it does not impact IVR performance. > > +Some products use DLVR instead of FIVR as switching voltage regulator. > +In this case attributes of DLVR must be adjusted instead of FIVR. > + > +While shifting the frequencies additional clock noise can be introduced, > +which is compensated by adjusting Spread spectrum percent. This helps > +to reduce the clock noise to meet regulatory compliance. This spreading > +% increases bandwidth of signal transmission and hence reduces the > +effects of interference, noise and signal fading. > + > DRAM devices of DDR IO interface and their power plane can generate EMI > at the data rates. Similar to IVR control mechanism, Intel offers a > mechanism by which DDR data rates can be changed if several conditions > @@ -264,6 +274,38 @@ DVFS attributes > ``rfi_disable (RW)`` > Disable DDR rate change feature > > +DLVR attributes > + > +:file:`/sys/bus/pci/devices/0000\:00\:04.0/dlvr/` > + > +``dlvr_hardware_rev`` (RO) > + DLVR hardware revision. > + > +``dlvr_freq_mhz`` (RO) > + Current DLVR PLL frequency in MHz. > + > +``dlvr_freq_select`` (RW) > + Sets DLVR PLL clock frequency. Once set, and enabled via > + dlvr_rfim_enable, the dlvr_freq_mhz will show the current > + DLVR PLL frequency. > + > +``dlvr_pll_busy`` (RO) > + PLL can't accept frequency change when set. > + > +``dlvr_rfim_enable`` (RW) > + 0: Disable RF frequency hopping, 1: Enable RF frequency hopping. > + > +``dlvr_spread_spectrum_pct`` (RW) > + Sets DLVR spread spectrum percent value. > + > +``dlvr_control_mode`` (RW) > + Specifies how frequencies are spread using spread spectrum. > + 0: Down spread, > + 1: Spread in the Center. > + > +``dlvr_control_lock`` (RW) > + 1: future writes are ignored. > + > DPTF Power supply and Battery Interface > ---------------------------------------- > > diff --git a/drivers/thermal/intel/int340x_thermal/processor_thermal_device.c b/drivers/thermal/intel/int340x_thermal/processor_thermal_device.c > index a1dc18be7609..3ca0a2f5937f 100644 > --- a/drivers/thermal/intel/int340x_thermal/processor_thermal_device.c > +++ b/drivers/thermal/intel/int340x_thermal/processor_thermal_device.c > @@ -337,7 +337,8 @@ int proc_thermal_mmio_add(struct pci_dev *pdev, > } > > if (feature_mask & PROC_THERMAL_FEATURE_FIVR || > - feature_mask & PROC_THERMAL_FEATURE_DVFS) { > + feature_mask & PROC_THERMAL_FEATURE_DVFS || > + feature_mask & PROC_THERMAL_FEATURE_DLVR) { > ret = proc_thermal_rfim_add(pdev, proc_priv); > if (ret) { > dev_err(&pdev->dev, "failed to add RFIM interface\n"); > diff --git a/drivers/thermal/intel/int340x_thermal/processor_thermal_device.h b/drivers/thermal/intel/int340x_thermal/processor_thermal_device.h > index 7d52fcff4937..7acaa8f1b896 100644 > --- a/drivers/thermal/intel/int340x_thermal/processor_thermal_device.h > +++ b/drivers/thermal/intel/int340x_thermal/processor_thermal_device.h > @@ -60,6 +60,7 @@ struct rapl_mmio_regs { > #define PROC_THERMAL_FEATURE_FIVR 0x02 > #define PROC_THERMAL_FEATURE_DVFS 0x04 > #define PROC_THERMAL_FEATURE_MBOX 0x08 > +#define PROC_THERMAL_FEATURE_DLVR 0x10 > > #if IS_ENABLED(CONFIG_PROC_THERMAL_MMIO_RAPL) > int proc_thermal_rapl_add(struct pci_dev *pdev, struct proc_thermal_device *proc_priv); > diff --git a/drivers/thermal/intel/int340x_thermal/processor_thermal_device_pci.c b/drivers/thermal/intel/int340x_thermal/processor_thermal_device_pci.c > index d71ee50e7878..8b260dd9221b 100644 > --- a/drivers/thermal/intel/int340x_thermal/processor_thermal_device_pci.c > +++ b/drivers/thermal/intel/int340x_thermal/processor_thermal_device_pci.c > @@ -351,7 +351,7 @@ static SIMPLE_DEV_PM_OPS(proc_thermal_pci_pm, proc_thermal_pci_suspend, > > static const struct pci_device_id proc_thermal_pci_ids[] = { > { PCI_DEVICE_DATA(INTEL, ADL_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_MBOX) }, > - { PCI_DEVICE_DATA(INTEL, MTLP_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_MBOX) }, > + { PCI_DEVICE_DATA(INTEL, MTLP_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_MBOX | PROC_THERMAL_FEATURE_DLVR) }, > { PCI_DEVICE_DATA(INTEL, RPL_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_MBOX) }, > { }, > }; > diff --git a/drivers/thermal/intel/int340x_thermal/processor_thermal_rfim.c b/drivers/thermal/intel/int340x_thermal/processor_thermal_rfim.c > index 92ed1213fe37..546b70434004 100644 > --- a/drivers/thermal/intel/int340x_thermal/processor_thermal_rfim.c > +++ b/drivers/thermal/intel/int340x_thermal/processor_thermal_rfim.c > @@ -39,6 +39,29 @@ static const struct mmio_reg tgl_fivr_mmio_regs[] = { > { 1, 0x5A14, 2, 0x3, 1}, /* fivr_fffc_rev */ > }; > > +static const char * const dlvr_strings[] = { > + "dlvr_spread_spectrum_pct", > + "dlvr_control_mode", > + "dlvr_control_lock", > + "dlvr_rfim_enable", > + "dlvr_freq_select", > + "dlvr_hardware_rev", > + "dlvr_freq_mhz", > + "dlvr_pll_busy", > + NULL > +}; > + > +static const struct mmio_reg dlvr_mmio_regs[] = { > + { 0, 0x15A08, 5, 0x1F, 0}, /* dlvr_spread_spectrum_pct */ > + { 0, 0x15A08, 1, 0x1, 5}, /* dlvr_control_mode */ > + { 0, 0x15A08, 1, 0x1, 6}, /* dlvr_control_lock */ > + { 0, 0x15A08, 1, 0x1, 7}, /* dlvr_rfim_enable */ > + { 0, 0x15A08, 12, 0xFFF, 8}, /* dlvr_freq_select */ > + { 1, 0x15A10, 2, 0x3, 30}, /* dlvr_hardware_rev */ > + { 1, 0x15A10, 16, 0xFFFF, 0}, /* dlvr_freq_mhz */ > + { 1, 0x15A10, 1, 0x1, 16}, /* dlvr_pll_busy */ > +}; > + > /* These will represent sysfs attribute names */ > static const char * const dvfs_strings[] = { > "rfi_restriction_run_busy", > @@ -78,14 +101,16 @@ static ssize_t suffix##_show(struct device *dev,\ > int ret;\ > \ > proc_priv = pci_get_drvdata(pdev);\ > - if (table) {\ > + if (table == 1) {\ > match_strs = (const char **)dvfs_strings;\ > mmio_regs = adl_dvfs_mmio_regs;\ > - } else { \ > + } else if (table == 2) { \ > + match_strs = (const char **)dlvr_strings;\ > + mmio_regs = dlvr_mmio_regs;\ > + } else {\ > match_strs = (const char **)fivr_strings;\ > mmio_regs = tgl_fivr_mmio_regs;\ > } \ > - \ > ret = match_string(match_strs, -1, attr->attr.name);\ > if (ret < 0)\ > return ret;\ > @@ -109,10 +134,13 @@ static ssize_t suffix##_store(struct device *dev,\ > u32 mask;\ > \ > proc_priv = pci_get_drvdata(pdev);\ > - if (table) {\ > + if (table == 1) {\ > match_strs = (const char **)dvfs_strings;\ > mmio_regs = adl_dvfs_mmio_regs;\ > - } else { \ > + } else if (table == 2) { \ > + match_strs = (const char **)dlvr_strings;\ > + mmio_regs = dlvr_mmio_regs;\ > + } else {\ > match_strs = (const char **)fivr_strings;\ > mmio_regs = tgl_fivr_mmio_regs;\ > } \ > @@ -147,6 +175,47 @@ RFIM_STORE(spread_spectrum_clk_enable, 0) > RFIM_STORE(rfi_vco_ref_code, 0) > RFIM_STORE(fivr_fffc_rev, 0) > > +RFIM_SHOW(dlvr_spread_spectrum_pct, 2) > +RFIM_SHOW(dlvr_control_mode, 2) > +RFIM_SHOW(dlvr_control_lock, 2) > +RFIM_SHOW(dlvr_hardware_rev, 2) > +RFIM_SHOW(dlvr_freq_mhz, 2) > +RFIM_SHOW(dlvr_pll_busy, 2) > +RFIM_SHOW(dlvr_freq_select, 2) > +RFIM_SHOW(dlvr_rfim_enable, 2) > + > +RFIM_STORE(dlvr_spread_spectrum_pct, 2) > +RFIM_STORE(dlvr_rfim_enable, 2) > +RFIM_STORE(dlvr_freq_select, 2) > +RFIM_STORE(dlvr_control_mode, 2) > +RFIM_STORE(dlvr_control_lock, 2) > + > +static DEVICE_ATTR_RW(dlvr_spread_spectrum_pct); > +static DEVICE_ATTR_RW(dlvr_control_mode); > +static DEVICE_ATTR_RW(dlvr_control_lock); > +static DEVICE_ATTR_RW(dlvr_freq_select); > +static DEVICE_ATTR_RO(dlvr_hardware_rev); > +static DEVICE_ATTR_RO(dlvr_freq_mhz); > +static DEVICE_ATTR_RO(dlvr_pll_busy); > +static DEVICE_ATTR_RW(dlvr_rfim_enable); > + > +static struct attribute *dlvr_attrs[] = { > + &dev_attr_dlvr_spread_spectrum_pct.attr, > + &dev_attr_dlvr_control_mode.attr, > + &dev_attr_dlvr_control_lock.attr, > + &dev_attr_dlvr_freq_select.attr, > + &dev_attr_dlvr_hardware_rev.attr, > + &dev_attr_dlvr_freq_mhz.attr, > + &dev_attr_dlvr_pll_busy.attr, > + &dev_attr_dlvr_rfim_enable.attr, > + NULL > +}; > + > +static const struct attribute_group dlvr_attribute_group = { > + .attrs = dlvr_attrs, > + .name = "dlvr" > +}; > + > static DEVICE_ATTR_RW(vco_ref_code_lo); > static DEVICE_ATTR_RW(vco_ref_code_hi); > static DEVICE_ATTR_RW(spread_spectrum_pct); > @@ -277,12 +346,22 @@ int proc_thermal_rfim_add(struct pci_dev *pdev, struct proc_thermal_device *proc > return ret; > } > > + if (proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_DLVR) { > + ret = sysfs_create_group(&pdev->dev.kobj, &dlvr_attribute_group); > + if (ret) > + return ret; > + } > + > if (proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_DVFS) { > ret = sysfs_create_group(&pdev->dev.kobj, &dvfs_attribute_group); > if (ret && proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_FIVR) { > sysfs_remove_group(&pdev->dev.kobj, &fivr_attribute_group); > return ret; > } > + if (ret && proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_DLVR) { > + sysfs_remove_group(&pdev->dev.kobj, &dlvr_attribute_group); > + return ret; > + } > } > > return 0; > @@ -296,6 +375,9 @@ void proc_thermal_rfim_remove(struct pci_dev *pdev) > if (proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_FIVR) > sysfs_remove_group(&pdev->dev.kobj, &fivr_attribute_group); > > + if (proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_DLVR) > + sysfs_remove_group(&pdev->dev.kobj, &dlvr_attribute_group); > + > if (proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_DVFS) > sysfs_remove_group(&pdev->dev.kobj, &dvfs_attribute_group); > } -- Linaro.org │ Open source software for ARM SoCs Follow Linaro: Facebook | Twitter | Blog