Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp572899imm; Fri, 22 Jun 2018 01:23:57 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJSvneVLMFJV930RGHWXjNd4vImMbz0D44M7z1zmbE4zWI4Qd3/03ML945TaHAsQiKyRFkZ X-Received: by 2002:aa7:8311:: with SMTP id t17-v6mr691968pfm.45.1529655837339; Fri, 22 Jun 2018 01:23:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529655837; cv=none; d=google.com; s=arc-20160816; b=Kpm1XSZah5uYhzgOq+BOPEUxZRmau2FRp0UIjSF/aAaw6Yoly1y0FlkuvhQkpHFgxi 6Bao47R39XIFSGeJYV87JTrici6feUmP4DR/sLtf+9EpKpp+FtSswzMDVvVYRt78FoP1 PUcKSZBo4flXQytC+fDbh9HgjYtSx9itrJLWGvKlCGwWpkZBBS78JCL7UYI+eeKRG3Em xgHpzgYC3DlvnR/ZuprsnkJZOqJaiYNzFBQW7SFmNmDQMquSf7pzaXacBvEDuykRQw+q xOc9rJqkP+Q2qkp8/Oe1aoznIJSOufpCIQdUkAy6uidxBc3lK3ebRwedSCmFvrpvGVL+ GHCQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=GcGMg6MLY8XyG/Gu0633V8OBx1rkRERa1kXZ3A6woM0=; b=sE260ihZrHPN6W7zTtxu5FAz4rv8R7mm2XFf3+uC/NAEZZD4brAeHelkjxc+swiipV bfJB15qVCkbIuOdO1JTz/WIgjwnSu5rJqsk2W4g7EtSF9a4wlcMvhK2VsVtdbRPwnWE1 JTXRBq9ixJFJkG12dHtMufAgPjfO7ux99yNtwicFZ3EbiL+Z+7h8eZeFfyGqFb9ox/UO xQ2a5j4n1ZB9yvXETe5S2ofyYnEEmSmsB6RFV53/HSZta6gzqeFuvYBPy5aVPWJ9IOs8 4bdYWJ83gW+qVDfb7QDxC20TNMqG4sWO1FPB+v3dxDRXmWigQnJskngBqhDlLlmfJCRq PQdg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q15-v6si5797282pgr.507.2018.06.22.01.23.43; Fri, 22 Jun 2018 01:23:57 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753270AbeFVIWm (ORCPT + 99 others); Fri, 22 Jun 2018 04:22:42 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:52520 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751393AbeFVIWj (ORCPT ); Fri, 22 Jun 2018 04:22:39 -0400 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id D5ADD28A5E1 Subject: Re: [PATCH v3] PM / devfreq: Fix devfreq_add_device() when drivers are built as modules. To: Akhil P Oommen , Ezequiel Garcia , linux-kernel@vger.kernel.org Cc: kernel@collabora.com, Chanwoo Choi , Kyungmin Park , MyungJoo Ham , linux-pm@vger.kernel.org References: <20180621220430.25644-1-enric.balletbo@collabora.com> <0383b4a703a0b619023c0654a4a7637419c72ebd.camel@collabora.com> From: Enric Balletbo i Serra Message-ID: <36c9720c-7428-0a17-5252-7afbd80bce6b@collabora.com> Date: Fri, 22 Jun 2018 10:22:34 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 >>> --- >>> >>> 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. >