Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp510910imm; Fri, 22 Jun 2018 00:05:00 -0700 (PDT) X-Google-Smtp-Source: ADUXVKL9k562R0nL9noSsP6Cjmy5nLSMMb4zZYnZY8S6PJSGfUThtHW6CEEldCnQAXLrIvAQcNZr X-Received: by 2002:a62:494f:: with SMTP id w76-v6mr468945pfa.152.1529651100097; Fri, 22 Jun 2018 00:05:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529651100; cv=none; d=google.com; s=arc-20160816; b=JRpx71QYSuqqEDNM9Q6rJJ6ywYeKleHoJpmolbQl0/I/icw6C+9xg5tpTkbXyB8gi9 +k/SgHK/fiMH+6FGtmWkH/pveJwVQGBXkYhTrdxf2OENILHZ81xUmewBHKEe4pbW78lj WFYKWUIMSzp1HR7ZQ2i8gFA3DREjJhWF6gZ3gTRnUWuTMkIzvFiuExoh7Ygq3WTNe+vI rME5SvKT+oe2FPFyb8wwW2wVVoFJxKSvB4+nbVTcj6DmGa9fi9MmvXgYcVPrypJ3UUdS o2CMtzg0mbi3y3sNIPgmpSP91rBB+6DTFclai5KoVMfJ+XqmMyl6xDkZ0HpwPX+qF5+U bMrQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=J4WuimpJJrfRfdYX5WX0HAl104qMgH33jbC6JYQABF8=; b=N/4e6aAh2730ZzNbExh3Yc6gMi/CJPA3QHgDSB1RUrUlhKXBF6p4tTMltgT818v2po 2GUqyWNMl4BIEJk+to0HXWernKQqsEO5i8VUn5BEMmM92qL8s011eiCah/GhygljW2d3 OMPD2CPNV9KRwhVJEtSLqCSBjkaR221HS85jdAKpx5avY0HF/CEK5S0sg8E7cLCeCvi9 86YAbI6YzzVcJ58/Y82TcbN2YN7REJEItOLBgTb8//crZOfZgRIkzuln4LZn1SUNHMAA X4p2150ItfIV+tl9xFl84vpLJ+PgAhJGKBXU15LhpX95B3RP2aFjgD7k0mJUpCNsApQK xAwA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=X8143tQr; dkim=pass header.i=@codeaurora.org header.s=default header.b=kQm7e4uz; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t20-v6si2055420ply.146.2018.06.22.00.04.45; Fri, 22 Jun 2018 00:05:00 -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; dkim=pass header.i=@codeaurora.org header.s=default header.b=X8143tQr; dkim=pass header.i=@codeaurora.org header.s=default header.b=kQm7e4uz; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751182AbeFVHEG (ORCPT + 99 others); Fri, 22 Jun 2018 03:04:06 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:46460 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750886AbeFVHEF (ORCPT ); Fri, 22 Jun 2018 03:04:05 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 7BB5460714; Fri, 22 Jun 2018 07:04:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1529651044; bh=LaXr7iFtgOjQNnwRtISsfO6vz338MEX0S/l2gRh8qg4=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=X8143tQr7FaPs9xUDZfzIuMmhxjX6r5rU3k7uyHZHBkZXDIPcFg8Ry902dwol0s8u 6zjkJD14pWgQNO0TcFQe3y7MHiy9kzrFzkfADPbhPuOl1u6/n5WcBLT1CeOy+f74U3 qEzEgaOym4ZdMTEIszwJrDdZkjHrPfD0NaAVw04c= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [10.204.66.249] (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: akhilpo@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id A539D60227; Fri, 22 Jun 2018 07:04:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1529651043; bh=LaXr7iFtgOjQNnwRtISsfO6vz338MEX0S/l2gRh8qg4=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=kQm7e4uzTXg9495Rg9QHOdCCL3HZLSjf93ouBu173wal3LhPItxYpNXjw9gCXkyfi UtAFlkRqMo+JUCsdyboXU6sx5YB3+hmNCa/i/Ayy9E1oeCabrRrN7ijGuvPN2X/Jq4 yhjacfuW9tdVt5YIZ6vgOYqrdpv8o3HNbTYdmwMk= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org A539D60227 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=akhilpo@codeaurora.org Subject: Re: [PATCH v3] PM / devfreq: Fix devfreq_add_device() when drivers are built as modules. To: Ezequiel Garcia , Enric Balletbo i Serra , 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: Akhil P Oommen Message-ID: Date: Fri, 22 Jun 2018 12:33:59 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <0383b4a703a0b619023c0654a4a7637419c72ebd.camel@collabora.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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. > >> 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? -Akhil.