From patchwork Mon Jan 13 18:56:15 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stefan Wahren X-Patchwork-Id: 11330765 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 8ADE21398 for ; Mon, 13 Jan 2020 18:57:36 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 683A021556 for ; Mon, 13 Jan 2020 18:57:36 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="VValF3E7" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 683A021556 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=i2se.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:MIME-Version:Cc:List-Subscribe: List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id:References: In-Reply-To:Message-Id:Date:Subject:To:From:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Owner; bh=hoJDAs/wP6ll62xK5w5ydnRbKIXjaKYQv5ynkZSJqcc=; b=VValF3E7oZHriNAixb7g28oDA1 5rbieHR83qpkyXxC/VcfYU2bzMZEEpzb4qnrIqhNqtXaDO3KyPi8PfUVU441OzGmboHgaWEoJYz/s cJjRELtcjqf/aXnFzSXjye+a60fli9zJ1F8646iSn0LVl3K0HAq8MaAd2dS7/Tz1yHDpeQWyj8kWA N/rULuecXHPIaN+hH2WSHUEiUIpVd0MLCyeWKfqcD1ZxjnFXXZXi9JvXDN2poMAW7jbuvWF6G+75f XIp2Q4ks/Nx/iUA5v4HD6KU5U2ro/z4HwkZj/3odaN0vIhcZku2RNh0Lp6ekyljJLYac5k8YXaEMU 2pNkyRPw==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4u6-0000U8-Va; Mon, 13 Jan 2020 18:57:34 +0000 Received: from mout.kundenserver.de ([212.227.126.131]) by bombadil.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4tR-0008EK-Kw for linux-arm-kernel@lists.infradead.org; Mon, 13 Jan 2020 18:56:55 +0000 Received: from localhost.localdomain ([37.4.249.154]) by mrelayeu.kundenserver.de (mreue011 [212.227.15.167]) with ESMTPSA (Nemesis) id 1M5PyX-1iqFPY1tHJ-001NIF; Mon, 13 Jan 2020 19:56:41 +0100 From: Stefan Wahren To: Zhang Rui , Daniel Lezcano , Amit Kucheria , Rob Herring , Mark Rutland , Nicolas Saenz Julienne , Florian Fainelli , Catalin Marinas , Will Deacon Subject: [PATCH V5 1/4] dt-bindings: Add Broadcom AVS RO thermal Date: Mon, 13 Jan 2020 19:56:15 +0100 Message-Id: <1578941778-23321-2-git-send-email-stefan.wahren@i2se.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> References: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> X-Provags-ID: V03:K1:1LJ2j7244eYkHFAUHdWlluvFEyk8XYcN5PXA1gFB39CpNctCmlA tHCLseCL17seFiEhGPXjTI7fZAU2vjdjjeBTRZlZJvpWQ+F+NJTMqHI2cxDMDNpXt6WFSrd URaMI8WB9CPCul3CewrF8jkvLQHySlDVor7raLVMen5Ha8pSkw8cQjEN40X7Ra4vWt2W9B6 1zVmC9h+RDBbMcfP5DvyA== X-Spam-Flag: NO X-UI-Out-Filterresults: notjunk:1;V03:K0:qxivOdifFGE=:4XZSIRqIgLFn5Se3XfzOXO hn3JrVw+qNXKVs2QVvzasuUduBzxughpiGolGcmx1npMHd5NAzfbe4Qd4mAYJqhP0TKdVJHtP /SuG0KScUUYnPK7YhaoFMRJrMPRp4bFDPgKmAQUmj4e6aHXsGPkj+jPIkJ1qhzYilxcHICg3/ 1mOzcT+YwH6t3SsaGyn6jhWYepFEFrgKVKY0ixjGdx5TZAeosmmRmhmNOn5VykDa7bPBGfdJP biIyTC/I4f1Xe6MKXJHw3velSKsbw1EL87w2im5MR1sLfmCvUD1Z1Mqw5A0EJhkih4UZzrKfV Cpabq/EE8eID7wixqSmJPCuw7XXjsLTFZfxXGGwKJOyPZO/Xx7QQannAvEpcyyd3KM8vX1TXa v5T2bxB6Y09h6RZtlnNZ/HH/zXhHC7jJYctEgLKNTrZt/FQbXNHTqyGS9H7fBtFYlelTbG3sl rPMop7FuKlK/4b1nCkxkDljJGrQSP48sTh+UltzCX4iwK45IsO4O9NDKzd4HmQfelsMpgBEZr NHnaqIof5HPK2dQaj5nDt2fa0RR2GimNWj7lGXeWe1CYyX7gvYEEvoYx7EeaLZ2aBYFDAEikD AsGhm/fVxlez8MnY1SrjE750KaWbCjEtgSx37HHV3zJF8oa29LiGv6g5gU09o5vRBxJy37j8Q SFFX4V1ho6WrZkZg+5E1r7W0SEjg8OKnOYubgU/3cokER8yhifXcQg2aQiFhP0XmqkqM8EJ1B 6ZKS/kHOwgufF1acrHlAVga/HvksHRRxNWavGJT0c3SgHjldJs1PLoNcXbUiOw4w/OsR7db/9 qA7yl1CwrrnRqpnT+5oyv1v+obYwFypvKulQodJqIVRnG4qJqwbSOdgcTZ3xPDIjC7WjJZ/Hb S6iSRXBZuKM2O/mUwK/6lFzt1L7n3RxqOHk8n3ow4= X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200113_105653_985586_1A341941 X-CRM114-Status: GOOD ( 13.32 ) X-Spam-Score: 0.0 (/) X-Spam-Report: SpamAssassin version 3.4.2 on bombadil.infradead.org summary: Content analysis details: (0.0 points) pts rule name description ---- ---------------------- -------------------------------------------------- -0.0 RCVD_IN_DNSWL_NONE RBL: Sender listed at https://www.dnswl.org/, no trust [212.227.126.131 listed in list.dnswl.org] 0.0 SPF_HELO_NONE SPF: HELO does not publish an SPF Record -0.0 SPF_PASS SPF: sender matches SPF record X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Stefan Wahren , devicetree@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, linux-arm-kernel@lists.infradead.org, linux-pm@vger.kernel.org MIME-Version: 1.0 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org Since the BCM2711 doesn't have a AVS TMON block, the thermal information must be retrieved from the AVS ring oscillator block. This block is part of the AVS monitor which contains a bunch of raw sensors. Signed-off-by: Stefan Wahren Reviewed-by: Rob Herring Reviewed-by: Nicolas Saenz Julienne --- .../bindings/thermal/brcm,avs-ro-thermal.yaml | 45 ++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 Documentation/devicetree/bindings/thermal/brcm,avs-ro-thermal.yaml diff --git a/Documentation/devicetree/bindings/thermal/brcm,avs-ro-thermal.yaml b/Documentation/devicetree/bindings/thermal/brcm,avs-ro-thermal.yaml new file mode 100644 index 0000000..98e7b57 --- /dev/null +++ b/Documentation/devicetree/bindings/thermal/brcm,avs-ro-thermal.yaml @@ -0,0 +1,45 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/thermal/brcm,avs-ro-thermal.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Broadcom AVS ring oscillator thermal + +maintainers: + - Stefan Wahren + +description: |+ + The thermal node should be the child of a syscon node with the + required property: + + - compatible: Should be one of the following: + "brcm,bcm2711-avs-monitor", "syscon", "simple-mfd" + + Refer to the the bindings described in + Documentation/devicetree/bindings/mfd/syscon.txt + +properties: + compatible: + const: brcm,bcm2711-thermal + + reg: + maxItems: 1 + +required: + - compatible + - reg + +examples: + - | + avs-monitor@7d5d2000 { + compatible = "brcm,bcm2711-avs-monitor", + "syscon", "simple-mfd"; + reg = <0x7d5d2000 0xf00>; + + thermal: thermal { + compatible = "brcm,bcm2711-thermal"; + #thermal-sensor-cells = <0>; + }; + }; +... From patchwork Mon Jan 13 18:56:16 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stefan Wahren X-Patchwork-Id: 11330767 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 0B24F14E3 for ; Mon, 13 Jan 2020 18:57:51 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id D35FD214AF for ; Mon, 13 Jan 2020 18:57:50 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="C86S9WaL" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org D35FD214AF Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=i2se.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:MIME-Version:Cc:List-Subscribe: List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id:References: In-Reply-To:Message-Id:Date:Subject:To:From:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Owner; bh=BIrnvxD2mNbY557DiyhoKi12n1rF9C/sApTQgbWT4p8=; b=C86S9WaLOWmmtuGmGvTQ+nSFHS NPRHsCahCTnpPTUv6OOklMyuUPDkn4J9/f/O6XYfsAOMHNRxnvY4tf5Wd3EfnE7BD4B9dNHIwAo5x MRPLKZ0gyi9b1Z/78TTQ1k4PKHF5jMejVw/D6buDgngCqXYqgz65uS9CQJGfh5BFub/GdGuJ1S54P 83CxTNcDfvEfk94tWP/IEPVP63tZ0EOmYloDqjcYZBYf31ogzCozzdW0a6hykrJN6axrbEYNxxkG2 x5Oeksl9EhDmeWIQEqmfNKgmPXe/0Fs3JgztMQ5mGPmUelXoX9pnXu+aXaQ9lUPDcWnpcEtsatwoH +8fhu1tA==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4uL-0000lc-NA; Mon, 13 Jan 2020 18:57:49 +0000 Received: from mout.kundenserver.de ([212.227.126.133]) by bombadil.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4tR-0008EN-LN for linux-arm-kernel@lists.infradead.org; Mon, 13 Jan 2020 18:56:55 +0000 Received: from localhost.localdomain ([37.4.249.154]) by mrelayeu.kundenserver.de (mreue011 [212.227.15.167]) with ESMTPSA (Nemesis) id 1MhULz-1jMY1q48VH-00eaBl; Mon, 13 Jan 2020 19:56:42 +0100 From: Stefan Wahren To: Zhang Rui , Daniel Lezcano , Amit Kucheria , Rob Herring , Mark Rutland , Nicolas Saenz Julienne , Florian Fainelli , Catalin Marinas , Will Deacon Subject: [PATCH V5 2/4] thermal: Add BCM2711 thermal driver Date: Mon, 13 Jan 2020 19:56:16 +0100 Message-Id: <1578941778-23321-3-git-send-email-stefan.wahren@i2se.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> References: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> X-Provags-ID: V03:K1:1LfmsR4Vn9+56G0d1CEK2niEtx3DZvTrXsrL0FEsHNj+N9lh5Uc +DTuqvdH/W7wW4mKlONuK1DUr5qphY26HC7iaG4aOxw8mga6jUr47jJcnYef28KoZVrW9Tq N7XUL9xTAn4+HV03N+vJel3gIxbgXgzNm+ist/e1CXzjutfIG0ymLZZF8+EriP91l2nOyfS FmeEnu0/0hkEVRy/sWGXA== X-Spam-Flag: NO X-UI-Out-Filterresults: notjunk:1;V03:K0:iX0TtP68v9I=:oHgJNTJ+l5CpYBhDeLNYBQ IgopAQcfKwz+E4hVzaAa3Au5DVWIh8MGJgqV84IIRLYE/272kjfl6jeGGrlz5dvArNteEL6ZN 1NMdN/U53wAIQk80ReK85nPK2zfE/6AUb5f7bXZ6Kjj45qhwkMANPsIe3Zre4QfydLIMN1Udz LUrQ2jO5LHd93l32TQ3PVUThy2wQSKrYJN/8MI/nTfuKjNvhMUHhqLqKlN+Hw+nM5jPOhl3Iv XdlCGGMxvLAZLGRmi2g9dwGml+uRUzAfJNOediNAKZTNhmdqSOYFliO+rlQXL8n9nguuaSbEU tvoObqm6qTlPwPGs3ilqP4fPG5rOP8CPbM3MzT0Y3LiX7bLnNGzm1ma4fmQOo+Ff8hdPEMLUP H/AeR4Cm9SoGEuDE4cnPo/XdclR0fVoquZ9pnZLjOee/rP7ZosphfO2+rxopRQlnFPYnOlBIq X4IEyfqcRSc2vtvKB9SIiwSMm41FDJ5TUko08QBfn/qQGQc4nw04LjCCVybENTHvU+v5ZEQMz vhXPBPOv8T2lh9H6Yjwhkgp2xPcgJQ6JSH3nbUBK5RV2DYpgL3EQzOAU/uHzR8pUUfifkhFFp CvPtWSIrZnzb/6w0FvyHp/CUB62hJX1GrkZjbH6YMVaLRScVA1z2YIAGKbDrJvPBXoNHuXfhh 2NOr40LXNwfHW140JC90tFpqlTuCW2DHkl6kEvtfmqLaTGOIq09F1aJS6QfEVAO1v0BS865aK JGQQl3yPj6Ut2VBifAu/MVzXQbeMkXbbFONh4WL2meJ23DvDUI3mKB+RxiAn6R4TIkABuLxqG 5iuzoYDJ+8IpTy/OtXazuVwCNXlOWtQfUKz2XuuZxJ1xszx8ezYPYINTJXT4CnWf9GDlHZIZL E/dt2TSGd8MqU+T6fxuV9IpJKy8HD5ef4Nfxo04hw= X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200113_105653_998784_FF43477A X-CRM114-Status: GOOD ( 19.28 ) X-Spam-Score: 0.0 (/) X-Spam-Report: SpamAssassin version 3.4.2 on bombadil.infradead.org summary: Content analysis details: (0.0 points) pts rule name description ---- ---------------------- -------------------------------------------------- -0.0 RCVD_IN_DNSWL_NONE RBL: Sender listed at https://www.dnswl.org/, no trust [212.227.126.133 listed in list.dnswl.org] 0.0 SPF_HELO_NONE SPF: HELO does not publish an SPF Record -0.0 SPF_PASS SPF: sender matches SPF record X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Stefan Wahren , devicetree@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, linux-arm-kernel@lists.infradead.org, linux-pm@vger.kernel.org MIME-Version: 1.0 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org This adds the thermal sensor driver for the Broadcom BCM2711 SoC, which is placed on the Raspberry Pi 4. The driver only provides SoC temperature reading so far. Signed-off-by: Stefan Wahren Reviewed-by: Florian Fainelli Reviewed-by: Nicolas Saenz Julienne Tested-by: Nicolas Saenz Julienne --- drivers/thermal/broadcom/Kconfig | 7 ++ drivers/thermal/broadcom/Makefile | 1 + drivers/thermal/broadcom/bcm2711_thermal.c | 123 +++++++++++++++++++++++++++++ 3 files changed, 131 insertions(+) create mode 100644 drivers/thermal/broadcom/bcm2711_thermal.c diff --git a/drivers/thermal/broadcom/Kconfig b/drivers/thermal/broadcom/Kconfig index cf43e15..061f1db 100644 --- a/drivers/thermal/broadcom/Kconfig +++ b/drivers/thermal/broadcom/Kconfig @@ -1,4 +1,11 @@ # SPDX-License-Identifier: GPL-2.0-only +config BCM2711_THERMAL + tristate "Broadcom AVS RO thermal sensor driver" + depends on ARCH_BCM2835 || COMPILE_TEST + depends on THERMAL_OF && MFD_SYSCON + help + Support for thermal sensors on Broadcom BCM2711 SoCs. + config BCM2835_THERMAL tristate "Thermal sensors on bcm2835 SoC" depends on ARCH_BCM2835 || COMPILE_TEST diff --git a/drivers/thermal/broadcom/Makefile b/drivers/thermal/broadcom/Makefile index 490ab1f..c917b24 100644 --- a/drivers/thermal/broadcom/Makefile +++ b/drivers/thermal/broadcom/Makefile @@ -1,4 +1,5 @@ # SPDX-License-Identifier: GPL-2.0-only +obj-$(CONFIG_BCM2711_THERMAL) += bcm2711_thermal.o obj-$(CONFIG_BCM2835_THERMAL) += bcm2835_thermal.o obj-$(CONFIG_BRCMSTB_THERMAL) += brcmstb_thermal.o obj-$(CONFIG_BCM_NS_THERMAL) += ns-thermal.o diff --git a/drivers/thermal/broadcom/bcm2711_thermal.c b/drivers/thermal/broadcom/bcm2711_thermal.c new file mode 100644 index 0000000..67c2a73 --- /dev/null +++ b/drivers/thermal/broadcom/bcm2711_thermal.c @@ -0,0 +1,123 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * Broadcom AVS RO thermal sensor driver + * + * based on brcmstb_thermal + * + * Copyright (C) 2020 Stefan Wahren + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "../thermal_hwmon.h" + +#define AVS_RO_TEMP_STATUS 0x200 +#define AVS_RO_TEMP_STATUS_VALID_MSK (BIT(16) | BIT(10)) +#define AVS_RO_TEMP_STATUS_DATA_MSK GENMASK(9, 0) + +struct bcm2711_thermal_priv { + struct regmap *regmap; + struct thermal_zone_device *thermal; +}; + +static int bcm2711_get_temp(void *data, int *temp) +{ + struct bcm2711_thermal_priv *priv = data; + int slope = thermal_zone_get_slope(priv->thermal); + int offset = thermal_zone_get_offset(priv->thermal); + u32 val; + int ret; + long t; + + ret = regmap_read(priv->regmap, AVS_RO_TEMP_STATUS, &val); + if (ret) + return ret; + + if (!(val & AVS_RO_TEMP_STATUS_VALID_MSK)) + return -EIO; + + val &= AVS_RO_TEMP_STATUS_DATA_MSK; + + /* Convert a HW code to a temperature reading (millidegree celsius) */ + t = slope * val + offset; + + *temp = t < 0 ? 0 : t; + + return 0; +} + +static const struct thermal_zone_of_device_ops bcm2711_thermal_of_ops = { + .get_temp = bcm2711_get_temp, +}; + +static const struct of_device_id bcm2711_thermal_id_table[] = { + { .compatible = "brcm,bcm2711-thermal" }, + {}, +}; +MODULE_DEVICE_TABLE(of, bcm2711_thermal_id_table); + +static int bcm2711_thermal_probe(struct platform_device *pdev) +{ + struct thermal_zone_device *thermal; + struct bcm2711_thermal_priv *priv; + struct device *dev = &pdev->dev; + struct device_node *parent; + struct regmap *regmap; + int ret; + + priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); + if (!priv) + return -ENOMEM; + + /* get regmap from syscon node */ + parent = of_get_parent(dev->of_node); /* parent should be syscon node */ + regmap = syscon_node_to_regmap(parent); + of_node_put(parent); + if (IS_ERR(regmap)) { + ret = PTR_ERR(regmap); + dev_err(dev, "failed to get regmap: %d\n", ret); + return ret; + } + priv->regmap = regmap; + + thermal = devm_thermal_zone_of_sensor_register(dev, 0, priv, + &bcm2711_thermal_of_ops); + if (IS_ERR(thermal)) { + ret = PTR_ERR(thermal); + dev_err(dev, "could not register sensor: %d\n", ret); + return ret; + } + + priv->thermal = thermal; + + thermal->tzp->no_hwmon = false; + ret = thermal_add_hwmon_sysfs(thermal); + if (ret) + return ret; + + return 0; +} + +static struct platform_driver bcm2711_thermal_driver = { + .probe = bcm2711_thermal_probe, + .driver = { + .name = "bcm2711_thermal", + .of_match_table = bcm2711_thermal_id_table, + }, +}; +module_platform_driver(bcm2711_thermal_driver); + +MODULE_LICENSE("GPL"); +MODULE_AUTHOR("Stefan Wahren"); +MODULE_DESCRIPTION("Broadcom AVS RO thermal sensor driver"); From patchwork Mon Jan 13 18:56:17 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stefan Wahren X-Patchwork-Id: 11330749 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id A384F1398 for ; Mon, 13 Jan 2020 18:56:55 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 74C6A214AF for ; Mon, 13 Jan 2020 18:56:55 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="XQX7clEE" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 74C6A214AF Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=i2se.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:MIME-Version:Cc:List-Subscribe: List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id:References: In-Reply-To:Message-Id:Date:Subject:To:From:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Owner; bh=00p+1DvyPD63ywTmoaUieIG/Ucvr2esb9KG//dEUXhk=; b=XQX7clEEDbTkAUlS0DLE6FCxko l79O2vE4CINx7Ja1gYxw4QrTFhxHkomN4LkfRC5bSwra7mJSpD3MqDbfZk44t2XinVlue5IdV7xeE 7oO649VIzB6GeGw144XD2N6kuvROMni3Si5ysi6vLGrM7TUnmqlJ4UOElMOVaw1j0eCPA+BEJUcHM 3W/CQAdVu0Vc0Z+Qf/t6BKls0SG7KaW0dM5UaSI16uA1REgWrt0pVpyOTGc1owrul2ZaYlJcBRLVv tU6a/K204Mw++HeGN/0YIkIwOK5uF1dHC4TJH/2cdAlxUwilYIanVk/DPKSbBlr55AJQZifRIXk1Q v2Rs5WLA==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4tS-0008G4-Td; Mon, 13 Jan 2020 18:56:54 +0000 Received: from mout.kundenserver.de ([212.227.126.134]) by bombadil.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4tQ-0008EH-DB for linux-arm-kernel@lists.infradead.org; Mon, 13 Jan 2020 18:56:54 +0000 Received: from localhost.localdomain ([37.4.249.154]) by mrelayeu.kundenserver.de (mreue011 [212.227.15.167]) with ESMTPSA (Nemesis) id 1Ml6Zo-1jVahK26do-00lTfi; Mon, 13 Jan 2020 19:56:42 +0100 From: Stefan Wahren To: Zhang Rui , Daniel Lezcano , Amit Kucheria , Rob Herring , Mark Rutland , Nicolas Saenz Julienne , Florian Fainelli , Catalin Marinas , Will Deacon Subject: [PATCH V5 3/4] ARM: dts: bcm2711: Enable thermal Date: Mon, 13 Jan 2020 19:56:17 +0100 Message-Id: <1578941778-23321-4-git-send-email-stefan.wahren@i2se.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> References: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> X-Provags-ID: V03:K1:SNWSISItmXIx6eBnLoCptDc6JzOtBscQcH5BvXlshAHdxm/pO/U nWGuWALXvxvoi2nUl2x5Bi5mw5ROnHHYRUmjT6GQBGF3ovXlPXW29EN1QuzwMuEF7iMWWvG oJorM/yZN5rYbL/0027fpe4I3SxbGTfNvYJMbvklxeW8H9cHpkzV1x8HW/znp2jgkWOOG16 ci+0JH72mCKwJhY9ujULA== X-Spam-Flag: NO X-UI-Out-Filterresults: notjunk:1;V03:K0:1sUaqkNUY28=:ONGBQllNlMxWag82getHbF C9TRj8WODi5/zj5ZssXoX7usomRTx3C6d0JBt+gExp++FSA3PSho3BpyxtHN1Iyd1CiGwa9zj e4z2JaiEBTOIVx64KItMokdZNraIsKkPxYdVgGJqEMFOTGjlfxqovj1FMbADRa605CsXW5T3D 6RiR50kOfCv6Y773oh3TQYjZ45sBmQ9bY8aw1s7yiT4jD8PmF+u8qLMYsfM3kcJe1/hXGCk6w 6XmAGu/ue0WskYFG9JfHPLVt7fxs4bwrmM1Gg6by8D6UKjR9v2b05QPsQdKCgYfb26Rp5SrDr 8VLZZhwu34EgughC1Xn3p0wXA0UmT/cAnK5Nd5Fnp8CEUpZByVt2YwX2fMP0PBZQvB5cDlzcW G5BoFUU0YjBQG1dBlsAJKheBQvvvqpIEjnH/uD0eywf0k65nLGkH9EEp3UfqAl3bfsuz6r4dn nh/CG/IBsgxgQ/Gki0SXjypWYXJz6mzU3l5zRR+a5L3AVWfBPqvqup8Qhodihg45va5cVp0l4 KNyqZAG+gpOEqP0AKbks5XzDInZsnnmS3Ijs65hFj8xnQKNdF9MSedlaxwiZQ2iXPXLY7IYiq 2WAzeArBITr/2gQlJVxpYTpmcBvboRoyqKRZym2v5FUL7oZXIz3a7xLMBvb87RWc81MjXCcin 0sCeyN5PqQKUWna+JSF8JUuWuNqKu/2ea8W8xqOwNCLY8t4Fa/1yOM/4W+cLtC9IfF5cpZHUq 7eQ6saS4a4C39bNzUMsnNNOef9qUrekTL8BBqOYs0pUF04ekLJ64KBBzTVQatp4k+/VvdNz8K KvLclkEQeRGtmn0ycInTaVvlZKbWE4oNxxA2GRVBwu6TlgdciKNGLgLcS1I3GDRznyPIT7qvh swdPoGeXY5wyMNNAbwMpIqzD4B13UTKAFD86w2Zlw= X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200113_105652_739323_B847E344 X-CRM114-Status: GOOD ( 11.83 ) X-Spam-Score: 0.0 (/) X-Spam-Report: SpamAssassin version 3.4.2 on bombadil.infradead.org summary: Content analysis details: (0.0 points) pts rule name description ---- ---------------------- -------------------------------------------------- -0.0 RCVD_IN_DNSWL_NONE RBL: Sender listed at https://www.dnswl.org/, no trust [212.227.126.134 listed in list.dnswl.org] 0.0 SPF_HELO_NONE SPF: HELO does not publish an SPF Record -0.0 SPF_PASS SPF: sender matches SPF record X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Stefan Wahren , devicetree@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, linux-arm-kernel@lists.infradead.org, linux-pm@vger.kernel.org MIME-Version: 1.0 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org This enables thermal for the BCM2711 (used on Raspberry Pi 4) by adding the AVS monitor and a subnode for the thermal part. Signed-off-by: Stefan Wahren Reviewed-by: Nicolas Saenz Julienne Tested-by: Nicolas Saenz Julienne Signed-off-by: Florian Fainelli --- arch/arm/boot/dts/bcm2711.dtsi | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/arch/arm/boot/dts/bcm2711.dtsi b/arch/arm/boot/dts/bcm2711.dtsi index 961bed8..96f341d 100644 --- a/arch/arm/boot/dts/bcm2711.dtsi +++ b/arch/arm/boot/dts/bcm2711.dtsi @@ -66,6 +66,17 @@ IRQ_TYPE_LEVEL_HIGH)>; }; + avs_monitor: avs-monitor@7d5d2000 { + compatible = "brcm,bcm2711-avs-monitor", + "syscon", "simple-mfd"; + reg = <0x7d5d2000 0xf00>; + + thermal: thermal { + compatible = "brcm,bcm2711-thermal"; + #thermal-sensor-cells = <0>; + }; + }; + dma: dma@7e007000 { compatible = "brcm,bcm2835-dma"; reg = <0x7e007000 0xb00>; @@ -363,6 +374,7 @@ &cpu_thermal { coefficients = <(-487) 410040>; + thermal-sensors = <&thermal>; }; &dsi0 { From patchwork Mon Jan 13 18:56:18 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stefan Wahren X-Patchwork-Id: 11330763 Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 5114C1398 for ; Mon, 13 Jan 2020 18:57:27 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 1067F214AF for ; Mon, 13 Jan 2020 18:57:27 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="FkTxBcEA" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 1067F214AF Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=i2se.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:MIME-Version:Cc:List-Subscribe: List-Help:List-Post:List-Archive:List-Unsubscribe:List-Id:References: In-Reply-To:Message-Id:Date:Subject:To:From:Reply-To:Content-ID: Content-Description:Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc :Resent-Message-ID:List-Owner; bh=y8yFrKqN9mI0o4tN9YnVC4jEakp+Uli2+mSL+/FGU2Y=; b=FkTxBcEAkCpxCJ3Vznyd/YGG08 Vb+Y4G11WqGFvpFoy6WIwsNsZRMQ7XEGfeErrTtkJcic3zjM/4EDbhNb38fqGzfSYWs007l7sJ78Z 1P3uuOFmLT2LLMdGexcK4yksKXjIImwIc7xOqvRwGhDMUVgbh63AN/9duLh3v9K2F/ughQFvd+alP cb7y+Pas7eQuOUYPzgqpNnX+TNB/Fg3pbB/6bF/aj2CZ1zgoPBNHKKqAz74I4urHt4iaaWNsNLRz0 hU8myAzO5xQYGJDaWMdwNZ9AcIEfjr+9vPQKgc8vB5vWvgf/NsUEHhHwbvBP9b74/dnUuqhGn/A2G fekcnUdA==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4tt-0000Eo-L1; Mon, 13 Jan 2020 18:57:21 +0000 Received: from mout.kundenserver.de ([212.227.126.133]) by bombadil.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1ir4tR-0008EP-Kp for linux-arm-kernel@lists.infradead.org; Mon, 13 Jan 2020 18:56:55 +0000 Received: from localhost.localdomain ([37.4.249.154]) by mrelayeu.kundenserver.de (mreue011 [212.227.15.167]) with ESMTPSA (Nemesis) id 1M1YtP-1iphB20GaJ-0032W1; Mon, 13 Jan 2020 19:56:43 +0100 From: Stefan Wahren To: Zhang Rui , Daniel Lezcano , Amit Kucheria , Rob Herring , Mark Rutland , Nicolas Saenz Julienne , Florian Fainelli , Catalin Marinas , Will Deacon Subject: [PATCH V5 4/4] ARM: configs: Build BCM2711 thermal as module Date: Mon, 13 Jan 2020 19:56:18 +0100 Message-Id: <1578941778-23321-5-git-send-email-stefan.wahren@i2se.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> References: <1578941778-23321-1-git-send-email-stefan.wahren@i2se.com> X-Provags-ID: V03:K1:O+u6pr4dhxrOSuuoknJ0DKNWGQ3vtlKGMbnvZc7/pEHB71+lP+5 GOE3qd05FrcJ8FBdCfOzxwdLICo+DAZoBiHFL/n+IQJKXnOiIJL7YGMZ20AzSjIq1ukoC1k elTVjDTE9+1ElflUv3hqX3kqVI8HCckwLZJlI+51Jn/I85rOFSrPc4g8HLA2f9tFtpFbgQ3 H3qP+9vGpB34IcID6KaKw== X-Spam-Flag: NO X-UI-Out-Filterresults: notjunk:1;V03:K0:Gyygl/ACfQE=:ygkkfD/TXRtXjs1fyw13d2 LemAh7UlXhneJPcb07l0sfrl7GzRJh/ZPAL16wRuc41qmzH5OQl8n5WB3qmNrVihu9rXn/SYx tyxY8fhIOfIO50B1fHtKyqsidXwaY+3dROUCan/WHRqmQHEfTpSJCrjR2EwVO5RtmJAjgOGyU HdFY6KvdqoTBtkOdfWFIok2dwV8n7B5QhTPJShug6GIzAE9t7ZbPk/vGtQudnCtYrNjRgEi3A LisEhG9GRYvYXSUYEuSfhjAchrzpGbgphwLSrNI54kEI42m3xOsaSmEl5MIssagEhz5BmEUDX v9qXfc0Y0iJTSPPVuhHn1HPwb0De+TcZblaYLPVqaMFTeSn7kKQqDPyUy9R0Y7FIFacIT2UoV yS7LLW7E4hvecp6tnJOzb0rAtF1FHocjspL5Iyo2V7LGSeSKGNjBFtz8B25qr3ce3wh3cHhr+ FC8ZWFxW5pNG4AXxRxgutVAKwT7PdEXXqbC3MWVitACsC9yw7e52ac0NcjO7WwSZ/sCvl9f+I 7q+mon0DP0fLEGVlHXkvLIslsrC34MBQPIroSCnBd3gf/TPd756a75uYRRNAjYrnBEP5K1A6O yH7hHnia+mEhijrqKPSIvQ7Pl9iIdaTfA70otgD+BDaUDDU5Syq+G0zoZzZTB7MN7jSaPcs05 SxaU4FjP+9ZLo0fJSoxqlXMWV2iMaVPuIxlO+Xrk0R8kbJ67Iu0mR/4sfFqAmSIgJXaSpL8FW vhwLxYtKvCeW7h8+jOZ7VUfWf0AEkyTYzaeITvznreg5BV8rJ26VmFm3EVgjGdRWcIcf599k2 HaulVm5OR6GEEfjuGUQLziZSl1UtnpxZIvTngLsUdAKNiKqt3b1ms/BVl0bJEhyc9RVv6rjHl +SMoH/iES+i0u8k/7sL4B9Xba9duNZ4+zQrhI0ldo= X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200113_105653_992878_56C4BE5C X-CRM114-Status: GOOD ( 11.64 ) X-Spam-Score: 0.0 (/) X-Spam-Report: SpamAssassin version 3.4.2 on bombadil.infradead.org summary: Content analysis details: (0.0 points) pts rule name description ---- ---------------------- -------------------------------------------------- -0.0 RCVD_IN_DNSWL_NONE RBL: Sender listed at https://www.dnswl.org/, no trust [212.227.126.133 listed in list.dnswl.org] 0.0 SPF_HELO_NONE SPF: HELO does not publish an SPF Record -0.0 SPF_PASS SPF: sender matches SPF record X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Stefan Wahren , devicetree@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, linux-arm-kernel@lists.infradead.org, linux-pm@vger.kernel.org MIME-Version: 1.0 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org This builds the BCM2711 thermal driver as module for the Raspberry Pi 4. Signed-off-by: Stefan Wahren Reviewed-by: Florian Fainelli Reviewed-by: Nicolas Saenz Julienne Tested-by: Nicolas Saenz Julienne --- arch/arm/configs/multi_v7_defconfig | 1 + arch/arm64/configs/defconfig | 1 + 2 files changed, 2 insertions(+) diff --git a/arch/arm/configs/multi_v7_defconfig b/arch/arm/configs/multi_v7_defconfig index 3f1b96d..f5d19cc 100644 --- a/arch/arm/configs/multi_v7_defconfig +++ b/arch/arm/configs/multi_v7_defconfig @@ -496,6 +496,7 @@ CONFIG_IMX_THERMAL=y CONFIG_ROCKCHIP_THERMAL=y CONFIG_RCAR_THERMAL=y CONFIG_ARMADA_THERMAL=y +CONFIG_BCM2711_THERMAL=m CONFIG_BCM2835_THERMAL=m CONFIG_BRCMSTB_THERMAL=m CONFIG_ST_THERMAL_MEMMAP=y diff --git a/arch/arm64/configs/defconfig b/arch/arm64/configs/defconfig index 6a83ba2..b2f6673 100644 --- a/arch/arm64/configs/defconfig +++ b/arch/arm64/configs/defconfig @@ -442,6 +442,7 @@ CONFIG_ROCKCHIP_THERMAL=m CONFIG_RCAR_THERMAL=y CONFIG_RCAR_GEN3_THERMAL=y CONFIG_ARMADA_THERMAL=y +CONFIG_BCM2711_THERMAL=m CONFIG_BCM2835_THERMAL=m CONFIG_BRCMSTB_THERMAL=m CONFIG_EXYNOS_THERMAL=y