Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp240323pxb; Thu, 21 Jan 2021 06:08:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJz1Iws1A3IeLn4XK7DBM00eKQby7K1ZnhLJ/u/lAtdBRwqS1JL5x4bdPLooztkxRp+or2Xr X-Received: by 2002:a17:906:780c:: with SMTP id u12mr9059872ejm.125.1611238107289; Thu, 21 Jan 2021 06:08:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611238107; cv=none; d=google.com; s=arc-20160816; b=dsmoR5zD8LEhqiFOk/FwSfI+ckR4GAqezZ8pNahT3xVJYImLSyO1UEPayV5T3uSZr+ YcMFVqkVGYVP2uI8zU2X9FrPBZZULKO3MT6tyqJZlqZdr7bECC/E2zhzVKwHlioFqDng rXHBwihlEdQ5px1Wkzhg1y35HAEoCUgl3Olxk0PZLeX8wyg+0MKECAN9oYWe0tgSUwYx uEDC3st8yd6f1XGE5pxrOQHM0DC1pnaj9bEvDacvSnqI76udkhAi4lX1k9kgvFYy3SCB JQi51bhYsSpc8BRt2GGlFRHFMaSADWrde9y5rMbTF5ajOVDujT0UmyHiuaVhlHafBc9j q3qA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:message-id:in-reply-to:date:references:subject:cc:to :from; bh=xAiahZopMYY9Gqnf3fkoV4WyTceuW6jQRkJXS8Q7lWU=; b=Hg60K0vi452hcKluOO+qB4Y45xPDtMJIUdAeH5gfJ5t106Rp5p8tiTuyu9vLXze0NZ NB9y9n1I+iYCuM0MZ8R/IYNFCb1HIndo+GOdpzbXWHAAkl6NvRupgFPHwTT2uoMA3Efe sBk3d1RLCFg2OLDKcdGdPnSEau1kq1vgEn9UdRqN52DgQjLVSoyUyI3vcsvWdLdX2uc1 WnD3fknHQSK4D+CiIYYjgSEZy6/Tq4+bOtHI7Mh1crGBGgz+3gqdlCPvi5kSv/5fgP2V 5JxTVmF/70fJI2HxOLIq6krFjaAA46h6DSBziTp3UfKZ+B5/vqzyNZTCfagJ7w3ATEhw z82A== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i1si2160530edx.383.2021.01.21.06.08.00; Thu, 21 Jan 2021 06:08:27 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729636AbhAUODw convert rfc822-to-8bit (ORCPT + 99 others); Thu, 21 Jan 2021 09:03:52 -0500 Received: from unicorn.mansr.com ([81.2.72.234]:60308 "EHLO unicorn.mansr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729244AbhAUOAu (ORCPT ); Thu, 21 Jan 2021 09:00:50 -0500 Received: from raven.mansr.com (raven.mansr.com [81.2.72.235]) by unicorn.mansr.com (Postfix) with ESMTPS id 2C9CC15362; Thu, 21 Jan 2021 13:59:33 +0000 (GMT) Received: by raven.mansr.com (Postfix, from userid 51770) id 29B4521A3D9; Thu, 21 Jan 2021 13:59:33 +0000 (GMT) From: =?iso-8859-1?Q?M=E5ns_Rullg=E5rd?= To: Arnd Bergmann Cc: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, Zhang Rui , Daniel Lezcano , Amit Kucheria , Arnd Bergmann , Marc Gonzalez Subject: Re: [PATCH 1/2] thermal: remove tango driver References: <20210120162400.4115366-1-arnd@kernel.org> <20210120162400.4115366-2-arnd@kernel.org> Date: Thu, 21 Jan 2021 13:59:33 +0000 In-Reply-To: <20210120162400.4115366-2-arnd@kernel.org> (Arnd Bergmann's message of "Wed, 20 Jan 2021 17:23:59 +0100") Message-ID: User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/27.1 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Transfer-Encoding: 8BIT Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Arnd Bergmann writes: > From: Arnd Bergmann > > The tango platform is getting removed, so the driver is no > longer needed. > > Cc: Marc Gonzalez > Cc: Mans Rullgard > Signed-off-by: Arnd Bergmann Acked-by: Mans Rullgard > --- > .../bindings/thermal/tango-thermal.txt | 17 --- > drivers/thermal/Kconfig | 9 -- > drivers/thermal/Makefile | 1 - > drivers/thermal/tango_thermal.c | 126 ------------------ > 4 files changed, 153 deletions(-) > delete mode 100644 Documentation/devicetree/bindings/thermal/tango-thermal.txt > delete mode 100644 drivers/thermal/tango_thermal.c > > diff --git a/Documentation/devicetree/bindings/thermal/tango-thermal.txt b/Documentation/devicetree/bindings/thermal/tango-thermal.txt > deleted file mode 100644 > index 2c918d742867..000000000000 > --- a/Documentation/devicetree/bindings/thermal/tango-thermal.txt > +++ /dev/null > @@ -1,17 +0,0 @@ > -* Tango Thermal > - > -The SMP8758 SoC includes 3 instances of this temperature sensor > -(in the CPU, video decoder, and PCIe controller). > - > -Required properties: > -- #thermal-sensor-cells: Should be 0 (see Documentation/devicetree/bindings/thermal/thermal-sensor.yaml) > > -- compatible: "sigma,smp8758-thermal" > -- reg: Address range of the thermal registers > - > -Example: > - > - cpu_temp: thermal@920100 { > - #thermal-sensor-cells = <0>; > - compatible = "sigma,smp8758-thermal"; > - reg = <0x920100 12>; > - }; > > diff --git a/drivers/thermal/Kconfig b/drivers/thermal/Kconfig > index 7edc8dc6bbab..cf199574c096 100644 > --- a/drivers/thermal/Kconfig > +++ b/drivers/thermal/Kconfig > @@ -450,15 +450,6 @@ depends on (ARCH_STI || ARCH_STM32) && OF > source "drivers/thermal/st/Kconfig" > endmenu > > -config TANGO_THERMAL > - tristate "Tango thermal management" > - depends on ARCH_TANGO || COMPILE_TEST > - help > - Enable the Tango thermal driver, which supports the primitive > - temperature sensor embedded in Tango chips since the SMP8758. > - This sensor only generates a 1-bit signal to indicate whether > - the die temperature exceeds a programmable threshold. > - > source "drivers/thermal/tegra/Kconfig" > > config GENERIC_ADC_THERMAL > diff --git a/drivers/thermal/Makefile b/drivers/thermal/Makefile > index b64dd50a6629..a44dda2d03bc 100644 > --- a/drivers/thermal/Makefile > +++ b/drivers/thermal/Makefile > @@ -42,7 +42,6 @@ obj-y += samsung/ > obj-$(CONFIG_DOVE_THERMAL) += dove_thermal.o > obj-$(CONFIG_DB8500_THERMAL) += db8500_thermal.o > obj-$(CONFIG_ARMADA_THERMAL) += armada_thermal.o > -obj-$(CONFIG_TANGO_THERMAL) += tango_thermal.o > obj-$(CONFIG_IMX_THERMAL) += imx_thermal.o > obj-$(CONFIG_IMX_SC_THERMAL) += imx_sc_thermal.o > obj-$(CONFIG_IMX8MM_THERMAL) += imx8mm_thermal.o > diff --git a/drivers/thermal/tango_thermal.c b/drivers/thermal/tango_thermal.c > deleted file mode 100644 > index 304b461e12aa..000000000000 > --- a/drivers/thermal/tango_thermal.c > +++ /dev/null > @@ -1,126 +0,0 @@ > -// SPDX-License-Identifier: GPL-2.0-only > -#include > -#include > -#include > -#include > -#include > - > -/* > - * According to a data sheet draft, "this temperature sensor uses a bandgap > - * type of circuit to compare a voltage which has a negative temperature > - * coefficient with a voltage that is proportional to absolute temperature. > - * A resistor bank allows 41 different temperature thresholds to be selected > - * and the logic output will then indicate whether the actual die temperature > - * lies above or below the selected threshold." > - */ > - > -#define TEMPSI_CMD 0 > -#define TEMPSI_RES 4 > -#define TEMPSI_CFG 8 > - > -#define CMD_OFF 0 > -#define CMD_ON 1 > -#define CMD_READ 2 > - > -#define IDX_MIN 15 > -#define IDX_MAX 40 > - > -struct tango_thermal_priv { > - void __iomem *base; > - int thresh_idx; > -}; > - > -static bool temp_above_thresh(void __iomem *base, int thresh_idx) > -{ > - writel(CMD_READ | thresh_idx << 8, base + TEMPSI_CMD); > - usleep_range(10, 20); > - writel(CMD_READ | thresh_idx << 8, base + TEMPSI_CMD); > - > - return readl(base + TEMPSI_RES); > -} > - > -static int tango_get_temp(void *arg, int *res) > -{ > - struct tango_thermal_priv *priv = arg; > - int idx = priv->thresh_idx; > - > - if (temp_above_thresh(priv->base, idx)) { > - /* Search upward by incrementing thresh_idx */ > - while (idx < IDX_MAX && temp_above_thresh(priv->base, ++idx)) > - cpu_relax(); > - idx = idx - 1; /* always return lower bound */ > - } else { > - /* Search downward by decrementing thresh_idx */ > - while (idx > IDX_MIN && !temp_above_thresh(priv->base, --idx)) > - cpu_relax(); > - } > - > - *res = (idx * 9 / 2 - 38) * 1000; /* millidegrees Celsius */ > - priv->thresh_idx = idx; > - > - return 0; > -} > - > -static const struct thermal_zone_of_device_ops ops = { > - .get_temp = tango_get_temp, > -}; > - > -static void tango_thermal_init(struct tango_thermal_priv *priv) > -{ > - writel(0, priv->base + TEMPSI_CFG); > - writel(CMD_ON, priv->base + TEMPSI_CMD); > -} > - > -static int tango_thermal_probe(struct platform_device *pdev) > -{ > - struct resource *res; > - struct tango_thermal_priv *priv; > - struct thermal_zone_device *tzdev; > - > - priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL); > - if (!priv) > - return -ENOMEM; > - > - res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > - priv->base = devm_ioremap_resource(&pdev->dev, res); > - if (IS_ERR(priv->base)) > - return PTR_ERR(priv->base); > - > - platform_set_drvdata(pdev, priv); > - priv->thresh_idx = IDX_MIN; > - tango_thermal_init(priv); > - > - tzdev = devm_thermal_zone_of_sensor_register(&pdev->dev, 0, priv, &ops); > - return PTR_ERR_OR_ZERO(tzdev); > -} > - > -static int __maybe_unused tango_thermal_resume(struct device *dev) > -{ > - tango_thermal_init(dev_get_drvdata(dev)); > - return 0; > -} > - > -static SIMPLE_DEV_PM_OPS(tango_thermal_pm, NULL, tango_thermal_resume); > - > -static const struct of_device_id tango_sensor_ids[] = { > - { > - .compatible = "sigma,smp8758-thermal", > - }, > - { /* sentinel */ } > -}; > -MODULE_DEVICE_TABLE(of, tango_sensor_ids); > - > -static struct platform_driver tango_thermal_driver = { > - .probe = tango_thermal_probe, > - .driver = { > - .name = "tango-thermal", > - .of_match_table = tango_sensor_ids, > - .pm = &tango_thermal_pm, > - }, > -}; > - > -module_platform_driver(tango_thermal_driver); > - > -MODULE_LICENSE("GPL"); > -MODULE_AUTHOR("Sigma Designs"); > -MODULE_DESCRIPTION("Tango temperature sensor"); > -- > > 2.29.2 > -- M?ns Rullg?rd