Received: by 10.223.185.116 with SMTP id b49csp5957570wrg; Wed, 28 Feb 2018 01:20:10 -0800 (PST) X-Google-Smtp-Source: AH8x2257e5K0DRmRiutlowyRcQyk6yl5tiHvDmEitlsusRtRXlGpWynuYImeP5/FpTCdcNR4fhq8 X-Received: by 10.99.190.15 with SMTP id l15mr14014989pgf.325.1519809610834; Wed, 28 Feb 2018 01:20:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519809610; cv=none; d=google.com; s=arc-20160816; b=Nmqp2QT4w4Wxe9Q7Asz4F09/j4a1BOoJn602Cs3bGpZUuOfjtXMzrHN4MX1wUAM1to eQb2Es/arU0g3b02kFd/4jgwBN+p2NnlAvvU3MR+NQzp8L82M4MbFxey/4oPFGLzgrQI Lt4PVdz7nljm9gUVEAVcGi57SBhoGBp1yfqQk7FlJPBiTUysvQDBhAEmhxuWqb9usXRa GvJX1M0LNS8v44X6p2TfAxWeV6GW4+pjYpDEzh1FLoAxfZCGGxAqzhcXopVB7EK4CooN UxEew7TRp58FaEOu/ywdoXhnJUgnK1pV1W9dMGRTeDFmszv5QQI3KK2b40Qlatign01F EAEQ== 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:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id :arc-authentication-results; bh=MokbG2eIWg/ntzeH1bkt/WNiESgcOZ1exf8nwaYAI3o=; b=loItYtz6gJAXG7OFKMRcsL1qehOGo47YF/MvN1lXPUEoBMfM2s9LCUWTSWaPqotQWo bFj7WJML8PLw4wfZfaHXrYh00chavlu57f+sMpONkWRGc9lKlUSc88s7rMMD3PrKHCeH HpVRNHSXCRizPPIW5cFgqBomwuFPCzJklhRb5GYRoBN/5+jBXu9Kc71ElT5IhsHMP5Ry ao77/ac/fuGXUnfM9siNVfDY0BSIm2uSE9QyeLSGyEJFzpx2ZazFmLBfv31Z/W7CLdt2 fKR3B2Cf4+a8/kYQinTpqxcDqMWpsX8chhvrnHSOTERU4sGVpDh5jTSuW0VnMkLGoEKr 7sZw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w31-v6si968068pla.315.2018.02.28.01.19.53; Wed, 28 Feb 2018 01:20:10 -0800 (PST) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752312AbeB1JQz (ORCPT + 99 others); Wed, 28 Feb 2018 04:16:55 -0500 Received: from metis.ext.pengutronix.de ([85.220.165.71]:33051 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752294AbeB1JQx (ORCPT ); Wed, 28 Feb 2018 04:16:53 -0500 Received: from lupine.hi.pengutronix.de ([2001:67c:670:100:3ad5:47ff:feaf:1a17] helo=lupine) by metis.ext.pengutronix.de with esmtp (Exim 4.89) (envelope-from ) id 1eqxr1-0000DH-7y; Wed, 28 Feb 2018 10:16:51 +0100 Message-ID: <1519809410.3975.1.camel@pengutronix.de> Subject: Re: [PATCH v5] reset: add support for non-DT systems From: Philipp Zabel To: Bartosz Golaszewski Cc: Bartosz Golaszewski , LKML , Sekhar Nori , Kevin Hilman , David Lechner Date: Wed, 28 Feb 2018 10:16:50 +0100 In-Reply-To: References: <20180223113924.28957-1-brgl@bgdev.pl> <1519747811.3402.17.camel@pengutronix.de> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.22.6-1+deb9u1 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit X-SA-Exim-Connect-IP: 2001:67c:670:100:3ad5:47ff:feaf:1a17 X-SA-Exim-Mail-From: p.zabel@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2018-02-27 at 19:07 +0100, Bartosz Golaszewski wrote: > 2018-02-27 17:10 GMT+01:00 Philipp Zabel : > > Hi Bartosz, > > > > thank you for the update. > > > > On Fri, 2018-02-23 at 12:39 +0100, Bartosz Golaszewski wrote: > > > From: Bartosz Golaszewski > > > > > > The reset framework only supports device-tree. There are some platforms > > > however, which need to use it even in legacy, board-file based mode. > > > > > > An example of such architecture is the DaVinci family of SoCs which > > > supports both device tree and legacy boot modes and we don't want to > > > introduce any regressions. > > > > > > We're currently working on converting the platform from its hand-crafted > > > clock API to using the common clock framework. Part of the overhaul will > > > be representing the chip's power sleep controller's reset lines using > > > the reset framework. > > > > > > This changeset extends the core reset code with a new reset lookup > > > entry structure. It contains data allowing the reset core to associate > > > reset lines with devices by comparing the dev_id and con_id strings. > > > > > > It also provides a function allowing drivers to register lookup entries > > > with the framework. > > > > > > The new lookup function is only called as a fallback in case the > > > of_node field is NULL and doesn't change anything for current users. > > > > > > Tested with a dummy reset driver with several lookup entries. > > > > > > An example lookup table registration from a driver can be found below: > > > > > > static struct reset_control_lookup foobar_reset_lookup[] = { > > > RESET_LOOKUP("foo.0", "foo", 15), > > > RESET_LOOKUP("bar.0", NULL, 5), > > > }; > > > > > > foobar_probe() > > > { > > > ... > > > > > > reset_controller_add_lookup(&rcdev, foobar_reset_lookup, > > > ARRAY_SIZE(foobar_reset_lookup)); > > > > > > ... > > > } > > > > > > Cc: Sekhar Nori > > > Cc: Kevin Hilman > > > Cc: David Lechner > > > Signed-off-by: Bartosz Golaszewski > > > --- > > > v1 -> v2: > > > - renamed the new function to __reset_control_get_from_lookup() > > > - added a missing break; when a matching entry is found > > > - rearranged the code in __reset_control_get() - we can no longer get to the > > > return at the bottom, so remove it and return from > > > __reset_control_get_from_lookup() if __of_reset_control_get() fails > > > - return -ENOENT from reset_contol_get() if we can't find a matching entry, > > > prevously returned -EINVAL referred to the fact that we passed a device > > > without the of_node which is no longer an error condition > > > - add a comment about needing a sentinel in the lookup table > > > > > > v2 -> v3: > > > - added the reset id number field to the lookup struct so that we don't need > > > to rely on the array index > > > > > > v3 -> v4: > > > - separated the driver and lookup table registration logic by adding a > > > function meant to be called by machine-specific code that adds a lookup > > > table to the internal list > > > - the correct reset controller is now found by first finding the lookup > > > table associated with it, then finding the actual reset controller by > > > the associated device > > > > > > v4 -> v5: > > > - since the first user of this will be the davinci clk driver and it > > > already registers clock lookup from within the driver code - allow > > > drivers to register lookups with the assumption that the code can be > > > extended to make it possible to register entries from machine code as > > > well > > > > How do you imagine this may be extended? By adding an rddev_devid field > > to the lookup, similarly to the pwm_lookup? > > I suppose reset_controller_add_lookup could then be called with a NULL > > rcdev to register lookups by id. > > > > Yes, this is what I was thinking about more or less. Ok. I just want to avoid having to change all users when somebody needs that functionality, even though hopefully there won't be that many. > > > - simplify the code - only expose a single lookup structure and a simply > > > registration function > > > - add the RESET_LOOKUP macro for brevity > > > > > > drivers/reset/core.c | 65 +++++++++++++++++++++++++++++++++++++++- > > > include/linux/reset-controller.h | 28 +++++++++++++++++ > > > 2 files changed, 92 insertions(+), 1 deletion(-) > > > > > > diff --git a/drivers/reset/core.c b/drivers/reset/core.c > > > index da4292e9de97..75e54a05147a 100644 > > > --- a/drivers/reset/core.c > > > +++ b/drivers/reset/core.c > > > @@ -23,6 +23,9 @@ > > > static DEFINE_MUTEX(reset_list_mutex); > > > static LIST_HEAD(reset_controller_list); > > > > > > +static DEFINE_MUTEX(reset_lookup_mutex); > > > +static LIST_HEAD(reset_lookup_list); > > > + > > > /** > > > * struct reset_control - a reset control > > > * @rcdev: a pointer to the reset controller device > > > @@ -148,6 +151,30 @@ int devm_reset_controller_register(struct device *dev, > > > } > > > EXPORT_SYMBOL_GPL(devm_reset_controller_register); > > > > > > +/** > > > + * reset_controller_add_lookup - register a set of lookup entries > > > + * @rcdev: initialized reset controller device owning the reset line > > > + * @lookup: array of reset lookup entries > > > + * @num_entries: number of entries in the lookup array > > > + */ > > > +void reset_controller_add_lookup(struct reset_controller_dev *rcdev, > > > + struct reset_control_lookup *lookup, > > > + unsigned int num_entries) > > > +{ > > > + struct reset_control_lookup *entry; > > > + unsigned int i; > > > + > > > + mutex_lock(&reset_lookup_mutex); > > > + for (i = 0; i < num_entries; i++) { > > > + entry = &lookup[i]; > > > + > > > + entry->rcdev = rcdev; > > > + list_add_tail(&entry->list, &reset_lookup_list); > > > + } > > > + mutex_unlock(&reset_lookup_mutex); > > > +} > > > +EXPORT_SYMBOL_GPL(reset_controller_add_lookup); > > > + > > > > What about reset_controller_remove_lookup? > > While I understand that we have those for phy or gpio, I don't really > think they're that useful. Not many users do it anyway. Can we add it > once it's actually needed? Agreed. > > > > > static inline struct reset_control_array * > > > rstc_to_array(struct reset_control *rstc) { > > > return container_of(rstc, struct reset_control_array, base); > > > @@ -493,6 +520,42 @@ struct reset_control *__of_reset_control_get(struct device_node *node, > > > } > > > EXPORT_SYMBOL_GPL(__of_reset_control_get); > > > > > > +static struct reset_control * > > > +__reset_control_get_from_lookup(struct device *dev, const char *con_id, > > > + bool shared, bool optional) > > > +{ > > > + const struct reset_control_lookup *lookup; > > > + const char *dev_id = dev_name(dev); > > > + struct reset_control *rstc = NULL; > > > + > > > + if (!dev) > > > + return ERR_PTR(-EINVAL); > > > + > > > + mutex_lock(&reset_lookup_mutex); > > > + > > > + list_for_each_entry(lookup, &reset_lookup_list, list) { > > > + if (strcmp(lookup->dev_id, dev_id)) > > > > This will crash if (lookup->dev_id == NULL). > > > > We're stating explicitly that dev_id is required in the kernel doc but > if you insist, I can add a check for that. This isn't such a hot path that we couldn't afford the NULL pointer check, but given that it is documented as required, maybe better let reset_controller_add_lookup check for it and never add malformed lookups to the list in the first place. > > > + continue; > > > + > > > + if ((!con_id && !lookup->con_id) || > > > + !strcmp(con_id, lookup->con_id)) { > > > > This will crash if only one of con_id or lookup->con_id is NULL. > > > > Call strcmp only if both strings are valid. > > > > Indeed, will fix it. regards Philipp