Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp2199753pxb; Fri, 25 Mar 2022 12:54:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxRa+GJG4mN/XfDoFzlgGjjVtbEKbzlv0nm2q/Iu2WAsx/WqeTg3/q+ro+8BR86MqwGjHQB X-Received: by 2002:a63:290:0:b0:386:5374:b8b5 with SMTP id 138-20020a630290000000b003865374b8b5mr922343pgc.528.1648238088734; Fri, 25 Mar 2022 12:54:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648238088; cv=none; d=google.com; s=arc-20160816; b=afAYdwXjNVgNHOyD6m67MSlvInCPPuse8Gow+DkELCuWrd7M8wSnsNV3UwGNjJhCNV d7hQDlAhl1XYK/0MMszC62MOO6HRMfyKeux9tkhiFONMgEzOtpRBLVy5yvo5PVJtaQ57 lqKkyJphCsWXqUHZ7/H7aHb8uWJeNzHrwLVJAUYD9nI4X3dWwfvMB6adNAfwItChtIdh EfThu82koRSswK8zdHCyzu/6axmW8SFkGiHCvPMMduqMgW8dwigiwoQEP4xXQthiyz+l icIIEjU2Fzch7g3gKr8zXJHJ9rfQ7ycFp/Hck8PBcdKrL6YduFWKRbf0HXQ//hMc0e8X Cxrw== 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=qAdaZltfQstOxSp/OnQrJ4FrAW/b8TEZPtJ4ucUile0=; b=ZZ536Jakmbp/fIsgI2oHQREHLaIC2nN1zwZK1TMyFJIu8QAdEotkPiHO7S7Qpmf/bM 2c5zrN1F3ENvOpu3NGNuLOupAJTsGirCoX0VF4iugzRtttNTX3YpXuf1q+GewodJVEzM 1tQ2x7goMwiAvwSxlcXEQYZ9b2jmkHfRenARPRobkAPJmFb7kk7urab68Uc9+9JJVFbi Oh5pc/qNsqLSItKa0a7R3GDTrzU7s0vHys/ilUgyBR6Kvo01oBZMSP17Xy3HVFRF9tF0 m8Y6LWpxaTaAwSheyWMhYRxemF3BGBI/hwAlBzDEXkjEdq/ft60Nu3Fbe2L9j369d7ZT 1IcQ== ARC-Authentication-Results: i=1; mx.google.com; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id n66-20020a632745000000b003816043f06bsi3215267pgn.608.2022.03.25.12.54.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 25 Mar 2022 12:54:48 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id AD8732EA901; Fri, 25 Mar 2022 11:44:08 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S245478AbiCYKpP (ORCPT + 99 others); Fri, 25 Mar 2022 06:45:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36506 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244975AbiCYKpM (ORCPT ); Fri, 25 Mar 2022 06:45:12 -0400 Received: from out28-76.mail.aliyun.com (out28-76.mail.aliyun.com [115.124.28.76]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1D9506C967; Fri, 25 Mar 2022 03:43:36 -0700 (PDT) X-Alimail-AntiSpam: AC=CONTINUE;BC=0.07436321|-1;CH=green;DM=|CONTINUE|false|;DS=CONTINUE|ham_news_journal|0.00648115-0.000568538-0.99295;FP=0|0|0|0|0|-1|-1|-1;HT=ay29a033018047211;MF=kant@allwinnertech.com;NM=1;PH=DS;RN=8;RT=8;SR=0;TI=SMTPD_---.NCMngfK_1648205012; Received: from 172.30.10.142(mailfrom:kant@allwinnertech.com fp:SMTPD_---.NCMngfK_1648205012) by smtp.aliyun-inc.com(33.13.197.192); Fri, 25 Mar 2022 18:43:34 +0800 Message-ID: Date: Fri, 25 Mar 2022 18:43:31 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 Subject: Re: [PATCH] thermal: devfreq_cooling: use local ops instead of global ops Content-Language: en-GB To: Lukasz Luba Cc: Amit Kucheria , Zhang Rui , "open list:THERMAL" , open list , "supporter:THERMAL" , "supporter:THERMAL" , allwinner-opensource-support References: <20220312045922.9779-1-kant@allwinnertech.com> <8529a647-6127-539f-20ba-271be293fe2f@arm.com> From: Kant Fan In-Reply-To: <8529a647-6127-539f-20ba-271be293fe2f@arm.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,NICE_REPLY_A, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY autolearn=no 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 14/03/2022 21:41, Lukasz Luba wrote: > Hi Kant, > > On 3/12/22 04:59, Kant Fan wrote: >> Fix access illegal address problem in following condition: >> There are muti devfreq cooling devices in system, some of them has >> em model but other does not, energy model ops such as state2power will >> append to global devfreq_cooling_ops when the cooling device with >> em model register. It makes the cooling device without em model >> 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 em model as a power >> actor >> because they also have energy model ops, and will access illegal address >> at dfc->em_pd when execute cdev->ops->get_requested_power, >> cdev->ops->state2power or cdev->ops->power2state. >> >> Signed-off-by: Kant Fan > > Thank you for finding this issue. This was also an issue since the > beginning of that code. The modified global ops after first registration > which went through, was also previously there. Thus, we would need two > different patches for stable kernels. > > For this one, please add the tag: > Fixes: 615510fe13bd2 ("thermal: devfreq_cooling: remove old power model > and use EM") > > This patch would also go via stable tree for kernels v5.11+ > Please read the process how to send a patch which will be merged to the > stable tree. > > There will be a need to create another patch(es) for stable kernels with > Fixes: a76caf55e5b35 ("thermal: Add devfreq cooling") > In those kernels also the global ops is modified and might not support > properly many cooling devices. It's present in other stable kernels: > v5.10 and older > >> --- >>   drivers/thermal/devfreq_cooling.c | 25 ++++++++++++++++++------- >>   1 file changed, 18 insertions(+), 7 deletions(-) >> >> diff --git a/drivers/thermal/devfreq_cooling.c >> b/drivers/thermal/devfreq_cooling.c >> index 4310cb342a9f..d38a80adec73 100644 >> --- a/drivers/thermal/devfreq_cooling.c >> +++ b/drivers/thermal/devfreq_cooling.c >> @@ -358,21 +358,28 @@ of_devfreq_cooling_register_power(struct >> device_node *np, struct devfreq *df, >>       struct thermal_cooling_device *cdev; >>       struct device *dev = df->dev.parent; >>       struct devfreq_cooling_device *dfc; >> +    struct thermal_cooling_device_ops *ops; >>       char *name; >>       int err, num_opps; >> -    dfc = kzalloc(sizeof(*dfc), GFP_KERNEL); >> -    if (!dfc) >> +    ops = kmemdup(&devfreq_cooling_ops, sizeof(*ops), GFP_KERNEL); >> +    if (!ops) >>           return ERR_PTR(-ENOMEM); >> +    dfc = kzalloc(sizeof(*dfc), GFP_KERNEL); >> +    if (!dfc) { >> +        err = -ENOMEM; >> +        goto free_ops; >> +    } >> + >>       dfc->devfreq = df; >>       dfc->em_pd = em_pd_get(dev); >>       if (dfc->em_pd) { >> -        devfreq_cooling_ops.get_requested_power = >> +        ops->get_requested_power = >>               devfreq_cooling_get_requested_power; >> -        devfreq_cooling_ops.state2power = devfreq_cooling_state2power; >> -        devfreq_cooling_ops.power2state = devfreq_cooling_power2state; >> +        ops->state2power = devfreq_cooling_state2power; >> +        ops->power2state = devfreq_cooling_power2state; >>           dfc->power_ops = dfc_power; >> @@ -407,8 +414,7 @@ of_devfreq_cooling_register_power(struct >> device_node *np, struct devfreq *df, >>       if (!name) >>           goto remove_qos_req; >> -    cdev = thermal_of_cooling_device_register(np, name, dfc, >> -                          &devfreq_cooling_ops); >> +    cdev = thermal_of_cooling_device_register(np, name, dfc, ops); >>       kfree(name); >>       if (IS_ERR(cdev)) { >> @@ -429,6 +435,8 @@ of_devfreq_cooling_register_power(struct >> device_node *np, struct devfreq *df, >>       kfree(dfc->freq_table); >>   free_dfc: >>       kfree(dfc); >> +free_ops: >> +    kfree(ops); >>       return ERR_PTR(err); >>   } >> @@ -510,11 +518,13 @@ EXPORT_SYMBOL_GPL(devfreq_cooling_em_register); >>   void devfreq_cooling_unregister(struct thermal_cooling_device *cdev) >>   { >>       struct devfreq_cooling_device *dfc; >> +    const struct thermal_cooling_device_ops *ops; >>       struct device *dev; >>       if (IS_ERR_OR_NULL(cdev)) >>           return; >> +    ops = cdev->ops; >>       dfc = cdev->devdata; >>       dev = dfc->devfreq->dev.parent; >> @@ -525,5 +535,6 @@ void devfreq_cooling_unregister(struct >> thermal_cooling_device *cdev) >>       kfree(dfc->freq_table); >>       kfree(dfc); >> +    kfree(ops); >>   } >>   EXPORT_SYMBOL_GPL(devfreq_cooling_unregister); > > The fix looks good. Hi Lukasz, Thanks for your advice. According to that, I made two separate patches for mainline and the stable trees: The first patch (patchwork.kernel.org: Message ID: 20220325073030.91919-1-kant@allwinnertech.com) is for mainline. I added the 'fix' tag and 'Cc: stable@vger.kernel.org # 5.13+' to remind which stable trees should be back-ported. The second patch (patchwork.kernel.org: Message ID: 20220325094436.101419-1-kant@allwinnertech.com) is for stable tree v5.10 and older. I added an upstream commit ID to indicate where the patch comes from. I also added 'Cc: stable@vger.kernel.org # 4.4+' to remind which stable trees should be back-ported. Please check if they are correct. Thank you. Kant Fan