Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp425841ybm; Thu, 28 May 2020 06:25:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxfenKsydxBEKtsL05fxe0fY0UsiXTp9747WT5wupnUjGDINb5sPpdUaTLev/nq1JOp/0qi X-Received: by 2002:aa7:cc84:: with SMTP id p4mr3164887edt.216.1590672346333; Thu, 28 May 2020 06:25:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590672346; cv=none; d=google.com; s=arc-20160816; b=kFbhL51Xy5gpepQILYnHGzqg1GDggsGJe64La/kjEEuOLP9Ur/yGf12MogWbwnPq+s X+2Ksb/dO6WT2wudgl7uCF6cy2OWBgLHsqzo8iqlvfOanOdbleQ6pN7AsjnescUKLJPU D2fXkNHj49ucjscUyIcndbg5ondERbilwjD+oyw21sPJEIh/KLoZF0kJ45t+mjLN2JKg Dtv+spJtsIKZ9k8fUfyNSXlYdjUbtMN4VvjOx81rnP9FPvv0FqDuTyopQ6kaEjLOqOUZ wMwPHq1rLi5tzTRMZuALdE9QDJnd/E0CZSBXJUt2M/rDRs+MYRkq2Q+UVlhFehrjeDMa Cs6w== 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; bh=IK2kjWi51ZqfffqiDkUuIu8HkHTwggvaKFXmh9zR9wI=; b=ckvWY2L1nqInMQZGNi6oabkIV7njJ5+h5AGRY0A7E9ufvNlj1rj1GcBiAh4KJXEoNi vykJLHO1rAkkL+ohwuPk14MEY3VLCa+WK5s+b4ySbxM1IWjhlT/IvojBOze97RxqNpbU m3PrtY3TrUfqPigivqQmAzRDXb2BV3UOPHVr5hyK2mqftb4GCCY0+c2PgLtA/YeD1cEE r2adyb1neSKE1k1jESUo5ft9gHY+rdtF7MsSdc+0LmK7y5NWVpujN4uEWE2KtJxaZ4dd OsQHchiK1cxR+F1uFkHpbatXgmKJsGV/neS9BgiKUPK4AuJmQ3NmfBdwOmoa2f4rvvQp mm8A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h23si3773218ejb.269.2020.05.28.06.25.23; Thu, 28 May 2020 06:25:46 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390330AbgE1NXF (ORCPT + 99 others); Thu, 28 May 2020 09:23:05 -0400 Received: from foss.arm.com ([217.140.110.172]:52622 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390314AbgE1NW5 (ORCPT ); Thu, 28 May 2020 09:22:57 -0400 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 8CA4DD6E; Thu, 28 May 2020 06:22:56 -0700 (PDT) Received: from [192.168.1.84] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 177183F52E; Thu, 28 May 2020 06:22:54 -0700 (PDT) Subject: Re: [PATCH 07/15] drm/panfrost: use device_property_present to check for OPP To: =?UTF-8?B?Q2zDqW1lbnQgUMOpcm9u?= , Rob Herring , Tomeu Vizoso , Alyssa Rosenzweig , Viresh Kumar , Nishanth Menon , Stephen Boyd , Maxime Ripard , Chen-Yu Tsai Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20200510165538.19720-1-peron.clem@gmail.com> <20200510165538.19720-8-peron.clem@gmail.com> From: Steven Price Message-ID: <2f7a41d6-325d-3731-0a6a-fa2e41d4e33a@arm.com> Date: Thu, 28 May 2020 14:22:52 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <20200510165538.19720-8-peron.clem@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed 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 On 10/05/2020 17:55, Clément Péron wrote: > Instead of expecting an error from dev_pm_opp_of_add_table() > do a simple device_property_present() check. > > Signed-off-by: Clément Péron I'm not sure I understand why this is better. We seem to have more code to do roughly the same thing just with the hard-coded "operating-points-v2" name (if there's ever a 'v3' we'll then have to update this). Is the desire just to get an error on probe if the table is malformed? Have you hit this situation? If so this sounds like something which would be better fixed in the generic OPP code rather than Panfrost itself. Steve > --- > drivers/gpu/drm/panfrost/panfrost_devfreq.c | 14 +++++++++----- > 1 file changed, 9 insertions(+), 5 deletions(-) > > diff --git a/drivers/gpu/drm/panfrost/panfrost_devfreq.c b/drivers/gpu/drm/panfrost/panfrost_devfreq.c > index d9007f44b772..fce21c682414 100644 > --- a/drivers/gpu/drm/panfrost/panfrost_devfreq.c > +++ b/drivers/gpu/drm/panfrost/panfrost_devfreq.c > @@ -96,15 +96,19 @@ int panfrost_devfreq_init(struct panfrost_device *pfdev) > struct thermal_cooling_device *cooling; > struct panfrost_devfreq *pfdevfreq = &pfdev->pfdevfreq; > > - ret = dev_pm_opp_of_add_table(dev); > - if (ret == -ENODEV) /* Optional, continue without devfreq */ > + if (!device_property_present(dev, "operating-points-v2")) > + /* Optional, continue without devfreq */ > return 0; > - else if (ret) > - return ret; > - pfdevfreq->opp_of_table_added = true; > > spin_lock_init(&pfdevfreq->lock); > > + ret = dev_pm_opp_of_add_table(dev); > + if (ret) { > + DRM_DEV_ERROR(dev, "Couldn't add OPP table\n"); > + goto err_fini; > + } > + pfdevfreq->opp_of_table_added = true; > + > panfrost_devfreq_reset(pfdevfreq); > > cur_freq = clk_get_rate(pfdev->clock); >