Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp888579pxb; Wed, 13 Apr 2022 14:58:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwTTcSKxV9XuhYLaWDmXc4HV+zuLWz3q5It5lCEllr+wVMDboBuGWFc4mNrM0+baLhmC37f X-Received: by 2002:a17:906:4ad9:b0:6cf:93f:f77e with SMTP id u25-20020a1709064ad900b006cf093ff77emr41083250ejt.558.1649887125275; Wed, 13 Apr 2022 14:58:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649887125; cv=none; d=google.com; s=arc-20160816; b=0FhHKv2ewZR8mJ+Chyo7FcQubg/Sqj7gENkVM+Xp7H8Zks60bNmJyG04z4Je2vev68 uSrSCpGY6Xow5+x87saaO/uQzyjj6w1dhJQxr0PkzZFXls48nM34p2BTXvpzye6Y2/C8 W3ZWrkLTuRoqflbeqgoupimKyJnuENiGw+BZDqsY33s8b3EDJHpDSefGQvD5P/ADOV68 zWJN7PXWpCt8a7Wgp14HB45VF5XG//Rcc2GLziz5L7fOvbjhJj/jt2HBFRqjj1mBjNrh 1KwGUmrMxnVrc+fsPaVqzgyCnIR+PNRJVDdVY/w2pozHCmrHEaz/5ja+dcg4hSorhi/I /tkA== 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:references :cc:to:from:content-language:subject:user-agent:mime-version:date :message-id; bh=ngiu6lXD072Hd6Pf2I5HA+9Y5EhFKIJM395JJa0eUFc=; b=N34xYRaiTQpsqSIrCO9Tf/aSD2ERIeIMNxWt5tl5c51e+KzJWfxCjQp5ZfM9GBgT2y gmuQsA+MJM+JFUHTQYs/6vVGJHnYSVmi2aw1Vr7o/Bbbd5SR2YJ2sKJJ+N2YMfO1dOqG YqjNhv2LSs58y++nRs9A/5Qx7Azsld6LTeqoquNcwsLjPu5e9J9CiZfQn8bqiqm459qW +OZ+bSmn1b9+Qw9WQGj8dwGfAXNkASDWHpS1o7U5v/jOuSLSihHDJcBRZDaoKPZtzrH9 9N9e2ourYN1MIGS/NxU4TapSriLnZ0gS9tijvEVbF5hEc90mMVDXuxW2DcGDBAWobeC8 n75A== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g5-20020a17090670c500b006df76385cdesi761384ejk.382.2022.04.13.14.58.18; Wed, 13 Apr 2022 14:58:45 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236635AbiDMPnx (ORCPT + 99 others); Wed, 13 Apr 2022 11:43:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56120 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229732AbiDMPnv (ORCPT ); Wed, 13 Apr 2022 11:43:51 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 76C1449CB2; Wed, 13 Apr 2022 08:41:29 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 42E681576; Wed, 13 Apr 2022 08:41:29 -0700 (PDT) Received: from [10.57.8.248] (unknown [10.57.8.248]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 81BA53F5A1; Wed, 13 Apr 2022 08:41:27 -0700 (PDT) Message-ID: Date: Wed, 13 Apr 2022 16:41:26 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.5.0 Subject: Re: [PATCH v2] thermal: devfreq_cooling: use local ops instead of global ops Content-Language: en-US From: Lukasz Luba To: "Rafael J. Wysocki" Cc: Amit Kucheria , "Zhang, Rui" , Linux PM , Linux Kernel Mailing List , allwinner-opensource-support@allwinnertech.com, Stable , Daniel Lezcano , Ionela Voinescu , Kant Fan References: <20220325073030.91919-1-kant@allwinnertech.com> In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-8.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 4/13/22 16:06, Lukasz Luba wrote: > > > On 4/13/22 15:58, Rafael J. Wysocki wrote: >> On Fri, Mar 25, 2022 at 10:02 AM Lukasz Luba wrote: >>> >>> Hi Kant, >>> >>> On 3/25/22 07:30, 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. >>>> >>>> Fixes: 615510fe13bd2 ("thermal: devfreq_cooling: remove old power >>>> model and use EM") >>>> Cc: stable@vger.kernel.org # 5.13+ >>>> Signed-off-by: Kant Fan >>>> --- >>>>    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); >>> >>> >>> Thank you for updating it, LGTM >>> >>> Reviewed-by: Lukasz Luba >> >> Applied as 5.19 material. >> >> Lukasz, this had a conflict with your EM series, please double check >> if my resolution in the bleeding-edge branch is correct. > > OK, I'll let you know after I fetch and build that branch. I've read the code and confirm you've do this correctly. I've also built that branch with ENERGY_MODEL and DEVFREQ_COOLING configs set - no issues observed. Later this week I would use it for some other development so I will test it as well. Thank you for solving this! Regards, Lukasz