Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp1477018pxb; Sat, 23 Apr 2022 07:39:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz7SweD05RIeFKxoixd0/eGvnp0LUcpx7/SzNmtd2O7QMNYB//9RMppYRoI7qL2XW5rg3Rb X-Received: by 2002:a17:907:3fa9:b0:6ef:f0e6:7285 with SMTP id hr41-20020a1709073fa900b006eff0e67285mr8714337ejc.350.1650724778532; Sat, 23 Apr 2022 07:39:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650724778; cv=none; d=google.com; s=arc-20160816; b=UFpyRecfO25Z0D/GtvvoK2hypfV1hTP3VJ57ASiItcMhLnYUSTcuPWt1mUoeSLEQmU ki9wjjajPAAw/hbj5SlkLGUd6jcW/jX7QNK8OGjPw2K58eytE68JzLKRHtNTAceUDARG Tobp4zgLvpxKwyBVubRxWZyxP/zdIcWPRxnBBr8YduTnWciA9IZGtCHR4Nhs169nDUvK zgotwMHvQLG92yhrHo64KSsWdHbknDoftugeE9BhYvA8L/GrxG3ylRxNV5QtP94IQVSm O2cGRvWcPgt+kcplBNrTOMePlUs6QXga0HCjAZNbBPnPC3fC9s5B3D5RntVNuRtUUbA6 U64g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=TouPYzylrCpxV5hXoadQnWsU1yyV2CpTKABup8e/KUU=; b=Wj9imnhQQ7MozZOFG6Er7rcj/gBeXM4IWEimUstoVXsXnNWj7tb+YbqBo55kspTsMH +vdX3ZbCo2xCsMPwH1EWm6tMXb6lSD8wEoEnEHikfmBOO6zbK45lH7nM39fO+Xzq85u7 xDtH3kza5B8D+TfiE3cilRXKYv+tqam8Gu35b2RzeXfCq9hxz1OMwoDqIJmuchqB5klU wCyMTnwAJEucJSwSu8oOi+JVqamSlGPSkIBBexg07QhRFIBEgDXmo0rd+0OtHCJ9o1Vv FzHS/d/m1x7DV/e4G4Nwb4up0sO/bOym3YQy4VLaS5cLFeY/Mk84h6RRPQ6yT57aEC7e TCHA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id kf24-20020a17090776d800b006efe2443277si8756005ejc.328.2022.04.23.07.39.14; Sat, 23 Apr 2022 07:39:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234934AbiDWKwV (ORCPT + 99 others); Sat, 23 Apr 2022 06:52:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39234 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229732AbiDWKwU (ORCPT ); Sat, 23 Apr 2022 06:52:20 -0400 Received: from out28-52.mail.aliyun.com (out28-52.mail.aliyun.com [115.124.28.52]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7EE21C8A9B; Sat, 23 Apr 2022 03:49:19 -0700 (PDT) X-Alimail-AntiSpam: AC=CONTINUE;BC=0.07436342|-1;CH=green;DM=|CONTINUE|false|;DS=CONTINUE|ham_social|0.164624-0.00134867-0.834027;FP=0|0|0|0|0|-1|-1|-1;HT=ay29a033018047201;MF=kant@allwinnertech.com;NM=1;PH=DS;RN=11;RT=11;SR=0;TI=SMTPD_---.NWHc4yz_1650710954; Received: from 192.168.110.175(mailfrom:kant@allwinnertech.com fp:SMTPD_---.NWHc4yz_1650710954) by smtp.aliyun-inc.com(33.32.92.215); Sat, 23 Apr 2022 18:49:16 +0800 Message-ID: Date: Sat, 23 Apr 2022 18:49:23 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.8.0 Subject: Re: [PATCH] thermal: devfreq_cooling: use local ops instead of global ops Content-Language: en-GB To: Lukasz Luba Cc: amitk@kernel.org, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, allwinner-opensource-support@allwinnertech.com, stable@vger.kernel.org, orjan.eide@arm.com, edubezval@gmail.com, javi.merino@kernel.org, daniel.lezcano@linaro.org, rui.zhang@intel.com References: <20220325094436.101419-1-kant@allwinnertech.com> <4db6b25c-dd78-a6ba-02a5-ac2e49996be1@arm.com> <6b89fa96-07f0-19bb-2e18-22afa27554a1@allwinnertech.com> <281fd0f0-d2fc-95cf-d183-31ca8c25830e@arm.com> From: Kant Fan In-Reply-To: <281fd0f0-d2fc-95cf-d183-31ca8c25830e@arm.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.8 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20/04/2022 18:32, Lukasz Luba wrote: > Hi Kant, > > On 4/19/22 16:49, Kant Fan wrote: >> On 29/03/2022 14:59, Lukasz Luba wrote: >>> >>> >>> On 3/25/22 09:44, Kant Fan wrote: >>>> commit 7b62935828266658714f81d4e9176edad808dc70 upstream. >>>> >>>> Fix access illegal address problem in following condition: >>>> There are muti devfreq cooling devices in system, some of them register >>>> with dfc_power but other does not, power model ops such as >>>> state2power will >>>> append to global devfreq_cooling_ops when the cooling device with >>>> dfc_power register. It makes the cooling device without dfc_power >>>> also use devfreq_cooling_ops after appending when register later by >>>> of_devfreq_cooling_register_power() or of_devfreq_cooling_register(). >>>> >>>> IPA governor regards the cooling devices without dfc_power as a >>>> power actor >>>> because they also have power model ops, and will access illegal >>>> address at >>>> dfc->power_ops when execute cdev->ops->get_requested_power or >>>> cdev->ops->power2state. As the calltrace below shows: >>>> >>>> Unable to handle kernel NULL pointer dereference at virtual address >>>> 00000008 >>>> ... >>>> calltrace: >>>> [] devfreq_cooling_power2state+0x24/0x184 >>>> [] power_actor_set_power+0x54/0xa8 >>>> [] power_allocator_throttle+0x770/0x97c >>>> [] handle_thermal_trip+0x1b4/0x26c >>>> [] thermal_zone_device_update+0x154/0x208 >>>> [] process_one_work+0x1ec/0x36c >>>> [] worker_thread+0x204/0x2ec >>>> [] kthread+0x140/0x154 >>>> [] ret_from_fork+0x14/0x2c >>>> >>>> Fixes: a76caf55e5b35 ("thermal: Add devfreq cooling") >>>> Cc: stable@vger.kernel.org # 4.4+ >>>> Signed-off-by: Kant Fan >>>> --- >>>>   drivers/thermal/devfreq_cooling.c | 25 ++++++++++++++++++------- >>>>   1 file changed, 18 insertions(+), 7 deletions(-) >>>> >>> >>> Looks good. So this patch should be applied for all stable >>> kernels starting from v4.4 to v5.12 (the v5.13 and later need >>> other patch). >>> >>> Next time you might use in the subject something like: >>> [PATCH 4.4] thermal: devfreq_cooling: use local ops instead of global >>> ops >>> It would be better distinguished from your other patch with the >>> same subject, which was for mainline and v5.13+ >> >> Hi Lukasz, >> Thank you for the guidance. I want to know if I'm understanding you in >> a right way. Could you confirm the following information? >> >> 1. The stable patches >> After the patch is merged into mainline later, I'll submit the >> following patches individually for v4.4 ~ v5.12: > > Correct, after it gets mainline you can point to that commit hash and > process with those patches. I don't now which of those older stable > kernels are still maintained, since some of them have longer support > and the rest had shorter and might already ended. You can check the > end of life for those 'Longterm' here [1]. AFAICS the 4.4 is not in that > table, so you can start from 4.9, should be OK. > So the list of needed patches would be for those stable kernels: > 4.9, 4.14, 4.19, 5.4, 5.10 > I can see that last release for 5.11.x was in May 2021, so it's probably > ended, similar for 5.12.x (Jul 2021). That's why I suggested that list > for the long support kernels. > Hi Lukasz, Thanks for figuring it out. I'll check the stable versions carefully. >> >> [PATCH 4.4] thermal: devfreq_cooling: use local ops instead of global ops >> [PATCH 4.5] thermal: devfreq_cooling: use local ops instead of global ops >> ... >> [PATCH 5.12] thermal: devfreq_cooling: use local ops instead of global >> ops >> >> And also the following patches individually for v5.13+ : > > For this, you probably don't have to. You have added 'v5.13+' in the > original patch v2, so it will be picked correctly. It should apply > on those stable kernels w/o issues. If there will be, stable kernel > engineers will ping us. > >> [PATCH 5.13] thermal: devfreq_cooling: use local ops instead of global >> ops >> [PATCH 5.14] thermal: devfreq_cooling: use local ops instead of global >> ops >> ... >> [PATCH 5.17] thermal: devfreq_cooling: use local ops instead of global >> ops >> >> 2. The mainline patch >> I saw your mail with Rafael, seems there are conflicts... I wonder if >> there's anything wrong with my patch, or anything I can help? >> > > Thank you for offering help. Rafael solved that correctly, so it doesn't > need any more work. > > Thank you for doing that work! > > Regards, > Lukasz > > [1] https://www.kernel.org/category/releases.html No problem. I'll submit the stable patches after the mainline patch is merged. -- Best Regards, Kant Fan