lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <9ecb2d61-5713-c0dc-9d35-2c926372fd03@codeaurora.org>
Date:   Fri, 22 Jun 2018 14:36:31 +0530
From:   Akhil P Oommen <akhilpo@...eaurora.org>
To:     Enric Balletbo i Serra <enric.balletbo@...labora.com>,
        Ezequiel Garcia <ezequiel@...labora.com>,
        linux-kernel@...r.kernel.org
Cc:     kernel@...labora.com, Chanwoo Choi <cw00.choi@...sung.com>,
        Kyungmin Park <kyungmin.park@...sung.com>,
        MyungJoo Ham <myungjoo.ham@...sung.com>,
        linux-pm@...r.kernel.org
Subject: Re: [PATCH v3] PM / devfreq: Fix devfreq_add_device() when drivers
 are built as modules.



On 6/22/2018 1:52 PM, Enric Balletbo i Serra wrote:
> Hi Ezequiel and Akhil,
>
> On 22/06/18 09:03, Akhil P Oommen wrote:
>> On 6/22/2018 6:41 AM, Ezequiel Garcia wrote:
>>> Hey Enric,
>>>
>>> On Fri, 2018-06-22 at 00:04 +0200, Enric Balletbo i Serra wrote:
>>>> When the devfreq driver and the governor driver are built as modules,
>>>> the call to devfreq_add_device() or governor_store() fails because
>>>> the
>>>> governor driver is not loaded at the time the devfreq driver loads.
>>>> The
>>>> devfreq driver has a build dependency on the governor but also should
>>>> have a runtime dependency. We need to make sure that the governor
>>>> driver
>>>> is loaded before the devfreq driver.
>>>>
>>>> This patch fixes this bug by adding a try_then_request_governor()
>>>> function. First tries to find the governor, and then, if it is not
>>>> found,
>>>> it requests the module and tries again.
>>>>
>>>> Fixes: 1b5c1be2c88e (PM / devfreq: map devfreq drivers to governor
>>>> using name)
>>>> Signed-off-by: Enric Balletbo i Serra <enric.balletbo@...labora.com>
>>>> ---
>>>>
>>>> Changes in v3:
>>>> - Remove unneded change in dev_err message.
>>>> - Fix err returned value in case to not find the governor.
>>>>
>>>> Changes in v2:
>>>> - Add a new function to request the module and call that function
>>>> from
>>>>     devfreq_add_device and governor_store.
>>>>
>>>>    drivers/devfreq/devfreq.c | 65 ++++++++++++++++++++++++++++++++-----
>>>> -- 
>>> [snip snip]
>>>> -    governor = find_devfreq_governor(devfreq->governor_name);
>>>> +    governor = try_then_request_governor(devfreq-
>>>>> governor_name);
>>>>        if (IS_ERR(governor)) {
>>>>            dev_err(dev, "%s: Unable to find governor for the
>>>> device\n",
>>>>                __func__);
>>>>            err = PTR_ERR(governor);
>>>> -        goto err_init;
>>>> +        goto err_unregister;
>>>>        }
>>>>    +    mutex_lock(&devfreq_list_lock);
>>>> +
>>> I know it's not something we are introducing in this patch,
>>> but still... calling a hook with a mutex held looks
>>> fishy to me.
>>>
>>> This lock should only protect the list, unless I am missing
>>> something.
>>>
> I think so too.
>
>>>>        devfreq->governor = governor;
>>>>        err = devfreq->governor->event_handler(devfreq,
>>>> DEVFREQ_GOV_START,
>>>>                            NULL);
>>>> @@ -663,14 +703,16 @@ struct devfreq *devfreq_add_device(struct
>>>> device *dev,
>>>>                __func__);
>>>>            goto err_init;
>>>>        }
>>>> +
>>>> +    list_add(&devfreq->node, &devfreq_list);
>>>> +
>>>>        mutex_unlock(&devfreq_list_lock);
>>>>          return devfreq;
>>>>      err_init:
>>>> -    list_del(&devfreq->node);
>>>>        mutex_unlock(&devfreq_list_lock);
>>>> -
>>>> +err_unregister:
>>>>        device_unregister(&devfreq->dev);
>>>>    err_dev:
>>>>        if (devfreq)
>>>> @@ -988,12 +1030,13 @@ static ssize_t governor_store(struct device
>>>> *dev, struct device_attribute *attr,
>>>>        if (ret != 1)
>>>>            return -EINVAL;
>>>>    -    mutex_lock(&devfreq_list_lock);
>>>> -    governor = find_devfreq_governor(str_governor);
>>>> +    governor = try_then_request_governor(str_governor);
>>>>        if (IS_ERR(governor)) {
>>>> -        ret = PTR_ERR(governor);
>>>> -        goto out;
>>>> +        return PTR_ERR(governor);
>>>>        }
>>>> +
>>>> +    mutex_lock(&devfreq_list_lock);
>>>> +
>>>>        if (df->governor == governor) {
>>>>            ret = 0;
>>>>            goto out;
>>>> -- 
>>>> 2.17.1
>>>>
>>>>
>>> Regards,
>>> Eze
>> Adding to Ezequiel's point, shouldn't we take more granular lock (devfreq->lock)
>> first and then call devfreq_list_lock at the time of adding to the list?
>>
> Yes, I think so. I think, though, that this should be a separate patch, not sure
> if a pre or post patch to this one, but for sure it's another topic. Current
> patch tries to solve different problem an only tries to follow the current
> locking/unlocking. Anyway this is a maintainer decision I guess.
>
> Thanks,
>   Enric
>
>> -Akhil.
>>
I agree.
-Akhil.

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ