Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp8128803pxb; Fri, 19 Feb 2021 08:05:34 -0800 (PST) X-Google-Smtp-Source: ABdhPJwWRzAKY/w59hCcAdYBOA1YD+h8HgiBJ15gcn7rpDeWfRNCgZbWOithYzFneQpBs/eVfAj+ X-Received: by 2002:aa7:d903:: with SMTP id a3mr9997457edr.237.1613750733885; Fri, 19 Feb 2021 08:05:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613750733; cv=none; d=google.com; s=arc-20160816; b=PBK3FuI7yPQVyWyMGmsYUSQFQ1ZCGBDm4oST4BhERs64SJQ4IECMHiru+BOLxaXwG6 OqNOqSCOKcpZU66tO19GPe7XKoTF4+soq1SrMMJ92QEuBtfaxEl0ZIDbagYkYB7peK+M hndo3GRJzWJ9GMeUiquqoJMH92GdhKya4YLuXuLXCrAh2JG/kaqERWQAhOUuFYO7EsJb ZtP7H5e003IPRY3hDTgmtvperWLvdCqyCgC4yFq3LyvKNAMWvi1wOYbtw5Z+59E5zksR w0w5zk13Bgebd9mJqDxoO5pV8ZWzyzBC7xwuJRJJmHoVn7jD8KfpD6jCHh+DlMm4X0xd stRQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=l9UZb17Zma5IqYJi1B4axFnKqcGijMjlsmIo6JIpR3U=; b=wfHvf7cV3hdPmtjyN87z6z7QhyU/OCgEcoHVBLRkph9cuzv2Bxr5ujVNLxxT9Qfhe7 EIyu8kumVqB7UZ1wJUziR8Ht1YV3nJG4WjiwqmxY0dGZpHiT46noXZ8XESYSEdkRtj9T aU1IaZ86MFBQ+HuBBH9QduxAHgrD5ISooqO91jEParAHX7w6Hwe/DN0DTn19tTF8rZXW oFX0cG1PMi6QkBES9Wa9JB2x4Auxd4xKYw/rsgniQue8V8f9ZtZ/A6FegjMF7QB16Wdg 6tU8tYdInf4/bwmJ5BMFXcoX03kttPIQgBSDxeM7z7Yyldvtdx67Z2YekoL3AwEI3o24 Z5bA== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cw18si6254707ejb.645.2021.02.19.08.04.48; Fri, 19 Feb 2021 08:05:33 -0800 (PST) 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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230108AbhBSQDM (ORCPT + 99 others); Fri, 19 Feb 2021 11:03:12 -0500 Received: from inva020.nxp.com ([92.121.34.13]:35798 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229840AbhBSQBu (ORCPT ); Fri, 19 Feb 2021 11:01:50 -0500 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 8083F1A02B6; Fri, 19 Feb 2021 17:01:01 +0100 (CET) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 718E71A01C8; Fri, 19 Feb 2021 17:01:01 +0100 (CET) Received: from fsr-ub1664-175.ea.freescale.net (fsr-ub1664-175.ea.freescale.net [10.171.82.40]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id D069F2042F; Fri, 19 Feb 2021 17:01:00 +0100 (CET) From: Abel Vesa To: Rob Herring , Shawn Guo , Sascha Hauer , Lucas Stach , Fabio Estevam , Chanwoo Choi , Georgi Djakov , Dong Aisheng , Peng Fan , Martin Kepplinger , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-clk@vger.kernel.org, Linux Kernel Mailing List Cc: NXP Linux Team , Abel Vesa Subject: [RFC 06/19] devfreq: imx8m-ddrc: Use the opps acquired from EL3 Date: Fri, 19 Feb 2021 18:00:03 +0200 Message-Id: <1613750416-11901-7-git-send-email-abel.vesa@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1613750416-11901-1-git-send-email-abel.vesa@nxp.com> References: <1613750416-11901-1-git-send-email-abel.vesa@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org i.MX8M platforms get their dram OPPs from the EL3. We don't need to duplicate that in the kernel dram dts node. We should just trust the OPPs provided by the EL3. Signed-off-by: Abel Vesa --- drivers/devfreq/imx8m-ddrc.c | 49 ++---------------------------------- 1 file changed, 2 insertions(+), 47 deletions(-) diff --git a/drivers/devfreq/imx8m-ddrc.c b/drivers/devfreq/imx8m-ddrc.c index 3a6c04ba4f2e..33de83acfd8b 100644 --- a/drivers/devfreq/imx8m-ddrc.c +++ b/drivers/devfreq/imx8m-ddrc.c @@ -333,38 +333,9 @@ static int imx8m_ddrc_init_freq_info(struct device *dev) if (freq->dram_core_parent_index == 2 && freq->dram_alt_parent_index == 0) return -ENODEV; - } - - return 0; -} - -static int imx8m_ddrc_check_opps(struct device *dev) -{ - struct imx8m_ddrc *priv = dev_get_drvdata(dev); - struct imx8m_ddrc_freq *freq_info; - struct dev_pm_opp *opp; - unsigned long freq; - int i, opp_count; - - /* Enumerate DT OPPs and disable those not supported by firmware */ - opp_count = dev_pm_opp_get_opp_count(dev); - if (opp_count < 0) - return opp_count; - for (i = 0, freq = 0; i < opp_count; ++i, ++freq) { - opp = dev_pm_opp_find_freq_ceil(dev, &freq); - if (IS_ERR(opp)) { - dev_err(dev, "Failed enumerating OPPs: %ld\n", - PTR_ERR(opp)); - return PTR_ERR(opp); - } - dev_pm_opp_put(opp); - freq_info = imx8m_ddrc_find_freq(priv, freq); - if (!freq_info) { - dev_info(dev, "Disable unsupported OPP %luHz %luMT/s\n", - freq, DIV_ROUND_CLOSEST(freq, 250000)); - dev_pm_opp_disable(dev, freq); - } + if (dev_pm_opp_add(dev, freq->rate * 250000, 0)) + return -ENODEV; } return 0; @@ -372,7 +343,6 @@ static int imx8m_ddrc_check_opps(struct device *dev) static void imx8m_ddrc_exit(struct device *dev) { - dev_pm_opp_of_remove_table(dev); } static int imx8m_ddrc_probe(struct platform_device *pdev) @@ -419,16 +389,6 @@ static int imx8m_ddrc_probe(struct platform_device *pdev) return ret; } - ret = dev_pm_opp_of_add_table(dev); - if (ret < 0) { - dev_err(dev, "failed to get OPP table\n"); - return ret; - } - - ret = imx8m_ddrc_check_opps(dev); - if (ret < 0) - goto err; - priv->profile.polling_ms = 1000; priv->profile.target = imx8m_ddrc_target; priv->profile.get_dev_status = imx8m_ddrc_get_dev_status; @@ -441,13 +401,8 @@ static int imx8m_ddrc_probe(struct platform_device *pdev) if (IS_ERR(priv->devfreq)) { ret = PTR_ERR(priv->devfreq); dev_err(dev, "failed to add devfreq device: %d\n", ret); - goto err; } - return 0; - -err: - dev_pm_opp_of_remove_table(dev); return ret; } -- 2.29.2