From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org 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 smtp.lore.kernel.org (Postfix) with ESMTPS id A40D6C4332F for ; Tue, 15 Nov 2022 13:47:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Content-Transfer-Encoding: Content-Type:In-Reply-To:From:References:Cc:To:Subject:MIME-Version:Date: Message-ID:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=GKSVED77pBiwPpJ2Rxir+nKGuTDM1BFyofF1Zlc2DKM=; b=JUlcOkstFCArGAnOoL57N8zBa4 SPGgXyxmRENGM7LpMpd8Qvh3X0EW3lzpjtVy7Sh7+8P5szGVGPTWENiKRBXfIJ8/D5wKTHz8whASz kmGZ92ia7PX0ylqWrVJr2vhl8G9cH8O4P5xf4D4zm0Fjo9NZoFm8AdcefkwBFJI958aDjmuzgXO9p cFOVcZT2UrZrvRizlnOXP4d8sCSZ5oxWGwNjnzrOAbK6Z337K3c4WfrADANoDx0ViQ9P9QD2H/iQj oCjUcTccRs8PS5fBsa2CMhxUtebOvQG7KqylkbhSJfzfLEYMglKcJsRjADjcNKQJ+2tmwEBIBneok a8Hgo0lQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1ouwH6-00BYrb-SY; Tue, 15 Nov 2022 13:46:52 +0000 Received: from mail-wm1-x32b.google.com ([2a00:1450:4864:20::32b]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1ouwH3-00BYkO-83 for linux-mediatek@lists.infradead.org; Tue, 15 Nov 2022 13:46:51 +0000 Received: by mail-wm1-x32b.google.com with SMTP id m7-20020a05600c090700b003cf8a105d9eso10252855wmp.5 for ; Tue, 15 Nov 2022 05:46:47 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20210112.gappssmtp.com; s=20210112; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=GKSVED77pBiwPpJ2Rxir+nKGuTDM1BFyofF1Zlc2DKM=; b=ajV3q/DBWIST9XnzaLUBlOUEBSdLAQqK1xUrmmix8OMOMNlF/Sky2+pKt3h41v2pMv 2Q8zfjga/05QO/Wxrbr1kdI9Ma6O/pKaRDIldQDP44LRSMEViXjU9XDgH0/gT8sOvzAE EUjTyy+ZdQnV3JCE39/AJKutOV29A49uSWi7iKVNl/UYVnw0lpNLb8AEXub5gqIslSbM he8yGZs62o0EBrjHVoOtJn/kylV44U5prleVZz35sA5yx2RbfGgl7aafIyusiNN4vSBL wYX6b3mO/Nb787I28cQvLlaCLPRQrAdAxbII3jScpr67IxabycomE/+wHPF4ced7/QSA uhoQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=GKSVED77pBiwPpJ2Rxir+nKGuTDM1BFyofF1Zlc2DKM=; b=PBExhayC2t0q3+I6jm9U/LpBHQmbCimRNHio6O6YYb0bz5DNfB4kCK1Zf7kZ4KWcYP Bk6jtuoISFX2UUrZ3Pp+uCNxi6db6bYwPzBFUkQgMCcShtZHOkkNAFxQktpx0sty3muZ r2Q8FIT4K8BJX7IRApq2/uaJ830qaEsNkPZMamWFhM1XmbUKBxOC1osSZpaH14MjnO0j t/oXMAFD9RSIky3L/zdsYAq2Aszm5VR+0MiasZINe7AcGotXuUSTyQ+isqnbX7c5YhPk EFa4YkrYoccGrmV0BLq5FiqgE8efVrZfiR1214oltJv9DBaCHlzzRYK83U6iCUjtBNpk AuiQ== X-Gm-Message-State: ANoB5plZMElx0QMECYQWp3FK4Z/VQM3VVtqRDaOaSUOSRpgOHMwJqGSw 3+uRF/x1rcDgooBglO51NbKzUQ== X-Google-Smtp-Source: AA0mqf5X5syFwbQSMWDFIqO7dVJyWje/diBdKJ0N7P3JuWEdDQfvhb0INF8arqz3z9IEe8X96oBSqA== X-Received: by 2002:a05:600c:1c1d:b0:3cf:5d41:bea1 with SMTP id j29-20020a05600c1c1d00b003cf5d41bea1mr1630709wms.118.1668520003893; Tue, 15 Nov 2022 05:46:43 -0800 (PST) Received: from [192.168.99.239] ([95.178.111.30]) by smtp.gmail.com with ESMTPSA id ay19-20020a05600c1e1300b003c6bbe910fdsm26460343wmb.9.2022.11.15.05.46.42 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 15 Nov 2022 05:46:43 -0800 (PST) Message-ID: Date: Tue, 15 Nov 2022 14:46:41 +0100 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 v6 4/4] thermal: mediatek: add another get_temp ops for thermal sensors To: Pin-yen Lin Cc: Krzysztof Kozlowski , Zhang Rui , Amit Kucheria , Rob Herring , "Rafael J. Wysocki" , Daniel Lezcano , Fabien Parent , linux-mediatek@lists.infradead.org, Rob Herring , Markus Schneider-Pargmann , linux-arm-kernel@lists.infradead.org, linux-pm@vger.kernel.org, AngeloGioacchino Del Regno , Michael Kao , Hsin-Yi Wang , linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Matthias Brugger References: <20221018-up-i350-thermal-bringup-v6-0-c87b9f75550b@baylibre.com> <20221018-up-i350-thermal-bringup-v6-4-c87b9f75550b@baylibre.com> Content-Language: en-US From: Amjad Ouled-Ameur In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20221115_054649_298047_05796124 X-CRM114-Status: GOOD ( 27.60 ) X-BeenThere: linux-mediatek@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "Linux-mediatek" Errors-To: linux-mediatek-bounces+linux-mediatek=archiver.kernel.org@lists.infradead.org Hi Pin-yen, On 11/15/22 11:49, Pin-yen Lin wrote: > Hi Amjad, > > On Wed, Oct 19, 2022 at 10:17 PM Amjad Ouled-Ameur > wrote: >> Provide thermal zone to read thermal sensor in the SoC. We can read all the >> thermal sensors value in the SoC by the node /sys/class/thermal/ >> >> In mtk_thermal_bank_temperature, return -EAGAIN instead of -EACCESS >> on the first read of sensor that often are bogus values. >> This can avoid following warning on boot: >> >> thermal thermal_zone6: failed to read out thermal zone (-13) >> >> Signed-off-by: Michael Kao >> Signed-off-by: Hsin-Yi Wang >> Signed-off-by: Amjad Ouled-Ameur >> Reviewed-by: AngeloGioacchino Del Regno >> --- >> drivers/thermal/mtk_thermal.c | 104 ++++++++++++++++++++++++++++++++---------- >> 1 file changed, 79 insertions(+), 25 deletions(-) >> >> diff --git a/drivers/thermal/mtk_thermal.c b/drivers/thermal/mtk_thermal.c >> index 3a5df1440822..311ad611fdab 100644 >> --- a/drivers/thermal/mtk_thermal.c >> +++ b/drivers/thermal/mtk_thermal.c >> @@ -259,6 +259,11 @@ enum mtk_thermal_version { >> >> struct mtk_thermal; >> >> +struct mtk_thermal_zone { >> + struct mtk_thermal *mt; >> + int id; >> +}; >> + >> struct thermal_bank_cfg { >> unsigned int num_sensors; >> const int *sensors; >> @@ -307,6 +312,8 @@ struct mtk_thermal { >> >> const struct mtk_thermal_data *conf; >> struct mtk_thermal_bank banks[MAX_NUM_ZONES]; >> + >> + int (*raw_to_mcelsius)(struct mtk_thermal *mt, int sensno, s32 raw); >> }; >> >> /* MT8183 thermal sensor data */ >> @@ -709,6 +716,29 @@ static void mtk_thermal_put_bank(struct mtk_thermal_bank *bank) >> mutex_unlock(&mt->lock); >> } >> >> +static int _get_sensor_temp(struct mtk_thermal *mt, int id) >> +{ >> + u32 raw; >> + int temp; >> + >> + const struct mtk_thermal_data *conf = mt->conf; >> + >> + raw = readl(mt->thermal_base + conf->msr[id]); >> + >> + temp = mt->raw_to_mcelsius(mt, id, raw); >> + >> + /* >> + * The first read of a sensor often contains very high bogus >> + * temperature value. Filter these out so that the system does >> + * not immediately shut down. >> + */ >> + >> + if (temp > 200000) >> + return -EAGAIN; >> + else >> + return temp; >> +} >> + >> /** >> * mtk_thermal_bank_temperature - get the temperature of a bank >> * @bank: The bank >> @@ -721,26 +751,9 @@ static int mtk_thermal_bank_temperature(struct mtk_thermal_bank *bank) >> struct mtk_thermal *mt = bank->mt; >> const struct mtk_thermal_data *conf = mt->conf; >> int i, temp = INT_MIN, max = INT_MIN; >> - u32 raw; >> >> for (i = 0; i < conf->bank_data[bank->id].num_sensors; i++) { >> - raw = readl(mt->thermal_base + conf->msr[i]); >> - >> - if (mt->conf->version == MTK_THERMAL_V1) { >> - temp = raw_to_mcelsius_v1( >> - mt, conf->bank_data[bank->id].sensors[i], raw); >> - } else { >> - temp = raw_to_mcelsius_v2( >> - mt, conf->bank_data[bank->id].sensors[i], raw); >> - } >> - >> - /* >> - * The first read of a sensor often contains very high bogus >> - * temperature value. Filter these out so that the system does >> - * not immediately shut down. >> - */ >> - if (temp > 200000) >> - temp = 0; >> + temp = _get_sensor_temp(mt, i); >> >> if (temp > max) >> max = temp; >> @@ -749,9 +762,10 @@ static int mtk_thermal_bank_temperature(struct mtk_thermal_bank *bank) >> return max; >> } >> >> -static int mtk_read_temp(struct thermal_zone_device *tz, int *temperature) >> +static int mtk_read_temp(struct thermal_zone_device *tzdev, int *temperature) >> { >> - struct mtk_thermal *mt = tz->devdata; >> + struct mtk_thermal_zone *tz = tzdev->devdata; >> + struct mtk_thermal *mt = tz->mt; >> int i; >> int tempmax = INT_MIN; >> >> @@ -770,10 +784,28 @@ static int mtk_read_temp(struct thermal_zone_device *tz, int *temperature) >> return 0; >> } >> >> +static int mtk_read_sensor_temp(struct thermal_zone_device *tzdev, int *temperature) >> +{ >> + struct mtk_thermal_zone *tz = tzdev->devdata; >> + struct mtk_thermal *mt = tz->mt; >> + int id = tz->id - 1; >> + >> + if (id < 0) >> + return -EACCES; >> + >> + *temperature = _get_sensor_temp(mt, id); >> + >> + return 0; >> +} >> + >> static const struct thermal_zone_device_ops mtk_thermal_ops = { >> .get_temp = mtk_read_temp, >> }; >> >> +static const struct thermal_zone_device_ops mtk_thermal_sensor_ops = { >> + .get_temp = mtk_read_sensor_temp, >> +}; >> + >> static void mtk_thermal_init_bank(struct mtk_thermal *mt, int num, >> u32 apmixed_phys_base, u32 auxadc_phys_base, >> int ctrl_id) >> @@ -1072,6 +1104,7 @@ static int mtk_thermal_probe(struct platform_device *pdev) >> u64 auxadc_phys_base, apmixed_phys_base; >> struct thermal_zone_device *tzdev; >> void __iomem *apmixed_base, *auxadc_base; >> + struct mtk_thermal_zone *tz; >> >> mt = devm_kzalloc(&pdev->dev, sizeof(*mt), GFP_KERNEL); >> if (!mt) >> @@ -1150,6 +1183,9 @@ static int mtk_thermal_probe(struct platform_device *pdev) >> >> mtk_thermal_turn_on_buffer(mt, apmixed_base); >> >> + mt->raw_to_mcelsius = (mt->conf->version == MTK_THERMAL_V1) ? >> + raw_to_mcelsius_v1 : raw_to_mcelsius_v2; >> + >> if (mt->conf->version == MTK_THERMAL_V2) { >> mtk_thermal_release_periodic_ts(mt, auxadc_base); >> } >> @@ -1161,11 +1197,29 @@ static int mtk_thermal_probe(struct platform_device *pdev) >> >> platform_set_drvdata(pdev, mt); >> >> - tzdev = devm_thermal_of_zone_register(&pdev->dev, 0, mt, >> - &mtk_thermal_ops); >> - if (IS_ERR(tzdev)) { >> - ret = PTR_ERR(tzdev); >> - goto err_disable_clk_peri_therm; >> + for (i = 0; i < mt->conf->num_sensors + 1; i++) { >> + tz = devm_kmalloc(&pdev->dev, sizeof(*tz), GFP_KERNEL); >> + if (!tz) >> + return -ENOMEM; >> + >> + tz->mt = mt; >> + tz->id = i; >> + >> + tzdev = devm_thermal_of_zone_register(&pdev->dev, i, tz, (i == 0) ? >> + &mtk_thermal_ops : >> + &mtk_thermal_sensor_ops); >> + >> + if (IS_ERR(tzdev)) { >> + if (PTR_ERR(tzdev) == -ENODEV) { >> + dev_warn(&pdev->dev, >> + "sensor %d not registered in thermal zone in dt\n", i); >> + continue; >> + } >> + if (PTR_ERR(tzdev) == -EACCES) { >> + ret = PTR_ERR(tzdev); >> + goto err_disable_clk_peri_therm; >> + } >> + } >> } >> >> ret = devm_thermal_add_hwmon_sysfs(tzdev); > tzdev can be an error pointer here. I think we should move the line > into the loop above, so hwmon sysfs is not added when IS_ERR(tzdev) == > true. Good catch, will fix this in next rev. Regards, Amjad > Regards, > Pin-yen