Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S968374AbdD0Kbk (ORCPT ); Thu, 27 Apr 2017 06:31:40 -0400 Received: from mx2.suse.de ([195.135.220.15]:43569 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1755400AbdD0KbZ (ORCPT ); Thu, 27 Apr 2017 06:31:25 -0400 Date: Thu, 27 Apr 2017 12:31:16 +0200 From: "Luis R. Rodriguez" To: Luca Coelho Cc: "Luis R. Rodriguez" , "gregkh@linuxfoundation.org" , "linux-kernel@vger.kernel.org" , "pjones@redhat.com" , "moritz.fischer@ettus.com" , "takahiro.akashi@linaro.org" , "dhowells@redhat.com" , "pmladek@suse.com" , "Berg, Johannes" , "rjw@rjwysocki.net" , "yi1.li@linux.intel.com" , "kvalo@codeaurora.org" , "luto@kernel.org" , "arend.vanspriel@broadcom.com" , "rafal@milecki.pl" , "dwmw2@infradead.org" , "wagi@monom.org" , "atull@opensource.altera.com" , "Grumbach, Emmanuel" Subject: Re: [PATCH v6 2/5] firmware: add extensible driver data API Message-ID: <20170427103116.GL28800@wotan.suse.de> References: <20170330032514.17173-1-mcgrof@kernel.org> <20170330032514.17173-3-mcgrof@kernel.org> <1491828162.31980.50.camel@intel.com> <20170427031625.GI28800@wotan.suse.de> <1493273387.14233.13.camel@coelho.fi> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <1493273387.14233.13.camel@coelho.fi> User-Agent: Mutt/1.6.0 (2016-04-01) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2740 Lines: 62 On Thu, Apr 27, 2017 at 09:09:47AM +0300, Luca Coelho wrote: > On Thu, 2017-04-27 at 05:16 +0200, Luis R. Rodriguez wrote: > > > > +int driver_data_request_sync(const char *name, > > > > +??????????????????????? const struct driver_data_req_params *req_params, > > > > +??????????????????????? struct device *device) > > > > +{ > > > > +???const struct firmware *driver_data; > > > > +???const struct driver_data_reqs *sync_reqs; > > > > +???struct driver_data_params params = { > > > > +???????????.req_params = *req_params, > > > > +???}; > > > > +???int ret; > > > > + > > > > +???if (!device || !req_params || !name || name[0] == '\0') > > > > +???????????return -EINVAL; > > > > + > > > > +???if (req_params->sync_reqs.mode != DRIVER_DATA_SYNC) > > > > +???????????return -EINVAL; > > > > > > Why do you need to check this here? If the caller is calling _sync(), > > > it's because that's what it needs.? This mode value here seems > > > redundant. > > > > Because we allow one data structure to be used for the specified requirements > > and technically someone can make a mistake and use the wrong macros to set up > > the data structure. This ensures users don't async macros to set up the > > parameters and then use the sync call. Eventually the underlying > > firmware_class.c code does its own conditional checks on this as well. > > If this could only happen in a programming error, maybe it's worth a > WARN() then, to make it easier to spot? > > > > > OTOH, if you do have a reason for this value, then you could use > > > driver_data_request_sync() in this if. > > > > You mean to allow *one* API call for all. Sure, that's possible, but I think > > its nicer to at least expose async/sync mechanisms on the caller side. The > > sync/async differences seem like a reasonable enough place to split the API. > > I don't remember the details of this anymore, but doesn't the > driver_data_sync() function does exactly the same check? I meant that > you could do this: > > if(WARN_ON_ONCE(!driver_data_request_sync())) > return -EINVAL; > > > And yes, I think either a single API call for all or not having the mode > in the struct would be cleaner. I think there are better ways to > prevent coding errors (since this should only happen if the user code is > implemented incorrectly). You're kind of right, this is stupid. The mode is already implied by the function used, and its an internal thing, so we can just deal with it ourselves. The reason why we can't just use the sync cb is its completely optional, we need a piece of information to tell the internal code its purpose so it can decide what data structures to check for. I'll try folding the mode into the priv params and remove the checks. Luis