Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752866AbdHUIpb (ORCPT ); Mon, 21 Aug 2017 04:45:31 -0400 Received: from metis.ext.4.pengutronix.de ([92.198.50.35]:54561 "EHLO metis.ext.4.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752560AbdHUIpW (ORCPT ); Mon, 21 Aug 2017 04:45:22 -0400 Message-ID: <1503305118.8125.8.camel@pengutronix.de> Subject: Re: [PATCH v3 2/5] reset: socfpga: use the reset-simple driver From: Philipp Zabel To: Alexandru Gagniuc , linux-kernel@vger.kernel.org Cc: Andre Przywara , Maxime Coquelin , Alexandre Torgue , Maxime Ripard , Chen-Yu Tsai , Baoyou Xie , Eugeniy Paltsev , Steffen Trumtrar , Dinh Nguyen , Andreas =?ISO-8859-1?Q?F=E4rber?= , linux-arm-kernel@lists.infradead.org, kernel@pengutronix.de Date: Mon, 21 Aug 2017 10:45:18 +0200 In-Reply-To: <900b3dad-7340-6ad9-d996-d2f0e389bd58@adaptrum.com> References: <20170816094701.30678-1-p.zabel@pengutronix.de> <20170816094701.30678-3-p.zabel@pengutronix.de> <900b3dad-7340-6ad9-d996-d2f0e389bd58@adaptrum.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.22.6-1 Mime-Version: 1.0 Content-Transfer-Encoding: 8bit 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 List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1485 Lines: 51 On Wed, 2017-08-16 at 13:46 -0700, Alexandru Gagniuc wrote: > Hi Phillip, > > On 08/16/2017 02:46 AM, Philipp Zabel wrote: > [snip] > > @@ -118,8 +151,23 @@ static int reset_simple_probe(struct > > platform_device *pdev) > >   data->rcdev.ops = &reset_simple_ops; > >   data->rcdev.of_node = dev->of_node; > > > > - if (devdata) > > + if (devdata) { > > + u32 reg_offset = devdata->reg_offset; > > + > > + if (reg_offset && > > +     of_property_read_u32(dev->of_node, > > "altr,modrst-offset", > > +  ®_offset)) { > > + dev_warn(dev, > > +  "missing altr,modrst-offset > > property, assuming 0x%x!\n", > > +  reg_offset); > > + } > > I would not make reading dt properties dependent on the presence of  > devdata. That breaks being able to configure the reset controller from  > dt. I would either just read the "altr,modrst-offset" property, or read  > it when > > of_device_is_compatible(dev->of_node, "altr,rst-mgr")); Checking the compatible again is unnecessary, we already have obtained devdata depending on the compatible value. I had effectively the same check in v2: if (devdata == &reset_simple_socfpga) I can change back to that, if you prefer. Note that the if (devdata) reg_offset = devdata->reg_offset; part has to stay now that reg_offset is stored in devdata. > Ideally, we could have a more generic "reg-offset" binding for new reset  > controllers, but that is beyond the scope of this patch. Agreed. regards Philipp