Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3619635pxk; Tue, 29 Sep 2020 01:33:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzIQVcpI5r67m63fC+Y3/CmpNkp6l246LdOoFs+pexbAZABWhBsRxmDgL6qg0TZS3wqxNzl X-Received: by 2002:a17:906:4bc4:: with SMTP id x4mr2867113ejv.240.1601368380878; Tue, 29 Sep 2020 01:33:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601368380; cv=none; d=google.com; s=arc-20160816; b=REu+qjMYgx46kuDEcAe6VcgwMspbUx0cDW/NNBGuxW9EdoaHpWzNkFrlIRknig9Bek 5DmAMXQ05p6IncKV/lMg09aivV2E+BitKtC7TU8Diarc6a03OFNo8qJP8JKuc1yQUm0m EFY9YIO/3sf15nh+5miCO7kdhFiVekqkIsrYOVP0unuIDYEip9m+AuCja9EJ2aSHyk3c qllgVbMnwgqt4LSqxetGMlB86nLfczcDkDrlupk0JYt50E9sN9WAgzfN2dVUhB7DwRRS AUqHp2TBMX+/6bjCmKoPgXmMGTJKa2QkA37uyEQ9KQSPJSuoTxmSX0DB9sMCf5O1Q1d3 OcgQ== 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=F60ebIvCMwHFeqNd9dKuN14Z0SX03w/mrvh45fLCYaQ=; b=RQAg5FGYzYt70ZyU32IdIYUzbUb+EMF6WIxPu3NCt9LNT2phJky0BeEFJVzws09YYj ALXDdO1zMMQu+cL4LUSH6ntpYi5Lty4fz58v9pAztQ1M8qcNz33C/8nilnIGT/yWJeZE QiHvy+ljT5WZoo92pP86JreN7td7L0btDJGE6GL6IHj9W9jrRymZDfJ9jBi5g8K5P/Oy QGQXmR+/SuhFoR8D0gqZWyRklNjDFnBf1Yhb3yS6kEStTQaZDFehjDGnga0zx8Oy/VyB azQ+V3z4DHqwF7AeFYYW+Sk+QyFr+meon30cFV98GS+SFSVqEQySy61yRcmgWvmLnJ5k 3nSg== 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 b19si2237282edy.519.2020.09.29.01.32.38; Tue, 29 Sep 2020 01:33:00 -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; 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 S1727790AbgI2Ib3 (ORCPT + 99 others); Tue, 29 Sep 2020 04:31:29 -0400 Received: from inva021.nxp.com ([92.121.34.21]:53744 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727035AbgI2IbW (ORCPT ); Tue, 29 Sep 2020 04:31:22 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 6404C201185; Tue, 29 Sep 2020 10:31:20 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id AC477201181; Tue, 29 Sep 2020 10:31:16 +0200 (CEST) Received: from localhost.localdomain (mega.ap.freescale.net [10.192.208.232]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 21327402FA; Tue, 29 Sep 2020 10:31:12 +0200 (CEST) From: Ran Wang To: Li Yang , Rob Herring , Shawn Guo Cc: linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Biwen Li , Ran Wang Subject: [PATCH v3 2/5] soc: fsl: handle RCPM errata A-008646 on SoC LS1021A Date: Tue, 29 Sep 2020 16:22:31 +0800 Message-Id: <20200929082234.36619-2-ran.wang_1@nxp.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200929082234.36619-1-ran.wang_1@nxp.com> References: <20200929082234.36619-1-ran.wang_1@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Biwen Li Hardware issue: - Reading register RCPM_IPPDEXPCR1 always return zero, this causes system firmware could not get correct information and wrongly do clock gating for all wakeup source IP during system suspend. Then those IPs will never get chance to wake system. Workaround: - Copy register RCPM_IPPDEXPCR1's setting to register SCFG_SPARECR8 to allow system firmware's psci method read it and do things accordingly. Signed-off-by: Biwen Li Signed-off-by: Ran Wang --- Change in v3: - Add copy_ippdexpcr1_setting(), simplize workaournd's implementation according to binding update. - Minor update on commit message. Change in v2: - Update commit message to be more clear. - Replace device_property_read_u32_array() with syscon_regmap_lookup_by_phandle_args() to make code simpler. drivers/soc/fsl/rcpm.c | 35 ++++++++++++++++++++++++++++++++++- 1 file changed, 34 insertions(+), 1 deletion(-) diff --git a/drivers/soc/fsl/rcpm.c b/drivers/soc/fsl/rcpm.c index a093dbe..4ac2a77 100644 --- a/drivers/soc/fsl/rcpm.c +++ b/drivers/soc/fsl/rcpm.c @@ -2,7 +2,7 @@ // // rcpm.c - Freescale QorIQ RCPM driver // -// Copyright 2019 NXP +// Copyright 2019-2020 NXP // // Author: Ran Wang @@ -22,6 +22,28 @@ struct rcpm { bool little_endian; }; +#define SCFG_SPARECR8 0x051c + +static void copy_ippdexpcr1_setting(u32 val) +{ + struct device_node *np; + void __iomem *regs; + u32 reg_val; + + np = of_find_compatible_node(NULL, NULL, "fsl,ls1021a-scfg"); + if (!np) + return; + + regs = of_iomap(np, 0); + if (!regs) + return; + + reg_val = ioread32be(regs + SCFG_SPARECR8); + iowrite32be(val | reg_val, regs + SCFG_SPARECR8); + + iounmap(regs); +} + /** * rcpm_pm_prepare - performs device-level tasks associated with power * management, such as programming related to the wakeup source control. @@ -90,6 +112,17 @@ static int rcpm_pm_prepare(struct device *dev) tmp |= ioread32be(address); iowrite32be(tmp, address); } + /* + * Workaround of errata A-008646 on SoC LS1021A: + * There is a bug of register ippdexpcr1. + * Reading configuration register RCPM_IPPDEXPCR1 + * always return zero. So save ippdexpcr1's value + * to register SCFG_SPARECR8.And the value of + * ippdexpcr1 will be read from SCFG_SPARECR8. + */ + if (dev_of_node(dev) && (i == 1)) + if (device_property_read_bool(dev, "fsl,ippdexpcr1-alt-reg")) + copy_ippdexpcr1_setting(tmp); } return 0; -- 2.7.4